:root{--dark:#111b18;--green:#15b86a;--green2:#1edb82;--cream:#f4f2ea;--muted:#77817c;--line:#e7ebe7;--card:#ffffff;--shadow:0 18px 45px rgba(17,27,24,.10);--radius:24px}*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:linear-gradient(135deg,#f6f4ed,#eef8f2);color:#18231f}a{text-decoration:none;color:inherit}.app-body{display:flex;min-height:100vh}.sidebar{width:280px;background:linear-gradient(180deg,#0f1b17,#14241f);color:white;padding:22px;position:fixed;height:100vh;overflow:auto}.brand{display:flex;gap:12px;align-items:center;margin-bottom:26px}.brand-icon{width:52px;height:52px;border-radius:18px;background:linear-gradient(135deg,var(--green),#e9ff69);display:grid;place-items:center;color:#082018;font-weight:900}.brand span{display:block;color:#b7c4bd;font-size:13px}.sidebar nav{display:grid;gap:8px}.sidebar a{padding:13px 14px;border-radius:16px;color:#dce8e1}.sidebar a:hover{background:rgba(255,255,255,.08);transform:translateX(3px)}.main{margin-left:280px;width:calc(100% - 280px);padding:28px}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.topbar h1{margin:0;font-size:32px}.topbar p{margin:4px 0;color:var(--muted)}.user-pill{background:white;padding:12px 16px;border-radius:999px;box-shadow:var(--shadow)}.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.card{background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.75);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}.stat b{display:block;font-size:28px}.stat span{color:var(--muted)}.btn{border:0;border-radius:15px;padding:12px 16px;font-weight:800;cursor:pointer;background:#17221e;color:white;display:inline-flex;gap:8px;align-items:center}.btn.green{background:linear-gradient(135deg,var(--green),var(--green2));color:#092116}.btn.light{background:white;color:#18231f;border:1px solid var(--line)}.btn.danger{background:#ef4444}.table{width:100%;border-collapse:separate;border-spacing:0 10px}.table th{text-align:left;color:var(--muted);font-size:13px}.table td{background:white;padding:14px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.table td:first-child{border-left:1px solid var(--line);border-radius:16px 0 0 16px}.table td:last-child{border-right:1px solid var(--line);border-radius:0 16px 16px 0}.form{display:grid;gap:12px}.form.two{grid-template-columns:repeat(2,1fr)}input,select,textarea{width:100%;padding:13px 14px;border:1px solid #dce5df;border-radius:15px;background:white;font:inherit}textarea{min-height:90px}.label{font-size:13px;font-weight:800;color:#53615b}.product-img{width:58px;height:58px;border-radius:16px;object-fit:cover;background:#eef3ef}.pos-layout{display:grid;grid-template-columns:1.5fr .9fr;gap:20px}.product-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.p-card{background:white;border-radius:22px;padding:14px;border:1px solid var(--line);box-shadow:0 10px 25px rgba(0,0,0,.05);cursor:pointer}.p-card:hover{transform:translateY(-3px)}.p-card img{width:100%;height:130px;border-radius:18px;object-fit:cover;background:#eef3ef}.p-card h4{margin:10px 0 4px}.muted{color:var(--muted)}.cart-line{display:flex;justify-content:space-between;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}.total{font-size:28px;font-weight:900}.login-wrap{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 20% 10%,#bcffd8,transparent 30%),linear-gradient(135deg,#101b17,#1c3029)}.login-card{width:min(430px,92vw);background:white;border-radius:30px;padding:34px;box-shadow:0 30px 80px rgba(0,0,0,.28)}.login-card h1{margin-top:0}.store-body{background:#f7f5ed}.store-hero{background:linear-gradient(135deg,#0f1b17,#20392f);color:white;border-radius:0 0 42px 42px;padding:32px 7vw 58px}.store-nav{display:flex;justify-content:space-between;align-items:center}.store-hero h1{font-size:52px;max-width:760px;margin:45px 0 12px}.store-container{padding:34px 7vw}.store-layout{display:grid;grid-template-columns:1fr 390px;gap:22px}.store-products{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.store-card{background:white;border-radius:28px;padding:16px;box-shadow:var(--shadow)}.store-card img{width:100%;height:190px;border-radius:22px;object-fit:cover;background:#eef3ef}.badge{background:#eafff2;color:#0b7b43;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:900}.alert{padding:14px 16px;border-radius:16px;background:#eafff2;border:1px solid #bff4d2;margin-bottom:14px}.low{color:#ef4444;font-weight:900}@media(max-width:1000px){.sidebar{position:static;width:100%;height:auto}.app-body{display:block}.main{margin:0;width:100%}.grid,.product-grid,.store-products,.store-layout,.pos-layout{grid-template-columns:1fr}.form.two{grid-template-columns:1fr}.store-hero h1{font-size:36px}}
/* Mejoras de catálogo, detalles y carrito */
.store-tools{display:grid;gap:16px;margin-bottom:24px}.category-pills{display:flex;gap:10px;flex-wrap:wrap}.pill{border:1px solid var(--line);background:white;color:#33413b;border-radius:999px;padding:10px 16px;font-weight:800;cursor:pointer}.pill.active,.pill:hover{background:var(--green);color:#082018;border-color:transparent}.store-card{display:flex;flex-direction:column;overflow:hidden;padding:0;transition:.25s ease}.store-card:hover{transform:translateY(-6px);box-shadow:0 24px 55px rgba(17,27,24,.15)}.product-photo-wrap{position:relative;padding:14px 14px 0}.store-card img,.p-card img{display:block}.store-card-body{display:flex;flex-direction:column;flex:1;padding:16px}.store-card h3{font-size:21px;margin:10px 0 6px}.product-description{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:42px;line-height:1.45;color:#6a766f;margin:5px 0 12px}.stock-chip{position:absolute;top:24px;right:24px;background:rgba(17,27,24,.88);color:white;padding:7px 10px;border-radius:999px;font-size:11px;font-weight:900;backdrop-filter:blur(8px)}.card-price-row{margin-top:auto;padding-top:6px}.card-price-row small,.p-card-footer small{display:block;color:var(--muted);font-size:11px}.card-price-row strong,.p-card-footer b{display:block;font-size:25px;margin-top:3px}.card-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}.card-actions .btn{justify-content:center;padding:12px 10px}.order-panel{position:sticky;top:20px;height:max-content}.order-panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.order-panel-head h2{margin:2px 0}.eyebrow{font-size:11px;letter-spacing:.14em;font-weight:900;color:var(--green)}.cart-count{display:grid;place-items:center;min-width:42px;height:42px;padding:0 12px;border-radius:999px;background:#eafff2;color:#087942;font-weight:900}.store-cart-list{max-height:390px;overflow:auto;padding-right:4px}.empty-cart{display:flex;flex-direction:column;gap:5px;align-items:center;text-align:center;padding:30px 12px;color:var(--muted);border:1px dashed #cbd8d0;border-radius:18px}.empty-cart b{color:#33413b}.cart-product{display:grid;grid-template-columns:58px minmax(0,1fr) auto;gap:11px;align-items:center;padding:12px 0;border-bottom:1px solid var(--line)}.cart-product img{width:58px;height:58px;object-fit:cover;border-radius:14px;background:#eef3ef}.cart-product-info{min-width:0}.cart-product-info b,.cart-product-info span{display:block}.cart-product-info b{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-product-info span{font-size:12px;color:var(--muted);margin:3px 0 7px}.qty-controls{display:flex;align-items:center;gap:7px}.qty-controls button{width:28px;height:28px;border:1px solid var(--line);background:white;border-radius:9px;font-weight:900;cursor:pointer}.qty-controls .remove-link{width:auto;border:0;background:none;color:#df3d3d;font-size:11px}.line-total{font-size:14px}.order-summary{display:flex;justify-content:space-between;align-items:end;padding:15px 0 8px;border-top:2px solid #edf1ee;margin-top:8px}.order-summary .total{margin:0}.full-btn{width:100%;justify-content:center}.product-modal{display:none;position:fixed;inset:0;z-index:1000;align-items:center;justify-content:center;padding:20px}.product-modal.open{display:flex}.modal-backdrop{position:absolute;inset:0;background:rgba(6,18,13,.72);backdrop-filter:blur(8px)}.product-modal-card{position:relative;width:min(860px,96vw);background:white;border-radius:30px;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;box-shadow:0 35px 100px rgba(0,0,0,.35);z-index:1}.product-modal-card>img{width:100%;height:100%;min-height:430px;object-fit:cover;background:#eef3ef}.modal-content{padding:38px;display:flex;flex-direction:column}.modal-content h2{font-size:34px;margin:16px 0 10px}.modal-description{font-size:16px;line-height:1.65;color:#65716b}.modal-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}.modal-meta span{background:#f2f5f3;border-radius:12px;padding:9px 11px;font-size:12px;font-weight:800}.modal-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:25px}.modal-footer strong{font-size:30px}.modal-close{position:absolute;right:18px;top:18px;width:42px;height:42px;border:0;border-radius:50%;background:white;box-shadow:0 8px 24px rgba(0,0,0,.15);font-size:27px;cursor:pointer;z-index:2}.modal-open{overflow:hidden}.toast{position:fixed;right:24px;bottom:24px;z-index:2000;background:#10251d;color:white;padding:14px 18px;border-radius:15px;box-shadow:0 18px 50px rgba(0,0,0,.25);transform:translateY(20px);opacity:0;transition:.25s}.toast.show{transform:translateY(0);opacity:1}.pos-search-row{display:flex;gap:12px;align-items:center}.scanner-hint{white-space:nowrap;background:#eafff2;color:#087942;padding:11px 13px;border-radius:14px;font-size:12px;font-weight:900}.p-card{display:flex;flex-direction:column;padding:0;overflow:hidden;transition:.22s}.p-card .product-photo-wrap{padding:12px 12px 0}.p-card .badge{margin:12px 12px 0;align-self:flex-start}.p-card h4{font-size:18px;margin:10px 12px 3px}.p-card .product-description{margin:0 12px 12px}.p-card-footer{display:flex;justify-content:space-between;align-items:end;margin-top:auto;padding:12px;border-top:1px solid var(--line)}.mini-add{width:44px;height:44px;border:0;border-radius:14px;background:linear-gradient(135deg,var(--green),var(--green2));font-size:25px;font-weight:900;cursor:pointer;color:#092116}.pos-checkout{position:sticky;top:20px;height:max-content}
@media(max-width:700px){.card-actions{grid-template-columns:1fr}.product-modal-card{grid-template-columns:1fr;max-height:92vh;overflow:auto}.product-modal-card>img{min-height:240px;height:260px}.modal-content{padding:25px}.modal-footer{gap:15px}.store-nav{align-items:flex-start;gap:15px}.store-nav>div:last-child{display:grid;gap:8px}.cart-product{grid-template-columns:50px minmax(0,1fr)}.line-total{grid-column:2}.pos-search-row{align-items:stretch;flex-direction:column}.scanner-hint{text-align:center}}
