:root{--primary-color:#198754;--primary-hover:#157347;--secondary-color:#6c757d;--success-color:#198754;--danger-color:#dc3545;--warning-color:#ffc107;--info-color:#0dcaf0;--light-color:#f8f9fa;--dark-color:#212529}body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;min-height:100vh;display:flex;flex-direction:column}main{flex:1}.navbar-brand{font-weight:700}.navbar-nav .nav-link{font-weight:500;padding:.5rem 1rem}.navbar-nav .nav-link:hover{color:var(--primary-color)}.product-card{transition:all .3s ease;overflow:hidden}.product-card:hover{box-shadow:0 .5rem 1rem rgba(0,0,0,.15)!important;transform:translateY(-5px)}.product-card .card-img-top{transition:transform .3s ease}.product-card:hover .card-img-top{transform:scale(1.05)}.btn-success{background-color:var(--primary-color);border-color:var(--primary-color)}.btn-success:hover{background-color:var(--primary-hover);border-color:var(--primary-hover)}.btn-outline-success{color:var(--primary-color);border-color:var(--primary-color)}.btn-outline-success:hover{background-color:var(--primary-color);border-color:var(--primary-color)}.badge{font-weight:500}.form-control:focus{border-color:var(--primary-color);box-shadow:0 0 0 .25rem rgba(25,135,84,.25)}.form-check-input:checked{background-color:var(--primary-color);border-color:var(--primary-color)}.pagination .page-link{color:var(--primary-color)}.pagination .page-item.active .page-link{background-color:var(--primary-color);border-color:var(--primary-color)}footer{margin-top:auto}footer a:hover{color:var(--primary-color)!important}.hero-section{min-height:400px;display:flex;align-items:center}@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}.fade-in{animation:fadeIn .5s ease-out}.hover-shadow{transition:box-shadow .3s ease}.hover-shadow:hover{box-shadow:0 .5rem 1rem rgba(0,0,0,.15)!important}.cart-item{transition:background-color .3s ease}.cart-item:hover{background-color:#f8f9fa}.admin-sidebar{min-height:calc(100vh - 56px);background-color:#343a40}.admin-sidebar .nav-link{color:rgba(255,255,255,.75);padding:.75rem 1rem}.admin-sidebar .nav-link:hover,.admin-sidebar .nav-link.active{color:#fff;background-color:rgba(255,255,255,.1)}.stat-card{border-left:4px solid var(--primary-color)}.stat-card.success{border-left-color:var(--success-color)}.stat-card.warning{border-left-color:var(--warning-color)}.stat-card.danger{border-left-color:var(--danger-color)}.stat-card.info{border-left-color:var(--info-color)}.table th{font-weight:600;background-color:#f8f9fa}.modal-header{background-color:var(--primary-color);color:#fff}.modal-header .btn-close{filter:invert(1)}.text-success{color:var(--primary-color)!important}.bg-success{background-color:var(--primary-color)!important}@media (max-width:768px){.hero-section{min-height:300px;text-align:center}.hero-section h1{font-size:2rem}.product-card .card-img-top{height:150px}}@media print{.no-print,.navbar,footer,.btn{display:none!important}.container{width:100%;max-width:none}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}::selection{background-color:rgba(25,135,84,.3)}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.loading{position:relative;pointer-events:none}.loading::after{content:'';position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid #f3f3f3;border-top:2px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.leaflet-bottom.leaflet-right{display:none}@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}@media (max-width:768px){.btn{min-height:44px;padding:12px 20px;font-size:16px}.form-control,.form-select{min-height:44px;font-size:16px}.navbar-collapse{max-height:80vh;overflow-y:auto}.navbar-nav{padding:1rem 0}.nav-link{padding:12px 16px!important;font-size:18px}.navbar .input-group{margin:1rem 0}.navbar .btn-outline-success{width:100%;margin-top:1rem;justify-content:center}.filters-sidebar{position:fixed;left:-100%;top:0;width:85%;max-width:320px;height:100vh;background:#fff;z-index:1050;transition:left .3s ease;overflow-y:auto;box-shadow:2px 0 10px rgba(0,0,0,.1)}.filters-sidebar.show{left:0}.filters-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:1040;display:none}.filters-overlay.show{display:block}.mobile-filters-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #ddd;position:sticky;top:0;background:#fff;z-index:10}.mobile-filters-close{background:none;border:none;font-size:24px;cursor:pointer;padding:0;width:40px;height:40px}.filters-body{padding:1rem}.mobile-filters-footer{position:sticky;bottom:0;background:#fff;padding:1rem;border-top:1px solid #ddd;display:flex;gap:10px}.mobile-filters-footer .btn{flex:1}}.mobile-filters-toggle{display:none}@media (max-width:768px){.mobile-filters-toggle{display:flex;position:fixed;bottom:80px;right:20px;width:60px;height:60px;border-radius:50%;background:#198754;color:#fff;border:none;box-shadow:0 4px 12px rgba(0,0,0,.3);z-index:1030;align-items:center;justify-content:center;font-size:24px}.mobile-filters-toggle:active{transform:scale(.95)}}@media (max-width:576px){.product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.product-card{padding:10px}.product-card img{height:150px;object-fit:cover}.product-card .card-title{font-size:14px;line-height:1.3;max-height:2.6em;overflow:hidden}.product-card .price{font-size:16px}}@media (max-width:768px){.product-images-gallery{margin-bottom:1rem}.product-main-image{height:300px;object-fit:cover}.product-thumbnails{display:flex;gap:10px;overflow-x:auto;padding:10px 0;-webkit-overflow-scrolling:touch}.product-thumbnail{flex:0 0 80px;height:80px}.product-info{padding:1rem}.product-title{font-size:20px;margin-bottom:1rem}.product-price{font-size:28px;margin-bottom:1rem}.product-actions{position:fixed;bottom:0;left:0;width:100%;background:#fff;padding:15px;box-shadow:0 -2px 10px rgba(0,0,0,.1);z-index:1020;display:flex;gap:10px}.product-actions .btn{flex:1}.cart-item{flex-direction:column;align-items:flex-start}.cart-item-image{width:100%;max-width:150px;margin-bottom:1rem}.cart-item-info{width:100%}.cart-summary{position:sticky;bottom:0;background:#fff;padding:1rem;box-shadow:0 -2px 10px rgba(0,0,0,.1)}.checkout-steps{display:flex;overflow-x:auto;margin-bottom:1rem;-webkit-overflow-scrolling:touch}.checkout-step{flex:0 0 auto;padding:10px 20px;white-space:nowrap}.order-summary{position:sticky;bottom:0;background:#fff;padding:1rem;box-shadow:0 -2px 10px rgba(0,0,0,.1)}.form-check-input{width:24px;height:24px;margin-top:0}.form-check-label{padding-left:10px;font-size:16px}.form-select{background-size:20px 20px;padding-right:40px}.quantity-control{display:flex;align-items:center;gap:10px}.quantity-control button{width:44px;height:44px;padding:0;font-size:20px}.quantity-control input{width:60px;text-align:center;font-size:18px}.mobile-bottom-nav{position:fixed;bottom:0;left:0;width:100%;height:65px;background:#fff;border-top:1px solid #ddd;display:flex;justify-content:space-around;align-items:center;z-index:1010;box-shadow:0 -2px 10px rgba(0,0,0,.1)}.mobile-bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#666;text-decoration:none;flex:1;padding:8px}.mobile-bottom-nav a.active,.mobile-bottom-nav a:hover{color:#198754}.mobile-bottom-nav i{font-size:24px;margin-bottom:4px}.mobile-bottom-nav span{font-size:11px}body{padding-bottom:65px}.swipeable-gallery{position:relative;overflow:hidden;touch-action:pan-y}.swipeable-gallery-track{display:flex;transition:transform .3s ease}.swipeable-gallery-item{flex:0 0 100%;width:100%}.swipeable-gallery-dots{display:flex;justify-content:center;gap:8px;padding:10px 0}.swipeable-gallery-dot{width:8px;height:8px;border-radius:50%;background:#ddd;border:none;padding:0;cursor:pointer}.swipeable-gallery-dot.active{background:#198754}.pull-to-refresh{position:absolute;top:-60px;left:50%;transform:translateX(-50%);width:40px;height:40px;display:flex;align-items:center;justify-content:center;transition:top .3s ease}.pull-to-refresh.pulling{top:10px}.pull-to-refresh .spinner{border:3px solid #f3f3f3;border-top:3px solid #198754;border-radius:50%;width:30px;height:30px;animation:spin 1s linear infinite}}@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}@media (max-width:768px){h1{font-size:24px}h2{font-size:20px}h3{font-size:18px}h4{font-size:16px}body{font-size:14px}.desktop-only{display:none!important}}.mobile-only{display:none!important}@media (max-width:768px){.mobile-only{display:block!important}.mobile-only.inline{display:inline!important}.mobile-only.flex{display:flex!important}}