@media (max-width: 1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}.product-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.two-col,.pos-layout{grid-template-columns:1fr}.cart-panel{position:static;top:auto}}
@media (max-width: 820px){.sidebar{display:none}.mobile-nav{display:flex}.content{padding:20px 16px 96px}.topbar{flex-direction:column;align-items:flex-start}.topbar h1{font-size:28px}.auth-card{grid-template-columns:1fr}.auth-copy{display:none}.settings-grid{grid-template-columns:1fr}}
@media (max-width: 560px){.stats-grid,.product-grid{grid-template-columns:1fr}.panel,.stat-card,.cart-panel,.product-card,.auth-card{border-radius:20px}.search-bar{flex-direction:column}.category-pill{min-height:52px;padding:0 14px;border-radius:16px}.category-pill-icon{width:30px;height:30px;font-size:17px}.category-pill-label{font-size:13px}.cart-items{max-height:none}}


@media (max-width: 900px){
  .report-filter-form,.report-summary-grid,.report-two-col{grid-template-columns:1fr 1fr}
  .print-header{flex-direction:column}
}
@media (max-width: 640px){
  .report-filter-form,.report-summary-grid,.report-two-col{grid-template-columns:1fr}
  .report-meta{min-width:0}
}

@media (max-width: 900px){.report-filter-form,.report-summary-grid,.report-two-col{grid-template-columns:1fr 1fr}.print-header{flex-direction:column}.report-filter-actions{grid-column:1/-1}}
@media (max-width: 640px){.report-filter-form,.report-summary-grid,.report-two-col{grid-template-columns:1fr}.report-meta{min-width:0}.report-filter-actions .btn,.report-filter-actions a{width:100%}}

@media (max-width: 980px){.product-admin-grid{grid-template-columns:1fr}}


@media (max-width: 820px){
  .sidebar-modern{
    width:100%;
    max-width:100%;
    border-right:none;
    border-bottom:1px solid var(--line);
    height:auto;
    position:static;
    padding:16px 12px;
  }
  .sidebar-window-dots,
  .sidebar-user-card{
    display:none;
  }
  .sidebar-brand-wrap{
    padding-bottom:4px;
  }
  .side-nav-modern{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
  }
  .side-nav-modern a{
    padding:12px;
  }
  .nav-divider{
    display:none;
  }
}


@media (max-width: 820px){
  .app-shell{
    display:block;
  }
  .sidebar{
    position:fixed;
    left:0;
    top:0;
    bottom:0;
    height:100vh;
    width:min(260px, 84vw) !important;
    z-index:30;
    transform:translateX(-110%);
    opacity:1 !important;
    padding:18px 14px 16px !important;
    border-right:1px solid var(--line) !important;
    box-shadow:0 16px 40px rgba(0,0,0,.12);
  }
  body.sidebar-mobile-open .sidebar{
    transform:translateX(0);
  }
  body.sidebar-mobile-open .sidebar-overlay{
    opacity:1;
    pointer-events:auto;
  }
  .content{
    padding:20px 16px 96px !important;
  }
}

@media (min-width: 821px){
  .sidebar-overlay{
    display:none;
  }
}

/* Responsive fixes for Android and tablet clinic screens */
@media (max-width: 1100px){
  .content{
    margin-left:0;
    padding:22px 18px 104px !important;
  }

  .pos-layout{
    grid-template-columns:1fr;
    gap:18px;
  }

  .cart-panel{
    order:2;
    position:static;
    top:auto;
  }

  .product-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media (max-width: 820px){
  .content{
    margin-left:0 !important;
    width:100%;
    max-width:100%;
    overflow-x:hidden;
    padding:18px 14px 108px !important;
  }

  .topbar{
    margin-bottom:18px;
  }

  .topbar-chip{
    width:100%;
    text-align:center;
  }

  .search-bar{
    flex-direction:column;
    align-items:stretch;
  }

  .search-bar .btn{
    width:100%;
  }

  .category-row{
    gap:10px;
    padding-bottom:8px;
    scroll-snap-type:x proximity;
  }

  .category-pill{
    scroll-snap-align:start;
  }

  .product-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
  }

  .product-card,
  .cart-panel,
  .panel,
  .stat-card{
    min-width:0;
  }

  .product-visual{
    height:auto;
    min-height:110px;
    padding:16px;
    gap:12px;
  }

  .product-avatar{
    width:52px;
    height:52px;
    border-radius:16px;
    font-size:24px;
  }

  .product-tag{
    font-size:12px;
    padding:7px 10px;
    text-align:center;
  }

  .product-copy{
    padding:14px;
    gap:8px;
  }

  .product-copy h3{
    font-size:22px;
    line-height:1.2;
  }

  .product-copy p{
    min-height:0;
  }

  .product-meta{
    flex-direction:column;
    align-items:flex-start;
    gap:6px;
  }

  .product-meta strong{
    font-size:20px;
  }

  .cart-items{
    max-height:none;
  }

  .mobile-nav{
    left:8px;
    right:8px;
    bottom:8px;
    padding:8px;
    gap:6px;
  }

  .mobile-nav a{
    min-width:0;
    padding:10px 6px;
    font-size:12px;
    line-height:1.15;
  }
}

@media (max-width: 640px){
  .content{
    padding:16px 12px 112px !important;
  }

  .topbar h1{
    font-size:26px;
  }

  .product-grid{
    grid-template-columns:1fr;
  }

  .form-split{
    grid-template-columns:1fr;
  }

  .checkout-form label,
  .stack-form label,
  .report-field{
    min-width:0;
  }
}

@media (max-width: 420px){
  .content{
    padding:14px 10px 116px !important;
  }

  .topbar h1{
    font-size:24px;
  }

  .product-copy h3{
    font-size:20px;
  }

  .mobile-nav a{
    font-size:11px;
    padding:9px 4px;
  }
}


@media (max-width: 820px){
  .mobile-more-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (min-width: 821px){
  .mobile-more-sheet{
    display:none;
  }
}
@media (max-width: 520px){
  .mobile-nav{
    grid-template-columns:repeat(5,minmax(0,1fr));
  }
  .mobile-nav a,
  .mobile-nav-more{
    padding:10px 4px;
    font-size:11px;
  }
  .mobile-more-sheet-panel{
    left:8px;
    right:8px;
    bottom:82px;
  }
}

.topbar-calendar{
  align-items:flex-start;
  gap:16px;
}
.calendar-nav-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.stats-grid-calendar{
  margin-bottom:20px;
}
.panel-head-stack .panel-subtext,
.panel-head .panel-subtext{
  color:var(--muted-color,#6b7280);
  margin-top:6px;
  display:block;
}
.calendar-filter-panel{
  margin-bottom:20px;
}
.calendar-filters-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:14px;
}
.calendar-filters-grid label{
  display:block;
  margin-bottom:8px;
  font-size:13px;
  font-weight:600;
}
.calendar-filters-grid select{
  width:100%;
  min-height:44px;
  border-radius:14px;
  border:1px solid rgba(120,140,120,.18);
  background:#fff;
  padding:10px 12px;
}
.calendar-filter-actions{
  display:flex;
  align-items:flex-end;
  gap:10px;
}
.calendar-panel{
  margin-bottom:20px;
}
.calendar-weekdays{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:10px;
  margin-bottom:10px;
  color:#68816a;
  font-weight:700;
  font-size:13px;
}
.calendar-weekdays span{
  padding:0 4px;
}
.calendar-grid{
  display:grid;
  grid-template-columns:repeat(7,minmax(0,1fr));
  gap:10px;
}
.calendar-day-card{
  background:#fff;
  border:1px solid rgba(96,151,108,.15);
  border-radius:20px;
  min-height:168px;
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:10px;
  box-shadow:0 10px 25px rgba(41,75,53,.05);
}
.calendar-day-card.is-muted{
  opacity:.65;
  background:#f8fbf8;
}
.calendar-day-card.is-today{
  border:2px solid rgba(87,170,109,.55);
  box-shadow:0 16px 30px rgba(81,147,101,.12);
}
.calendar-day-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
}
.calendar-day-head strong{
  font-size:22px;
}
.calendar-day-head span{
  font-size:12px;
  color:#6f8671;
}
.calendar-day-list{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.calendar-event-pill{
  display:grid;
  grid-template-columns:48px minmax(0,1fr);
  gap:8px;
  align-items:start;
  padding:8px 9px;
  border-radius:14px;
  background:#eef8f0;
}
.calendar-event-pill strong,
.agenda-content strong{
  display:block;
  font-size:13px;
}
.calendar-event-pill small,
.agenda-content small{
  color:#5f6f61;
}
.calendar-event-time{
  font-size:12px;
  font-weight:700;
  color:#35573c;
}
.status-scheduled{background:#eaf7ff;}
.status-completed{background:#ebf9ef;}
.status-cancelled{background:#fff0f0;}
.status-pending{background:#fff7e8;}
.calendar-empty-day,
.calendar-more-note,
.empty-state-card{
  color:#708271;
  font-size:13px;
  padding:8px 0;
}
.calendar-lists{
  align-items:start;
}
.calendar-agenda-list{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.agenda-item{
  display:grid;
  grid-template-columns:74px minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  background:#fff;
  border:1px solid rgba(96,151,108,.13);
  border-radius:18px;
  padding:12px;
}
.agenda-date{
  background:#f3fbf4;
  border-radius:14px;
  padding:10px 8px;
  text-align:center;
}
.agenda-date strong{
  display:block;
  font-size:24px;
  line-height:1;
}
.agenda-date span{
  font-size:11px;
  color:#5e7160;
}
.agenda-content p{
  margin:4px 0 6px;
  color:#48584b;
}

@media (max-width: 1180px){
  .calendar-filters-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
  .calendar-grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
}
@media (max-width: 820px){
  .calendar-filters-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .calendar-grid,
  .calendar-weekdays{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .calendar-weekdays{display:none;}
  .calendar-day-card{min-height:140px;}
  .agenda-item{
    grid-template-columns:1fr;
    align-items:flex-start;
  }
  .calendar-nav-actions{width:100%;}
}
@media (max-width: 520px){
  .calendar-filters-grid{
    grid-template-columns:1fr;
  }
  .calendar-grid{
    grid-template-columns:1fr;
  }
  .calendar-day-card{min-height:auto;}
}

.google-calendar-topbar{
  align-items:flex-start;
}
.calendar-main-grid{
  display:grid;
  grid-template-columns:minmax(0,1.7fr) minmax(320px,.9fr);
  gap:20px;
  align-items:start;
  margin-bottom:20px;
}
.calendar-panel-google{
  margin-bottom:0;
}
.calendar-grid-google{
  gap:8px;
}
.calendar-day-link{
  text-decoration:none;
  color:inherit;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.calendar-day-link:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 32px rgba(41,75,53,.08);
}
.calendar-day-card.is-selected{
  border:2px solid rgba(67,145,86,.72);
  box-shadow:0 18px 34px rgba(66,130,80,.14);
}
.calendar-today-chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:24px;
  padding:4px 10px;
  border-radius:999px;
  background:#dff3e4;
  color:#2f6a3c;
  font-size:11px;
  font-weight:700;
}
.google-day-list{
  gap:6px;
}
.calendar-inline-event{
  display:grid;
  grid-template-columns:10px 44px minmax(0,1fr);
  gap:6px;
  align-items:center;
  min-height:24px;
  padding:4px 6px;
  border-radius:10px;
  background:#f7fbf8;
}
.calendar-inline-event strong{
  font-size:12px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.calendar-inline-time{
  font-size:11px;
  font-weight:700;
  color:#45664b;
}
.calendar-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  background:currentColor;
  display:inline-block;
}
.calendar-inline-event.status-scheduled{color:#2a6ea8;background:#eef6ff;}
.calendar-inline-event.status-completed{color:#2f7b4f;background:#edf9f1;}
.calendar-inline-event.status-cancelled{color:#b04747;background:#fff2f2;}
.calendar-inline-event.status-pending{color:#996c15;background:#fff8e8;}
.calendar-day-panel{
  position:sticky;
  top:88px;
}
.selected-day-list{
  max-height:720px;
  overflow:auto;
  padding-right:4px;
}
.day-focus-item{
  grid-template-columns:96px minmax(0,1fr);
  align-items:start;
}
.agenda-time-box{
  text-align:center;
}
.agenda-time-box strong{
  font-size:18px;
}
.agenda-time-box span{
  display:block;
  margin-top:6px;
  font-size:11px;
  text-transform:capitalize;
}
@media (max-width: 1180px){
  .calendar-main-grid{
    grid-template-columns:1fr;
  }
  .calendar-day-panel{
    position:static;
  }
}
@media (max-width: 820px){
  .calendar-grid-google,
  .calendar-weekdays{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .day-focus-item{
    grid-template-columns:1fr;
  }
}
@media (max-width: 520px){
  .calendar-grid-google{
    grid-template-columns:1fr;
  }
  .calendar-inline-event{
    grid-template-columns:10px 38px minmax(0,1fr);
  }
}


@media (max-width: 900px){
  .appointment-datetime-row{
    grid-template-columns:1fr;
    gap:14px;
  }
}

@media (max-width: 560px){
  .appointment-datetime-row input[type="date"],
  .appointment-datetime-row input[type="time"]{
    font-size:16px;
    padding-right:44px;
  }
}

@media (max-width: 1100px){.patients-layout{grid-template-columns:1fr}}
@media (max-width: 720px){.patient-form-grid{grid-template-columns:1fr}}
