*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#333}a{color:inherit;text-decoration:none}.navbar{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#fff;box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:10}.logo{font-size:1.4rem;font-weight:700}.cart-link{font-weight:600;background:#111;color:#fff;padding:.5rem 1rem;border-radius:6px}.container{max-width:1200px;margin:2rem auto;padding:0 1rem}h1{margin-bottom:1.5rem}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.product-card{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 2px 8px #00000014;transition:transform .2s}.product-card:hover{transform:translateY(-4px)}.product-card img{width:100%;height:220px;object-fit:cover}.product-card h3{padding:.75rem 1rem 0}.product-card .price{padding:.25rem 1rem;font-weight:700;color:#2d7d46;font-size:1.1rem}.product-card button{width:calc(100% - 2rem);margin:.75rem 1rem;padding:.6rem;border:none;background:#111;color:#fff;border-radius:6px;cursor:pointer;font-size:.95rem}.product-card button:hover{background:#333}.product-detail{max-width:900px;margin:0 auto}.product-detail>a{display:inline-block;margin-bottom:1rem;color:#666}.detail-layout{display:flex;gap:2rem;background:#fff;border-radius:10px;padding:2rem;box-shadow:0 2px 8px #00000014}.detail-layout img{width:400px;height:400px;object-fit:cover;border-radius:8px}.detail-layout h1{margin-bottom:.5rem}.detail-layout .price{font-size:1.5rem;font-weight:700;color:#2d7d46;margin:.5rem 0}.detail-layout .stock{color:#666;margin-bottom:1rem}.detail-layout button{padding:.75rem 2rem;border:none;background:#111;color:#fff;border-radius:6px;cursor:pointer;font-size:1rem}.detail-layout button:disabled{background:#ccc;cursor:not-allowed}.cart-items{display:flex;flex-direction:column;gap:1rem}.cart-item{display:flex;align-items:center;gap:1rem;background:#fff;padding:1rem;border-radius:8px;box-shadow:0 1px 4px #0000000f}.cart-item img{width:80px;height:80px;object-fit:cover;border-radius:6px}.cart-item-info{flex:1}.cart-item-actions{display:flex;align-items:center;gap:.5rem}.cart-item-actions button{width:32px;height:32px;border:1px solid #ddd;background:#fff;border-radius:6px;cursor:pointer;font-size:1rem}.cart-item-actions .remove{border-color:#e55;color:#e55}.cart-item-actions span{min-width:24px;text-align:center}.cart-total{margin-top:2rem;text-align:right}.cart-total button{margin-top:.75rem;padding:.75rem 2rem;border:none;background:#111;color:#fff;border-radius:6px;cursor:pointer;font-size:1rem}.checkout-layout{display:flex;gap:2rem}.checkout-form{flex:1;background:#fff;padding:2rem;border-radius:10px;box-shadow:0 2px 8px #00000014;display:flex;flex-direction:column;gap:1rem}.checkout-form input{padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.checkout-form button{padding:.75rem;border:none;background:#2d7d46;color:#fff;border-radius:6px;cursor:pointer;font-size:1.1rem;font-weight:600}.checkout-form button:disabled{background:#aaa}.error{color:#e55}.order-summary{width:350px;background:#fff;padding:2rem;border-radius:10px;box-shadow:0 2px 8px #00000014;height:fit-content}.summary-item{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #eee}.summary-total{display:flex;justify-content:space-between;padding-top:1rem;font-size:1.1rem}.confirmation{max-width:600px;margin:0 auto;background:#fff;padding:2rem;border-radius:10px;box-shadow:0 2px 8px #00000014;text-align:center}.confirmation h1{color:#2d7d46}.confirmation p{margin:.5rem 0}.confirmation button{margin-top:1.5rem;padding:.75rem 2rem;border:none;background:#111;color:#fff;border-radius:6px;cursor:pointer}.order-items-list{text-align:left;margin-top:1.5rem}@media (max-width: 768px){.detail-layout{flex-direction:column}.detail-layout img{width:100%;height:300px}.checkout-layout{flex-direction:column}.order-summary{width:100%}.product-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}
