/* ═══ STAFF DASHBOARD HOME ═══ */
.dash-two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.dash-col-left,.dash-col-right{min-width:0}
@media(max-width:600px){.dash-two-col{grid-template-columns:1fr}}
.dash-sum-section{background:var(--white);border-radius:10px;border:1px solid var(--sand);overflow:hidden;margin-bottom:10px}
.dash-sum-header{display:flex;align-items:stretch}
.dash-sum-header-text{flex:1;padding:7px 12px;font-size:12px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase}
.dash-sum-accent{width:4px;flex-shrink:0}
.dash-sum-item{padding:6px 12px 6px 14px;font-size:13px;color:var(--text-mid);border-bottom:1px solid var(--cream-dark)}
.dash-sum-item:last-child{border-bottom:none}
.dash-sum-empty{padding:7px 12px 7px 14px;font-size:12px;color:var(--text-muted)}

/* ═══ STATS ROW ═══ */
.stats-row{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:16px}
.stat-card{background:var(--white);border-radius:10px;border:1px solid var(--sand);padding:10px 6px;text-align:center}
.stat-label{font-size:9px;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:2px}
.stat-value{font-family:'Cormorant Garamond',serif;font-size:26px;color:var(--earth);line-height:1}

/* ═══ STAFF HOME ═══ */
.staff-home-date-header{margin-bottom:14px}
.staff-home-date-label{font-size:11px;font-weight:700;letter-spacing:0.09em;text-transform:uppercase;color:var(--text-muted)}
.staff-home-date-main{font-family:'Cormorant Garamond',serif;font-size:32px;line-height:1.05;color:var(--earth);margin-top:4px}
.staff-home-done-label{font-size:12px;color:var(--text-muted);margin-top:6px}
.trainer-duty-card{background:var(--white);border-radius:12px;border:1px solid var(--sand);padding:14px 16px;margin-bottom:14px}
.trainer-duty-row{display:flex;align-items:center;gap:10px}
.trainer-duty-avatar{width:38px;height:38px;border-radius:50%;background:var(--cream-dark);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--earth);flex-shrink:0}
.trainer-duty-name{font-size:14px;font-weight:600;color:var(--earth)}
.trainer-duty-time{font-size:12px;color:var(--text-muted);margin-top:2px}
.staff-home-summary-wrap{margin-top:8px}
.staff-home-summary-label{font-size:10px;font-weight:700;letter-spacing:0.09em;text-transform:uppercase;color:#fff;background:#3a3a3a;padding:8px 12px;border-radius:6px 6px 0 0;margin-bottom:0}
.staff-home-summary-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.staff-home-summary-grid .stat-card{border-color:var(--sand);box-shadow:0 4px 20px rgba(0,0,0,0.04)}
@media(max-width:700px){
  .staff-home-summary-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:480px){
  .staff-home-summary-grid{grid-template-columns:repeat(2,1fr)}
}

/* ═══ NEXT UP CARD ═══ */
.next-up-card{background:var(--earth);border-radius:12px;padding:16px 18px;margin-bottom:14px;color:var(--white)}
.next-up-label{font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--hay);margin-bottom:6px}
.next-up-horse{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--white);line-height:1;margin-bottom:4px}
.next-up-detail{font-size:13px;color:rgba(255,255,255,0.7)}
.next-up-time{font-size:12px;color:var(--hay);margin-top:6px;font-weight:500}

/* ═══ TRAINER INFO ═══ */
.trainer-band{height:6px;border-radius:3px;margin-bottom:2px;display:flex;gap:2px}
.trainer-band-seg{flex:1;border-radius:2px;background:var(--trainer-band);opacity:0.85}

/* ═══ SCHEDULE CARDS ═══ */
.schedule-card{background:var(--white);border-radius:10px;border:1px solid var(--sand);overflow:hidden;margin-bottom:16px}
.schedule-header{padding:12px 16px;background:#3a3a3a;display:flex;align-items:center;justify-content:space-between}
.schedule-title{font-size:13px;font-weight:600;color:#fff}
.schedule-meta{font-size:11px;color:rgba(255,255,255,0.75)}
.schedule-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--cream-dark)}
.schedule-item:last-child{border-bottom:none}
.schedule-time{font-size:12px;font-weight:500;color:var(--earth);min-width:44px}
.schedule-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.schedule-info{flex:1;min-width:0}
.schedule-horse{font-size:14px;color:var(--text);font-weight:400}
.schedule-detail{font-size:11px;color:var(--text-muted);margin-top:1px}
.schedule-rider{font-size:11px;color:var(--earth-light);font-weight:500;margin-top:1px}
.unassigned-badge{font-size:10px;background:#faeeda;color:#633806;padding:2px 7px;border-radius:8px;margin-left:6px;font-weight:normal}

/* ═══ DAY CALENDAR VIEW (Google Calendar style) ═══ */
.gcal-scroll{overflow-y:auto;max-height:420px;-webkit-overflow-scrolling:touch}
.gcal-grid{position:relative;display:flex}
.gcal-times{width:48px;flex-shrink:0;position:relative}
.gcal-time-label{position:absolute;right:8px;font-size:10px;color:var(--text-muted);transform:translateY(-50%);white-space:nowrap;user-select:none}
.gcal-events{position:relative;flex:1;border-left:1px solid var(--cream-dark)}
.gcal-hour-line{position:absolute;left:0;right:0;border-top:1px solid var(--cream-dark);pointer-events:none}
.gcal-half-line{position:absolute;left:0;right:0;border-top:1px dashed var(--cream-dark);opacity:0.5;pointer-events:none}
.gcal-event{position:absolute;border-radius:4px;padding:3px 6px;overflow:hidden;cursor:pointer;border-left-width:3px;border-left-style:solid;box-sizing:border-box;transition:filter 0.1s}
.gcal-event:active{filter:brightness(0.92)}
.gcal-event-title{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}
.gcal-event-sub{font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;margin-top:1px}
.gcal-now-line{position:absolute;left:0;right:0;height:2px;background:#ea4335;z-index:3;pointer-events:none}
.gcal-now-dot{position:absolute;left:-5px;top:-4px;width:10px;height:10px;border-radius:50%;background:#ea4335}

/* TRAINER INFO CARD */
.trainer-info-card{background:var(--white);border-radius:10px;border:1px solid var(--sand);padding:14px 16px;margin-bottom:14px}
.trainer-info-title{font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px}
.trainer-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.trainer-row:last-child{margin-bottom:0}
.trainer-dot{width:10px;height:10px;border-radius:50%;background:var(--trainer-band);flex-shrink:0}
.trainer-name{font-size:14px;font-weight:500;color:var(--earth)}
.trainer-days{font-size:11px;color:var(--text-muted);margin-top:1px}

/* ═══ PC DESKTOP LAYOUT ═══ */

/* Hidden on mobile; shown by the media query below */
.pc-sidenav{display:none}
.pc-right-rail{display:none}

@media(min-width:900px){
  /* Switch staff screen to 3-column grid */
  #screen-app.active{
    display:grid;
    grid-template-columns:220px 1fr 280px;
    grid-template-rows:auto 1fr;
    grid-template-areas:"header header header" "sidebar main rail";
    overflow:hidden;
  }
  #screen-app>.sm-top{grid-area:header;border-bottom:1px solid var(--hair)}
  #screen-app>.panels{grid-area:main}
  #screen-app>.sm-tabs{display:none}

  /* Back button not needed with persistent sidenav */
  #staff-back-btn{display:none!important}

  /* Reduce panel bottom padding (no floating tab bar on desktop) */
  #screen-app>.panels>.panel{padding-bottom:40px}

  /* Sidenav */
  .pc-sidenav{
    grid-area:sidebar;
    display:flex;
    flex-direction:column;
    background:var(--paper);
    border-right:1px solid var(--hair);
    overflow-y:auto;
  }
  .pc-sidenav-brand{
    padding:20px 20px 14px;
    border-bottom:1px solid var(--hair);
    margin-bottom:6px;
  }
  .pc-brand-logo{
    font-family:var(--serif);
    font-size:22px;
    font-weight:300;
    color:var(--earth);
    letter-spacing:0.01em;
  }
  .pc-brand-logo span{color:var(--hay-dark)}
  .pc-brand-barn{
    font-size:11px;
    color:var(--text-muted);
    margin-top:2px;
    letter-spacing:0.06em;
    text-transform:uppercase;
  }
  .pc-nav{flex:1;padding:6px 10px}
  .pc-nav-item{
    display:flex;
    align-items:center;
    gap:10px;
    width:100%;
    padding:10px 12px;
    border:none;
    background:none;
    border-radius:10px;
    cursor:pointer;
    font-size:14px;
    color:var(--text-mid);
    font-family:var(--sf);
    text-align:left;
    transition:background 0.12s;
    margin-bottom:2px;
  }
  .pc-nav-item svg{width:18px;height:18px;flex-shrink:0;stroke:currentColor}
  .pc-nav-item:hover{background:var(--ios-fill)}
  .pc-nav-item.active{
    background:var(--primary-muted);
    color:var(--primary);
    font-weight:500;
  }
  .pc-sidenav-footer{
    padding:12px 16px;
    border-top:1px solid var(--hair);
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:8px;
  }
  .pc-user-row{display:flex;align-items:center;gap:8px;min-width:0}
  .pc-user-avatar{
    width:28px;height:28px;
    border-radius:50%;
    background:var(--earth);
    color:var(--hay-light);
    display:flex;align-items:center;justify-content:center;
    font-size:11px;font-weight:600;
    flex-shrink:0;
  }
  .pc-user-name{
    font-size:13px;color:var(--text);font-weight:500;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  }
  .pc-signout{
    border:none;background:none;
    font-size:12px;color:var(--text-muted);
    cursor:pointer;padding:4px 0;white-space:nowrap;
    font-family:var(--sf);
  }
  .pc-signout:hover{color:var(--danger)}

  /* Right rail */
  .pc-right-rail{
    grid-area:rail;
    display:flex;
    flex-direction:column;
    gap:20px;
    background:var(--cream-2);
    border-left:1px solid var(--hair);
    overflow-y:auto;
    padding:20px 16px;
  }
  .pc-rail-title{
    font-size:10px;letter-spacing:0.1em;text-transform:uppercase;
    color:var(--text-muted);margin-bottom:10px;font-weight:600;
  }
  .pc-req-item{
    background:var(--paper);
    border-radius:10px;
    padding:12px;
    margin-bottom:8px;
    border:1px solid var(--hair);
  }
  .pc-req-title{font-size:13px;font-weight:500;color:var(--text);margin-bottom:3px}
  .pc-req-meta{font-size:11px;color:var(--text-muted);margin-bottom:10px}
  .pc-req-actions{display:flex;gap:6px}
  .pc-req-btn{
    flex:1;padding:6px 8px;border-radius:8px;border:none;
    font-size:12px;font-weight:500;cursor:pointer;
    font-family:var(--sf);transition:opacity 0.1s;
  }
  .pc-req-btn:active{opacity:0.75}
  .pc-req-btn.approve{background:var(--success);color:#fff}
  .pc-req-btn.reject{background:var(--ios-fill);color:var(--text-mid)}
  .pc-empty-rail{
    font-size:12px;color:var(--text-muted);
    text-align:center;padding:16px 0;
  }
  .pc-trainer-row{
    display:flex;align-items:center;gap:8px;
    padding:10px;
    background:var(--paper);border-radius:10px;
    margin-bottom:6px;
    border:1px solid var(--hair);
  }
  .pc-trainer-dot{width:8px;height:8px;border-radius:50%;background:var(--trainer-band);flex-shrink:0}
  .pc-trainer-name{font-size:13px;font-weight:500;color:var(--earth)}
  .pc-trainer-time{font-size:11px;color:var(--text-muted);margin-top:1px}
}

/* ═══ HOME GRID ═══ */

/* Mobile: block stack in DOM order (trainer → flags → pending → schedule) */
.home-grid{padding:0}
.home-trainer-wrap{margin-bottom:16px}
.home-flags-wrap{margin-bottom:16px}
.home-pending-wrap{margin-bottom:16px}
.home-schedule-wrap{}

/* Schedule Activity button inside the schedule column */
.home-sched-btn{
  display:block;width:100%;margin:0 0 12px;padding:14px 16px;
  background:var(--earth);color:#fff;border:none;border-radius:14px;
  font-family:var(--sf);font-size:15px;font-weight:600;letter-spacing:-0.24px;
  cursor:pointer;text-align:center;
}
.home-sched-btn:active{opacity:0.85}

/* Flags card */
.home-flags-card{background:var(--paper);border-radius:10px;border:1px solid var(--sand);overflow:hidden}
.home-flags-header{padding:12px 16px;background:#3a3a3a;display:flex;align-items:center;justify-content:space-between}
.home-flags-title{font-size:13px;font-weight:600;color:#fff}
.home-flag-row{
  display:flex;align-items:flex-start;gap:10px;
  padding:12px 16px;border-bottom:1px solid var(--cream-dark);
}
.home-flag-row:last-child{border-bottom:none}
.home-flag-dot{
  width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px;
}
.home-flag-body{flex:1;min-width:0}
.home-flag-horse{
  font-size:13px;font-weight:600;color:var(--primary);
  cursor:pointer;letter-spacing:-0.08px;
}
.home-flag-horse:hover{text-decoration:underline}
.home-flag-text{font-size:13px;color:var(--text);margin-top:2px;line-height:1.4}
.home-flag-meta{font-size:11px;color:var(--text-muted);margin-top:3px;text-transform:capitalize;letter-spacing:0.02em}
.home-flag-resolve{
  flex-shrink:0;padding:4px 10px;border-radius:8px;border:1px solid var(--hair);
  background:var(--paper);color:var(--text-mid);font-size:11px;font-weight:500;
  cursor:pointer;font-family:var(--sf);white-space:nowrap;
}
.home-flag-resolve:hover{background:var(--ios-fill)}
.home-flags-clear{
  padding:32px 16px;text-align:center;
  color:var(--text-muted);font-size:13px;
}
.home-flags-clear-icon{font-size:24px;margin-bottom:8px}

/* Messaging icon in topbar */
.topbar-msg-btn{
  position:relative;background:none;border:none;cursor:pointer;
  padding:6px;border-radius:10px;color:var(--text-mid);
  display:flex;align-items:center;justify-content:center;
  transition:background 0.1s;
}
.topbar-msg-btn:hover{background:var(--ios-fill)}
.topbar-msg-btn svg{display:block;stroke:var(--earth)}
.msg-badge{
  position:absolute;top:0px;right:0px;
  min-width:16px;height:16px;
  background:var(--danger);color:#fff;
  font-size:10px;font-weight:700;
  border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  padding:0 4px;line-height:1;
  border:1.5px solid #fff;
}

/* Pending card in mobile rail */
.home-pending-wrap .pc-rail-section{
  background:var(--paper);border-radius:10px;border:1px solid var(--sand);padding:12px 14px;
}
.home-pending-wrap .pc-rail-title{margin-bottom:8px}
.home-pending-wrap .pc-req-item{border:1px solid var(--hair)}
.home-pending-wrap .pc-empty-rail{padding:8px 0}

/* Desktop: 2-col grid inside home panel, right rail stays as col 3 */
@media(min-width:900px){
  .home-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto 1fr;
    gap:0 20px;
    align-items:start;
    padding:0;
  }
  .home-trainer-wrap{grid-column:1;grid-row:1;margin-bottom:16px}
  .home-flags-wrap{grid-column:2;grid-row:1/3;margin-bottom:0}
  .home-pending-wrap{display:none}
  .home-schedule-wrap{grid-column:1;grid-row:2;align-self:start}
  .gcal-scroll{max-height:520px}
}

/* ═══ EVENT BADGES ═══ */
.ev-badge{font-size:10px;padding:2px 7px;border-radius:10px;font-weight:500;white-space:nowrap}
.ev-lesson{background:#e8f0e0;color:#3b6d11}
.ev-arena{background:#e8dcc8;color:#6b4c35}
.ev-vet{background:#fdecea;color:#8b2020}
.ev-farrier{background:#e8f4fd;color:#0c447c}
.ev-competition{background:#faeeda;color:#633806}
.ev-lunge{background:#f0e8ff;color:#5b2d8e}
.ev-turnout{background:#e0f4e8;color:#1a5c35}
.ev-walker{background:#fff3e0;color:#8c4a00}

/* ═══ ADMIN / SETTINGS ═══ */
.admin-tabs{display:flex;gap:0;border-bottom:1px solid var(--hair);margin:0 0 16px}
.admin-tab{background:none;border:none;padding:10px 16px;font-size:14px;font-weight:600;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;font-family:var(--sf)}
.admin-tab.active{color:var(--primary);border-bottom-color:var(--primary)}
.admin-actions-row{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.admin-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);cursor:pointer}
.admin-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--paper);border:1px solid var(--hair);border-radius:10px;margin-bottom:8px}
.admin-row-inactive{opacity:0.55}
.admin-row-main{flex:1;min-width:0}
.admin-row-name{font-size:14px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.admin-row-meta{font-size:12px;color:var(--text-muted);margin-top:2px}
.admin-badge{display:inline-block;background:var(--hay);color:var(--earth);font-size:10px;font-weight:700;letter-spacing:0.04em;padding:2px 6px;border-radius:4px;text-transform:uppercase}
.admin-badge-off{background:var(--hair-2);color:var(--text-muted)}
