:root{--radius: 12px;--maxw: 480px}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--color-dark);background:var(--color-bg)}.app{min-height:100vh;display:flex;flex-direction:column}.card-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:24px 16px}.card{width:100%;max-width:var(--maxw);display:flex;flex-direction:column;gap:12px;padding:28px 22px;border:1px solid #e7e9ee;border-radius:var(--radius);box-shadow:0 6px 24px #0000000f}.card h1{margin:0;color:var(--color-primary);font-size:1.5rem}label{font-size:.9rem;font-weight:600}input{width:100%;font-size:16px;padding:12px 14px;border:1px solid #ccd2dc;border-radius:10px}input:focus{outline:2px solid var(--color-accent);border-color:var(--color-accent)}button{font-size:16px;font-weight:600;padding:12px 16px;border:0;border-radius:10px;color:#fff;background:var(--color-primary);cursor:pointer}button:disabled{opacity:.55;cursor:not-allowed}button.ghost{background:transparent;color:var(--color-primary);border:1px solid var(--color-primary);padding:8px 12px}.muted{color:#5b6573;margin:0}.ok{color:#1c6b3a}.err{color:#b3261e}button.link{background:transparent;color:var(--color-primary);border:0;padding:4px 0;font-size:.92rem;font-weight:600;text-align:left;text-decoration:underline;cursor:pointer}button.link:hover{opacity:.8}.alt{margin-top:4px;padding-top:12px;border-top:1px solid #eef0f4}.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;background:var(--color-primary);color:#fff}.topbar-right{display:flex;align-items:center;gap:12px}.topbar .ghost{color:#fff;border-color:#ffffffb3}.who{font-size:.9rem;opacity:.95}.banner{background:#fff7e6;border-bottom:1px solid #f0d9a8;color:#7a5a00;padding:10px 18px;font-size:.9rem}.dash{padding:24px 18px;max-width:760px;width:100%;margin:0 auto}.badge{display:inline-block;text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:700;color:var(--color-primary);background:color-mix(in srgb,var(--color-accent) 22%,#fff);padding:4px 10px;border-radius:999px}.dash h2{margin:12px 0 4px;color:var(--color-primary)}.bullets{margin-top:14px;padding-left:18px;line-height:1.7}.splash{flex:1;display:flex;align-items:center;justify-content:center;color:#5b6573}.agenda{padding:18px 16px 40px;max-width:1100px;width:100%;margin:0 auto}.agenda-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.agenda-head h2{margin:8px 0 0;color:var(--color-primary)}.agenda-nota{margin-top:16px}.board{margin-top:16px;display:grid;grid-template-columns:1fr;gap:14px}@media(min-width:720px){.board{grid-template-columns:repeat(5,1fr);align-items:start}}.col{background:#f6f8fb;border:1px solid #e7e9ee;border-radius:var(--radius);padding:10px}.col>header{display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:.9rem;color:var(--color-primary);padding:4px 6px 10px}.col .count{background:color-mix(in srgb,var(--color-accent) 24%,#fff);color:var(--color-primary);border-radius:999px;padding:1px 9px;font-size:.8rem}.col-pendiente{background:#fdeef0;border-color:#f3c6cd}.col-reservada{background:#eef3fd;border-color:#c6d6f3}.col-en_proceso{background:#fff7e6;border-color:#f0d9a8}.col-lista{background:#eaf7ef;border-color:#bfe6cd}.col-entregada{background:#eef1f5}.vacio{color:#8a93a3;font-size:.85rem;padding:6px;margin:0}.cita{background:#fff;border:1px solid #e1e5ec;border-radius:10px;padding:10px 12px;margin-bottom:10px;cursor:pointer}.cita:hover{border-color:var(--color-accent)}.cita-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.cita-top strong{letter-spacing:.02em}.cita .hora{font-size:.8rem;color:#5b6573}.cita-serv{font-size:.9rem;color:#333a45;margin:4px 0 8px}.cita-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.85rem}.cita .cliente{color:#5b6573}.cita .precio{font-weight:700;color:var(--color-primary)}.agenda-acciones{display:flex;gap:8px}.cita-acciones{display:flex;gap:6px;margin-top:10px}button.mini{font-size:.82rem;padding:6px 10px;flex:1}button.mini.ghost{flex:0 0 auto}.modal-wrap{position:fixed;top:0;right:0;bottom:0;left:0;background:#141a238c;display:flex;align-items:flex-start;justify-content:center;padding:24px 14px;overflow-y:auto;z-index:50}.modal{width:100%;max-width:460px;background:#fff;border-radius:var(--radius);padding:18px 18px 22px;display:flex;flex-direction:column;gap:10px;box-shadow:0 12px 40px #00000040}.modal-head{display:flex;align-items:center;justify-content:space-between}.modal-head h3{margin:0;color:var(--color-primary)}.modal .x{background:transparent;color:#5b6573;border:0;font-size:1.1rem;padding:4px 8px;cursor:pointer}.modal select{width:100%;font-size:16px;padding:12px 14px;border:1px solid #ccd2dc;border-radius:10px;background:#fff}.modal .row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.precio-resumen{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#f6f8fb;border:1px solid #e7e9ee;border-radius:10px;padding:10px 12px;font-size:.92rem}.precio-resumen strong{color:var(--color-primary)}.shell{display:flex;flex:1;min-height:0}.shell-main{flex:1;min-width:0}.side{flex:0 0 220px;border-right:1px solid #e7e9ee;background:#fafbfc;padding:14px 10px;display:flex;flex-direction:column;gap:4px}.side-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:transparent;color:#333a45;border:0;border-radius:10px;padding:10px 12px;font-size:.95rem;font-weight:600;cursor:pointer}.side-item .ic{font-size:1.05rem}.side-item.activo{background:color-mix(in srgb,var(--color-accent) 22%,#fff);color:var(--color-primary)}.side-item:disabled{color:#9aa3b0;cursor:default}.side-item .pronto{margin-left:auto;font-size:.66rem;text-transform:uppercase;letter-spacing:.04em;background:#eef0f4;color:#8a93a3;padding:2px 6px;border-radius:999px}@media(max-width:760px){.shell{flex-direction:column}.side{flex:none;flex-direction:row;overflow-x:auto;border-right:0;border-bottom:1px solid #e7e9ee;padding:8px}.side-item{flex:0 0 auto;width:auto}.side-item .pronto{display:none}}.ficha{margin:0;display:grid;gap:8px}.ficha>div{display:grid;grid-template-columns:120px 1fr;gap:8px;font-size:.92rem}.ficha dt{color:#8a93a3;font-weight:600}.ficha dd{margin:0}.fotos{border-top:1px solid #eef0f4;padding-top:12px}.fotos-head{display:flex;align-items:center;justify-content:space-between}.foto-add{display:inline-flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;border-radius:10px;font-size:.82rem;font-weight:600;padding:6px 10px;cursor:pointer}.foto-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:8px;margin-top:10px}.foto-grid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;border:1px solid #e1e5ec}.owner-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:16px}@media(min-width:720px){.owner-grid{grid-template-columns:repeat(2,1fr)}}.owner-card{border:1px solid #e7e9ee;border-radius:var(--radius);padding:16px;background:#fff}.owner-card h3{margin:0 0 12px;color:var(--color-primary)}.owner-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.owner-stat{background:#f6f8fb;border-radius:10px;padding:10px 6px;text-align:center}.owner-stat .n{display:block;font-size:1.3rem;font-weight:800;color:var(--color-primary)}.owner-stat .l{font-size:.72rem;color:#5b6573}.owner-fact{margin-top:12px;font-size:.92rem;color:#333a45}.owner-entrar{margin-top:12px;width:100%}.owner-nota{margin-top:16px}.owner-altas{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}.modal-form{display:flex;flex-direction:column;gap:10px}.modal-form select{width:100%;font-size:16px;padding:12px 14px;border:1px solid #ccd2dc;border-radius:10px;background:#fff}.modal-form .check{flex-direction:row;align-items:center;gap:8px;display:flex;font-weight:500}.modal-form .check input{width:auto}.cliente-citas{display:grid;gap:14px;margin-top:16px}.cliente-cita{border:1px solid #e7e9ee;border-radius:var(--radius);padding:16px;background:#fff}.cliente-cita-top{display:flex;align-items:baseline;justify-content:space-between}.cliente-cita-top .precio{font-weight:700;color:var(--color-primary)}.cliente-serv{color:#5b6573;margin:4px 0 14px}.stepper{list-style:none;margin:0;padding:0;display:flex;gap:4px}.stepper li{flex:1;text-align:center;font-size:.72rem;color:#9aa3b0;position:relative}.stepper .dot{display:block;height:8px;border-radius:999px;background:#e1e5ec;margin-bottom:6px}.stepper li.on{color:var(--color-primary);font-weight:700}.stepper li.on .dot{background:var(--color-accent)}.modal .check{flex-direction:row;align-items:center;gap:8px;display:flex;font-weight:500;margin:6px 0 2px;font-size:.9rem;line-height:1.3}.modal .check input{width:auto;margin-top:2px}.seg{display:inline-flex;background:#eef1f5;border:1px solid #e1e5ec;border-radius:999px;padding:3px}.seg button{border:none;background:transparent;color:#5b6573;font-size:.85rem;font-weight:600;padding:6px 14px;border-radius:999px;cursor:pointer}.seg button.activo{background:#fff;color:var(--color-primary);box-shadow:0 1px 3px #0000001f}.calendario{margin-top:16px}.cal-nav{display:flex;align-items:center;justify-content:space-between;gap:10px}.cal-titulo{display:flex;flex-direction:column;align-items:center;gap:2px;text-align:center}.cal-titulo strong{color:var(--color-primary);font-size:1.05rem}.cal-semana{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin:14px 0}.cal-dia{position:relative;display:flex;flex-direction:column;align-items:center;gap:2px;background:#f6f8fb;border:1px solid #e7e9ee;border-radius:10px;padding:8px 2px;cursor:pointer}.cal-dia .cal-dow{font-size:.7rem;color:#8a93a3;text-transform:uppercase}.cal-dia .cal-num{font-weight:700;color:#333a45}.cal-dia.hoy{border-color:var(--color-accent)}.cal-dia.activo{background:var(--color-primary)}.cal-dia.activo .cal-dow,.cal-dia.activo .cal-num{color:#fff}.cal-dia .cal-badge{position:absolute;top:-6px;right:-4px;min-width:18px;height:18px;padding:0 4px;border-radius:999px;background:var(--color-accent);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center}.cal-lista{display:flex;flex-direction:column;gap:10px}.cal-item{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid #e1e5ec;border-radius:10px;padding:10px 12px;cursor:pointer}.cal-item:hover{border-color:var(--color-accent)}.cal-hora{font-weight:700;color:var(--color-primary);min-width:48px}.cal-item-cuerpo{display:flex;flex-direction:column;gap:2px;flex:1}.cal-item-cuerpo strong{letter-spacing:.02em}.cal-serv{font-size:.88rem;color:#333a45}.cal-cliente{font-size:.82rem;color:#8a93a3}.cal-item-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.cal-item-meta .precio{font-weight:700;color:var(--color-primary)}.chip{font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:999px;white-space:nowrap}.chip.estado-pendiente{background:#fdeef0;color:#b03a4a}.chip.estado-reservada{background:#eef3fd;color:#2f5bb7}.chip.estado-en_proceso{background:#fff7e6;color:#9a6b15}.chip.estado-lista{background:#eaf7ef;color:#1f7a44}.chip.estado-entregada{background:#eef1f5;color:#5b6573}.chip.estado-cancelada{background:#f1f1f1;color:#999}.reserva{min-height:100vh;background:linear-gradient(160deg,color-mix(in srgb,var(--color-primary) 12%,#fff),#f3f5f8);display:flex;justify-content:center;padding:24px 16px 48px}.reserva-card{width:100%;max-width:460px;background:#fff;border:1px solid #e6e9ef;border-radius:16px;padding:24px;box-shadow:0 10px 40px #14285014;display:flex;flex-direction:column;gap:6px;margin-top:12px}.reserva-card h1{margin:0;color:var(--color-primary);font-size:1.4rem}.reserva-sub{margin:0 0 8px}.reserva-card label{font-size:.85rem;font-weight:600;color:#46505f;margin-top:8px}.reserva-card input,.reserva-card select{width:100%;padding:10px 12px;border:1px solid #ccd2dc;border-radius:10px;background:#fff;font-size:.95rem;box-sizing:border-box}.reserva-card input:focus,.reserva-card select:focus{outline:none;border-color:var(--color-accent)}.reserva-card .row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.reserva-card button[type=submit]{margin-top:14px;background:var(--color-primary);color:#fff;border:none;border-radius:10px;padding:12px;font-size:1rem;font-weight:700;cursor:pointer}.reserva-card button[type=submit]:disabled{opacity:.6;cursor:default}.reserva-desc{font-size:.82rem;color:#6b7480;margin:2px 0 0}.reserva-aviso{color:#b03a4a;font-size:.85rem;margin:4px 0 0}.reserva-pie{text-align:center;margin:10px 0 0;font-size:.78rem}.reserva-extras{display:flex;flex-direction:column;gap:2px;margin-top:8px;border:1px solid #e6e9ef;border-radius:10px;padding:8px 10px}.reserva-extra{display:flex!important;flex-direction:row;align-items:center;gap:8px;margin-top:0!important;font-weight:500!important;font-size:.9rem!important;padding:4px 0;cursor:pointer}.reserva-extra input{width:auto!important}.reserva-extra-nom{flex:1}.reserva-extra-precio{color:var(--color-primary);font-weight:700;font-size:.85rem}.reserva-consent{display:flex!important;flex-direction:row;align-items:flex-start;gap:8px;margin-top:14px!important;font-size:.8rem!important;font-weight:500!important;color:#5b6573!important;line-height:1.35}.reserva-consent input{width:auto!important;margin-top:2px}.reserva-ok{align-items:center;text-align:center}.reserva-tick{width:56px;height:56px;border-radius:999px;background:color-mix(in srgb,var(--color-accent) 22%,#fff);color:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:800;margin:4px auto 6px}
