:root{--primary:#7C3AED;--primary-hover:#6D28D9;--primary-light:#EDE9FE;--primary-mid:#A78BFA;--accent:#F59E0B;--accent-light:#FEF3C7;--green:#10B981;--green-light:#D1FAE5;--red:#EF4444;--red-light:#FEE2E2;--blue:#3B82F6;--blue-light:#DBEAFE;--orange:#F97316;--orange-light:#FFEDD5;--bg:#F7F8FA;--white:#FFFFFF;--text:#111827;--text2:#374151;--gray:#6B7280;--gray2:#9CA3AF;--border:#E5E7EB;--shadow:0 2px 12px rgba(0,0,0,0.06);--shadow-md:0 8px 28px rgba(124,58,237,0.12);--radius:14px;}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--bg);color:var(--text);font-family:'Plus Jakarta Sans',sans-serif;display:flex;min-height:100vh;}
.sidebar{width:240px;flex-shrink:0;background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;}
.sidebar-logo{padding:20px;border-bottom:1px solid var(--border);font-family:'Fraunces',serif;font-size:1.3rem;font-weight:900;color:var(--primary);}
.sidebar-logo span{color:var(--accent);}
.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 14px;border-radius:10px;cursor:pointer;font-size:0.875rem;font-weight:600;color:var(--gray);transition:all .2s;text-decoration:none;}
.nav-item:hover{background:var(--bg);color:var(--text);}
.nav-item.active{background:var(--primary-light);color:var(--primary);}
.nav-icon{font-size:1.1rem;width:20px;text-align:center;flex-shrink:0;}
.nav-badge{background:var(--red);color:#fff;border-radius:100px;font-size:0.65rem;font-weight:800;padding:2px 7px;margin-left:auto;display:none;}
.sidebar-bottom{padding:12px;}
.trial-box{background:linear-gradient(135deg,var(--primary),#6D28D9);border-radius:12px;padding:14px;color:#fff;font-size:0.8rem;}
.trial-box strong{display:block;font-size:0.9rem;margin-bottom:4px;}
.trial-bar-wrap{background:rgba(255,255,255,0.2);border-radius:100px;height:5px;margin:8px 0 6px;}
.trial-bar{background:#fff;border-radius:100px;height:5px;}
.trial-box a{color:#fff;font-weight:700;font-size:0.78rem;text-decoration:underline;cursor:pointer;}
.main{margin-left:240px;flex:1;display:flex;flex-direction:column;min-height:100vh;}
.topbar{background:var(--white);border-bottom:1px solid var(--border);padding:0 28px;height:62px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:40;}
.topbar-title{font-size:1rem;font-weight:800;color:var(--text);}
.topbar-right{display:flex;align-items:center;gap:10px;}
.topbar-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:0.85rem;cursor:pointer;}
.badge-plan{background:var(--primary-light);color:var(--primary);padding:4px 12px;border-radius:100px;font-size:0.75rem;font-weight:800;}
.btn-topbar{background:var(--bg);border:1px solid var(--border);padding:7px 14px;border-radius:100px;font-size:0.8rem;font-weight:700;color:var(--primary);cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s;font-family:inherit;}
.btn-topbar:hover{background:var(--primary-light);}
.content{padding:24px 28px;flex:1;}
.tab-panel{display:none;}.tab-panel.active{display:block;}
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:18px;}
.card-title{font-size:1rem;font-weight:800;margin-bottom:4px;}
.card-sub{font-size:0.82rem;color:var(--gray);margin-bottom:18px;}

/* Estilos para tarjetas colapsables */
.gh-collapsible.collapsed .card-body { display: none; }
.gh-collapsible.collapsed .card-chevron { transform: rotate(-90deg); }
.gh-collapsible.collapsed { padding-bottom: 0 !important; }

.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;}
.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column;justify-content:space-between;min-height:160px;}
.stat-card[onclick]:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--primary-mid);}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;}
.stat-card.c-purple::before{background:var(--primary);}.stat-card.c-green::before{background:var(--green);}.stat-card.c-orange::before{background:var(--orange);}.stat-card.c-blue::before{background:var(--blue);}
.stat-icon{font-size:1.5rem;margin-bottom:12px;background:var(--bg);width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;}
.stat-val{font-family:'Fraunces',serif;font-size:1.8rem;font-weight:900;line-height:1;margin-bottom:4px;}
.stat-label{font-size:0.75rem;color:var(--gray);font-weight:700;text-transform:uppercase;letter-spacing:0.5px;}
.stat-change{font-size:0.75rem;font-weight:700;margin-top:10px;padding-top:10px;border-top:1px solid var(--bg);display:block;}
.citas-list{display:flex;flex-direction:column;gap:8px;}
.cita-row{display:flex;align-items:center;gap:12px;padding:13px 15px;background:var(--bg);border-radius:10px;border:1px solid var(--border);transition:all .2s;flex-wrap:wrap;}
.cita-row:hover{border-color:var(--primary-mid);background:var(--primary-light);}
.cita-hora{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:900;color:var(--primary);min-width:48px;}
.cita-info{flex:1;min-width:150px;}
.cita-cliente{font-weight:700;font-size:0.875rem;}
.cita-detalle{font-size:0.75rem;color:var(--gray);margin-top:2px;}
.cita-precio{font-weight:800;color:var(--primary);font-size:0.875rem;white-space:nowrap;}
.cita-estado{padding:3px 10px;border-radius:100px;font-size:0.7rem;font-weight:800;white-space:nowrap;}
.est-confirmada{background:var(--green-light);color:var(--green);}.est-pendiente{background:var(--orange-light);color:var(--orange);}.est-cancelada{background:var(--red-light);color:var(--red);}
.cita-actions{display:flex;gap:5px;}
.btn-cita{padding:7px 12px;border-radius:8px;border:none;cursor:pointer;font-size:0.75rem;font-weight:700;font-family:inherit;transition:all .2s;min-height:34px;}
.btn-ok{background:var(--green-light);color:var(--green);}.btn-ok:hover{background:var(--green);color:#fff;}
.btn-del{background:var(--red-light);color:var(--red);}.btn-del:hover{background:var(--red);color:#fff;}
.cl-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
.cl-table{width:100%;border-collapse:collapse;min-width:500px;}
.date-nav{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap;}
.date-btn{padding:7px 12px;border-radius:8px;border:1px solid var(--border);background:var(--white);cursor:pointer;font-size:0.8rem;font-weight:700;color:var(--gray);transition:all .2s;font-family:inherit;}
.date-btn:hover{border-color:var(--primary-mid);color:var(--primary);}
.date-btn.act{background:var(--primary);color:#fff;border-color:var(--primary);}
.date-display{font-weight:800;font-size:0.875rem;flex:1;text-align:center;}
.form-group{margin-bottom:16px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
label{display:block;font-size:0.8rem;font-weight:700;color:var(--text2);margin-bottom:5px;}
input[type=text],input[type=email],input[type=tel],input[type=number],textarea,select{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:9px;font-size:0.875rem;font-family:inherit;color:var(--text);background:var(--white);outline:none;transition:border .2s;}
input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(124,58,237,0.08);}
textarea{resize:vertical;min-height:80px;}
.logo-upload{border:2px dashed var(--border);border-radius:12px;padding:28px;text-align:center;cursor:pointer;transition:all .25s;position:relative;overflow:hidden;}
.logo-upload:hover{border-color:var(--primary-mid);background:var(--primary-light);}
.logo-upload.has-img{border-style:solid;border-color:var(--primary);padding:0;}
.logo-preview{width:100%;max-height:150px;object-fit:contain;display:none;border-radius:10px;}
.logo-upload.has-img .logo-preview{display:block;}
.logo-upload.has-img .logo-placeholder{display:none;}
.upload-change-overlay{position:absolute;bottom:0;left:0;right:0;background:rgba(124,58,237,0.85);color:#fff;padding:7px;font-size:0.78rem;font-weight:700;opacity:0;transition:opacity .2s;}
.logo-upload.has-img:hover .upload-change-overlay{opacity:1;}
input[type=file]{display:none;}
.color-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;}
.color-swatch{width:32px;height:32px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:all .2s;}
.color-swatch.sel{border-color:var(--text);transform:scale(1.15);}
.color-custom{width:32px;height:32px;border-radius:50%;border:1.5px dashed var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;}
.color-custom input[type=color]{position:absolute;opacity:0;width:0;height:0;}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-bottom:14px;}
.svc-card{background:var(--white);border:1.5px solid var(--border);border-radius:14px;overflow:hidden;transition:all .25s;}
.svc-card:hover{border-color:var(--primary-mid);box-shadow:var(--shadow-md);}
.svc-img-wrap{height:160px;background:var(--bg);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.svc-img-wrap img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;}
.svc-placeholder{font-size:2.8rem;opacity:0.3;}
.svc-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0);cursor:pointer;transition:background .2s;}
.svc-overlay:hover{background:rgba(0,0,0,0.35);}
.svc-overlay:hover .svc-overlay-label{opacity:1;}
.svc-overlay-label{background:#fff;color:var(--primary);border-radius:100px;padding:5px 12px;font-size:0.72rem;font-weight:800;opacity:0;transition:opacity .2s;}
.svc-body{padding:12px;}
.svc-name-inp{font-weight:700;font-size:0.875rem;border:none;background:transparent;width:100%;padding:0;margin-bottom:6px;color:var(--text);font-family:inherit;}
.svc-name-inp:focus{outline:none;border-bottom:1.5px solid var(--primary);}
.svc-row{display:flex;gap:5px;align-items:center;}
.svc-price-inp,.svc-dur-sel{padding:6px 8px;border:1.5px solid var(--border);border-radius:7px;font-size:0.8rem;font-family:inherit;}
.svc-price-inp{flex:1;min-width:80px;}
.svc-price-inp:focus,.svc-dur-sel:focus{outline:none;border-color:var(--primary);}
.svc-del-btn{width:28px;height:28px;border-radius:7px;border:none;background:var(--red-light);color:var(--red);cursor:pointer;font-size:0.85rem;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;}
.svc-del-btn:hover{background:var(--red);color:#fff;}
.add-svc-btn{border:2px dashed var(--border);border-radius:12px;padding:16px;width:100%;background:transparent;cursor:pointer;font-size:0.875rem;font-weight:700;color:var(--gray);transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;}
.add-svc-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light);}
.prof-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:14px;}
.prof-card{background:var(--white);border:1.5px solid var(--border);border-radius:12px;padding:18px;text-align:center;transition:all .25px;position:relative;}
.prof-card:hover{border-color:var(--primary-mid);box-shadow:var(--shadow-md);}
.prof-avatar{width:56px;height:56px;border-radius:50%;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;margin:0 auto 10px;}
.prof-name-inp{font-weight:700;font-size:0.875rem;border:none;background:transparent;width:100%;text-align:center;padding:0;margin-bottom:4px;color:var(--text);font-family:inherit;}
.prof-name-inp:focus{outline:none;border-bottom:1.5px solid var(--primary);}
.prof-rol-inp{font-size:0.78rem;color:var(--gray);border:none;background:transparent;width:100%;text-align:center;padding:0;font-family:inherit;}
.prof-rol-inp:focus{outline:none;border-bottom:1px solid var(--border);}
.prof-wa-inp{font-size:0.75rem;border:1.5px solid var(--border);border-radius:7px;padding:5px 8px;width:100%;margin-top:8px;font-family:inherit;text-align:center;}
.prof-wa-inp:focus{outline:none;border-color:var(--primary);}
.prof-del-btn{position:absolute;top:8px;right:8px;width:24px;height:24px;border-radius:6px;border:none;background:var(--red-light);color:var(--red);cursor:pointer;font-size:0.75rem;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.prof-del-btn:hover{background:var(--red);color:#fff;}
.add-prof-btn{border:2px dashed var(--border);border-radius:12px;padding:16px;width:100%;background:transparent;cursor:pointer;font-size:0.875rem;font-weight:700;color:var(--gray);transition:all .2s;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;}
.add-prof-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light);}
.sch-list{display:flex;flex-direction:column;gap:8px;}
.sch-row{display:grid;grid-template-columns:110px 1fr auto;gap:10px;align-items:center;padding:12px 14px;background:var(--bg);border-radius:10px;border:1px solid var(--border);}
.sch-row.off{opacity:0.45;}
.day-nm{font-weight:700;font-size:0.875rem;}
.time-range{display:flex;align-items:center;gap:7px;}
.time-range input{width:100px;padding:6px 8px;border:1.5px solid var(--border);border-radius:7px;font-size:0.8rem;font-family:inherit;}
.time-range input:focus{outline:none;border-color:var(--primary);}
.time-sep{color:var(--gray2);font-size:0.8rem;}
.toggle{position:relative;width:38px;height:21px;flex-shrink:0;}
.toggle input{opacity:0;width:0;height:0;position:absolute;}
.tog-slider{position:absolute;inset:0;border-radius:100px;background:var(--border);cursor:pointer;transition:.25s;}
.tog-slider::before{content:'';position:absolute;width:15px;height:15px;border-radius:50%;background:#fff;top:3px;left:3px;transition:.25s;box-shadow:0 1px 4px rgba(0,0,0,0.15);}
.toggle input:checked+.tog-slider{background:var(--primary);}
.toggle input:checked+.tog-slider::before{transform:translateX(17px);}
.cl-table{width:100%;border-collapse:collapse;}
.cl-table th{padding:10px 13px;background:var(--bg);font-size:0.73rem;font-weight:800;color:var(--gray);text-transform:uppercase;letter-spacing:0.5px;text-align:left;border-bottom:1px solid var(--border);}
.cl-table td{padding:11px 13px;border-bottom:1px solid var(--border);font-size:0.875rem;vertical-align:middle;}
.cl-table tr:hover td{background:var(--primary-light);}
.wa-btn{background:var(--green-light);color:var(--green);border:none;padding:5px 10px;border-radius:100px;font-size:0.72rem;font-weight:800;cursor:pointer;font-family:inherit;transition:all .2s;}
.wa-btn:hover{background:var(--green);color:#fff;}
.pay-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px;}
.pay-opt{border:2px solid var(--border);border-radius:12px;padding:14px;cursor:pointer;transition:all .2s;text-align:center;}
.pay-opt:hover{border-color:var(--primary-mid);}
.pay-opt.sel{border-color:var(--primary);background:var(--primary-light);}
.pay-logo{font-size:1.6rem;margin-bottom:5px;}.pay-name{font-weight:700;font-size:0.85rem;}.pay-desc{font-size:0.73rem;color:var(--gray);margin-top:2px;}
.qr-wrap{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start;}
.qr-box{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:18px;text-align:center;box-shadow:var(--shadow);}
.qr-url{font-size:0.72rem;color:var(--gray);word-break:break-all;margin-top:8px;}
.qr-actions{display:flex;gap:8px;justify-content:center;margin-top:10px;flex-wrap:wrap;}
.qr-info h3{font-size:1rem;font-weight:800;margin-bottom:8px;}
.qr-info p{font-size:0.875rem;color:var(--gray);line-height:1.65;margin-bottom:14px;}
.qr-tip{background:var(--primary-light);border-radius:9px;padding:10px 13px;font-size:0.8rem;color:var(--primary);font-weight:600;margin-bottom:10px;}
.btn-save{background:var(--primary);color:#fff;padding:10px 22px;border-radius:100px;border:none;font-weight:700;font-size:0.875rem;cursor:pointer;transition:all .25s;font-family:inherit;box-shadow:0 4px 14px rgba(124,58,237,0.3);}
.btn-save:hover{background:var(--primary-hover);transform:translateY(-1px);}
.btn-ghost{background:transparent;color:var(--gray);padding:10px 18px;border-radius:100px;border:1.5px solid var(--border);font-weight:600;font-size:0.875rem;cursor:pointer;font-family:inherit;transition:all .2s;}
.btn-ghost:hover{border-color:var(--primary-mid);color:var(--primary);}
.btn-row{display:flex;gap:10px;align-items:center;margin-top:10px;flex-wrap:wrap;}
.preview-bar{
  background:rgba(255,255,255,0.92);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid var(--border);
  border-radius:16px;
  padding:14px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:24px;
  gap:12px;
  flex-wrap:wrap;
  position:sticky;
  top:62px;
  z-index:35;
  box-shadow:0 8px 20px rgba(0,0,0,0.05);
  transition:all 0.3s ease;
}
.preview-link-txt{font-size:0.78rem;color:var(--primary);font-weight:700;word-break:break-all;flex:1;}
.btn-copy{background:var(--primary);color:#fff;border:none;border-radius:100px;padding:7px 14px;font-size:0.78rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap;}
.btn-copy:hover{background:var(--primary-hover);}
.loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--gray);font-size:0.875rem;}
.spinner{width:22px;height:22px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-right:10px;}
@keyframes spin{to{transform:rotate(360deg);}}
.empty-state{text-align:center;padding:40px 20px;color:var(--gray);}
.empty-icon{font-size:2.8rem;opacity:0.4;margin-bottom:10px;}
.empty-title{font-weight:700;font-size:0.95rem;margin-bottom:5px;color:var(--text2);}
.empty-sub{font-size:0.82rem;}
.toast{position:fixed;bottom:24px;right:24px;background:var(--text);color:#fff;padding:12px 20px;border-radius:12px;font-size:0.875rem;font-weight:600;box-shadow:0 8px 28px rgba(0,0,0,0.2);transform:translateY(80px);opacity:0;transition:all .35s cubic-bezier(.34,1.56,.64,1);z-index:999;}
.toast.show{transform:translateY(0);opacity:1;}

/* Tabs de vista (día/semana/mes) */
.vista-tabs{display:flex;gap:6px;background:var(--bg);border-radius:12px;padding:4px;border:1.5px solid var(--border);}
.vista-btn{padding:8px 18px;border-radius:9px;border:none;font-weight:700;font-size:0.82rem;cursor:pointer;font-family:inherit;background:transparent;color:var(--gray);transition:all .2s;}
.vista-btn.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px rgba(124,58,237,0.2);}
.vista-btn:hover:not(.active){background:var(--primary-light);color:var(--primary);}

/* Botón Hoy */
.btn-hoy-ghost{
  background:var(--white);
  color:var(--primary);
  border:1.5px solid var(--primary);
  border-radius:100px;
  padding:8px 20px;
  font-weight:700;
  font-size:0.82rem;
  cursor:pointer;
  font-family:inherit;
  transition:all .2s;
  display:flex;
  align-items:center;
  gap:6px;
}
.btn-hoy-ghost:hover{
  background:var(--primary);
  color:#fff;
  box-shadow:0 4px 12px rgba(124,58,237,0.2);
}
.step-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:9px;cursor:pointer;transition:all .2s;}
.step-item.done{background:var(--green-light);}.step-item.pending{background:var(--bg);}
.step-item:hover.pending{background:var(--primary-light);}
.membresia-info{background:var(--primary-light);border-radius:12px;padding:16px;margin-bottom:14px;}
.membresia-wa{padding:14px;border:1px solid var(--border);border-radius:12px;}
.sidebar-toggle{display:none;position:fixed;top:10px;left:12px;z-index:200;width:40px;height:40px;border-radius:10px;background:var(--white);border:1px solid var(--border);box-shadow:var(--shadow);cursor:pointer;align-items:center;justify-content:center;font-size:1.15rem;transition:all .2s;}
.sidebar-toggle:hover{background:var(--primary-light);}
.sidebar-toggle:active{transform:scale(0.93);}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.40);z-index:49;backdrop-filter:blur(3px);}
.sidebar-overlay.active{display:block;}

/* Icono de calendario neutral (evita el "July 17" de los emojis en Android/iOS) */
.icon-calendar-neutral {
  display: inline-block;
  width: 1.2em;
  height: 1.2em;
  vertical-align: middle;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E") no-repeat center;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E") no-repeat center;
  margin-right: 5px;
  position: relative;
  top: -1px;
}
.sidebar-close-btn{display:none !important;}
@media(max-width:900px){
  .sidebar-close-btn{display:flex !important;}
}
.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--white);border-top:1px solid var(--border);padding:4px 0 env(safe-area-inset-bottom,6px);box-shadow:0 -4px 24px rgba(0,0,0,0.09);}
.bottom-nav-inner{display:flex;align-items:center;justify-content:space-around;}
.bn-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 6px 5px;border-radius:12px;cursor:pointer;min-width:54px;position:relative;transition:all .18s;-webkit-tap-highlight-color:transparent;}
.bn-item:active{transform:scale(0.91);}
.bn-item .bn-icon{font-size:1.3rem;line-height:1;transition:transform .18s;}
.bn-item .bn-label{font-size:0.6rem;font-weight:700;color:var(--gray2);letter-spacing:0.1px;transition:color .18s;}
.bn-item.active .bn-label{color:var(--primary);}
.bn-item.active .bn-icon{transform:scale(1.08);}
.bn-item.active .bn-icon-bg{position:absolute;top:3px;left:50%;transform:translateX(-50%);width:44px;height:30px;background:var(--primary-light);border-radius:100px;z-index:-1;}
.bn-badge{position:absolute;top:3px;right:4px;background:var(--red);color:#fff;border-radius:100px;font-size:0.55rem;font-weight:800;padding:1px 5px;min-width:16px;text-align:center;box-shadow:0 1px 4px rgba(239,68,68,0.4);}
.bn-more-panel{display:none;position:fixed;bottom:62px;left:0;right:0;background:var(--white);border-top:1px solid var(--border);padding:16px 16px 12px;z-index:99;box-shadow:0 -10px 32px rgba(0,0,0,0.12);border-radius:24px 24px 0 0;}
.bn-more-panel.open{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;}
.bn-more-panel-handle{width:36px;height:4px;background:var(--border);border-radius:100px;margin:0 auto 14px;display:block;}
.bn-more-item{display:flex;flex-direction:column;align-items:center;gap:5px;padding:13px 8px 11px;border-radius:14px;cursor:pointer;transition:all .18s;-webkit-tap-highlight-color:transparent;}
.bn-more-item:hover,.bn-more-item:active{background:var(--primary-light);}
.bn-more-item:active{transform:scale(0.93);}
.bn-more-item .bm-icon{font-size:1.5rem;}
.bn-more-item .bm-label{font-size:0.68rem;font-weight:700;color:var(--gray);text-align:center;line-height:1.2;}
.bn-more-item.active .bm-label{color:var(--primary);}
.cita-row{cursor:default;}
.btn-cita{min-width:70px;font-size:0.78rem;padding:8px 13px;}
.cita-estado{font-size:0.72rem;padding:4px 11px;}
.est-confirmada::before,.est-pendiente::before,.est-cancelada::before{content:'•';margin-right:4px;}
.card{transition:box-shadow .2s;}
.content{scroll-behavior:smooth;}
button:focus-visible,a:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:6px;}
.sch-list-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
@media(max-width:900px){
  .sidebar{transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);width:260px;box-shadow:6px 0 32px rgba(0,0,0,0.14);}
  .sidebar.open{transform:translateX(0);}
  .sidebar-bottom{display:block!important;padding:12px 12px 90px 12px!important;}
  .sidebar-nav{overflow-y:auto;max-height:calc(100vh - 160px);}
  .nav-item span{display:inline!important;}
  .sidebar-logo span{display:inline!important;}
  .sidebar-logo{padding:18px 20px;font-size:1.2rem;}
  .sidebar-toggle{display:flex;}
  .bottom-nav{display:block;}
  .main{margin-left:0;padding-bottom:72px;}
  .topbar{padding:0 14px 0 62px;height:58px;gap:8px;}
  .topbar-title{font-size:0.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px;}
  .topbar-right{gap:7px;}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:10px;}
  .stat-val{font-size:1.6rem;}
  .stat-card{padding:15px 14px;}
  .form-row{grid-template-columns:1fr;}
  .qr-wrap{grid-template-columns:1fr;gap:18px;}
  .pay-grid{grid-template-columns:1fr 1fr;}
  .content{padding:12px 13px 16px;}
  .preview-bar{flex-direction:row;align-items:center;gap:8px;padding:10px 14px;top:58px;border-radius:0;margin: -12px -13px 16px -13px;width:calc(100% + 26px);border-left:none;border-right:none;}
  .preview-link-txt{display:none;}
  .btn-copy{width:auto;padding:8px 12px;}
  .prof-grid{grid-template-columns:repeat(2,1fr);}
  .card{padding:15px 14px;border-radius:12px;}
  .cita-row{gap:8px;padding:12px 12px;}
  .sch-row{grid-template-columns:95px 1fr auto;gap:7px;padding:11px 10px;}
  .time-range input{width:82px;}
  .membresia-wa{padding:12px;}
  .qr-box{max-width:220px;margin:0 auto;}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:8px;}
  .stat-card{padding:13px 12px;}
  .stat-val{font-size:1.35rem;}
  .stat-label{font-size:0.68rem;}
  .prof-grid{grid-template-columns:1fr 1fr;}
  .svc-grid{grid-template-columns:repeat(2,1fr);gap:10px;}
  .svc-img-wrap{height:130px;}
  .pay-grid{grid-template-columns:1fr 1fr;}
  .sch-row{grid-template-columns:78px 1fr auto;gap:5px;}
  .sch-row .time-range{flex-wrap:wrap;gap:4px;}
  .time-range input{width:75px;font-size:0.75rem;padding:5px 6px;}
  .time-sep{display:none;}
  .cita-actions{width:100%;justify-content:flex-end;margin-top:4px;}
  .btn-cita{flex:1;font-size:0.75rem;}
  .topbar .badge-plan{display:none;}
  .btn-topbar span{display:none;}
  .btn-topbar{padding:8px 11px;}
  .card-title{font-size:0.95rem;}
  .card-sub{font-size:0.78rem;}
  .date-nav{gap:6px;}
  .date-btn{padding:7px 10px;font-size:0.78rem;}
  .date-display{font-size:0.8rem;}
  .cl-table th,.cl-table td{padding:9px 10px;font-size:0.78rem;}
  .qr-box{max-width:100%;}
  .qr-actions{flex-direction:column;gap:7px;}
  .qr-actions button{width:100%;}
  .qr-tip{font-size:0.75rem;padding:9px 11px;}
  .preview-bar{padding:9px 12px;}
  .form-group{margin-bottom:13px;}
  input[type=text],input[type=email],input[type=tel],input[type=number],textarea,select{padding:10px 11px;font-size:0.85rem;}
}
.wizard-steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:28px;flex-wrap:wrap;row-gap:10px;}
.wstep{display:flex;flex-direction:column;align-items:center;gap:5px;position:relative;flex:1;max-width:90px;}
.wstep:not(:last-child)::after{content:'';position:absolute;top:16px;left:58%;width:84%;height:2px;background:var(--border);z-index:0;transition:background .3s;}
.wstep.done:not(:last-child)::after{background:var(--green);}
.wstep .wnum{width:32px;height:32px;border-radius:50%;border:2px solid var(--border);background:var(--bg);color:var(--gray);font-size:0.75rem;font-weight:800;display:flex;align-items:center;justify-content:center;z-index:1;transition:all .25s;}
.wstep.active .wnum{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 5px var(--primary-light);}
.wstep.done .wnum{background:var(--green);border-color:var(--green);color:#fff;}
.wstep .wlabel{font-size:0.65rem;font-weight:700;color:var(--gray2);text-align:center;transition:color .25s;white-space:nowrap;}
.wstep.active .wlabel{color:var(--primary);}
.wstep.done .wlabel{color:var(--green);}
.wizard-nav{display:flex;gap:10px;justify-content:space-between;align-items:center;margin-top:24px;padding-top:20px;border-top:1px solid var(--border);}
.wizard-nav .wbtn-back{background:transparent;border:1.5px solid var(--border);color:var(--gray);padding:11px 22px;border-radius:100px;font-weight:600;font-size:0.875rem;cursor:pointer;font-family:inherit;transition:all .2s;}
.wizard-nav .wbtn-back:hover{border-color:var(--primary-mid);color:var(--primary);}
.wizard-nav .wbtn-back:disabled{opacity:0.3;cursor:default;}
.wizard-nav .wbtn-next{background:var(--primary);color:#fff;border:none;padding:12px 28px;border-radius:100px;font-weight:700;font-size:0.875rem;cursor:pointer;font-family:inherit;box-shadow:0 4px 14px rgba(124,58,237,0.3);transition:all .2s;flex:1;max-width:220px;}
.wizard-nav .wbtn-next:hover{background:var(--primary-hover);transform:translateY(-1px);}
.wizard-section-title{font-size:1.25rem;font-weight:800;color:var(--text);margin-bottom:4px;}
.wizard-section-sub{font-size:0.875rem;color:var(--gray);margin-bottom:22px;}
.wstep-inner{text-align:left;}
/* ════════════════════════════════════════════════════════════
   MIS SEDES — CARDS EXPANDIBLES (FASE D)
   ════════════════════════════════════════════════════════════ */
.sede-card{background:var(--white);border:1.5px solid var(--border);border-radius:14px;margin-bottom:10px;overflow:hidden;transition:all .25s ease;box-shadow:0 1px 3px rgba(0,0,0,0.04);}
.sede-card:hover{box-shadow:0 6px 20px rgba(124,58,237,0.08);}
.sede-card.activa{border-color:var(--primary);box-shadow:0 4px 16px rgba(124,58,237,0.12);}
.sede-card.expandida{box-shadow:0 8px 28px rgba(124,58,237,0.14);}

.sede-header{display:flex;align-items:center;gap:14px;padding:14px 16px;cursor:pointer;user-select:none;flex-wrap:wrap;}
.sede-header:hover{background:rgba(124,58,237,0.03);}
.sede-avatar{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--primary-mid));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.05rem;flex-shrink:0;overflow:hidden;}
.sede-avatar img{width:100%;height:100%;object-fit:cover;}
.sede-info{flex:1;min-width:130px;}
.sede-nombre{font-weight:800;font-size:0.96rem;color:var(--text);display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.sede-meta{font-size:0.74rem;color:var(--gray);margin-top:3px;}
.sede-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:100px;font-size:0.62rem;font-weight:800;letter-spacing:0.3px;text-transform:uppercase;}
.sede-badge.activa{background:var(--primary-light);color:var(--primary);}
.sede-badge.principal{background:#FEF3C7;color:#92400E;}
.sede-badge.alerta{background:#FEE2E2;color:#991B1B;}

.sede-quickstats{display:flex;gap:14px;padding-right:8px;flex-wrap:wrap;}
.sede-qs{text-align:center;min-width:54px;}
.sede-qs-val{font-weight:800;font-size:1rem;color:var(--text);line-height:1;}
.sede-qs-lbl{font-size:0.62rem;color:var(--gray);margin-top:2px;text-transform:uppercase;letter-spacing:0.4px;font-weight:700;}

.sede-chevron{width:32px;height:32px;border-radius:8px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:0.85rem;color:var(--gray);transition:transform .25s ease;flex-shrink:0;}
.sede-card.expandida .sede-chevron{transform:rotate(180deg);background:var(--primary-light);color:var(--primary);}

.sede-body{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.sede-card.expandida .sede-body{max-height:600px;}
.sede-body-inner{padding:0 16px 16px;border-top:1px solid var(--border);margin-top:4px;padding-top:14px;}

.sede-stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px;margin-bottom:14px;}
.sede-stat-mini{background:var(--bg);border-radius:10px;padding:9px 11px;}
.sede-stat-mini-val{font-weight:800;font-size:0.92rem;color:var(--text);}
.sede-stat-mini-lbl{font-size:0.67rem;color:var(--gray);margin-top:2px;text-transform:uppercase;font-weight:700;}

.sede-pagos{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px;}
.sede-pago-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:100px;font-size:0.7rem;font-weight:700;}
.sede-pago-chip.ok{background:#ECFDF5;color:#065F46;border:1px solid #A7F3D0;}
.sede-pago-chip.off{background:#F3F4F6;color:#9CA3AF;border:1px solid #E5E7EB;text-decoration:line-through;}

.sede-acciones{display:flex;gap:6px;flex-wrap:wrap;}
.sede-btn{padding:8px 14px;border-radius:100px;font-size:0.74rem;font-weight:800;cursor:pointer;border:none;font-family:inherit;text-decoration:none;display:inline-flex;align-items:center;gap:4px;transition:all .15s;}
.sede-btn:hover{transform:translateY(-1px);}
.sede-btn-primary{background:var(--primary);color:#fff;}
.sede-btn-secondary{background:var(--green-light);color:var(--green);}
.sede-btn-edit{background:var(--blue-light);color:var(--blue);}
.sede-btn-link{background:var(--primary-light);color:var(--primary);}
.sede-btn-danger{background:var(--red-light);color:var(--red);}

@media (max-width:560px){
  .sede-quickstats{display:none;}
  .sede-header{padding:12px 14px;}
  .sede-avatar{width:42px;height:42px;}
}