/* ============================================================
   SoftClinic — Global Stylesheet
   ============================================================ */
:root {
  --primary:       #0b6e99;
  --primary-dark:  #0a4d6e;
  --secondary:     #14b8a6;
  --secondary-dark:#0d9488;
  --accent:        #0ea5e9;
  --light:         #f5f9fb;
  --gray:          #6c757d;
  --gray-light:    #e9ecef;
  --dark-text:     #0f172a;
  --body-text:     #475569;
  --border:        #e2e8f0;
  --success:       #22c55e;
  --warning:       #f59e0b;
  --danger:        #ef4444;
  --shadow-sm:     0 2px 8px rgba(11,110,153,.08);
  --shadow-md:     0 4px 20px rgba(11,110,153,.12);
  --shadow-lg:     0 8px 40px rgba(11,110,153,.16);
  --radius:        10px;
  --radius-lg:     18px;
  --transition:    all .25s ease;
  --font-head:     'Poppins', sans-serif;
  --font-body:     'Inter', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--body-text);background:#fff;line-height:1.7;overflow-x:hidden}
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);color:var(--dark-text);font-weight:700;line-height:1.25}
a{color:var(--primary);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--secondary)}
img{max-width:100%;height:auto;display:block}

.text-gold{color:var(--secondary)!important}
.section-pad{padding:90px 0}
.section-pad-sm{padding:60px 0}
.section-title{font-size:clamp(1.8rem,3vw,2.4rem);color:var(--dark-text);margin-bottom:12px}
.section-title span{color:var(--secondary)}
.title-divider{width:60px;height:4px;background:linear-gradient(90deg,var(--secondary),var(--primary));border-radius:2px;margin:16px 0 24px}

/* Buttons */
.btn-gold{background:var(--secondary);color:#fff;border:none;padding:12px 28px;border-radius:var(--radius);font-family:var(--font-head);font-weight:600;font-size:.9rem;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:8px;text-decoration:none}
.btn-gold:hover{background:var(--secondary-dark);color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(20,184,166,.35)}
.btn-navy{background:var(--primary);color:#fff;border:2px solid var(--primary);padding:12px 28px;border-radius:var(--radius);font-family:var(--font-head);font-weight:600;font-size:.9rem;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:8px;text-decoration:none}
.btn-navy:hover{background:transparent;color:var(--primary)}
.btn-outline-gold{background:transparent;color:var(--secondary);border:2px solid var(--secondary);padding:11px 26px;border-radius:var(--radius);font-family:var(--font-head);font-weight:600;font-size:.9rem;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:8px;text-decoration:none}
.btn-outline-gold:hover{background:var(--secondary);color:#fff}

/* Navbar */
#mainNav{background:transparent;transition:var(--transition);padding:20px 0;position:fixed;top:0;left:0;right:0;z-index:1000}
#mainNav.scrolled{background:rgba(15,23,42,.97);backdrop-filter:blur(12px);padding:12px 0;box-shadow:0 2px 20px rgba(0,0,0,.2)}
.brand-text{font-family:var(--font-head);font-weight:800;font-size:1.35rem;color:#fff;letter-spacing:.5px}
.navbar-nav .nav-link{color:rgba(255,255,255,.9)!important;font-family:var(--font-head);font-weight:500;font-size:.88rem;padding:8px 14px!important;transition:var(--transition)}
.navbar-nav .nav-link:hover,.navbar-nav .nav-link.active{color:var(--secondary)!important}
.navbar-toggler{border-color:rgba(255,255,255,.4)}
.navbar-toggler-icon{filter:brightness(0) invert(1)}
.nav-btn-login{background:transparent;color:#fff!important;border:1.5px solid rgba(255,255,255,.4);border-radius:var(--radius);padding:7px 18px!important;margin-left:8px}
.nav-btn-login:hover{border-color:var(--secondary)!important;color:var(--secondary)!important}

/* Hero */
.hero{min-height:92vh;position:relative;display:flex;flex-direction:column;justify-content:center;overflow:hidden;background:linear-gradient(135deg,#0a4d6e 0%,#0b6e99 60%,#14b8a6 100%)}
.hero::before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="60" height="60" viewBox="0 0 60 60"><g fill="none" stroke="rgba(255,255,255,.05)" stroke-width="1"><path d="M0 30 L60 30 M30 0 L30 60"/></g></svg>') repeat;opacity:.6}
.hero-content{position:relative;z-index:2;padding:160px 0 60px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);color:#fff;padding:8px 20px;border-radius:50px;font-size:.82rem;font-weight:600;margin-bottom:28px}
.hero h1{font-size:clamp(2.2rem,5vw,3.6rem);color:#fff;font-weight:800;line-height:1.15;margin-bottom:20px}
.hero h1 span{color:#bae6fd}
.hero p.lead{font-size:1.1rem;color:rgba(255,255,255,.85);max-width:560px;margin-bottom:36px}
.hero-visual{background:rgba(255,255,255,.08);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:24px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.hero-visual .mini-card{background:rgba(255,255,255,.14);border-radius:14px;padding:16px;color:#fff}

/* Feature card */
.feature-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;height:100%;transition:var(--transition)}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--secondary)}
.feature-icon{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,var(--secondary),var(--primary));color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:18px}
.feature-card h5{color:var(--dark-text);margin-bottom:10px}

/* Pricing */
.price-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 28px;height:100%;position:relative;transition:var(--transition)}
.price-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.price-card.featured{border:2px solid var(--secondary);box-shadow:var(--shadow-md)}
.price-badge{position:absolute;top:-12px;right:20px;background:var(--secondary);color:#fff;padding:4px 14px;border-radius:50px;font-size:.75rem;font-weight:700}
.price-card h3{font-size:2.4rem;color:var(--primary);margin:12px 0}
.price-card h3 small{font-size:.95rem;color:var(--gray);font-weight:400}
.price-feat{list-style:none;margin:20px 0;padding:0}
.price-feat li{padding:8px 0;border-bottom:1px dashed var(--border);display:flex;align-items:center;gap:10px}
.price-feat li:last-child{border-bottom:none}
.price-feat li i{color:var(--secondary)}

/* Footer */
.site-footer{background:#0f172a;color:rgba(255,255,255,.7);padding:70px 0 20px;margin-top:80px}
.site-footer .footer-logo{font-size:1.4rem;color:#fff}
.site-footer .footer-heading{display:block;color:#fff;font-family:var(--font-head);font-weight:700;margin-bottom:18px;font-size:1rem}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:8px}
.footer-links a{color:rgba(255,255,255,.65);font-size:.92rem}
.footer-links a:hover{color:var(--secondary)}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;font-size:.92rem}
.footer-contact-item i{color:var(--secondary);margin-top:4px}
.footer-contact-item a{color:rgba(255,255,255,.75)}
.footer-social a{display:inline-flex;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;align-items:center;justify-content:center;margin-right:8px;transition:var(--transition)}
.footer-social a:hover{background:var(--secondary);transform:translateY(-3px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:18px;font-size:.85rem}
.footer-bottom a{color:rgba(255,255,255,.65)}

.wa-float{position:fixed;bottom:24px;right:24px;width:54px;height:54px;background:#25D366;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;z-index:999;box-shadow:0 8px 30px rgba(37,211,102,.4)}
#backToTop{position:fixed;bottom:88px;right:24px;width:44px;height:44px;background:var(--primary);color:#fff;border:none;border-radius:50%;display:none;align-items:center;justify-content:center;z-index:999;cursor:pointer}
#backToTop.show{display:flex}

/* Auth */
.auth-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:linear-gradient(135deg,#0b6e99 0%,#14b8a6 100%)}
.auth-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:40px;max-width:440px;width:100%}
.auth-logo{text-align:center;margin-bottom:28px}
.auth-logo .brand-text{color:var(--primary);font-size:1.8rem}
.alert-custom{padding:12px 16px;border-radius:var(--radius);display:flex;align-items:center;gap:10px;font-size:.9rem}
.form-control:focus{border-color:var(--secondary);box-shadow:0 0 0 .2rem rgba(20,184,166,.15)}

/* ============================================================
   DASHBOARD
   ============================================================ */
.dashboard-body{background:#f4f7fa;font-family:var(--font-body)}
.dash-sidebar{position:fixed;top:0;left:0;height:100vh;width:260px;background:#0f172a;color:#e2e8f0;z-index:1030;display:flex;flex-direction:column;transition:transform .3s ease}
.sidebar-brand{padding:22px 24px;border-bottom:1px solid rgba(255,255,255,.08)}
.sidebar-brand .brand-text{color:#fff;font-size:1.3rem}
.sidebar-nav{flex:1;padding:18px 12px;overflow-y:auto}
.sidebar-label{display:block;color:rgba(255,255,255,.35);font-size:.72rem;text-transform:uppercase;letter-spacing:1.2px;padding:14px 12px 6px;font-weight:700}
.sidebar-link{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.75);padding:10px 14px;border-radius:8px;font-size:.9rem;margin-bottom:2px;position:relative}
.sidebar-link i{width:18px;text-align:center;color:rgba(255,255,255,.55)}
.sidebar-link:hover{background:rgba(255,255,255,.06);color:#fff}
.sidebar-link.active{background:linear-gradient(90deg,rgba(20,184,166,.18),rgba(20,184,166,.04));color:#fff}
.sidebar-link.active i{color:var(--secondary)}
.badge-dot{margin-left:auto;background:var(--secondary);color:#fff;font-size:.7rem;padding:2px 8px;border-radius:10px;font-weight:700}
.sidebar-footer{padding:14px;border-top:1px solid rgba(255,255,255,.08)}
.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px;background:rgba(255,255,255,.04);border-radius:10px}
.sidebar-avatar{width:38px;height:38px;border-radius:50%;background:var(--secondary);color:#0f172a;display:flex;align-items:center;justify-content:center;font-weight:800}
.sidebar-user-name{color:#fff;font-weight:600;font-size:.85rem;line-height:1.2}
.sidebar-user-role{color:rgba(255,255,255,.5);font-size:.72rem;text-transform:uppercase}

.dash-main{margin-left:260px;min-height:100vh}
.dash-topbar{background:#fff;border-bottom:1px solid var(--border);padding:14px 28px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:20}
.topbar-title{font-family:var(--font-head);font-weight:700;color:var(--dark-text);font-size:1.15rem}
.topbar-actions{display:flex;align-items:center;gap:8px}
.topbar-btn{width:40px;height:40px;border-radius:10px;background:var(--light);color:var(--primary);display:inline-flex;align-items:center;justify-content:center;transition:var(--transition)}
.topbar-btn:hover{background:var(--secondary);color:#fff}
.sidebar-toggle{display:none;background:none;border:none;font-size:1.2rem;color:var(--dark-text)}
.dash-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:1020}
.dash-overlay.active{display:block}

.dash-content{padding:28px}
.dash-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px;margin-bottom:20px}
.dash-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}
.dash-card-title{font-family:var(--font-head);font-weight:700;color:var(--dark-text);font-size:1.05rem;margin:0}
.dash-card-body{padding:0}

.kpi-card{background:#fff;border-radius:14px;padding:22px;display:flex;align-items:center;justify-content:space-between;gap:14px;position:relative;overflow:hidden;border:1px solid var(--border);height:100%}
.kpi-card.navy{background:linear-gradient(135deg,#0b6e99,#0a4d6e);color:#fff;border:none}
.kpi-card.gold{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;border:none}
.kpi-card.green{background:linear-gradient(135deg,#22c55e,#15803d);color:#fff;border:none}
.kpi-card.purple{background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff;border:none}
.kpi-card.orange{background:linear-gradient(135deg,#f97316,#c2410c);color:#fff;border:none}
.kpi-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;opacity:.85}
.kpi-value{font-family:var(--font-head);font-size:1.9rem;font-weight:800}
.kpi-change{font-size:.78rem;margin-top:4px;opacity:.85}
.kpi-icon{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:1.3rem}

.dash-table{width:100%;border-collapse:collapse}
.dash-table th{background:var(--light);color:var(--gray);font-weight:600;text-transform:uppercase;font-size:.72rem;letter-spacing:.5px;padding:12px 14px;text-align:left;border-bottom:1px solid var(--border)}
.dash-table td{padding:14px;border-bottom:1px solid var(--border);font-size:.9rem;vertical-align:middle}
.dash-table tr:hover{background:var(--light)}
.status-badge{display:inline-block;padding:4px 10px;border-radius:50px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.status-pendiente,.status-nuevo{background:#fef3c7;color:#92400e}
.status-confirmada,.status-activo,.status-pagado,.status-leido{background:#dcfce7;color:#15803d}
.status-cancelada,.status-inactivo,.status-vencido{background:#fee2e2;color:#991b1b}
.status-completada{background:#dbeafe;color:#1e40af}
.status-parcial{background:#e0e7ff;color:#3730a3}

.notif-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.notif-item:last-child{border-bottom:none}
.notif-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notif-title{font-size:.88rem;font-weight:600;margin:0;color:var(--dark-text)}
.notif-time{font-size:.72rem;color:var(--gray);margin:0}

/* Odontogram */
.odonto-grid{display:grid;grid-template-columns:repeat(16,1fr);gap:6px;max-width:920px;margin:0 auto}
.odonto-tooth{aspect-ratio:1;background:#fff;border:1.5px solid #cbd5e1;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:var(--dark-text);cursor:pointer;transition:var(--transition);position:relative}
.odonto-tooth:hover{border-color:var(--secondary);transform:scale(1.05)}
.odonto-tooth.caries{background:#fee2e2;border-color:#ef4444;color:#991b1b}
.odonto-tooth.restauracion{background:#dbeafe;border-color:#3b82f6;color:#1e40af}
.odonto-tooth.extraccion{background:#e5e7eb;border-color:#9ca3af;color:#6b7280;text-decoration:line-through}
.odonto-tooth.corona{background:#fef3c7;border-color:#f59e0b;color:#92400e}
.odonto-tooth.endodoncia{background:#e9d5ff;border-color:#8b5cf6;color:#6d28d9}
.odonto-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:22px;justify-content:center}
.odonto-legend span{font-size:.8rem;display:inline-flex;align-items:center;gap:6px}
.odonto-legend span::before{content:"";width:14px;height:14px;border-radius:4px;border:1.5px solid;display:inline-block}
.odonto-legend span.caries::before{background:#fee2e2;border-color:#ef4444}
.odonto-legend span.restauracion::before{background:#dbeafe;border-color:#3b82f6}
.odonto-legend span.extraccion::before{background:#e5e7eb;border-color:#9ca3af}
.odonto-legend span.corona::before{background:#fef3c7;border-color:#f59e0b}
.odonto-legend span.endodoncia::before{background:#e9d5ff;border-color:#8b5cf6}

/* Print ticket */
.ticket{max-width:300px;margin:0 auto;font-family:'Courier New',monospace;font-size:12px;color:#000;background:#fff;padding:18px}
.ticket h4{text-align:center;margin-bottom:8px;font-size:14px}
.ticket .tk-row{display:flex;justify-content:space-between;padding:2px 0}
.ticket hr{border:none;border-top:1px dashed #000;margin:8px 0}
@media print{
  body{background:#fff!important}
  .no-print{display:none!important}
  .dash-sidebar,.dash-topbar{display:none!important}
  .dash-main{margin-left:0!important}
  .dash-content{padding:0!important}
}

/* Responsive */
@media (max-width:992px){
  .dash-sidebar{transform:translateX(-100%)}
  .dash-sidebar.open{transform:translateX(0)}
  .dash-main{margin-left:0}
  .sidebar-toggle{display:block}
}
@media (max-width:576px){
  .dash-content{padding:16px}
  .kpi-card{padding:16px}
  .kpi-value{font-size:1.5rem}
}
