*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--white: #ffffff;--bg: #f5f5f5;--bg-2: #ffffff;--bg-3: #f0f0f0;--border: #e5e7eb;--border-2: #d1d5db;--text: #111827;--text-2: #4b5563;--text-3: #9ca3af;--navy: #1e3a5f;--navy-h: #152d4a;--accent: #2563eb;--accent-h: #1d4ed8;--accent-light: #eff6ff;--green: #16a34a;--green-light: #f0fdf4;--red: #dc2626;--red-light: #fef2f2;--yellow: #d97706;--yellow-light: #fffbeb;--radius: 6px;--radius-lg: 10px;--radius-xl: 16px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow: 0 2px 10px rgba(0,0,0,.09);--shadow-hover: 0 6px 20px rgba(0,0,0,.13);--transition: all .18s ease;font-size:15px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font:inherit}input,select,textarea{font:inherit;background:var(--white);border:1.5px solid var(--border-2);border-radius:var(--radius);color:var(--text);padding:.65rem 1rem;width:100%;transition:var(--transition);font-size:.9rem}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a}input::placeholder{color:var(--text-3)}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.65rem 1.4rem;border-radius:var(--radius);font-weight:600;font-size:.9rem;transition:var(--transition);white-space:nowrap}.btn-primary{background:var(--navy);color:#fff}.btn-primary:hover:not(:disabled){background:var(--navy-h)}.btn-secondary{background:var(--white);color:var(--text);border:1.5px solid var(--border-2)}.btn-secondary:hover:not(:disabled){background:var(--bg-3)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(.9)}.btn-sm{padding:.4rem .9rem;font-size:.82rem}.btn-lg{padding:.85rem 2rem;font-size:1rem}.btn:disabled{opacity:.45;cursor:not-allowed}.card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm)}.badge{display:inline-block;padding:.2rem .65rem;border-radius:99px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-pending{background:#fef3c7;color:#92400e}.badge-confirmed{background:#dbeafe;color:#1e40af}.badge-ready{background:#d1fae5;color:#065f46}.badge-completed{background:#f3f4f6;color:#374151}.badge-cancelled{background:#fee2e2;color:#991b1b}.spinner{width:1.5rem;height:1.5rem;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-label{font-size:.85rem;font-weight:600;color:var(--text-2)}.form-error{font-size:.8rem;color:var(--red)}.page-container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.page-title{font-size:1.6rem;font-weight:700;margin-bottom:1.5rem}.grid-products{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem}.announcement-bar{background:var(--navy);color:#ffffffe0;text-align:center;padding:.5rem 1rem;font-size:.78rem;font-weight:500;letter-spacing:.03em}.site-header{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}.header-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:68px;display:flex;align-items:center;gap:1.25rem}.header-logo{font-size:1.25rem;font-weight:800;color:var(--navy);letter-spacing:-.5px;white-space:nowrap;flex-shrink:0}.header-logo span{color:var(--accent)}.header-search{flex:1;max-width:480px;position:relative}.header-search input{padding-left:2.5rem;border-radius:24px;background:var(--bg);font-size:.88rem}.search-icon{position:absolute;left:.85rem;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:.85rem;pointer-events:none}.header-actions{display:flex;align-items:center;gap:.25rem;margin-left:auto}.header-link{display:flex;flex-direction:column;align-items:center;padding:.4rem .6rem;border-radius:var(--radius);font-size:.72rem;font-weight:500;color:var(--text-2);transition:var(--transition);line-height:1.3;white-space:nowrap}.header-link:hover{background:var(--bg-3);color:var(--text)}.header-link svg,.header-link .icon{font-size:1.1rem}.cart-link{display:flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border-radius:var(--radius);background:var(--navy);color:#fff!important;font-size:.85rem;font-weight:600;transition:var(--transition);position:relative}.cart-link:hover{background:var(--navy-h);color:#fff}.cart-count{background:var(--accent);color:#fff;border-radius:99px;padding:0 .4rem;font-size:.68rem;font-weight:700;min-width:18px;text-align:center;line-height:18px;height:18px;display:inline-flex;align-items:center;justify-content:center}.cat-nav{background:var(--white);border-bottom:1px solid var(--border)}.cat-nav-inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:flex;gap:0;overflow-x:auto;scrollbar-width:none}.cat-nav-inner::-webkit-scrollbar{display:none}.cat-btn{padding:.75rem 1.1rem;font-size:.84rem;font-weight:500;color:var(--text-2);white-space:nowrap;border-bottom:2px solid transparent;transition:var(--transition);cursor:pointer}.cat-btn:hover{color:var(--navy)}.cat-btn.cat-active{color:var(--navy);border-bottom-color:var(--navy);font-weight:600}.product-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow .2s ease,transform .2s ease;display:flex;flex-direction:column}.product-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px)}.product-img-wrap{width:100%;aspect-ratio:1;overflow:hidden;position:relative}.product-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e0e7ff,#dbeafe,#e0f2fe);font-size:3.5rem}.product-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.product-card:hover .product-img-wrap img{transform:scale(1.04)}.product-body{padding:.9rem 1rem 1rem;flex:1;display:flex;flex-direction:column}.product-cat{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--accent);margin-bottom:.3rem}.product-name{font-size:.9rem;font-weight:600;color:var(--text);line-height:1.35;margin-bottom:.5rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.product-price-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem}.product-price{font-size:1.1rem;font-weight:700;color:var(--text)}.stock-tag{font-size:.72rem;font-weight:500}.in-stock{color:var(--green)}.out-of-stock{color:var(--red)}.add-cart-btn{width:100%;padding:.6rem;border-radius:var(--radius);border:none;background:var(--navy);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--transition)}.add-cart-btn:hover:not(:disabled){background:var(--navy-h)}.add-cart-btn.btn-added{background:var(--green)}.add-cart-btn:disabled{opacity:.4;cursor:not-allowed}.page-hero{background:linear-gradient(135deg,var(--navy) 0%,#2563eb 100%);color:#fff;padding:2.5rem 1.5rem;margin-bottom:0}.page-hero-inner{max-width:1200px;margin:0 auto}.page-hero h1{font-size:1.8rem;font-weight:800;margin-bottom:.3rem}.page-hero p{font-size:.9rem;opacity:.8}.breadcrumb{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--text-3);margin-bottom:1.5rem}.breadcrumb a{color:var(--accent)}.breadcrumb a:hover{text-decoration:underline}.breadcrumb-sep{color:var(--border-2)}.auth-wrap{min-height:calc(100vh - 120px);display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:var(--bg)}.auth-card{width:100%;max-width:440px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow)}.auth-logo-text{font-size:1.4rem;font-weight:800;color:var(--navy);letter-spacing:-.5px}.auth-logo-text span{color:var(--accent)}.auth-error{background:var(--red-light);border:1px solid #fecaca;border-radius:var(--radius);padding:.7rem 1rem;font-size:.85rem;color:#991b1b;margin-bottom:1rem}.order-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer;transition:box-shadow .15s ease,border-color .15s ease}.order-card:hover{box-shadow:var(--shadow);border-color:var(--border-2)}.trust-row{display:flex;gap:1.5rem;flex-wrap:wrap;padding:1rem 0;border-top:1px solid var(--border);margin-top:1rem}.trust-item{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-2)}.trust-item .ti{font-size:1rem}.site-footer{background:var(--navy);color:#ffffffb3;margin-top:4rem;padding:2rem 1.5rem}.footer-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-logo{font-size:1rem;font-weight:800;color:#fff}.footer-logo span{color:#60a5fa}.footer-copy{font-size:.78rem}.leaflet-container{border-radius:var(--radius-lg)}
