/* DoctorShop — Doctor Dashboard (Light, Apple-like, Mobile-first) */
/* Basado en tus patrones: nav + btn-ghost + cinematic reveal + layout mobile-first sidebar :contentReference[oaicite:2]{index=2} :contentReference[oaicite:3]{index=3} */

:root{
  --bg:#f5f7fb;
  --panel:#ffffff;
  --panel-2:#fbfcff;
  --text:#0f172a;
  --muted:#5b6475;
  --border:rgba(15,23,42,.08);
  --shadow:0 18px 38px rgba(15,23,42,.08);
  --accent:#0071e3;
  --accent-soft:rgba(0,113,227,.12);
  --danger:#ef4444;
  --ok:#22c55e;
  --radius:16px;
  --max:1120px;

  --sidebar-w: 286px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  color:var(--text);
  background:linear-gradient(180deg,#f7f9ff 0%, #f3f6fb 100%) fixed;
  overflow-x:hidden;
}

html{overflow-x:hidden;}

/* Shell */
.ds-wrap{
  display:grid;
  grid-template-columns: 1fr;
  min-height:100dvh;
  width:100%;
  max-width:100%;
}

.ds-aside{
  position:fixed;
  inset:0 auto 0 0;
  width:min(86vw, var(--sidebar-w));
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(14px);
  border-right:1px solid var(--border);
  transform:translateX(-102%);
  transition:transform .24s ease;
  z-index:30;
  overflow:auto;
  padding:18px 14px;
}

.ds-aside.open{ transform:translateX(0); }

.ds-main{
  width:100%;
  min-width:0;
  /* Global horizontal gutter for all doctor dashboard pages */
  padding-inline: clamp(10px, 1.5vw, 22px);
}

.ds-header{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,255,255,.78);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--border);
}

.ds-header__in{
  max-width:var(--max);
  margin:0 auto;
  padding:12px clamp(14px, 2vw, 28px);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  width:100%;
  min-width:0;
}
.ds-headcopy{
  flex:1 1 auto;
  min-width:0;
}
.ds-headcopy .ds-sub{
  overflow-wrap:anywhere;
  word-break:break-word;
}

.ds-content{
  max-width:var(--max);
  margin:0 auto;
  padding:clamp(14px, 1.6vw, 24px) clamp(14px, 2vw, 28px);
  width:100%;
  min-width:0;
}

/* Brand */
.ds-brand{
  display:flex;
  align-items:center;
  gap:10px;
  padding:8px 10px;
  border-radius:12px;
}
.ds-brand img{
  width:28px;height:28px; object-fit:contain;
}
.ds-brand span{
  font-weight:800;
  letter-spacing:.2px;
}

/* Buttons */
.ds-btn{
  appearance:none;
  border:1px solid var(--border);
  background:var(--panel);
  color:var(--text);
  border-radius:12px;
  padding:10px 12px;
  cursor:pointer;
  box-shadow:none;
  transition:transform .14s ease, box-shadow .14s ease, background .14s ease, border-color .14s ease;
}
.ds-btn:active{ transform:scale(.98); }
.ds-btn.ghost{
  background:rgba(15,23,42,.04);
  border-color:rgba(15,23,42,.12);
}
.ds-btn.primary{
  background:linear-gradient(180deg,#1478ff,#0062c9);
  border-color:rgba(0,98,201,.45);
  color:#fff;
  box-shadow:0 14px 34px rgba(0,113,227,.18);
}
.ds-btn.danger{
  background:rgba(239,68,68,.08);
  border-color:rgba(239,68,68,.22);
  color:#b91c1c;
}
.ds-icon-btn{
  width:38px;
  height:38px;
  padding:0;
  border-radius:12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  position:relative;
}
.ds-icon-btn svg{
  width:18px;
  height:18px;
  display:block;
}
.ds-icon-btn::after{
  content:attr(data-tooltip);
  position:absolute;
  right:0;
  top:calc(100% + 8px);
  background:rgba(2,6,23,.92);
  color:#fff;
  font-size:.74rem;
  font-weight:700;
  letter-spacing:.01em;
  padding:6px 8px;
  border-radius:8px;
  opacity:0;
  transform:translateY(-2px);
  pointer-events:none;
  white-space:nowrap;
  transition:opacity .16s ease, transform .16s ease;
}
.ds-icon-btn:hover::after,
.ds-icon-btn:focus-visible::after{
  opacity:1;
  transform:translateY(0);
}

/* Haptic/spinner micro */
.ds-a{
  text-decoration:none;
  color:inherit;
}
.ds-a[data-ds-nav]{
  position:relative;
}
.ds-a .btn-spinner{
  display:none;
  margin-left:10px;
}
.ds-a.is-loading .btn-spinner{display:inline-flex}
.apple-spinner{
  width:14px;height:14px;border-radius:999px;
  border:2px solid rgba(15,23,42,.18);
  border-top-color:rgba(15,23,42,.48);
  animation:spin .72s linear infinite;
}
@keyframes spin{ to {transform:rotate(360deg)} }

/* Sidebar nav */
.ds-navgrp{ margin-top:14px; }
.ds-navttl{
  color:var(--muted);
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.12rem;
  margin:16px 10px 8px;
}
.ds-nav a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:10px 12px;
  margin:6px 6px;
  border-radius:12px;
  border:1px solid transparent;
  color:var(--text);
}
.ds-nav a:hover{
  background:var(--panel);
  border-color:var(--border);
  box-shadow:var(--shadow);
}
.ds-nav a.active{
  background:linear-gradient(90deg, var(--accent-soft), transparent);
  border-color:rgba(0,113,227,.22);
}

.ds-pill{
  font-size:.78rem;
  color:var(--muted);
  border:1px solid var(--border);
  background:rgba(255,255,255,.7);
  border-radius:999px;
  padding:4px 10px;
}

/* Cards + grid */
.ds-grid{ display:grid; gap:12px; }
.ds-grid.cols-4{ grid-template-columns:1fr; }
.ds-card{
  background:rgba(255,255,255,.92);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:14px;
  min-width:0;
  max-width:100%;
}
.ds-card h3{
  margin:0 0 8px;
  font-size:.92rem;
  color:var(--muted);
  font-weight:700;
}
.ds-kpi{
  font-size:1.55rem;
  font-weight:900;
  letter-spacing:-.02em;
}
.ds-sub{
  color:var(--muted);
  font-size:.92rem;
}
.ds-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  min-width:0;
}
.ds-divider{
  height:1px;
  background:var(--border);
  margin:12px 0;
}

/* Table */
.ds-tablewrap{
  overflow:auto;
  border:1px solid var(--border);
  border-radius:14px;
  background:rgba(255,255,255,.92);
  max-width:100%;
  -webkit-overflow-scrolling:touch;
}
.ds-table{
  width:100%;
  border-collapse:collapse;
  min-width:820px;
  font-size:.95rem;
}
.ds-table th,.ds-table td{
  padding:12px 14px;
  border-bottom:1px solid var(--border);
  text-align:left;
}
.ds-table th{
  color:var(--muted);
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.08rem;
  background:rgba(15,23,42,.02);
}

/* Prevent horizontal overflow on nested dashboard layouts */
.ds-wrap,
.ds-main,
.ds-header,
.ds-header__in,
.ds-content,
.ds-grid,
.ds-grid > *,
.ds-card,
.ds-row,
.ds-headcopy{
  min-width:0;
  max-width:100%;
}

@media (min-width:641px) and (max-width:1023px){
  .ds-grid.cols-4{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width:640px){
  .ds-header__in{
    display:grid;
    grid-template-columns:auto minmax(0, 1fr);
    align-items:center;
    gap:8px;
  }
  .ds-headcopy{
    width:100%;
  }
  .ds-card{
    padding:12px;
  }
  .ds-kpi{
    font-size:clamp(1.3rem, 6vw, 1.7rem);
  }
  .ds-row{
    align-items:stretch;
  }
  .ds-row > .ds-btn,
  .ds-row > .ds-a.ds-btn,
  .ds-row > .ds-actions{
    width:100%;
  }
  .ds-actions{
    width:100%;
    justify-content:stretch;
  }
  .ds-actions .ds-btn,
  .ds-actions .ds-icon-btn{
    flex:1 1 100%;
    width:100%;
  }
  .ds-header__in > .ds-btn.primary,
  .ds-header__in > a.ds-btn.primary{
    grid-column:1 / -1;
    width:100%;
    justify-content:center;
  }
}

@media (max-width:860px){
  .ds-content{
    padding-inline:14px;
  }
  .ds-tablewrap{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
}

/* Cinematic reveal (similar to tus footer pages) :contentReference[oaicite:4]{index=4} */
.cinematic{
  opacity:0;
  transform:translateY(10px);
  transition:opacity .5s ease, transform .5s ease;
  transition-delay: var(--delay, 0ms);
}
.cinematic.is-in{
  opacity:1;
  transform:none;
}

/* Desktop */
@media (min-width:1024px){
  .ds-wrap{ grid-template-columns:260px 1fr; }
  .ds-aside{
    position:sticky;
    top:0;
    height:100dvh;
    transform:none;
    width:auto;
    z-index:auto;
  }
  #dsOpenMenu,
  #dsCloseMenu{
    display:none !important;
  }
  .ds-content{ padding:26px clamp(22px, 2.4vw, 36px); }
  .ds-grid.cols-4{ grid-template-columns:repeat(4, minmax(0,1fr)); }
}

/* Invoicing pages: mobile-first controls and table cards */
.ds-page--invoicing .ds-actions{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  width:100%;
  justify-items:stretch;
}
.ds-page--invoicing .ds-actions .ds-field{
  min-width:0 !important;
  margin:0;
}
.ds-page--invoicing .ds-field,
.ds-page--invoicing .ds-input,
.ds-page--invoicing .ds-select{
  width:100%;
  min-width:0;
}
.ds-page--invoicing .ds-label{
  color:var(--muted);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.ds-page--invoicing .ds-kpi{
  font-size:clamp(1.35rem, 5vw, 1.9rem);
}
.ds-page--invoicing .ds-sub{
  line-height:1.35;
}
.ds-page--invoicing .ds-mono{
  word-break:break-word;
  overflow-wrap:anywhere;
}
.ds-page--invoicing .ds-actions .ds-btn,
.ds-page--invoicing .ds-actions .ds-icon-btn{
  width:100%;
  justify-content:center;
}
.ds-page--invoicing .ds-actions .ds-row{
  width:100%;
  justify-content:stretch;
}
.ds-page--invoicing .ds-actions .ds-row .ds-btn{
  flex:1 1 0;
}
.ds-page--invoicing .ds-seg{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  width:100%;
}
.ds-page--invoicing .ds-seg a{
  text-align:center;
}

@media (max-width:860px){
  .ds-page--invoicing .ds-header__in{
    display:flex;
    flex-wrap:wrap;
    align-items:flex-start;
    gap:10px;
  }
  .ds-page--invoicing .ds-headcopy{
    flex:1 1 190px;
  }
  .ds-page--invoicing .ds-header__in > .ds-btn.primary,
  .ds-page--invoicing .ds-header__in > .ds-seg{
    flex:1 1 100%;
  }
  .ds-page--invoicing .ds-header__in > .ds-icon-btn{
    margin-left:auto;
  }
  .ds-page--invoicing .ds-modal{
    padding:10px;
  }
  .ds-page--invoicing .ds-modal-card,
  .ds-page--invoicing .ds-sheet{
    width:100%;
    max-height:88vh;
    border-radius:16px;
    padding:12px;
  }
  .ds-page--invoicing .ds-content{
    padding-bottom:max(20px, env(safe-area-inset-bottom));
  }
}

@media (max-width:820px){
  .ds-page--invoicing .ds-tablewrap{
    overflow:visible;
    border:none;
    background:transparent;
  }
  .ds-page--invoicing .ds-table{
    min-width:100%;
    border-collapse:separate;
    border-spacing:0;
  }
  .ds-page--invoicing .ds-table thead{
    display:none;
  }
  .ds-page--invoicing .ds-table tbody{
    display:block;
  }
  .ds-page--invoicing .ds-table tr{
    display:block;
    margin:0 0 12px;
    border:1px solid var(--border);
    border-radius:14px;
    background:rgba(255,255,255,.94);
    box-shadow:var(--shadow);
    padding:6px 6px 4px;
  }
  .ds-page--invoicing .ds-table td{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:10px;
    text-align:right;
    padding:10px 10px;
    border-bottom:1px solid var(--border);
    white-space:normal;
  }
  .ds-page--invoicing .ds-table td::before{
    content:attr(data-label);
    text-align:left;
    color:var(--muted);
    font-size:.74rem;
    letter-spacing:.06em;
    text-transform:uppercase;
    font-weight:700;
  }
  .ds-page--invoicing .ds-table td:last-child{
    border-bottom:0;
  }
  .ds-page--invoicing .ds-table td[data-label="Acciones"] .ds-actions,
  .ds-page--invoicing .ds-table td[data-label="Archivos"] .ds-actions{
    width:100%;
    justify-content:stretch;
  }
  .ds-page--invoicing .ds-table td[data-label="Acciones"] .ds-actions .ds-btn,
  .ds-page--invoicing .ds-table td[data-label="Archivos"] .ds-actions .ds-btn{
    flex:1 1 0;
  }
  .ds-page--invoicing .ds-table td[colspan]{
    display:block;
    text-align:left;
  }
  .ds-page--invoicing .ds-table td[colspan]::before{
    content:none;
  }
}

@media (min-width:821px){
  .ds-page--invoicing .ds-actions{
    display:flex;
    width:auto;
    justify-content:flex-end;
    align-items:flex-end;
    flex-wrap:wrap;
  }
  .ds-page--invoicing .ds-actions .ds-btn,
  .ds-page--invoicing .ds-actions .ds-icon-btn{
    width:auto;
  }
}

@media (min-width:821px) and (max-width:1080px){
  .ds-page--invoicing .ds-actions{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    width:100%;
    justify-items:stretch;
  }
  .ds-page--invoicing .ds-actions .ds-btn,
  .ds-page--invoicing .ds-actions .ds-icon-btn{
    width:100%;
  }
}

@media (max-width:640px){
  .ds-page--invoicing .ds-kv{
    grid-template-columns:1fr !important;
  }
}
