/* ══════════════════════════════════════════════════════════
   Dashboard Pro — Oraltek Admin Panel
   Global styles (unscoped) to enhance the Astro dashboard
   ══════════════════════════════════════════════════════════ */

/* ── Reset / Base ────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
body{font-family:Inter,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:#f0f2f5;color:#1a1a2e;min-height:100vh;-webkit-font-smoothing:antialiased}

/* ── Topbar ──────────────────────────────────────────── */
.dash-topbar{position:fixed;top:0;left:0;right:0;z-index:100;height:56px;background:#fff;border-bottom:1px solid #e8ecf0;display:flex;align-items:center;padding:0 1.25rem;gap:.75rem;box-shadow:0 1px 3px #0000000a}
.dash-topbar .logo{display:flex;align-items:center;gap:.5rem;font-weight:700;color:#0077b6;text-decoration:none;font-size:1rem}
.dash-topbar .logo img{height:32px;width:32px;border-radius:8px}
.dash-topbar .spacer{flex:1}
.dash-topbar .user-badge{display:flex;align-items:center;gap:.6rem;padding:.35rem .75rem;border-radius:10px;background:#f5f7fa;font-size:.85rem;cursor:pointer;position:relative;transition:background .15s}
.dash-topbar .user-badge:hover{background:#e8ecf0}
.dash-topbar .user-badge .avatar{width:30px;height:30px;border-radius:50%;object-fit:cover;background:linear-gradient(135deg,#0077b6,#00b4d8);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.75rem;font-weight:700;flex-shrink:0}
.dash-topbar .user-badge .user-role-tag{font-size:.6rem;padding:.1rem .4rem;border-radius:4px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.role-superadmin{background:#fef3c7;color:#92400e}
.role-admin{background:#dbeafe;color:#1e40af}
.role-soporte{background:#e0e7ff;color:#3730a3}
.role-doctor{background:#d1fae5;color:#065f46}
.role-citas{background:#fce7f3;color:#9d174d}
.role-client{background:#f3f4f6;color:#374151}

/* User dropdown */
.dash-topbar .user-menu{display:none;position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border-radius:12px;box-shadow:0 8px 30px #00000018,0 1px 3px #0000000f;min-width:220px;overflow:hidden;border:1px solid #e8ecf0;z-index:200}
.dash-topbar .user-badge:hover .user-menu{display:block}
.dash-topbar .user-menu .menu-header{padding:.75rem 1rem;border-bottom:1px solid #f0f2f5;font-weight:600;color:#1a1a2e;font-size:.82rem}
.dash-topbar .user-menu .menu-header small{display:block;font-weight:400;color:#8899a6;font-size:.72rem;margin-top:.1rem}
.dash-topbar .user-menu a{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;color:#555;text-decoration:none;font-size:.82rem;transition:all .12s}
.dash-topbar .user-menu a:hover{background:#f5f7fa;color:#0077b6}
.dash-topbar .user-menu a.danger{color:#e74c3c}
.dash-topbar .user-menu a.danger:hover{background:#fef2f2;color:#dc2626}
.dash-topbar .user-menu .menu-divider{height:1px;background:#f0f2f5;margin:.25rem 0}

/* ── Sidebar ─────────────────────────────────────────── */
.dash-sidebar{position:fixed;top:56px;left:0;bottom:0;width:240px;background:linear-gradient(180deg,#1a1a2e 0%,#16162a 100%);color:#fff;overflow-y:auto;transition:transform .25s ease;z-index:50}
.dash-sidebar nav{padding:.5rem 0}
.dash-sidebar .nav-section{padding:.75rem 1rem .25rem;font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:#5c6b7a;font-weight:700}
.dash-sidebar a{display:flex;align-items:center;gap:.6rem;padding:.55rem 1rem;color:#9ca8b4;text-decoration:none;font-size:.84rem;border-left:3px solid transparent;transition:all .15s;position:relative}
.dash-sidebar a:hover{background:#ffffff08;color:#e0e6ed}
.dash-sidebar a.active{background:linear-gradient(90deg,#0077b620,transparent);color:#4fc3f7;border-left-color:#0077b6;font-weight:600}
.dash-sidebar a .icon{font-size:1rem;width:1.2rem;text-align:center;flex-shrink:0}
.dash-sidebar a .badge-count{position:absolute;right:.75rem;background:#e74c3c;color:#fff;font-size:.6rem;padding:.1rem .35rem;border-radius:8px;font-weight:700;min-width:16px;text-align:center}
.dash-sidebar .nav-bottom{position:absolute;bottom:0;left:0;right:0;padding:.75rem 1rem;border-top:1px solid #ffffff0d}
.dash-sidebar .nav-bottom a{font-size:.78rem;color:#5c6b7a;padding:.4rem 0;border-left:none}
.dash-sidebar .nav-bottom a:hover{color:#9ca8b4}
.btn-menu-toggle{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;padding:.25rem;color:#555}

/* Hidden nav items per role */
.dash-sidebar a[data-role-hide]{display:none}

/* ── Main Content ────────────────────────────────────── */
.dash-main{margin-left:240px;margin-top:56px;padding:1.5rem;min-height:calc(100vh - 56px)}

/* ── Cards ───────────────────────────────────────────── */
.card{background:#fff;border-radius:14px;padding:1.25rem;box-shadow:0 1px 3px #0000000a;border:1px solid #f0f2f5;transition:box-shadow .2s}
.card:hover{box-shadow:0 4px 12px #0000000f}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #f0f2f5}
.card-header h2{font-size:1rem;font-weight:600;color:#1a1a2e}

/* ── Stats Grid (Bento) ─────────────────────────────── */
.grid-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}
.stat-card{padding:1.25rem;position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#0077b6,#00b4d8);border-radius:14px 14px 0 0;opacity:0;transition:opacity .2s}
.stat-card:hover::before{opacity:1}
.stat-card .stat-value{font-size:2rem;font-weight:800;background:linear-gradient(135deg,#0077b6,#00b4d8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.1}
.stat-card .stat-label{font-size:.78rem;color:#8899a6;margin-top:.3rem;font-weight:500}
.stat-card .stat-icon{font-size:2rem;opacity:.15;position:absolute;top:.75rem;right:1rem}

/* ── Buttons ─────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:8px;border:none;font-size:.82rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all .15s;font-family:inherit}
.btn-primary{background:linear-gradient(135deg,#0077b6,#005f8a);color:#fff;box-shadow:0 2px 8px #0077b630}
.btn-primary:hover{background:linear-gradient(135deg,#005f8a,#004a6e);transform:translateY(-1px);box-shadow:0 4px 12px #0077b640}
.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b98130}
.btn-success:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px)}
.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef444430}
.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px)}
.btn-outline{background:#fff;border:1.5px solid #e0e4e8;color:#555}
.btn-outline:hover{border-color:#0077b6;color:#0077b6;background:#f0f9ff}
.btn-sm{padding:.35rem .65rem;font-size:.75rem}
.btn-icon{padding:.4rem;border-radius:6px}
.btn-group{display:flex;flex-wrap:wrap;gap:.5rem}

/* ── Badges ──────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:.15rem .55rem;border-radius:99px;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}
.badge-pending{background:#fef3cd;color:#92400e}
.badge-confirmed,.badge-approved{background:#d1fae5;color:#065f46}
.badge-cancelled{background:#fce7f3;color:#9d174d}
.badge-completed{background:#dbeafe;color:#1e40af}
.badge-new{background:#e0e7ff;color:#4338ca}

/* ── Tables ──────────────────────────────────────────── */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:.72rem;text-transform:uppercase;color:#8899a6;padding:.65rem .75rem;letter-spacing:.04em;font-weight:600;border-bottom:2px solid #f0f2f5}
td{padding:.6rem .75rem;border-top:1px solid #f5f7fa;font-size:.84rem;vertical-align:middle;color:#444}
tr:hover td{background:#f8fafc}
tbody tr{transition:background .1s}

/* ── Empty State ─────────────────────────────────────── */
.empty-state{text-align:center;padding:3rem 1rem;color:#8899a6}
.empty-state .icon{font-size:2.5rem;margin-bottom:.5rem;opacity:.5}
.empty-state p{font-size:.9rem}

/* ── Forms ───────────────────────────────────────────── */
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-size:.78rem;font-weight:600;color:#555;margin-bottom:.3rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.55rem .85rem;border:1.5px solid #e0e4e8;border-radius:10px;font-size:.85rem;font-family:inherit;background:#fff;transition:all .15s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#0077b6;box-shadow:0 0 0 3px #0077b615}
.form-group textarea{resize:vertical;min-height:80px}

/* ── Modals ──────────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:#00000050;backdrop-filter:blur(4px);z-index:200;align-items:center;justify-content:center}
.modal-overlay.show{display:flex}
.modal{background:#fff;border-radius:16px;width:92%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000020;animation:modalSlide .25s ease}
@keyframes modalSlide{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.modal-header{padding:1.15rem 1.5rem;border-bottom:1px solid #f0f2f5;display:flex;align-items:center;justify-content:space-between}
.modal-header h3{font-size:1.05rem;color:#1a1a2e}
.modal-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:#999;border-radius:6px;padding:.2rem .5rem;transition:all .12s}
.modal-close:hover{background:#f0f2f5;color:#333}
.modal-body{padding:1.5rem}
.modal-footer{padding:.75rem 1.5rem;border-top:1px solid #f0f2f5;display:flex;gap:.5rem;justify-content:flex-end}

/* ── Filters bar ─────────────────────────────────────── */
.filters-bar{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.25rem;align-items:center}
.filters-bar input,.filters-bar select{padding:.45rem .75rem;border:1.5px solid #e0e4e8;border-radius:8px;font-size:.82rem;font-family:inherit;background:#fff}
.filters-bar input:focus,.filters-bar select:focus{outline:none;border-color:#0077b6}

/* ── Quick action grid (bento style) ─────────────────── */
.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem}
.action-card{display:flex;align-items:center;gap:.6rem;padding:.85rem 1rem;border-radius:12px;border:1.5px solid #e8ecf0;background:#fff;text-decoration:none;color:#333;font-size:.84rem;font-weight:500;transition:all .15s;cursor:pointer}
.action-card:hover{border-color:#0077b6;background:#f0f9ff;transform:translateY(-2px);box-shadow:0 4px 12px #0077b615}
.action-card .action-icon{font-size:1.4rem;width:2.2rem;height:2.2rem;display:flex;align-items:center;justify-content:center;border-radius:10px;flex-shrink:0}
.action-card .action-icon.blue{background:#e0f2fe}
.action-card .action-icon.green{background:#d1fae5}
.action-card .action-icon.yellow{background:#fef3c7}
.action-card .action-icon.purple{background:#ede9fe}

/* ── Recent appointments ─────────────────────────────── */
.appt-item{display:flex;align-items:center;gap:1rem;padding:.75rem 0;border-bottom:1px solid #f5f7fa}
.appt-item:last-child{border-bottom:none}
.appt-item .appt-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#0077b6,#48cae4);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.75rem;flex-shrink:0}
.appt-item .appt-info{flex:1}
.appt-item .appt-name{font-weight:600;font-size:.88rem;color:#1a1a2e}
.appt-item .appt-detail{font-size:.76rem;color:#8899a6}
.appt-item .appt-status{font-size:.7rem}

/* ── Notification dot ────────────────────────────────── */
.has-notification::after{content:'';position:absolute;top:.3rem;right:.3rem;width:8px;height:8px;background:#ef4444;border-radius:50%;border:2px solid #1a1a2e}

/* ── Responsive ──────────────────────────────────────── */
@media(max-width:768px){
  .btn-menu-toggle{display:flex!important;align-items:center;justify-content:center}
  .dash-sidebar{transform:translateX(-100%);z-index:99;box-shadow:4px 0 20px #00000030}
  .dash-sidebar.open{transform:translateX(0)}
  .dash-main{margin-left:0;padding:1rem}
  .grid-stats{grid-template-columns:repeat(2,1fr);gap:.75rem}
  .actions-grid{grid-template-columns:repeat(2,1fr)}
  .stat-card .stat-value{font-size:1.5rem}
}

/* ── Scrollbar ───────────────────────────────────────── */
.dash-sidebar::-webkit-scrollbar{width:4px}
.dash-sidebar::-webkit-scrollbar-track{background:transparent}
.dash-sidebar::-webkit-scrollbar-thumb{background:#ffffff15;border-radius:4px}

/* ── Page titles ─────────────────────────────────────── */
.page-title{font-size:1.4rem;font-weight:700;margin-bottom:1.5rem;color:#1a1a2e;display:flex;align-items:center;gap:.5rem}
.page-title .title-badge{font-size:.7rem;padding:.2rem .5rem;border-radius:6px;font-weight:600}

/* ── Welcome banner ──────────────────────────────────── */
.welcome-banner{background:linear-gradient(135deg,#0077b6 0%,#00b4d8 50%,#48cae4 100%);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;color:#fff;position:relative;overflow:hidden}
.welcome-banner::after{content:'🦷';position:absolute;right:1.5rem;top:50%;transform:translateY(-50%);font-size:4rem;opacity:.15}
.welcome-banner h2{font-size:1.15rem;font-weight:700;margin-bottom:.3rem}
.welcome-banner p{font-size:.85rem;opacity:.85}
.welcome-banner .welcome-role{display:inline-block;background:#ffffff25;padding:.15rem .5rem;border-radius:6px;font-size:.72rem;font-weight:600;margin-top:.4rem}

/* ── Transition animations ───────────────────────────── */
.fade-in{animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── Profile card styles ─────────────────────────────── */
.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.profile-avatar-lg{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#0077b6,#00b4d8);display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:700;margin:0 auto 1rem}
.info-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f5f7fa;font-size:.84rem}
.info-row .label{color:#8899a6;font-weight:500}
.info-row .value{color:#1a1a2e;font-weight:600}

@media(max-width:768px){
  .profile-grid{grid-template-columns:1fr}
}
