:root{color:#111827;background:#f5f7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.45;--brand: #243c96;--brand-strong: #17215f;--brand-soft: #e8edff;--line: #d8deea;--surface: #ffffff;--danger: #a43b2b}*{box-sizing:border-box}body{margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;padding-bottom:84px}.topbar{position:sticky;top:0;z-index:2;display:flex;align-items:center;justify-content:space-between;min-height:58px;padding:0 16px;color:#111827;background:var(--surface);border-bottom:1px solid var(--line);box-shadow:0 4px 18px #1118271f}.brand,.bottom-nav a{color:inherit;text-decoration:none}.brand{display:inline-flex;align-items:center}.brand img{display:block;width:auto;height:40px}.topbar-actions{display:inline-flex;align-items:center;gap:8px}.topbar-badge{min-height:30px;padding:5px 9px;color:var(--brand);text-decoration:none;border-radius:999px;background:var(--brand-soft);font-size:.78rem;font-weight:900}main{width:min(100%,780px);margin:0 auto;padding:18px 14px 28px}.bottom-nav{position:fixed;right:0;bottom:0;left:0;z-index:3;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));width:100%;max-width:100vw;overflow:hidden;min-height:64px;color:#34433f;background:#fff;border-top:1px solid var(--line)}.bottom-nav.has-admin-link{grid-template-columns:repeat(5,minmax(0,1fr))}.bottom-nav a{display:grid;gap:3px;place-items:center;min-width:0;padding:8px 4px 7px;overflow:hidden;font-size:.72rem;font-weight:800;line-height:1}.bottom-nav a span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bottom-nav a.router-link-active{color:var(--brand);background:var(--brand-soft)}.page-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 16px}.page-title h1{margin:0;font-size:1.55rem}.card,.form-panel,.empty-state{border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:0 8px 26px #11182712}.card{padding:14px}.stack,.grid{display:grid;gap:12px}.form-panel{display:grid;gap:14px;padding:16px}.field{display:grid;gap:6px}.field label,.label{color:#475955;font-size:.88rem;font-weight:700}.field input:not([type=checkbox]),.field select,.field textarea{width:100%;min-height:44px;padding:10px 12px;color:#16221f;border:1px solid #cbd3df;border-radius:7px;background:#fff}.field input[type=checkbox]{width:18px;min-width:18px;height:18px;margin:0;accent-color:var(--brand)}.field textarea{min-height:104px;resize:vertical}.readonly-value{min-height:44px;margin:0;padding:10px 12px;border:1px solid #cbd3df;border-radius:7px;background:#f8fbf9;font-weight:800}.error{color:#a43b2b;font-size:.88rem}.button-row{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.section-label{display:flex;align-items:baseline;justify-content:space-between;gap:10px}.choice-list{display:grid;gap:8px}.choice-list.scroll{max-height:260px;overflow:auto}.selection-list{display:grid;gap:8px}.selection-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;min-height:46px;padding:10px 12px;text-align:left;color:#253834;border:1px solid #cbd3df;border-radius:7px;background:#fff}.selection-row.is-selected{color:var(--brand-strong);border-color:var(--brand);background:var(--brand-soft)}.selection-state{color:var(--brand);font-size:.78rem;font-weight:900}.choice-row{display:grid;grid-template-columns:22px minmax(0,1fr);gap:10px;align-items:center;min-height:46px;padding:10px 12px;color:#253834;border:1px solid #cbd3df;border-radius:7px;background:#fff}.choice-row.is-selected{color:var(--brand-strong);border-color:var(--brand);background:var(--brand-soft)}.choice-row:focus-within{outline:3px solid rgba(36,60,150,.22);outline-offset:2px}.choice-input{width:22px;min-width:22px;height:22px;accent-color:var(--brand)}.choice-name{min-width:0;overflow-wrap:anywhere;font-weight:800}.selected-list{display:flex;flex-wrap:wrap;gap:8px}.selected-chip{display:inline-flex;align-items:center;gap:6px;max-width:100%;min-height:32px;padding:0 10px;color:var(--brand-strong);border:1px solid #b8c3ee;border-radius:999px;background:var(--brand-soft);font-weight:800}.selected-chip span{min-width:0;overflow-wrap:anywhere}.selected-chip svg{flex:0 0 auto}.search-hint{margin-top:-2px}.acompanantes-results{gap:6px}.acompanante-row{min-height:38px;padding:7px 10px}.acompanante-row .choice-name{font-size:.95rem}.icon-state{justify-content:center;width:28px;min-width:28px;height:28px;color:var(--brand);border-radius:999px;background:var(--brand-soft)}.acompanante-row.is-selected .icon-state{color:#fff;background:var(--brand)}.file-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:44px;padding:0 14px;color:var(--brand);border:1px solid #b8c3ee;border-radius:7px;background:var(--brand-soft);font-weight:900}.field label.file-button{color:var(--brand);cursor:pointer}.photo-grid{display:grid;gap:10px}.photo-item{display:grid;grid-template-columns:86px minmax(0,1fr);gap:10px;align-items:center;padding:8px;border:1px solid var(--line);border-radius:8px;background:#f8fbf9}.photo-item img{width:86px;aspect-ratio:1;object-fit:cover;border-radius:7px}.photo-item span{min-width:0;overflow-wrap:anywhere;font-weight:800}.thumb-strip{display:flex;flex-wrap:wrap;gap:8px}.thumb-button{width:86px;height:86px;padding:0;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#fff}.thumb-button img{width:100%;height:100%;object-fit:cover}.button-row.compact{grid-column:1 / -1;gap:6px}.error-summary{padding:10px 12px;color:#7a2b20;border:1px solid #e4b2a7;border-radius:7px;background:#fff3f0;font-weight:800}.primary-button,.secondary-button,.danger-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;border:0;border-radius:7px;font-weight:800}.primary-button{padding:0 15px;color:#fff;background:var(--brand)}.secondary-button{padding:0 15px;color:var(--brand);background:var(--brand-soft)}.danger-button{padding:0 15px;color:#fff;background:var(--danger)}.icon-button{width:42px;color:var(--brand);background:var(--brand-soft)}.badge{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:999px;color:var(--brand);background:var(--brand-soft);font-size:.78rem;font-weight:800}.meta{color:#5c6b67;font-size:.9rem}.empty-state{padding:22px;text-align:center}.scroll-sentinel{min-height:1px}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;place-items:center;padding:18px;background:#111827d1}.lightbox img{max-width:min(100%,900px);max-height:88vh;border-radius:8px;background:#fff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10;display:grid;place-items:center;padding:18px;background:#11182785}.modal-card{width:min(100%,440px);padding:18px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 20px 60px #0c18143d}.modal-card h2{margin:0 0 6px}.modal-card p{margin:0}.toast{position:fixed;right:14px;bottom:78px;left:14px;z-index:30;padding:12px 14px;border-radius:8px;color:#fff;box-shadow:0 14px 34px #1118273d;font-weight:800}.toast-exito{background:#17663a}.toast-error{background:var(--danger)}.login-page{min-height:calc(100vh - 120px);align-content:center}.login-logo{justify-self:center;width:min(220px,78vw);height:auto}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.field input.sr-only{position:absolute;width:1px;min-width:0;height:1px;min-height:0;padding:0;overflow:hidden;border:0}.line-list{display:grid;gap:10px}.line-list.compact{margin:0;padding-left:18px}.line-item,.summary-row{display:grid;gap:10px;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff}.input-with-suffix{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px}.input-with-suffix span{min-width:34px;color:var(--muted);font-weight:800}.line-summary{display:grid;gap:8px}@media(min-width:680px){.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}}
