:root{--bg: #eef3fb;--surface: #ffffff;--surface-2: #e4edfb;--text: #0f2247;--muted: #5b6b8c;--primary: #2f6feb;--primary-hover: #1d52c4;--primary-deep: #0b2e6b;--primary-soft: #dbe8ff;--accent: #f5793a;--accent-hover: #dd5f1f;--accent-soft: #ffe4d3;--danger: #e0393e;--success: #16a34a;--border: #ccdcf7;--radius: 14px;--shadow: 0 2px 6px rgba(11, 46, 107, .08), 0 12px 28px rgba(11, 46, 107, .1);color-scheme:light}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;overflow-x:hidden}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);background-image:radial-gradient(circle at 12% -10%,rgba(47,111,235,.14),transparent 55%);color:var(--text);-webkit-font-smoothing:antialiased}a{color:var(--primary)}h1,h2,h3{letter-spacing:-.02em;font-weight:800;color:var(--primary-deep)}.center-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1rem;padding:max(1rem,env(safe-area-inset-top)) 1rem max(1rem,env(safe-area-inset-bottom))}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);max-width:100%}.center-screen{background-image:radial-gradient(circle at 50% 0%,rgba(47,111,235,.16),transparent 60%)}.login-card{width:100%;max-width:380px;border-top:4px solid var(--accent)}.login-card h1{margin:0 0 .25rem;font-size:1.6rem;color:var(--primary-deep)}.login-card p.subtitle{margin:0 0 1.5rem;color:var(--muted);font-size:.9rem}.public-solicitud-screen{align-items:flex-start;padding-top:max(1.5rem,env(safe-area-inset-top));padding-bottom:max(1.5rem,env(safe-area-inset-bottom))}.public-solicitud-card{width:100%;max-width:520px}.public-solicitud-card h1{margin:0 0 .25rem;font-size:1.5rem;color:var(--primary-hover)}.public-link-hint{margin:0 0 1rem;font-size:.85rem;color:var(--muted);word-break:break-all}.public-link-hint a{font-weight:500}.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.field label{font-size:.85rem;color:var(--muted)}.field-hint{margin:-.25rem 0 .75rem;font-size:.82rem;color:var(--muted);line-height:1.4}.ruta-motivo-no-entrega{margin:.25rem 0 0;font-size:.78rem;font-weight:500;color:var(--danger);line-height:1.3}.ruta-elementos-cell{font-size:.88rem;font-weight:600;min-width:120px}input,select{width:100%;padding:.75rem .9rem;font-size:1rem;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:10px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}select{padding-right:2.5rem;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-color:var(--surface);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1.1rem}input:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}button{width:100%;padding:.8rem 1rem;font-size:1rem;font-weight:700;color:#fff;background:linear-gradient(180deg,var(--primary) 0%,var(--primary-hover) 100%);border:none;border-radius:10px;cursor:pointer;box-shadow:0 2px 8px #1d52c440;transition:transform .1s ease,box-shadow .15s ease,background .15s ease}button:hover{background:linear-gradient(180deg,var(--primary-hover) 0%,var(--primary-deep) 100%);box-shadow:0 4px 12px #1d52c452}button:active{transform:translateY(1px)}button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}button.secondary{background:var(--surface-2);color:var(--primary-hover);box-shadow:none}button.secondary:hover{background:var(--primary-soft);box-shadow:none}button.accent{background:linear-gradient(180deg,var(--accent) 0%,var(--accent-hover) 100%);box-shadow:0 2px 8px #dd5f1f4d}button.accent:hover{background:linear-gradient(180deg,var(--accent-hover) 0%,#b6470f 100%);box-shadow:0 4px 12px #dd5f1f59}button.danger{background:var(--surface);color:var(--danger);border:1px solid #f6c6c8;box-shadow:none}button.danger:hover{background:#fdeced;border-color:var(--danger);box-shadow:none}.btn-icon-delete{width:auto;flex-shrink:0;padding:.45rem .6rem;font-size:1rem;line-height:1;background:var(--surface);color:var(--danger);border:1px solid #f6c6c8;box-shadow:none}.btn-icon-delete:hover{background:#fdeced;border-color:var(--danger);box-shadow:none}.error{color:var(--danger);font-size:.85rem;margin:0 0 1rem}.success{color:var(--success);font-size:.85rem;margin:0 0 1rem}.app-shell{min-height:100dvh;display:flex;flex-direction:column;width:100%;max-width:100vw;overflow-x:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;padding-top:max(.75rem,env(safe-area-inset-top));padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));background:linear-gradient(180deg,#fff,#f3f8ff);border-bottom:1px solid var(--border);box-shadow:0 1px #0b2e6b0a;position:sticky;top:0;z-index:20}.topbar:before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--accent) 0%,var(--primary) 45%,var(--primary-deep) 100%)}.topbar-left{display:flex;align-items:center;gap:.75rem;min-width:0;flex:1}.topbar-left .brand{order:2;flex:1}.desktop-nav{display:none;order:3}.topbar .brand{font-weight:700;font-size:.95rem;color:var(--primary-hover);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar .user-info{display:flex;align-items:center;gap:.4rem;font-size:.85rem;flex-shrink:0}.topbar .user-info .name{color:var(--muted);display:none}.topbar .user-info button.secondary{width:auto;padding:.45rem .75rem;font-size:.8rem}.nav-toggle{display:flex;align-items:center;justify-content:center;flex-shrink:0;order:1;width:2.5rem;height:2.5rem;padding:0;color:var(--text);background:var(--surface-2);border:1px solid var(--border);border-radius:10px;cursor:pointer}.nav-toggle:hover{background:var(--primary-soft);color:var(--primary-hover)}.nav-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;width:100%;background:#0f172a66;border:none;padding:0;cursor:pointer}.sidebar{position:fixed;top:0;left:0;z-index:50;width:min(300px,88vw);height:100dvh;display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--border);box-shadow:4px 0 24px #0f172a1f;transform:translate(-105%);transition:transform .25s ease;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.sidebar.open{transform:translate(0)}.sidebar-header{padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--primary-deep) 0%,var(--primary) 100%)}.sidebar-brand{font-weight:800;font-size:1.1rem;color:#fff}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem;padding:1rem}.nav-link{display:block;padding:.85rem 1rem;border-radius:10px;color:var(--text);text-decoration:none;font-weight:500;font-size:1rem;transition:background .15s ease,color .15s ease}.nav-link:hover{background:var(--surface-2);color:var(--primary-hover)}.nav-link.active{background:var(--primary-soft);color:var(--primary-hover);font-weight:700;box-shadow:inset 3px 0 0 var(--accent)}.badge{display:inline-block;padding:.2rem .65rem;border-radius:999px;font-size:.75rem;font-weight:700;background:var(--primary-soft);color:var(--primary-hover);text-transform:capitalize;letter-spacing:.01em}.badge.pendiente,.badge.en_ruta{background:var(--accent-soft);color:var(--accent-hover)}.badge.entregado{background:#dcf5e3;color:var(--success)}.badge.no_entregado{background:#fbdcdd;color:var(--danger)}.content{width:100%;max-width:900px;margin:0 auto;padding:1.25rem 1rem;padding-bottom:max(1.25rem,env(safe-area-inset-bottom));min-width:0}.content h2{margin-top:0;font-size:1.35rem}.content h3{font-size:1.05rem}.table-wrap{width:100%;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.65rem .75rem;border-bottom:1px solid var(--border);font-size:.85rem;white-space:nowrap}th{color:var(--primary-deep);font-weight:700;background:var(--surface-2);border-bottom:2px solid var(--primary-soft)}tbody tr:hover{background:var(--surface-2)}tr:last-child td{border-bottom:none}.row-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.row-actions button{width:auto}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card{display:flex;flex-direction:column;gap:.25rem;padding:1rem;border-top:3px solid var(--primary)}.stat-card:nth-child(4n+2){border-top-color:var(--accent)}.stat-card:nth-child(4n+3){border-top-color:var(--success)}.stat-value{font-size:1.75rem;font-weight:800;color:var(--primary-deep);letter-spacing:-.02em}.stat-label{font-size:.8rem;color:var(--muted)}@media(min-width:640px){.stats-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:900px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.parada-card{margin-bottom:1rem}.parada-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap}.maps-btn{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:2.75rem;height:2.75rem;margin-left:auto;border-radius:10px;background:var(--primary-soft);color:var(--primary-hover);text-decoration:none;transition:background .15s ease,color .15s ease}.maps-btn:hover{background:var(--primary);color:#fff}.parada-fields{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem;margin:0 0 1rem}.entrega-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.entrega-nombre{flex:1;font-size:.9rem;min-width:0}.entrega-row .elemento-cantidad{max-width:6rem;flex-shrink:0}.page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.page-header h2{margin:0}.btn-nuevo{width:auto;padding:.55rem 1rem;font-size:.9rem;flex-shrink:0}.btn-compact{width:auto;padding:.5rem .85rem;font-size:.85rem}.detail-list{display:grid;gap:.85rem;margin:0}.detail-list dt{font-size:.8rem;font-weight:600;color:var(--muted);margin-bottom:.15rem}.detail-list dd{margin:0}.card-header-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.card-header-row h3{margin:0;font-size:1.05rem}.solicitud-form-card{margin-bottom:1.5rem}.elemento-row{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.elemento-row:last-of-type{border-bottom:none}.elemento-cantidad{max-width:100%}.list-count{margin:0 0 .75rem;font-size:.85rem;color:var(--muted)}.filter-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.filter-tab{width:auto;padding:.45rem .85rem;font-size:.85rem;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:999px;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.filter-tab:hover{border-color:var(--primary)}.filter-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.search-bar{margin-bottom:.75rem}.search-input{width:100%}.solicitud-list{display:flex;flex-direction:column;gap:.75rem}.solicitud-card{display:block;text-decoration:none;color:inherit;transition:border-color .15s ease,box-shadow .15s ease;padding:1rem}.solicitud-card:hover{border-color:var(--primary);box-shadow:0 2px 12px #2563eb1a}.solicitud-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.85rem}.solicitud-card-info{min-width:0;flex:1}.solicitud-card-info strong{display:block;font-size:1.05rem;margin-bottom:.2rem}.solicitud-card-direccion{margin:0;font-size:.88rem;color:var(--muted);line-height:1.4}.solicitud-card-entrega{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:.75rem;margin-bottom:.85rem}.solicitud-card-entrega-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.6rem}.solicitud-card-entrega-label{font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--primary-deep)}.solicitud-card-entrega-total{font-size:.78rem;font-weight:600;color:var(--muted)}.solicitud-card-sin-items{margin:0;font-size:.85rem;color:var(--muted);font-style:italic}.solicitud-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.5rem;list-style:none;margin:0;padding:0}.solicitud-item{display:flex;align-items:center;gap:.55rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:.55rem .65rem;min-width:0}.solicitud-item--plato{border-left:3px solid var(--accent)}.solicitud-item--insumo{border-left:3px solid var(--primary)}.solicitud-item-qty{flex-shrink:0;font-size:1.35rem;font-weight:800;line-height:1;color:var(--primary-deep);min-width:1.75rem;text-align:center}.solicitud-item-name{font-size:.88rem;font-weight:600;line-height:1.25;color:var(--text);overflow:hidden;text-overflow:ellipsis}.solicitud-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-size:.85rem}.solicitud-card-telefono{color:var(--muted)}.solicitud-card-link{font-size:.85rem;font-weight:600;color:var(--primary);margin-left:auto}.solicitud-card-footer-actions{display:flex;align-items:center;gap:.6rem;margin-left:auto}.solicitud-card-footer-actions .solicitud-card-link{margin-left:0}@media(min-width:640px){.elemento-row{flex-direction:row;flex-wrap:wrap;align-items:center;border-bottom:none;padding-bottom:0}.elemento-row select,.elemento-row .elemento-cantidad{max-width:110px;flex-shrink:0}.elemento-row input:not(.elemento-cantidad){flex:1;min-width:140px}}@media(min-width:768px){.topbar{padding-left:max(1.5rem,env(safe-area-inset-left));padding-right:max(1.5rem,env(safe-area-inset-right))}.topbar-left{gap:2rem}.topbar-left .brand{order:1;flex:0 1 auto}.desktop-nav{order:2}.topbar .brand{font-size:1rem}.topbar .user-info{gap:.75rem;font-size:.9rem}.topbar .user-info .name{display:inline}.topbar .user-info button.secondary{padding:.5rem .9rem;font-size:.85rem}.nav-toggle,.nav-overlay,.sidebar{display:none}.desktop-nav{display:flex;align-items:center;gap:.35rem}.desktop-nav .nav-link{padding:.5rem .9rem;font-size:.9rem}th,td{padding:.7rem .9rem;font-size:.9rem}}@media(min-width:640px){.content{padding:2rem}}
