/* ═══ Agenda Clinica — .ag-* ═════════════════════════════ */
.ag-root { display:flex; flex-direction:column; height:100%; overflow:hidden; }

/* ── Toolbar (patron Staff) ─────────────────────────────── */
.ag-toolbar { display:flex; align-items:center; gap:8px; padding:10px 20px; border-bottom:1px solid var(--border); flex-shrink:0; background:var(--bg-body); flex-wrap:wrap; min-height:52px; position:relative; z-index:10; }
.ag-toolbar-left { display:flex; align-items:center; gap:8px; flex:1; min-width:0; }
.ag-toolbar-right { display:flex; align-items:center; gap:6px; }
.ag-mod-icon { color:var(--c-brand); display:flex; align-items:center; flex-shrink:0; }
.ag-header-title { font-size:var(--font-lg); font-weight:700; color:var(--tx-base); margin-right:12px; white-space:nowrap; }

.ag-prof-select { height:34px; padding:0 28px 0 10px; border:1px solid var(--border); border-radius:var(--radius-md); background:var(--bg-surface); color:var(--tx-base); font-size:var(--font-sm); cursor:pointer; appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 8px center; max-width:200px; transition:border-color var(--transition-fast); }
.ag-prof-select:hover { border-color:var(--c-brand); }
.ag-prof-select:focus { outline:none; border-color:var(--c-brand); box-shadow:0 0 0 3px var(--c-brand-muted); }

.ag-date-nav { display:flex; align-items:center; gap:4px; margin:0 4px; }
.ag-nav-btn { width:32px; height:32px; border:1px solid var(--border); border-radius:var(--radius-md); background:var(--bg-surface); color:var(--tx-muted); cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all var(--transition-fast); padding:0; }
.ag-nav-btn:hover { background:var(--bg-hover); border-color:var(--c-brand); color:var(--c-brand); }
.ag-nav-today { height:32px; padding:0 12px; border:1px solid var(--border); border-radius:var(--radius-md); background:var(--bg-surface); color:var(--tx-base); font-size:var(--font-xs); font-weight:500; cursor:pointer; transition:all var(--transition-fast); }
.ag-nav-today:hover { background:var(--c-brand); color:#fff; border-color:var(--c-brand); }
.ag-date-label { font-size:var(--font-md); font-weight:600; color:var(--tx-base); white-space:nowrap; min-width:140px; text-align:center; user-select:none; }

.ag-view-pills { display:flex; background:var(--bg-surface); border:1px solid var(--border); border-radius:var(--radius-md); overflow:hidden; }
.ag-view-btn { height:32px; padding:0 14px; border:none; background:transparent; color:var(--tx-muted); font-size:var(--font-xs); font-weight:500; cursor:pointer; transition:all var(--transition-fast); white-space:nowrap; }
.ag-view-btn:hover:not(.ag-view-active):not(:disabled) { color:var(--tx-base); }
.ag-view-btn.ag-view-active { background:var(--c-brand); color:#fff; }
.ag-view-btn:disabled { opacity:.35; cursor:not-allowed; }

.ag-btn-new { height:34px; padding:0 14px; border:none; border-radius:var(--radius-md); background:var(--c-brand); color:#fff; font-size:var(--font-sm); font-weight:500; cursor:pointer; display:flex; align-items:center; gap:6px; transition:opacity var(--transition-fast); white-space:nowrap; }
.ag-btn-new:hover { opacity:.85; }

/* ── Content ────────────────────────────────────────────── */
.ag-content { flex:1; overflow:auto; position:relative; background:var(--bg-body); }

/* ── Loading / Empty ────────────────────────────────────── */
.ag-loading { display:flex; align-items:center; justify-content:center; height:100%; color:var(--tx-muted); font-size:var(--font-sm); gap:8px; }
.ag-spinner { width:18px; height:18px; border:2px solid var(--border); border-top-color:var(--c-brand); border-radius:50%; animation:ag-spin .6s linear infinite; }
@keyframes ag-spin { to { transform:rotate(360deg); } }
.ag-empty { display:flex; flex-direction:column; align-items:center; justify-content:center; height:100%; color:var(--tx-muted); gap:8px; padding:40px; text-align:center; }
.ag-empty-icon { opacity:.4; }
.ag-empty-text { font-size:var(--font-md); font-weight:500; color:var(--tx-muted); }
.ag-empty-sub { font-size:var(--font-xs); }

/* ══ WEEK ═══════════════════════════════════════════════ */
.ag-week { display:grid; grid-template-columns:52px repeat(6,1fr); min-height:100%; }
.ag-week-header { display:contents; }
.ag-week-hcell { position:sticky; top:0; z-index:5; background:var(--bg-card); border-bottom:2px solid var(--border); padding:8px 6px; text-align:center; font-size:var(--font-xs); font-weight:600; color:var(--tx-muted); text-transform:uppercase; letter-spacing:.5px; }
.ag-week-hcell.ag-today-col { color:var(--c-brand); background:var(--bg-active); }
.ag-week-hcell-date { display:block; font-size:var(--font-xl); font-weight:700; color:var(--tx-base); margin-top:2px; line-height:1; }
.ag-today-col .ag-week-hcell-date { background:var(--c-brand); color:#fff; width:28px; height:28px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:var(--font-md); }
.ag-week-gutter { border-right:1px solid var(--border); background:var(--bg-card); }
.ag-time-label { height:48px; display:flex; align-items:flex-start; justify-content:flex-end; padding:0 8px; font-size:10px; font-weight:500; color:var(--tx-dim); transform:translateY(-6px); user-select:none; }
.ag-week-col { position:relative; border-right:1px solid var(--border-soft); min-height:calc(12 * 48px); }
.ag-week-col:last-child { border-right:none; }
.ag-hour-line { position:absolute; left:0; right:0; height:1px; background:var(--border-soft); pointer-events:none; }
.ag-hour-line-half { background:var(--border-soft); opacity:.4; }

.ag-now-line { position:absolute; left:-4px; right:0; height:2px; background:#ef4444; z-index:4; pointer-events:none; }
.ag-now-dot { position:absolute; left:-4px; top:-3px; width:8px; height:8px; border-radius:50%; background:#ef4444; }

/* ── Cita blocks ────────────────────────────────────────── */
.ag-cita { position:absolute; left:3px; right:4px; border-radius:var(--radius-sm); border-left:3px solid var(--ag-cita-border); background:var(--ag-cita-bg); padding:3px 6px; cursor:pointer; overflow:hidden; z-index:2; transition:box-shadow var(--transition-fast); font-size:var(--font-xs); line-height:1.3; user-select:none; }
.ag-cita:hover { box-shadow:var(--shadow-sm); z-index:3; }
.ag-cita.ag-dragging { opacity:.5; transform:scale(.96); }
.ag-cita-time { font-weight:600; color:var(--tx-base); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ag-cita-badges { display:flex; align-items:center; gap:4px; margin-top:1px; }
.ag-badge { font-size:9px; font-weight:600; padding:1px 5px; border-radius:var(--radius-sm); white-space:nowrap; line-height:1.4; }
.ag-badge-estado { color:var(--ag-cita-border); background:var(--ag-cita-bg); border:1px solid var(--ag-cita-border); }
.ag-consent-ok { color:var(--tx-green); display:flex; align-items:center; }
.ag-consent-warn { color:var(--tx-amber); display:flex; align-items:center; }
.ag-cita-prof { font-size:9px; color:var(--tx-muted); font-weight:500; }
.ag-drop-target { background:var(--bg-active) !important; }
.ag-slot-available { position:absolute; left:3px; right:4px; border:1px dashed var(--border); border-radius:var(--radius-sm); cursor:pointer; opacity:0; transition:opacity var(--transition-fast); z-index:1; display:flex; align-items:center; justify-content:center; font-size:var(--font-xs); color:var(--tx-muted); }
.ag-week-col:hover .ag-slot-available { opacity:1; }
.ag-slot-available:hover { background:var(--bg-active); border-color:var(--c-brand); color:var(--c-brand); }

/* ══ MONTH ══════════════════════════════════════════════ */
.ag-month { display:grid; grid-template-columns:repeat(6,1fr); gap:1px; background:var(--border); border-radius:var(--radius-md); overflow:hidden; margin:16px 20px; }
.ag-month-header { background:var(--bg-card); padding:8px; text-align:center; font-size:var(--font-xs); font-weight:600; color:var(--tx-muted); text-transform:uppercase; letter-spacing:.5px; }
.ag-month-cell { background:var(--bg-card); padding:8px; min-height:80px; cursor:pointer; transition:background var(--transition-fast); }
.ag-month-cell:hover { background:var(--bg-hover); }
.ag-month-cell.ag-outside { opacity:.35; }
.ag-month-day { font-size:var(--font-sm); font-weight:600; color:var(--tx-base); margin-bottom:4px; }
.ag-month-cell.ag-today .ag-month-day { background:var(--c-brand); color:#fff; width:24px; height:24px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:var(--font-xs); }
.ag-month-dots { display:flex; flex-wrap:wrap; gap:3px; }
.ag-month-dot { width:7px; height:7px; border-radius:50%; }
.ag-month-more { font-size:9px; color:var(--tx-muted); font-weight:600; }
.ag-dot-tooltip { position:absolute; z-index:20; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-md); padding:8px 10px; box-shadow:var(--shadow-md); font-size:var(--font-xs); min-width:140px; max-width:220px; pointer-events:none; animation:ag-fade-in .12s ease-out; }
.ag-dot-tooltip-item { padding:2px 0; display:flex; align-items:center; gap:6px; color:var(--tx-base); }
.ag-legend-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }

/* ══ DAY ════════════════════════════════════════════════ */
.ag-day { padding:0 20px 20px; }
.ag-day-slot { display:flex; gap:12px; padding:8px 0; border-bottom:1px solid var(--border-soft); min-height:64px; align-items:flex-start; }
.ag-day-time { width:52px; font-size:var(--font-sm); font-weight:600; color:var(--tx-dim); padding-top:4px; flex-shrink:0; text-align:right; }
.ag-day-card { flex:1; border-radius:var(--radius-md); padding:10px 14px; border-left:3px solid var(--ag-cita-border); background:var(--ag-cita-bg); cursor:pointer; transition:box-shadow var(--transition-fast); }
.ag-day-card:hover { box-shadow:var(--shadow-sm); }
.ag-day-card-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:4px; }
.ag-day-card-name { font-size:var(--font-md); font-weight:600; color:var(--tx-base); }
.ag-day-card-meta { font-size:var(--font-xs); color:var(--tx-muted); display:flex; gap:8px; align-items:center; }
.ag-day-card-badges { display:flex; gap:6px; align-items:center; margin-top:4px; }
.ag-day-available { flex:1; border:1px dashed var(--border); border-radius:var(--radius-md); padding:10px 14px; color:var(--tx-muted); font-size:var(--font-xs); cursor:pointer; transition:all var(--transition-fast); display:flex; align-items:center; gap:6px; }
.ag-day-available:hover { border-color:var(--c-brand); color:var(--c-brand); background:var(--bg-active); }
.ag-btn-atender { height:28px; padding:0 10px; border:none; border-radius:var(--radius-sm); background:var(--tx-green); color:#fff; font-size:var(--font-xs); font-weight:600; cursor:pointer; display:flex; align-items:center; gap:4px; transition:opacity var(--transition-fast); }
.ag-btn-atender:hover { opacity:.85; }
.ag-btn-atender:disabled { opacity:.4; cursor:not-allowed; }

/* ══ FOCUS ══════════════════════════════════════════════ */
.ag-focus { display:flex; gap:1px; background:var(--border); height:100%; overflow-x:auto; }
.ag-focus-col { flex:1; min-width:220px; max-width:320px; background:var(--bg-card); display:flex; flex-direction:column; }
.ag-focus-header { padding:12px; border-bottom:1px solid var(--border-soft); display:flex; align-items:center; gap:10px; position:sticky; top:0; background:var(--bg-card); z-index:5; }
.ag-focus-avatar { width:32px; height:32px; border-radius:50%; background:var(--c-brand); color:#fff; display:flex; align-items:center; justify-content:center; font-size:var(--font-xs); font-weight:700; flex-shrink:0; }
.ag-focus-name { font-size:var(--font-sm); font-weight:600; color:var(--tx-base); line-height:1.2; }
.ag-focus-spec { font-size:10px; color:var(--tx-muted); }
.ag-focus-badge { margin-left:auto; font-size:10px; font-weight:700; background:var(--c-brand); color:#fff; padding:2px 7px; border-radius:10px; }
.ag-focus-slots { flex:1; overflow-y:auto; padding:4px; }
.ag-focus-slot { padding:6px 8px; border-radius:var(--radius-sm); margin-bottom:2px; font-size:var(--font-sm); display:flex; align-items:center; gap:6px; cursor:pointer; transition:background var(--transition-fast); border-left:3px solid transparent; }
.ag-focus-slot:hover { background:var(--bg-hover); }
.ag-focus-slot[data-ag-cita] { border-left-color:var(--ag-cita-border); background:var(--ag-cita-bg); }
.ag-focus-time { font-weight:600; color:var(--tx-muted); font-size:var(--font-xs); width:40px; flex-shrink:0; }
.ag-focus-patient { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--tx-base); }

/* ══ CONTEXT MENU ═══════════════════════════════════════ */
.ag-ctx { position:fixed; z-index:100; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-md); box-shadow:var(--shadow-lg); padding:4px; min-width:180px; animation:ag-fade-in .1s ease-out; }
.ag-ctx-item { display:flex; align-items:center; gap:8px; padding:8px 12px; border-radius:var(--radius-sm); font-size:var(--font-sm); color:var(--tx-base); cursor:pointer; transition:background var(--transition-fast); border:none; background:none; width:100%; text-align:left; }
.ag-ctx-item:hover { background:var(--bg-hover); }
.ag-ctx-item--danger { color:var(--tx-red); }
.ag-ctx-item--danger:hover { background:rgba(220,38,38,.06); }
.ag-ctx-sep { height:1px; background:var(--border-soft); margin:4px 8px; }

/* ══ MOBILE ═════════════════════════════════════════════ */
.ag-mobile-toolbar { display:flex; align-items:center; padding:10px 16px; gap:8px; background:var(--bg-card); border-bottom:1px solid var(--border); }
.ag-mobile-date { flex:1; text-align:center; font-size:var(--font-lg); font-weight:600; color:var(--tx-base); }
.ag-mobile-slots { flex:1; overflow-y:auto; padding:8px 16px; -webkit-overflow-scrolling:touch; }
.ag-mobile-card { border-radius:var(--radius-md); padding:12px 14px; margin-bottom:8px; border-left:4px solid var(--ag-cita-border); background:var(--bg-card); box-shadow:var(--shadow-sm); cursor:pointer; -webkit-tap-highlight-color:transparent; }
.ag-mobile-card:active { transform:scale(.98); }
.ag-mobile-fab { position:fixed; bottom:76px; right:16px; width:52px; height:52px; border-radius:16px; background:var(--c-brand); color:#fff; border:none; box-shadow:0 4px 16px rgba(109,40,217,.35); display:flex; align-items:center; justify-content:center; cursor:pointer; z-index:20; }
.ag-mobile-fab:active { transform:scale(.9); }

/* ══ ANIMATIONS ═════════════════════════════════════════ */
@keyframes ag-fade-in { from { opacity:0; transform:translateY(-4px); } to { opacity:1; transform:translateY(0); } }
.ag-view-enter { animation:ag-fade-in .2s ease-out; }
.ag-skeleton { background:linear-gradient(90deg, var(--border) 25%, rgba(255,255,255,.1) 50%, var(--border) 75%); background-size:200% 100%; animation:ag-shimmer 1.2s infinite; border-radius:var(--radius-sm); }
@keyframes ag-shimmer { 0% { background-position:200% 0; } 100% { background-position:-200% 0; } }

/* ══ PRINT ══════════════════════════════════════════════ */
@media print { .ag-toolbar, .ag-mobile-fab, .ag-ctx, .ag-btn-new, .ag-nav-btn, .ag-nav-today, .ag-view-pills { display:none !important; } .ag-content { overflow:visible !important; } .ag-cita { break-inside:avoid; box-shadow:none !important; border:1px solid var(--border); } }
