:root{--color-navy:#036;--color-navy-dark:#024;--color-green:#55a534;--color-green-dark:#3d7a26;--color-sky:#1e88b4;--color-yellow:#f5b800;--color-white:#fff;--color-bg:#f4f7fb;--color-text:#1a2b3c;--color-muted:#5c6b7a;--color-border:#dce4ee;--color-danger:#c62828;--color-warning:#ed6c02;--color-success:#2e7d32;--sidebar-width:260px;--header-height:64px;--radius:12px;--shadow:0 4px 20px #00336614;--font:"Segoe UI", system-ui, -apple-system, sans-serif}*,:before,:after{box-sizing:border-box}html,body,#root{min-height:100%;font-family:var(--font);color:var(--color-text);background:var(--color-bg);margin:0}a{color:var(--color-sky)}.app-shell{min-height:100vh;display:flex}.app-main{min-width:0;margin-left:var(--sidebar-width);flex:1;padding:1.5rem 2rem}.sidebar{width:var(--sidebar-width);background:var(--color-navy);height:100vh;color:var(--color-white);z-index:100;flex-direction:column;padding:1.25rem 1rem;display:flex;position:fixed;top:0;left:0;box-shadow:4px 0 24px #00000026}.sidebar__brand{border-bottom:1px solid #ffffff26;flex-direction:column;align-items:stretch;gap:.5rem;padding-bottom:1rem;display:flex}.sidebar__brand-tag{color:#ffffffb3;text-transform:uppercase;text-align:center;font-size:.65rem}.app-logo{object-fit:contain;width:100%;height:auto;display:block}.app-logo--sidebar{border-radius:8px;max-width:100%}.app-logo--login{border-radius:10px;max-width:min(300px,92%);margin:0 auto .5rem}.logos-config__grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;margin-top:1rem;display:grid}.logo-upload-card{border:1px solid var(--color-border,#e2e8f0);background:var(--color-surface,#f8fafc);border-radius:10px;flex-direction:column;gap:.65rem;padding:1rem;display:flex}.logo-upload-card__title{color:var(--color-navy);align-items:center;gap:.4rem;margin:0;font-size:1rem;display:flex}.logo-upload-card__desc{margin:0;font-size:.85rem;line-height:1.4}.logo-upload-card__input{display:none}.logo-upload-preview{background:#fff;border:1px dashed #cbd5e1;border-radius:8px;justify-content:center;align-items:center;min-height:80px;padding:.5rem;display:flex}.logo-upload-preview img{object-fit:contain;max-width:100%;height:auto}.logo-upload-preview--panel{min-height:72px}.logo-upload-preview--panel img{max-height:56px}.logo-upload-preview--landing{aspect-ratio:218/79;width:min(100%,436px);height:auto;min-height:unset;padding:.5rem}.logo-upload-preview--landing img{object-fit:contain;width:100%;height:100%;max-height:none}.landing-logo-config__checkbox{cursor:pointer;align-items:center;gap:.5rem;margin:0 0 1rem;font-weight:500;display:flex}.landing-logo-config__checkbox input{width:1rem;height:1rem;accent-color:var(--color-sky)}.logo-upload-preview--app img,.logo-upload-preview--icon img{max-width:96px;max-height:96px}.sidebar__user{border-bottom:1px solid #ffffff1a;padding:1rem 0}.sidebar__name{margin:0;font-size:.9rem;font-weight:600}.sidebar__role{color:var(--color-green);font-size:.75rem}.sidebar__nav{flex-direction:column;flex:1;gap:.25rem;margin-top:.75rem;display:flex;overflow-y:auto}.sidebar__link{color:#ffffffd9;border-radius:8px;align-items:center;gap:.65rem;padding:.65rem .75rem;font-size:.875rem;text-decoration:none;transition:background .15s;display:flex}.sidebar__link:hover{background:#ffffff1a}.sidebar__link--active{background:var(--color-green);color:var(--color-white)}.sidebar__group{flex-direction:column;display:flex}.sidebar__group-toggle{cursor:pointer;text-align:left;width:100%;font:inherit;background:0 0;border:none}.sidebar__group-toggle .sidebar__chevron{opacity:.75;margin-left:auto;transition:transform .2s}.sidebar__chevron--open{transform:rotate(180deg)}.sidebar__subnav{border-left:2px solid #ffffff26;flex-direction:column;gap:.15rem;margin:.15rem 0 .35rem .75rem;padding-left:.5rem;display:flex}.sidebar__sublink{color:#ffffffd1;border-radius:6px;align-items:center;gap:.5rem;padding:.45rem .65rem;font-size:.88rem;text-decoration:none;display:flex}.sidebar__sublink:hover{color:#fff;background:#ffffff14}.sidebar__sublink--active{color:#fff;background:#ffffff24;font-weight:600}.sidebar__logout{color:var(--color-white);cursor:pointer;background:0 0;border:1px solid #ffffff40;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;margin-top:auto;padding:.75rem;font-size:.85rem;display:flex}.sidebar__logout:hover{background:#ffffff14}.page{max-width:1200px}.page--wide{max-width:1280px}.contabilidad-kpis{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.contabilidad-kpi{flex-direction:column;gap:.25rem;display:flex}.contabilidad-kpi__label{color:var(--color-muted);font-size:.8rem;font-weight:500}.contabilidad-kpi__value{color:var(--color-navy);font-size:1.35rem}.contabilidad-section-title{color:var(--color-navy);margin:0 0 1rem;font-size:1.1rem}.contabilidad-hub{flex-direction:column;gap:.65rem;display:flex}.contabilidad-hub__card{border:1px solid var(--color-border);background:var(--color-surface,#fff);color:inherit;border-radius:10px;align-items:flex-start;gap:1rem;padding:1rem 1.1rem;text-decoration:none;transition:border-color .15s,box-shadow .15s;display:flex}.contabilidad-hub__card:hover{border-color:var(--color-sky);box-shadow:0 4px 14px #0f172a0f}.contabilidad-hub__icon{width:2.5rem;height:2.5rem;color:var(--color-primary,#2563eb);background:#2563eb1a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.contabilidad-hub__body{flex:1;min-width:0}.contabilidad-hub__body h3{color:var(--color-navy);margin:0 0 .35rem;font-size:1rem}.contabilidad-hub__body p{color:var(--color-muted);margin:0 0 .5rem;font-size:.88rem}.contabilidad-hub__arrow{color:var(--color-muted);flex-shrink:0;margin-top:.35rem}.contabilidad-submodule__head{flex-wrap:wrap;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.contabilidad-submodule__head h2{color:var(--color-navy);margin:0;font-size:1.35rem}.contabilidad-submodule__icon-wrap{width:3rem;height:3rem;color:var(--color-primary,#2563eb);background:#2563eb1a;border-radius:10px;justify-content:center;align-items:center;display:flex}.contabilidad-feature-list{color:var(--color-text,#334155);margin:0;padding-left:1.25rem}.contabilidad-feature-list li+li{margin-top:.35rem}.contabilidad-submodule__note{margin-top:1rem;font-size:.88rem}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.page-header h1{color:var(--color-navy);margin:0;font-size:1.75rem;font-style:italic}.page-header p{color:var(--color-muted);margin:.25rem 0 0}.module-subnav{border-bottom:1px solid var(--color-border);flex-wrap:wrap;gap:.35rem;margin-bottom:1.25rem;padding-bottom:.75rem;display:flex}.module-subnav__link{color:var(--color-muted);border:1px solid var(--color-border);background:var(--color-surface);border-radius:999px;padding:.45rem .9rem;font-size:.9rem;font-weight:500;text-decoration:none}.module-subnav__link:hover{color:var(--color-navy);border-color:var(--color-sky)}.module-subnav__link--active{background:var(--color-navy);border-color:var(--color-navy);color:#fff}.rol-card h3{color:var(--color-navy);margin:0}.rol-card--clickable{cursor:pointer;transition:box-shadow .15s,border-color .15s}.rol-card--clickable:hover,.rol-card--clickable:focus-visible{border-color:var(--color-sky);outline:none;box-shadow:0 4px 16px #0033661f}.rol-card--inactive{opacity:.72}.rol-card__header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.35rem;display:flex}.rol-card__edit-hint{color:var(--color-muted);white-space:nowrap;align-items:center;gap:.25rem;font-size:.78rem;display:inline-flex}.rol-card__meta{margin:.35rem 0 .5rem}.rol-card__actions{border-top:1px solid var(--color-border);flex-wrap:wrap;gap:.5rem;margin-top:1rem;padding-top:.75rem;display:flex}.rol-card__actions .btn{flex:auto}.rol-card__delete-hint{flex:100%;margin:0;font-size:.8rem}.page-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.page-toolbar__search{border:1px solid var(--color-border);border-radius:8px;flex:1;min-width:min(100%,280px);max-width:420px;padding:.55rem .65rem;font-family:inherit;font-size:.9rem}.features-picker__item--permiso{align-items:flex-start}.features-picker__permiso-text{text-align:left;flex-direction:column;align-items:flex-start;gap:.1rem;min-width:0;display:flex}.features-picker__permiso-text strong{font-size:.88rem;font-weight:600}.features-picker__permiso-text small{color:var(--color-muted);font-size:.75rem}.rol-card__permisos{flex-wrap:wrap;gap:.35rem;margin-top:.75rem;display:flex}.mb{margin-bottom:1rem}.header-actions{flex-wrap:wrap;gap:.5rem;display:flex}.card{background:var(--color-white);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.card__title{color:var(--color-navy);margin:0 0 1rem;font-size:1rem}.mt{margin-top:1rem}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.4rem;padding:.55rem 1.1rem;font-size:.875rem;font-weight:600;transition:opacity .15s,transform .1s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background:var(--color-navy);color:var(--color-white)}.btn--primary:hover:not(:disabled){background:var(--color-navy-dark)}.btn--secondary{background:var(--color-green);color:var(--color-white)}.btn--danger{background:var(--color-danger);color:var(--color-white)}.btn--ghost{color:var(--color-navy);border:1px solid var(--color-border);background:0 0}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{align-items:center;gap:1rem;display:flex}.stat-card svg{color:var(--color-navy);opacity:.8}.stat-card--navy svg{color:var(--color-navy)}.stat-card--green svg{color:var(--color-green)}.stat-card--sky svg{color:var(--color-sky)}.stat-value{color:var(--color-navy);font-size:1.5rem;font-weight:700;display:block}.stat-label{color:var(--color-muted);font-size:.8rem}.dashboard-grid{grid-template-columns:1.5fr 1fr;gap:1rem;display:grid}@media (width<=900px){.dashboard-grid{grid-template-columns:1fr}}.data-table{border-collapse:collapse;width:100%;font-size:.875rem}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--color-border);padding:.65rem .75rem}.data-table th{color:var(--color-navy);background:#f8fafc;font-weight:600}.select-inline{border:1px solid var(--color-border);border-radius:6px;max-width:160px;padding:.35rem .5rem;font-size:.8rem}.actions-cell{flex-wrap:wrap;gap:.35rem;display:flex}.plans-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;display:grid}.plan-card{background:var(--color-white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.plan-card--clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.plan-card--clickable:hover,.plan-card--clickable:focus-visible{box-shadow:var(--shadow-lg);outline:2px solid var(--color-sky);outline-offset:2px;transform:translateY(-2px)}.plan-card--inactive{opacity:.72}.plan-card--inactive .plan-card__header{filter:grayscale(.35)}.plan-card__header{color:#fff;padding:.75rem 1rem;position:relative}.plan-card__edit-hint{opacity:.85;align-items:center;gap:.25rem;font-size:.7rem;font-weight:600;display:inline-flex;position:absolute;top:.75rem;right:1rem}.plan-card__header span{letter-spacing:.08em;font-size:.7rem;font-weight:700}.plan-card__header h3{margin:.25rem 0 0;font-size:1.1rem}.plan-card--navy .plan-card__header{background:var(--color-navy)}.plan-card--green .plan-card__header{background:var(--color-green)}.plan-card--sky .plan-card__header{background:var(--color-sky)}.plan-card__body{padding:1.25rem}.plan-price{margin:0;font-size:1.75rem;font-weight:800}.plan-card--navy .plan-price{color:var(--color-navy)}.plan-card--green .plan-price{color:var(--color-green)}.plan-card--sky .plan-price{color:var(--color-sky)}.plan-duration{color:var(--color-muted);font-size:.85rem}.plan-features{margin:1rem 0 0;padding:0;list-style:none}.plan-features li{padding:.35rem 0;font-size:.875rem}.plan-card__actions{border-top:1px solid var(--color-border);flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}.plan-card__actions .btn{justify-content:center;align-items:center;gap:.35rem;width:100%;display:inline-flex}.inventario-desc{max-width:420px;margin:.25rem 0 0;font-size:.78rem}.inventario-thumb-cell{text-align:center;width:64px}.inventario-thumb{object-fit:cover;border:1px solid var(--color-border);border-radius:6px;width:44px;height:44px}.cards-row{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.estacion-card h3{color:var(--color-navy);margin:0 0 .5rem}.estacion-card--clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.estacion-card--clickable:hover,.estacion-card--clickable:focus-visible{box-shadow:var(--shadow-lg);outline:2px solid var(--color-sky);outline-offset:2px;transform:translateY(-2px)}.estacion-card--inactive{opacity:.72}.estacion-card__head{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.estacion-card__head h3{margin:0}.estacion-card__edit-hint{color:var(--color-muted);white-space:nowrap;align-items:center;gap:.25rem;font-size:.7rem;font-weight:600;display:inline-flex}.estacion-card__actions{border-top:1px solid var(--color-border);flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}.estacion-card__actions .btn{justify-content:center;align-items:center;gap:.35rem;width:100%;display:inline-flex}.ubicacion-section{margin-bottom:2rem}.ubicacion-section--inactive{opacity:.85}.ubicacion-section__head{border-bottom:2px solid var(--color-sky);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.75rem 1rem;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.ubicacion-section__title{color:var(--color-navy);margin:0;font-size:1.25rem}.ubicacion-section__title-btn{cursor:pointer;text-align:left;background:0 0;border:none;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;padding:0;display:inline-flex}.ubicacion-section__title-btn:hover .ubicacion-section__title,.ubicacion-section__title-btn:focus-visible .ubicacion-section__title{color:var(--color-sky)}.ubicacion-section__edit-hint{color:var(--color-muted);align-items:center;gap:.25rem;font-size:.7rem;font-weight:600;display:inline-flex}.ubicacion-section__desc{max-width:42rem;margin:.35rem 0 0}.ubicacion-section__actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.ubicacion-section__actions .btn{align-items:center;gap:.35rem;display:inline-flex}.ubicacion-section__empty{flex-direction:column;align-items:flex-start;gap:.75rem;display:flex}.ubicacion-section__empty p{margin:0}.ubicaciones-config__toolbar{margin-bottom:1rem}.ubicaciones-config__list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.ubicaciones-config__item{border:1px solid var(--color-border);background:var(--color-surface);border-radius:8px;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:1rem;display:flex}.ubicaciones-config__item--inactive{opacity:.75}.ubicaciones-config__item-main{flex:1;min-width:200px}.ubicaciones-config__desc{margin:.25rem 0}.ubicaciones-config__item-actions{flex-wrap:wrap;gap:.5rem;display:flex}.ubicaciones-config__item-actions .btn{align-items:center;gap:.35rem;display:inline-flex}.productos-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}.producto-card--clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.producto-card--clickable:hover,.producto-card--clickable:focus-visible{box-shadow:var(--shadow-lg);outline:2px solid var(--color-sky);outline-offset:2px;transform:translateY(-2px)}.producto-card--inactive{opacity:.72}.producto-card__main{align-items:flex-start;gap:1rem;display:flex}.producto-card__thumb{background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;display:flex;overflow:hidden}.producto-card__thumb img{object-fit:cover;width:100%;height:100%}.producto-card__placeholder{color:var(--color-muted);text-align:center;padding:.25rem;font-size:.65rem}.producto-card__info{flex:1;min-width:0}.producto-card__head{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.producto-card__head h3{color:var(--color-navy);margin:0 0 .35rem;font-size:1rem}.producto-card__edit-hint{color:var(--color-muted);white-space:nowrap;align-items:center;gap:.25rem;font-size:.7rem;font-weight:600;display:inline-flex}.producto-card__desc{color:var(--color-muted);margin:.25rem 0;font-size:.85rem}.producto-card__badges{flex-wrap:wrap;gap:.35rem;margin-top:.5rem;display:flex}.producto-card__actions{border-top:1px solid var(--color-border);flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}.producto-card__actions .btn{justify-content:center;align-items:center;gap:.35rem;width:100%;display:inline-flex}.producto-form-preview{flex-direction:column;align-items:flex-start;gap:.5rem;display:flex}.producto-form-preview img{object-fit:cover;border:1px solid var(--color-border);border-radius:8px;max-width:120px;max-height:120px}.proveedor-card h3{color:var(--color-navy);margin:0}.proveedor-card--clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.proveedor-card--clickable:hover,.proveedor-card--clickable:focus-visible{box-shadow:var(--shadow-lg);outline:2px solid var(--color-sky);outline-offset:2px;transform:translateY(-2px)}.proveedor-card--inactive{opacity:.72}.proveedor-card__head{justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.5rem;display:flex}.proveedor-card__edit-hint{color:var(--color-muted);white-space:nowrap;align-items:center;gap:.25rem;font-size:.7rem;font-weight:600;display:inline-flex}.proveedor-card__actions{border-top:1px solid var(--color-border);flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}.proveedor-card__actions .btn{justify-content:center;align-items:center;gap:.35rem;width:100%;display:inline-flex}.form-hint{font-size:.78rem;font-weight:400}.form-hint--error{color:var(--color-danger,#b91c1c)}.form-section-title{color:var(--color-text,#111);border-bottom:1px solid var(--color-border);margin:.5rem 0 0;padding-bottom:.35rem;font-size:.95rem;font-weight:600}.cliente-card{min-width:0}.cliente-card h3{overflow-wrap:anywhere;word-break:break-word;margin:0 0 .35rem;font-size:1.05rem}.cliente-card .muted{overflow-wrap:anywhere;word-break:break-word}.cliente-card__correo{margin:0}.cliente-card--clickable{cursor:pointer;transition:box-shadow .15s,border-color .15s}.cliente-card--clickable:hover,.cliente-card--clickable:focus-visible{border-color:var(--color-primary,#2563eb);outline:none;box-shadow:0 4px 14px #2563eb1f}.cliente-card--inactive{opacity:.72}.cliente-card__head{justify-content:space-between;align-items:flex-start;gap:.5rem;min-width:0;display:flex}.cliente-card__head h3{flex:1;min-width:0}.cliente-card__edit-hint{color:var(--color-muted,#6b7280);flex-shrink:0;align-items:center;gap:.25rem;font-size:.75rem;display:inline-flex}.cliente-card__actions{flex-wrap:wrap;gap:.5rem;margin-top:.75rem;display:flex}.cliente-card__actions .btn{flex:1;justify-content:center;min-width:7rem}.proveedor-card__condiciones{color:var(--color-muted);margin:.25rem 0;font-size:.85rem}.config-help{max-width:52rem;margin:0 0 1rem}.dns-instructions{border:1px solid var(--color-border);border-radius:var(--radius);background:#f8fafc;margin-top:1.25rem;padding:1rem 1.25rem}.dns-instructions h4{align-items:center;gap:.5rem;margin:0 0 .75rem;font-size:.95rem;display:flex}.dns-table{border-collapse:collapse;width:100%;max-width:36rem;margin:.75rem 0;font-size:.9rem}.dns-table th{text-align:left;color:var(--color-muted);vertical-align:top;width:8rem;padding:.35rem .75rem .35rem 0;font-weight:600}.dns-table td{padding:.35rem 0}.login-page{background:linear-gradient(135deg,#e8f0f8 0%,#f4f7fb 50%,#dceee4 100%);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.login-card{background:var(--color-white);border-radius:16px;width:100%;max-width:420px;overflow:hidden;box-shadow:0 12px 40px #0033661f}.login-card__brand{background:var(--color-navy);color:#fff;text-align:center;padding:2rem 1.5rem 1.5rem}.login-residencial{text-transform:uppercase;color:var(--color-green);letter-spacing:.05em;margin:0;font-size:.65rem}.login-tenant-hint{color:#ffffffd9;margin:.35rem 0 0;font-size:.72rem}.login-tenant-hint code{color:#fff;font-size:.72rem}.login-tag{text-transform:uppercase;letter-spacing:.04em;background:#ffffff26;border-radius:20px;padding:.35rem .85rem;font-size:.7rem;display:inline-block}.login-form{padding:1.5rem}.login-form h2{color:var(--color-navy);margin:0;font-size:1.25rem}.login-sub{color:var(--color-muted);margin:.25rem 0 1rem;font-size:.85rem}.login-form label{color:var(--color-text);margin-bottom:1rem;font-size:.85rem;font-weight:500;display:block}.login-form input{border:1px solid var(--color-border);border-radius:8px;width:100%;margin-top:.35rem;padding:.65rem .75rem;font-size:.95rem;display:block}.login-submit{justify-content:center;width:100%;margin-top:.5rem}.login-footer{text-align:center;color:var(--color-muted);background:#f8fafc;padding:1rem 1.5rem 1.25rem;font-size:.8rem}.login-footer__note{color:var(--color-sky);font-weight:600}.form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-grid label{flex-direction:column;gap:.35rem;font-size:.85rem;font-weight:500;display:flex}.form-grid input,.form-grid select,.form-grid textarea{border:1px solid var(--color-border);color:inherit;background-color:#fff;border-radius:8px;padding:.55rem .65rem;font-family:inherit;font-size:.9rem}.form-grid select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .65rem center;background-repeat:no-repeat;background-size:1rem;min-height:2.5rem;padding-right:2.25rem;line-height:1.35}.form-grid select:disabled{opacity:.65;cursor:not-allowed;background-color:#f8fafc}.form-full{grid-column:1/-1}.searchable-select{width:100%;position:relative}.searchable-select__trigger{border:1px solid var(--color-border);background:var(--color-surface,#fff);width:100%;min-height:2.35rem;color:inherit;text-align:left;cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:.55rem .65rem;font-family:inherit;font-size:.9rem;display:flex}.searchable-select--disabled .searchable-select__trigger{opacity:.6;cursor:not-allowed}.searchable-select__placeholder{color:var(--color-muted,#6b7280)}.searchable-select__icons{flex-shrink:0;align-items:center;gap:.25rem;margin-left:.5rem;display:flex}.searchable-select__clear{color:var(--color-muted,#6b7280);border-radius:4px;padding:2px;display:flex}.searchable-select__clear:hover{color:inherit;background:#0000000f}.searchable-select--open .searchable-select__chevron{transform:rotate(180deg)}.searchable-select__chevron{transition:transform .15s}.searchable-select__validator{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.searchable-select__dropdown{z-index:50;background:var(--color-surface,#fff);border:1px solid var(--color-border);border-radius:8px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden;box-shadow:0 8px 24px #0000001f}.searchable-select__search{border:none;border-bottom:1px solid var(--color-border);outline:none;width:100%;padding:.5rem .65rem;font-family:inherit;font-size:.9rem}.searchable-select__list{max-height:220px;margin:0;padding:.25rem 0;list-style:none;overflow-y:auto}.searchable-select__option{text-align:left;cursor:pointer;width:100%;color:inherit;background:0 0;border:none;flex-direction:column;align-items:flex-start;padding:.45rem .65rem;font-family:inherit;font-size:.88rem;display:flex}.searchable-select__option:hover,.searchable-select__option--selected{background:#2563eb14}.searchable-select__hint{color:var(--color-muted,#6b7280);font-size:.75rem}.searchable-select__empty{color:var(--color-muted,#6b7280);padding:.65rem;font-size:.85rem}.form-actions{justify-content:flex-end;gap:.5rem;display:flex}.checkbox-label{align-items:center;gap:.5rem;flex-direction:row!important}.checkbox-label input[type=checkbox]{width:auto}.features-picker{margin-top:.25rem}.features-picker__label{margin:0 0 .25rem;font-size:.85rem;font-weight:500}.features-picker__hint{margin:0 0 .75rem;font-size:.8rem}.features-picker__columns{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (width<=720px){.features-picker__columns{grid-template-columns:1fr}}.features-picker__panel{border:1px dashed var(--color-border);background:#f8fafc;border-radius:10px;min-height:220px;padding:.75rem;transition:border-color .15s,background .15s}.features-picker__panel--included{background:#f0f7fb}.features-picker__panel--active{border-color:var(--color-sky);background:#e8f4fa}.features-picker__panel h4{text-transform:uppercase;letter-spacing:.04em;color:var(--color-navy);margin:0 0 .65rem;font-size:.8rem}.features-picker__panel-head{margin-bottom:.75rem}.features-picker__panel-head h4{margin-bottom:.5rem}.features-picker__search{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-muted);border-radius:8px;align-items:center;gap:.45rem;padding:.45rem .65rem;display:flex}.features-picker__search:focus-within{border-color:var(--color-sky);box-shadow:0 0 0 2px #00336614}.features-picker__search input{min-width:0;font:inherit;color:var(--color-text);background:0 0;border:none;flex:1;padding:0}.features-picker__search input:focus{outline:none}.features-picker__search input::-webkit-search-cancel-button{display:none}.features-picker__search-clear{color:var(--color-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:.15rem;display:inline-flex}.features-picker__search-clear:hover{color:var(--color-navy);background:#0033660f}.features-picker__list{flex-direction:column;gap:.45rem;margin:0;padding:0;list-style:none;display:flex}.features-picker__empty{color:var(--color-muted);padding:.5rem 0;font-size:.85rem;font-style:italic}.features-picker__item{border:1px solid var(--color-border);text-align:left;cursor:grab;width:100%;color:inherit;background:#fff;border-radius:8px;align-items:center;gap:.4rem;padding:.55rem .65rem;font-family:inherit;font-size:.85rem;display:flex}.features-picker__item:active{cursor:grabbing}.features-picker__item--included{justify-content:space-between}.features-picker__item--included span{flex:1}.features-picker__remove{color:#c0392b;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:.2rem;display:inline-flex}.features-picker__remove:hover{background:#fdecea}.modal-overlay{z-index:200;background:#001e3c73;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius);background:#fff;width:100%;max-width:480px;max-height:90vh;overflow:auto;box-shadow:0 20px 60px #0003}.modal--wide{max-width:640px}.modal__header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.modal__header h2{color:var(--color-navy);margin:0;font-size:1.1rem}.modal__close{cursor:pointer;color:var(--color-muted);background:0 0;border:none}.modal__body{padding:1.25rem}.badge{color:var(--color-navy);background:#e8eef4;border-radius:6px;margin-right:.25rem;padding:.2rem .5rem;font-size:.7rem;font-weight:600;display:inline-block}.badge--success{color:var(--color-success);background:#e8f5e9}.badge--warning{color:var(--color-warning);background:#fff3e0}.badge--danger{color:var(--color-danger);background:#ffebee}.badge--info{color:var(--color-sky);background:#e3f2fd}.alert{border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.alert--error{color:var(--color-danger);background:#ffebee}.alert--success{color:var(--color-success);background:#e8f5e9}.alert--warning{color:#e65100;background:#fff8e1}.muted{color:var(--color-muted)}.empty-msg{text-align:center;padding:1rem 0}.link-more{margin-top:1rem;font-weight:600;text-decoration:none;display:inline-block}.info-list{margin:0;padding-left:1.25rem;line-height:1.8}.info-list__multiline{white-space:pre-line;margin-top:.15rem;display:block}.info-list__block{margin-left:-1.25rem;padding-left:0;list-style:none}.info-list__block strong{margin-bottom:.25rem;display:block}.info-list__line{margin-top:.2rem;padding-left:0;display:block}.loading{min-height:200px;color:var(--color-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.loading__spinner{border:3px solid var(--color-border);border-top-color:var(--color-navy);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.notif-list{flex-direction:column;gap:.75rem;display:flex}.notif-item--unread{border-left:4px solid var(--color-green)}.notif-item__head{justify-content:space-between;align-items:center;display:flex}.notif-item__head h3{margin:0;font-size:1rem}.table-actions{flex-wrap:wrap;gap:.35rem;display:flex}.table-actions .btn{align-items:center;gap:.25rem;padding:.35rem .6rem;font-size:.8rem;display:inline-flex}.data-table tr.row-inactive{opacity:.65}.horarios-empty{flex-direction:column;align-items:flex-start;gap:1rem;display:flex}.horarios-card-footer{border-top:1px solid var(--color-border);margin-top:1rem;padding-top:1rem}.horario-hero{align-items:center;gap:1.25rem;display:flex}.text-navy{color:var(--color-navy)}.disponibilidad-box{border:1px solid var(--color-border);background:#f8fafc;border-radius:8px;padding:.75rem 1rem}.disponibilidad-fin{margin:0 0 .5rem;font-size:.9rem}.disponibilidad-status{align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;display:flex}.disponibilidad-status--ok{color:var(--color-success)}.disponibilidad-status--error{color:var(--color-danger)}.disponibilidad-status--checking{color:var(--color-muted)}.modal--calendar{max-width:720px}.form-grid--reserva{grid-template-columns:1fr 1fr}.calendario-placeholder{text-align:center;border-radius:var(--radius);border:1px dashed var(--color-border);color:var(--color-muted);background:#f8fafc;padding:1.5rem}.calendario__header h3{color:var(--color-navy);margin:0 0 .25rem;font-size:1rem}.calendario__header p{margin:0 0 1rem;font-size:.8rem}.cal-nav{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.cal-nav__btn{border:1px solid var(--color-border);cursor:pointer;color:var(--color-navy);background:0 0;border-radius:8px;align-items:center;padding:.35rem;display:flex}.cal-nav__btn:hover{background:#f0f4f8}.cal-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.cal-weekday{text-align:center;color:var(--color-muted);padding:.25rem;font-size:.7rem;font-weight:600}.cal-day{aspect-ratio:1;border:1px solid var(--color-border);cursor:pointer;color:var(--color-text);background:#fff;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:2px;min-height:40px;padding:.15rem;font-size:.85rem;display:flex}.cal-day:disabled{cursor:not-allowed;opacity:.4;color:#999!important;background:#f0f0f0!important;border-color:#ddd!important}.cal-day--libre{color:#2e7d32;background:#e8f5e9;border-color:#66bb6a;font-weight:600}.cal-day--parcial{color:#e65100;background:#fff8e1;border-color:#ffb74d;font-weight:600}.cal-day--lleno{color:#c62828;background:#ffebee;border-color:#ef5350;font-weight:600}.cal-day--cerrado{color:#9e9e9e;background:#f5f5f5;border-color:#e0e0e0}.cal-day--libre:hover:not(:disabled),.cal-day--parcial:hover:not(:disabled),.cal-day--lleno:hover:not(:disabled),.cal-day--cerrado:hover:not(:disabled){filter:brightness(.95);box-shadow:0 2px 8px #00336626}.cal-leyenda-dias{flex-wrap:wrap;gap:.75rem 1.25rem;margin:.5rem 0 0;display:flex}.cal-leyenda-dias__item{border-radius:6px;padding:.25rem .6rem;font-size:.8rem;font-weight:600}.cal-leyenda-dias__item--libre{color:#2e7d32;background:#e8f5e9}.cal-leyenda-dias__item--parcial{color:#e65100;background:#fff8e1}.cal-leyenda-dias__item--lleno{color:#c62828;background:#ffebee}.cal-day--empty{cursor:default;background:0 0;border:none}.cal-day--today{border-color:var(--color-sky);font-weight:700}.cal-day--selected{border-color:var(--color-navy);box-shadow:0 0 0 2px var(--color-navy);background:#e8f0f8}.cal-day__num{line-height:1}.cal-day__dot{border-radius:50%;width:6px;height:6px}.cal-day__dot--libre{background:var(--color-green)}.cal-day__dot--parcial{background:var(--color-warning)}.cal-day__dot--lleno{background:var(--color-muted)}.cal-slots{border-top:1px solid var(--color-border);margin-top:1.25rem;padding-top:1rem}.cal-slots__date{color:var(--color-navy);text-transform:capitalize;margin:0 0 .75rem;font-weight:600}.cal-slots__count{color:var(--color-green);font-weight:500}.cal-slots__empty{font-size:.85rem}.cal-franja h4{color:var(--color-muted);align-items:center;gap:.4rem;margin:0 0 .5rem;font-size:.85rem;display:flex}.cal-franja{margin-bottom:1rem}.cal-franja__slots{flex-wrap:wrap;gap:.4rem;display:flex}.cal-slot{cursor:pointer;border:1px solid #0000;border-radius:8px;padding:.45rem .75rem;font-size:.8rem;font-weight:600;transition:transform .1s}.cal-slot--libre{color:var(--color-green-dark);background:#e8f5e9;border-color:#c8e6c9}.cal-slot--libre:hover{background:var(--color-green);color:#fff}.cal-slot--ocupado{color:var(--color-danger);background:#ffebee;border-color:#ffcdd2}.cal-slot--ocupado:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.cal-slot--selected{box-shadow:0 2px 8px #0033664d;background:var(--color-navy)!important;color:#fff!important;border-color:var(--color-navy)!important}.cal-leyenda{color:var(--color-muted);flex-wrap:wrap;gap:1rem;margin-top:1rem;font-size:.75rem;display:flex}.cal-leyenda span{align-items:center;gap:.35rem;display:flex}.cal-leyenda__dot{border-radius:3px;width:10px;height:10px;display:inline-block}.cal-leyenda__dot--libre{background:var(--color-green)}.cal-leyenda__dot--lleno,.cal-leyenda__dot--ocupado{background:var(--color-danger)}.cal-leyenda-inline{align-items:center;gap:.35rem;margin-right:1rem;font-size:.8rem;font-weight:600;display:inline-flex}.cal-leyenda-inline:before{content:"";border-radius:4px;width:12px;height:12px}.cal-leyenda-inline--libre:before{background:var(--color-green)}.cal-leyenda-inline--ocupado:before{background:var(--color-danger)}.cal-leyenda-inline--parcial:before{background:var(--color-warning)}.dia-estaciones__head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.dia-estaciones__head h2{color:var(--color-navy);text-transform:capitalize;margin:0;font-size:1.2rem}.station-grid-section{margin-bottom:1.5rem}.station-grid-section__title{color:var(--color-muted);align-items:center;gap:.4rem;margin:0 0 .75rem;font-size:.95rem;display:flex}.station-grid-wrap{overflow-x:auto}.station-grid{grid-template-columns:88px repeat(var(--station-cols,1), minmax(100px, 1fr));min-width:min(100%, calc(88px + var(--station-cols,1) * 120px));gap:4px;display:grid}.station-grid__head{text-align:center;color:var(--color-navy);background:#eef3f9;border-radius:6px;padding:.5rem .4rem;font-size:.75rem;font-weight:700}.station-grid__head--hora{text-align:left}.station-grid__hora{color:var(--color-text);align-items:center;padding:.5rem .35rem;font-size:.8rem;font-weight:600;display:flex}.station-grid__cell{cursor:pointer;border:1px solid #0000;border-radius:8px;min-height:44px;padding:.35rem;font-size:.75rem;font-weight:700;transition:transform .1s,box-shadow .15s}.station-grid__cell:hover{transform:scale(1.02);box-shadow:0 2px 8px #0000001a}.station-grid__cell--libre{color:var(--color-green-dark);background:#e8f5e9;border-color:#a5d6a7}.station-grid__cell--libre:hover{background:var(--color-green);color:#fff}.station-grid__cell--ocupado{color:var(--color-danger);background:#ffebee;border-color:#ffcdd2}.station-grid__cell--ocupado:hover{background:var(--color-danger);color:#fff}.horario-resumen{color:var(--color-navy);margin:0 0 .5rem;font-size:.9rem}.horario-resumen .muted{font-weight:400}.horario-resumen-lineas{margin:.35rem 0 0;padding:0;line-height:1.45;list-style:none}.horario-resumen-lineas li+li{margin-top:.2rem}.horario-resumen-lineas--compact{margin-top:.25rem;font-size:.85rem}.horario-resumen-lineas--inline{vertical-align:top;text-align:left;margin:0;display:inline-block}.horario-resumen-lineas--inline li{display:block}.horario-resumen-nota{margin:.5rem 0 0;font-size:.875rem}.login-footer__horario{text-align:left}.login-footer__horario strong{margin-bottom:.15rem;display:block}.hora-am-pm{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.hora-am-pm__select{min-width:4rem}.hora-am-pm__select.hora-am-pm__period{min-width:4.5rem}.hora-am-pm__sep{color:var(--color-navy);font-weight:600}.calendario--main{padding:.25rem 0}.card--calendario{padding:1.5rem}.filtro-servicio{flex-direction:column;gap:.35rem;font-size:.85rem;font-weight:500;display:flex}.filtro-servicio select{border:1px solid var(--color-border);border-radius:8px;min-width:220px;padding:.5rem .75rem}.reserva-detalle__back{color:var(--color-sky);cursor:pointer;background:0 0;border:none;align-items:center;gap:.4rem;margin-bottom:1rem;padding:0;font-size:.9rem;font-weight:600;display:inline-flex}.reserva-detalle__back:hover{text-decoration:underline}.reserva-detalle__head{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;padding-bottom:1rem;display:flex}.reserva-detalle__head h2{color:var(--color-navy);margin:0;font-size:1.25rem}.reserva-detalle__hora{color:var(--color-text);align-items:center;gap:.4rem;margin:.35rem 0 0;display:flex}.reserva-detalle__card{border:1px solid var(--color-border);border-radius:var(--radius);background:#fafbfc;margin-bottom:.75rem;padding:1rem}.reserva-detalle__meta{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.reserva-detalle__list{margin:0 0 1rem;padding:0;list-style:none}.reserva-detalle__list li{align-items:center;gap:.5rem;padding:.35rem 0;font-size:.9rem;display:flex}.reserva-detalle__actions{flex-wrap:wrap;gap:1rem;display:flex}.reserva-detalle__actions label{flex-direction:column;gap:.35rem;font-size:.8rem;font-weight:500;display:flex}.cal-slots__count{color:var(--color-muted);font-size:.85rem;font-weight:400}.cal-leyenda__dot--cerrado{background:#eee;border:1px solid #ddd}.spin{animation:.8s linear infinite spin}@media (width<=768px){.app-main{margin-left:0;padding-bottom:5rem}.sidebar{flex-flow:wrap;width:100%;height:auto;padding:.5rem;top:auto;bottom:0;left:0}.sidebar__brand,.sidebar__user,.sidebar__logout{display:none}.sidebar__nav{flex-direction:row;flex:1;margin:0;overflow-x:auto}.sidebar__link span{display:none}}.config-mobile-app__header{align-items:flex-start;gap:.75rem;margin-bottom:1rem;display:flex}.config-mobile-app__header h3{color:var(--color-navy);margin:0 0 .25rem}.checkbox-row{align-items:center;gap:.5rem;margin-bottom:1rem;font-weight:500;display:flex}.mobile-app-preview{background:#f8fafc;border-radius:8px;margin:1rem 0;padding:.75rem 1rem;font-size:.9rem}.mobile-app-branding__status{border-radius:var(--radius);border:1px solid var(--color-border);color:#5c4a00;background:#fff8e1;align-items:flex-start;gap:.65rem;margin-top:1.25rem;padding:.85rem 1rem;font-size:.9rem;display:flex}.mobile-app-branding__status--ok{color:#1b5e20;background:#e8f5e9;border-color:#a5d6a7}.mobile-app-branding__checklist{margin:0;padding-left:1.1rem}.mobile-app-readiness{border-radius:8px;margin:1rem 0;padding:.75rem 1rem}.mobile-app-readiness--ok{color:var(--color-success);background:#e8f5e9}.mobile-app-readiness--warn{color:#e65100;background:#fff8e1}.mobile-app-readiness ul{margin:.5rem 0 0;padding-left:1.25rem}.mobile-app-build-hint{border:1px dashed var(--color-border);background:#fafbfc;border-radius:8px;align-items:flex-start;gap:.75rem;margin:1rem 0;padding:1rem;display:flex}.code-block{color:#e8f0f8;background:#1a2b3c;border-radius:6px;margin:.5rem 0;padding:.65rem .75rem;font-size:.82rem;overflow-x:auto}.field-hint{color:var(--color-muted);margin-top:.25rem;font-size:.8rem;display:block}.theme-preset-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-top:.5rem;display:grid}.theme-preset-card{border:2px solid var(--color-border);text-align:left;cursor:pointer;background:#fff;border-radius:12px;flex-direction:column;gap:.5rem;padding:.85rem;transition:border-color .15s,box-shadow .15s;display:flex;position:relative}.theme-preset-card:hover:not(:disabled){border-color:var(--color-sky);box-shadow:0 4px 16px #00336614}.theme-preset-card--active{border-color:var(--color-green);box-shadow:0 0 0 1px var(--color-green)}.theme-preset-card:disabled{opacity:.7;cursor:wait}.theme-preset-card__badge{background:var(--color-green);color:#fff;border-radius:999px;justify-content:center;align-items:center;width:1.5rem;height:1.5rem;display:flex;position:absolute;top:.5rem;right:.5rem}.theme-preset-card__swatches{gap:.35rem;display:flex}.theme-preset-card__swatches span{border-radius:999px;flex:1;height:.55rem}.theme-preset-card__preview{border-radius:8px;gap:.35rem;padding:.65rem;display:flex}.theme-preset-card__preview span{border-radius:6px;flex:1;height:2rem}.theme-preset-card__name{color:var(--color-text);font-size:.92rem}.theme-preset-card__desc{color:var(--color-muted);margin:0;font-size:.78rem;line-height:1.4}.theme-preset-card__saving{color:var(--color-sky);font-size:.75rem}.personalizacion-tabs{flex-wrap:wrap;gap:.5rem;margin-top:1.25rem;display:flex}.personalizacion-tabs__btn{border:1px solid var(--color-border);font:inherit;color:var(--color-text);cursor:pointer;background:#fff;border-radius:999px;align-items:center;gap:.45rem;padding:.65rem 1.1rem;font-size:.875rem;font-weight:600;transition:background .15s,border-color .15s,color .15s;display:inline-flex}.personalizacion-tabs__btn:hover{border-color:var(--color-sky)}.personalizacion-tabs__btn--active{background:var(--color-navy);border-color:var(--color-navy);color:#fff}
