*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--blue:#185fa5;--blue-dark:#0c447c;--blue-light:#e6f1fb;--blue-mid:#378add;--green:#0f6e56;--green-light:#e1f5ee;--amber:#854f0b;--amber-light:#faeeda;--red:#a32d2d;--red-light:#fcebeb;--gray-50:#f8f8f6;--gray-100:#f0efeb;--gray-200:#e5e4df;--gray-400:#9b9a95;--gray-500:#737270;--gray-600:#5f5e5a;--gray-900:#1a1a18;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--sidebar-w:220px}html{font-size:16px}body{color:var(--gray-900);background:var(--gray-100);font-family:Lato,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}h1{font-size:1.375rem;font-weight:500}h2{font-size:1.125rem;font-weight:500}h3{font-size:1rem;font-weight:500}p{color:var(--gray-600);font-size:.875rem}.layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);border-right:1px solid var(--gray-100);z-index:300;background:#fff;flex-direction:column;height:100dvh;display:flex;position:fixed;top:0;left:0}.sidebar-logo{padding:1.375rem 1.25rem 1rem}.sidebar-brand{color:var(--gray-900);margin-top:.5rem;font-size:.875rem;font-weight:700}.sidebar-sub{color:var(--gray-500);margin-top:2px;font-size:.6875rem}.sidebar-body{flex:1;padding:.625rem .75rem;overflow-y:auto}.nav-label{color:var(--gray-500);letter-spacing:.04em;text-transform:uppercase;padding:1rem .625rem .375rem;font-size:.6875rem;font-weight:600}.nav-item{color:var(--gray-600);border-radius:8px;align-items:center;gap:10px;margin-bottom:2px;padding:9px 12px;font-size:.8125rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-item:hover{background:var(--gray-50);color:var(--gray-900)}.nav-item.active{background:var(--blue-light);color:var(--blue);font-weight:600}.nav-item svg{width:16px;height:16px;color:var(--gray-400);flex-shrink:0;transition:color .15s}.nav-item:hover svg{color:var(--gray-600)}.nav-item.active svg{color:var(--blue)}.sidebar-footer{border-top:1px solid var(--gray-100);align-items:center;gap:10px;padding:.875rem 1rem;display:flex}.main{margin-left:var(--sidebar-w);background:var(--gray-100);flex-direction:column;flex:1;min-width:0;min-height:100vh;display:flex}.mobile-topbar{display:none}.page-header{justify-content:space-between;align-items:center;gap:1rem;padding:2rem 2rem 0;display:flex}.page-title{color:var(--blue);flex-shrink:0;font-size:1.5625rem;font-weight:700}.page-actions{align-items:center;gap:.75rem;display:flex}.page-actions input{min-width:320px;height:46px}.page-actions-mobile{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem 0;display:none}.content{flex:1;min-width:0;padding:1.25rem 2rem 2rem}.card{border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;padding:1.25rem}.card-sm{padding:.875rem 1rem}.card-flush{padding:0;overflow:hidden}.metric{border:1px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;align-items:center;gap:.875rem;padding:1rem 1.25rem;display:flex}.metric-compact{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.125rem;padding:.75rem 1rem}.metric-icon{background:var(--blue-light);width:48px;height:48px;color:var(--blue);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.metric-body{flex:1;min-width:0}.metric-row{align-items:baseline;gap:.375rem;display:flex}.metric-val{color:var(--gray-900);font-size:1.5rem;font-weight:700;line-height:1}.metric-sub{color:var(--gray-400);font-size:.6875rem;font-weight:500}.metric-label{color:var(--gray-500);margin-top:.2rem;font-size:.75rem}.metric-compact .metric-label{margin-top:0}.pac-meta-mobile{display:none}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.875rem}thead tr{border-bottom:1px solid var(--gray-200)}th{text-align:left;color:var(--gray-900);padding:1rem 1.25rem;font-size:.875rem;font-weight:600}td{border-bottom:1px solid var(--gray-100);color:var(--gray-600);padding:.875rem 1.25rem}tr:last-child td{border-bottom:none}tr:hover td{background:var(--gray-50)}.form-group{margin-bottom:1rem}.form-label{color:var(--gray-600);margin-bottom:4px;font-size:.75rem;display:block}.form-input{border-radius:var(--radius-md);border:1px solid var(--gray-200);width:100%;color:var(--gray-900);background:#fff;padding:8px 10px;font-size:.875rem;transition:border-color .15s}.form-input:focus{border-color:var(--blue);outline:none}.form-input::placeholder{color:var(--gray-400);opacity:1;font-size:.875rem}input,textarea,select,button{font-family:inherit}input[type=date],input[type=time]{color:var(--gray-900);font-size:.875rem}.form-input.error{border-color:var(--red)}.form-error{color:var(--red);margin-top:3px;font-size:.75rem}.form-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:.75rem;display:grid}.btn{border-radius:var(--radius-md);cursor:pointer;border:1px solid var(--gray-200);color:var(--gray-900);background:#fff;align-items:center;gap:6px;padding:8px 16px;font-size:.8125rem;font-weight:500;text-decoration:none;transition:background .1s;display:inline-flex}.btn:hover{background:var(--gray-50)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-primary:hover{background:var(--blue-dark);border-color:var(--blue-dark)}.btn-danger{background:var(--red-light);color:var(--red);border-color:#0000}.btn-sm{padding:5px 10px;font-size:.75rem}.btn-block{justify-content:center;width:100%}.pagination{align-items:center;gap:.25rem;display:flex}.page-btn{border:1px solid var(--gray-200);width:32px;height:32px;color:var(--gray-700);cursor:pointer;background:#fff;border-radius:6px;justify-content:center;align-items:center;font-size:.8125rem;font-weight:500;transition:background .1s,border-color .1s,color .1s;display:inline-flex}.page-btn:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300)}.page-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}.page-btn:disabled{opacity:.35;cursor:default}.page-btn.ellipsis{cursor:default;color:var(--gray-400);background:0 0;border-color:#0000}.badge{border-radius:100px;padding:2px 8px;font-size:.6875rem;font-weight:500;display:inline-block}.badge-ok{background:var(--green-light);color:var(--green)}.badge-warn{background:var(--amber-light);color:var(--amber)}.badge-danger{background:var(--red-light);color:var(--red)}.badge-info{background:var(--blue-light);color:var(--blue)}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:500;display:inline-flex}.avatar-sm{width:32px;height:32px}.avatar-md{width:40px;height:40px;font-size:.875rem}.avatar-lg{width:52px;height:52px;font-size:1rem}.avatar-blue{background:var(--blue-light);color:var(--blue)}.avatar-green{background:var(--green-light);color:var(--green)}.avatar-purple{color:#3c3489;background:#eeedfe}.avatar-pink{color:#72243e;background:#f4c0d1}.chip{border-radius:var(--radius-md);border:1px solid var(--gray-200);cursor:pointer;align-items:center;gap:10px;padding:10px 12px;transition:border-color .15s,background .15s;display:flex}.chip:hover{border-color:var(--blue-mid)}.chip.selected{border-color:var(--blue);background:var(--blue-light)}.tipo-turno-btn{border:none;border-right:1px solid var(--gray-200);cursor:pointer;text-align:left;min-width:140px;color:var(--gray-700);background:#fff;flex-direction:column;flex:1;align-items:flex-start;gap:2px;padding:.75rem 1.25rem;transition:background .15s,color .15s;display:flex}.tipo-turno-btn:last-child{border-right:none}.tipo-turno-btn.active{background:var(--blue-light);color:var(--blue)}.tipo-turno-btn .label{font-size:.8125rem;font-weight:500}.tipo-turno-btn.active .label{font-weight:600}.tipo-turno-btn .sub{opacity:.6;font-size:.75rem}.modalidad-btn{cursor:pointer;color:var(--gray-600);background:#fff;border:none;flex:1;padding:7px 12px;font-size:.8125rem;font-weight:500;transition:background .15s,color .15s}.modalidad-btn.active{background:var(--gray-900);color:#fff}.steps{gap:6px;margin-bottom:1.5rem;display:flex}.step-dot{background:var(--gray-200);border-radius:2px;flex:1;height:3px}.step-dot.done{background:var(--blue)}.step-dot.active{background:var(--blue-mid)}.flash{z-index:9999;border-radius:var(--radius-md);align-items:center;gap:8px;max-width:320px;padding:10px 16px;font-size:.8125rem;font-weight:500;display:flex;position:fixed;top:1rem;right:1rem;box-shadow:0 2px 8px #0000001f}.flash-ok{background:var(--green-light);color:var(--green)}.flash-error{background:var(--red-light);color:var(--red)}.flash-warn{background:var(--amber-light);color:var(--amber)}.btn-campana{background:var(--gray-50);border:1.5px solid var(--gray-200);appearance:none;cursor:pointer;color:var(--gray-500);border-radius:10px;outline:none;flex-shrink:0;justify-content:center;align-items:center;padding:8px 10px;transition:background .12s,border-color .12s;display:flex;position:relative}.btn-campana:hover,.btn-campana.activo{background:var(--gray-100);border-color:var(--gray-300);color:var(--gray-700)}.btn-campana .campana-badge{color:#fff;pointer-events:none;background:#dc2626;border:2px solid #fff;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:.5625rem;font-weight:700;line-height:1;display:flex;position:absolute;top:-5px;right:-5px}.alert{border-radius:var(--radius-md);margin-bottom:1rem;padding:10px 14px;font-size:.8125rem}.alert-ok{background:var(--green-light);color:var(--green)}.alert-info{background:var(--blue-light);color:var(--blue)}.alert-warn{background:var(--amber-light);color:var(--amber)}.alert-danger{background:var(--red-light);color:var(--red)}.modal-bg{z-index:200;background:#0006;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-lg);background:#fff;width:100%;max-width:480px;max-height:calc(100dvh - 2rem);padding:1.5rem;overflow-y:auto}.modal-title{margin-bottom:.5rem;font-size:1rem;font-weight:500}.modal-body{color:var(--gray-600);margin-bottom:1.25rem;font-size:.875rem}.modal-actions{justify-content:flex-end;gap:.5rem;display:flex}.modal-anuncio-overlay{z-index:9999;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-anuncio-backdrop{background:#00000073;position:absolute;inset:0}.modal-anuncio-panel{border-radius:var(--radius-lg);background:#fff;flex-direction:column;width:100%;max-width:640px;max-height:85vh;display:flex;position:relative;box-shadow:0 20px 60px #0003}.modal-panel{border-radius:var(--radius-lg);background:#fff;flex-direction:column;width:100%;max-width:480px;max-height:calc(100dvh - 2rem);display:flex;position:relative;box-shadow:0 8px 32px #0000002e}.modal-panel-body{flex:1;overflow-y:auto}.progress{background:var(--gray-200);border-radius:2px;height:3px;overflow:hidden}.progress-bar{background:var(--blue);border-radius:2px;height:100%;transition:width .3s}.slot-grid{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.slot{border-radius:var(--radius-md);border:1px solid var(--gray-200);text-align:center;cursor:pointer;padding:8px 4px;font-size:.75rem;transition:border-color .1s}.slot:hover{border-color:var(--blue-mid)}.slot.selected{border-color:var(--blue);background:var(--blue-light);font-weight:500}.slot.taken{opacity:.35;cursor:default;pointer-events:none}.ev-block{border-left:2px solid var(--blue-mid);margin-bottom:1.25rem;padding-left:.75rem}.ev-date{color:var(--gray-500);margin-bottom:3px;font-size:.6875rem}.ev-title{margin-bottom:3px;font-size:.875rem;font-weight:500}.ev-text{color:var(--gray-600);font-size:.8125rem;line-height:1.6}.timeline{flex-direction:column;display:flex}.tl-item{gap:.875rem;padding-bottom:1.25rem;display:flex;position:relative}.tl-item:last-child{padding-bottom:0}.tl-left{flex-direction:column;flex-shrink:0;align-items:center;display:flex}.tl-icon{z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.tl-line{background:var(--gray-200);flex:1;width:2px;margin-top:4px}.tl-item:last-child .tl-line{display:none}.tl-body{flex:1;min-width:0;padding-top:6px}.tl-title{color:var(--gray-900);margin-bottom:2px;font-size:.875rem;font-weight:600}.tl-sub{color:var(--gray-500);margin-bottom:.5rem;font-size:.75rem}.tl-tags{flex-wrap:wrap;gap:.375rem;display:flex}[x-cloak]{display:none!important}.agenda-toolbar{flex-direction:column;gap:.5rem;display:flex}.agenda-toolbar-fecha{color:var(--gray-900);flex-wrap:wrap;align-items:center;gap:.375rem;font-size:1rem;font-weight:600;display:flex}@media (width<=768px){.agenda-toolbar-fecha{font-size:.875rem}}.agenda-row{border-bottom:1px solid var(--gray-100);border-radius:var(--radius-sm);align-items:center;gap:1rem;padding:.75rem .25rem;transition:background .12s;display:flex}.agenda-row:last-child{border-bottom:none}.agenda-row:hover{background:var(--gray-50)}.agenda-time{color:var(--blue);text-align:center;background:var(--blue-light);border-radius:var(--radius-sm);flex-shrink:0;min-width:48px;padding:.3rem .375rem;font-size:.8125rem;font-weight:600;line-height:1.2}.agenda-info{flex:1;min-width:0}.agenda-name{flex-wrap:wrap;align-items:center;gap:.375rem;font-size:.875rem;font-weight:500;display:flex}.agenda-sub{color:var(--gray-500);flex-wrap:wrap;align-items:center;gap:.25rem;margin-top:2px;font-size:.75rem;display:flex}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-4{margin-top:1rem}.text-sm{font-size:.8125rem}.text-xs{font-size:.75rem}.text-muted{color:var(--gray-500)}.text-right{text-align:right}.font-medium{font-weight:500}.grid-2{grid-template-columns:1fr 1fr;align-items:start;gap:1rem;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:1rem;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:.75rem;display:grid}.w-full{width:100%}@media (width<=768px){.sidebar{transition:transform .2s;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main{margin-left:0}.mobile-topbar{border-bottom:1px solid var(--gray-100);z-index:100;background:#fff;justify-content:space-between;align-items:center;padding:.875rem 1rem;display:flex;position:sticky;top:0}.campana-desktop{display:none!important}.page-header{flex-wrap:wrap;padding:1.25rem 1rem 0}.page-actions{display:none!important}.page-actions-mobile{align-items:center;width:100%;display:flex}.page-actions-mobile>div[style*=max-width]{flex:1;max-width:none!important}.page-actions-mobile>button,.page-actions-mobile>a{flex-shrink:0;margin-left:auto}.content{padding:.75rem 1rem 1.25rem}.form-row,.form-row-3,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.grid-2.metrics-grid{grid-template-columns:1fr 1fr;gap:.5rem}.grid-2.metrics-grid .metric{padding:.75rem}.grid-2.metrics-grid .metric-icon{border-radius:8px;width:36px;height:36px}.grid-2.metrics-grid .metric-val{font-size:1.25rem}.grid-4-mobile{grid-template-columns:repeat(4,1fr)!important;gap:.375rem!important}.nuevo-turno-grid{grid-template-columns:1fr!important}.slot-grid{grid-template-columns:repeat(3,1fr)}.agenda-layout{grid-template-columns:1fr!important}.agenda-layout .agenda-cal{order:-1;width:100%!important}.semana-grid{grid-template-columns:1fr!important;min-width:0!important}.disponibilidad-dia,.agenda-row{flex-wrap:wrap}.agenda-info{width:100%}.agenda-row>.flex{width:100%;margin-left:48px}.disponibilidad-dia>div:first-child{width:100%;min-width:0}.disponibilidad-dia>div:nth-child(2){width:100%}.disponibilidad-dia>div:nth-child(2) input{flex:1;width:auto;min-width:0}.disponibilidad-dia>div:last-child{width:100%}.hide-mobile{display:none!important}.table-wrap{overflow-x:visible}.table-wrap table{width:100%;display:block}.table-wrap thead{display:none}.table-wrap tbody{display:block}.table-wrap tbody tr{border-bottom:1px solid var(--gray-200);padding:.5rem .75rem;display:block}.table-wrap tbody td{border:none;align-items:flex-start;gap:.5rem;padding:.2rem 0;font-size:.8125rem;display:flex}.table-wrap tbody td:before{content:attr(data-label);min-width:90px;color:var(--gray-500);flex-shrink:0;padding-top:1px;font-size:.75rem;font-weight:600}.table-wrap tbody td[data-label=""]:before{display:none}.table-wrap tbody td.hide-mobile{display:flex!important}.table-wrap tbody td.hide-on-mobile{display:none!important}.pac-meta-mobile{color:var(--gray-500);flex-wrap:wrap;gap:.25rem;margin-top:.15rem;font-size:.75rem;display:flex}}@media print{.sidebar,.mobile-topbar,.page-header,.btn,button,input,select,textarea{display:none!important}.main{margin-left:0!important}.content{padding:0!important}.card{break-inside:avoid;border:1px solid #e0e0e0!important}.ev-block{border-left:2px solid #378add!important}h2,h3{color:#185fa5!important}}.toggle{cursor:pointer;border-radius:100px;flex-shrink:0;width:36px;height:20px;transition:background .2s;position:relative}.toggle-dot{background:#fff;border-radius:50%;width:16px;height:16px;transition:left .2s;position:absolute;top:2px}.btn-tab-top{border:.875px solid;border-bottom:none;border-radius:8px 8px 0 0;padding:8px 16px}.disponibilidad-dia{border-bottom:1px solid var(--gray-200);align-items:center;gap:1rem;padding:.875rem 1.25rem;display:flex}.bloquear-dias .form-group{align-items:center;column-gap:16px;display:flex}.bloquear-dias .flex{margin-bottom:16px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}
