*{box-sizing:border-box;margin:0;padding:0}*{scrollbar-width:thin;scrollbar-color:var(--muted-foreground) var(--muted)}*::-webkit-scrollbar{width:8px;height:8px}*::-webkit-scrollbar-track{background:var(--muted);border-radius:4px}*::-webkit-scrollbar-thumb{background:var(--muted-foreground);border-radius:4px;border:2px solid var(--muted)}*::-webkit-scrollbar-thumb:hover{background:var(--primary)}:root{--background: hsl(0, 0%, 98%);--foreground: hsl(220, 15%, 20%);--card: hsl(0, 0%, 100%);--card-foreground: hsl(220, 15%, 20%);--primary: #C46754;--primary-foreground: hsl(0, 0%, 100%);--secondary: hsl(220, 15%, 94%);--muted: hsl(220, 10%, 96%);--muted-foreground: hsl(220, 10%, 45%);--accent: hsl(145, 60%, 45%);--destructive: hsl(0, 84%, 60%);--border: hsl(220, 15%, 88%);--radius: .75rem;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--background);color:var(--foreground);min-height:100vh;padding:2rem 1rem;line-height:1.5}.container{max-width:1024px;margin:0 auto}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--border);overflow:hidden}.header{background:var(--muted);color:var(--primary-foreground);padding:1rem;text-align:center;border-bottom:1px solid #ddd}.header h1{font-size:1.25rem;font-weight:700;color:#000}.content{padding:1rem}.step-indicator{padding:1.5rem;border-bottom:1px solid var(--border);background:linear-gradient(to bottom,var(--muted),transparent)}.step-indicator-mobile{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.5rem}.step-indicator-mobile .step-label{font-size:.875rem;color:var(--muted-foreground)}.step-indicator-mobile .step-current{font-size:.875rem;font-weight:700;color:var(--primary)}.steps-container{display:flex;align-items:center;justify-content:space-between;position:relative;max-width:600px;margin:0 auto}.step-line{position:absolute;left:2rem;right:2rem;top:50%;transform:translateY(-50%);height:4px;background:var(--muted);border-radius:2px;z-index:0}.step-line-progress{position:absolute;left:2rem;top:50%;transform:translateY(-50%);height:4px;background:linear-gradient(90deg,var(--primary),var(--primary));border-radius:2px;z-index:1;transition:width .5s ease-out}.step{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .3s}.step:hover:not(.step-upcoming){transform:scale(1.1)}.step-upcoming{cursor:not-allowed}.step-circle{width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;transition:all .3s}.step-completed .step-circle{background:var(--primary);color:var(--primary-foreground);box-shadow:0 4px 6px #2563eb4d}.step-current .step-circle{background:var(--primary);color:var(--primary-foreground);box-shadow:0 0 0 4px #2563eb33,0 4px 6px #2563eb66;transform:scale(1.1)}.step-upcoming .step-circle{background:var(--muted);color:var(--muted-foreground);border:2px solid var(--border)}.step-title{margin-top:.5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:none}.step-completed .step-title{color:var(--primary)}.step-current .step-title{color:var(--foreground)}.step-upcoming .step-title{color:var(--muted-foreground)}.step-subtitle{font-size:.625rem;margin-top:.125rem;display:none}.step-completed .step-subtitle{color:var(--primary);opacity:.7}.step-current .step-subtitle{color:var(--muted-foreground)}@media(min-width:640px){.step-indicator-mobile{display:none}.step-title,.step-subtitle{display:block}.step-circle{width:3rem;height:3rem}}.search-container{position:relative;margin-bottom:1rem}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1.25rem;height:1.25rem;color:var(--muted-foreground)}.search-input{width:100%;height:3rem;padding:0 1rem 0 2.5rem;font-size:1rem;border:1px solid var(--border);border-radius:.5rem;background:var(--card);color:var(--foreground);transition:border-color .2s,box-shadow .2s}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.search-input::placeholder{color:var(--muted-foreground)}.category-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media(min-width:768px){.category-grid{grid-template-columns:repeat(3,1fr)}}@media(min-width:1024px){.category-grid{grid-template-columns:repeat(4,1fr)}}.category-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem;background:var(--muted);border:2px solid transparent;border-radius:var(--radius);cursor:pointer;transition:all .2s;min-height:120px}.category-card:hover{background:var(--primary);border-color:var(--primary)}.category-card:hover .category-icon,.category-card:hover .category-name{color:var(--primary-foreground)}.category-icon{width:2rem;height:2rem;margin-bottom:.5rem;color:var(--primary);transition:color .2s}.category-name{font-weight:600;font-size:.875rem;text-align:center;color:var(--foreground);transition:color .2s;line-height:1.2}.category-count{font-size:.875rem;color:var(--muted-foreground);margin-top:.25rem;transition:color .2s}.category-card:hover .category-count{color:var(--primary-foreground);opacity:.8}.product-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.product-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.product-grid{grid-template-columns:repeat(3,1fr);height:128vh;overflow:auto}.product-card{height:456px}}.product-card{background:var(--card);border:2px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:all .2s}.product-card.in-cart{border-color:var(--primary);box-shadow:var(--shadow-lg)}.product-image-container{position:relative;aspect-ratio:1;background:var(--muted);overflow:hidden}.product-image{width:100%;height:100%;object-fit:cover}.product-qty-badge{position:absolute;top:.5rem;right:.5rem;width:2rem;height:2rem;background:var(--primary);color:var(--primary-foreground);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem}.product-info{padding:1rem}.product-name{font-weight:600;color:var(--foreground);margin-bottom:.25rem;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.product-description{font-size:.875rem;color:var(--muted-foreground);margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-footer{display:flex;align-items:center;justify-content:space-between}.product-price{font-size:1.125rem;font-weight:700;color:var(--primary)}.qty-controls{display:flex;align-items:center;gap:.25rem}.qty-btn{width:2rem;height:2rem;border:1px solid var(--border);background:var(--card);border-radius:.375rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.qty-btn:hover{background:var(--muted)}.qty-value{width:1.5rem;text-align:center;font-weight:700;font-size:.875rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;border-radius:.5rem;border:none;cursor:pointer;transition:all .2s}.btn-primary{background:var(--primary);color:var(--primary-foreground)}.btn-primary:hover{filter:brightness(1.1)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-outline{background:transparent;color:var(--foreground);border:1px solid var(--border)}.btn-outline:hover{background:var(--muted)}.btn-ghost{background:transparent;color:var(--foreground)}.btn-ghost:hover{background:var(--muted)}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-lg{padding:1rem 2rem;font-size:1rem}.btn-full{width:100%}.back-btn{margin-bottom:.5rem}.breadcrumb{background:var(--muted);border-radius:.5rem;padding:.75rem 1rem;margin-bottom:1rem}.breadcrumb-label{font-size:.875rem;color:var(--muted-foreground)}.breadcrumb-value{font-weight:600;color:var(--foreground)}.cart-summary{background:var(--muted);border-radius:.5rem;padding:1rem;margin-top:1rem}.cart-title{font-weight:600;margin-bottom:.5rem}.cart-items{font-size:.875rem}.cart-item{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0;gap:.5rem}.cart-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cart-item-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.cart-remove-btn{display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem;padding:0;border:none;background:transparent;color:var(--muted-foreground);font-size:1rem;line-height:1;cursor:pointer;border-radius:50%;transition:all .2s}.cart-remove-btn:hover{background:var(--destructive);color:#fff}.cart-total{display:flex;justify-content:space-between;border-top:1px solid var(--border);margin-top:.5rem;padding-top:.5rem;font-weight:700}.cart-total-price{color:var(--primary)}.form-section{margin-top:1rem}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.form-title{font-size:1.125rem;font-weight:600}.form-required-legend{font-size:.75rem;color:var(--muted-foreground)}.form-required-legend .asterisk{color:var(--destructive)}.form-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:640px){.form-grid{grid-template-columns:1fr 1fr;gap:1.5rem}}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group.full-width{grid-column:1/-1}.form-label{font-size:.875rem;font-weight:500}.form-label .asterisk{color:var(--destructive)}.form-label.optional{color:var(--muted-foreground)}.form-label .optional-text{font-size:.75rem;font-weight:400}.form-input{height:2.75rem;width:100%;padding:0 .75rem;font-size:.875rem;border:1px solid var(--border);border-radius:.375rem;background:var(--card);color:var(--foreground);transition:border-color .2s,box-shadow .2s}@media(min-width:640px){.form-input{height:3rem}}.form-input::placeholder{color:var(--muted-foreground)}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.submit-btn{margin-top:1.5rem;height:3.5rem;font-size:1rem}.error-message{background:#ef44441a;border:1px solid var(--destructive);color:var(--destructive);padding:.75rem 1rem;border-radius:.375rem;font-size:.875rem;margin-top:1rem}.confirmation-header{text-align:center;padding:1rem 0}.confirmation-icon{width:3rem;height:3rem;color:var(--accent);margin:0 auto .75rem}.confirmation-title{font-size:1.25rem;font-weight:700;color:var(--foreground)}.confirmation-subtitle{font-size:.875rem;color:var(--muted-foreground);margin-top:.25rem}.invoice{border:1px solid var(--border);border-radius:.5rem;overflow:hidden;margin-top:1.5rem}.invoice-header{background:var(--muted);padding:.75rem 1rem;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem}@media(min-width:640px){.invoice-header{flex-direction:row;align-items:center;justify-content:space-between}}.invoice-company h3{font-weight:700;font-size:.875rem}.invoice-company p{font-size:.75rem;color:var(--muted-foreground)}.invoice-meta{text-align:left}@media(min-width:640px){.invoice-meta{text-align:right}}.invoice-number{font-family:monospace;font-size:.875rem}.invoice-date{font-size:.75rem;color:var(--muted-foreground)}.invoice-body{padding:1rem}.invoice-billing{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}@media(min-width:640px){.invoice-billing{flex-direction:row;justify-content:space-between}}.invoice-billing-label{font-size:.75rem;color:var(--muted-foreground);margin-bottom:.25rem}.invoice-billing-name{font-weight:500;font-size:.875rem}.invoice-billing-detail{font-size:.75rem;color:var(--muted-foreground)}.invoice-status{display:inline-block;padding:.25rem .5rem;background:#2563eb1a;color:var(--accent);font-size:.75rem;font-weight:500;border-radius:.25rem}.invoice-items{border-top:1px solid var(--border);padding-top:.75rem}.invoice-item{display:flex;justify-content:space-between;align-items:flex-start;padding:.25rem 0;font-size:.875rem;gap:.5rem}.invoice-item-left{display:flex;align-items:flex-start;gap:.5rem;flex:1;min-width:0}.invoice-item-num{color:var(--muted-foreground);width:1.25rem;flex-shrink:0}.invoice-item-name{word-break:break-word}.invoice-item-qty{color:var(--muted-foreground);flex-shrink:0}.invoice-item-price{font-weight:500;flex-shrink:0}.invoice-total{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding-top:.75rem;margin-top:.75rem}.invoice-total-label{font-weight:500}.invoice-total-price{font-size:1.125rem;font-weight:700;color:var(--primary)}.invoice-footer{text-align:center;font-size:.75rem;color:var(--muted-foreground);padding-top:.75rem}.action-buttons{display:flex;flex-direction:column;gap:.5rem;margin-top:1.5rem}@media(min-width:640px){.action-buttons{flex-direction:row;gap:.75rem}}.action-buttons .btn{flex:1;height:2.75rem}.hidden{display:none!important}.space-y-4>*+*{margin-top:1rem}.icon{width:1rem;height:1rem;display:inline-block;vertical-align:middle}.icon-lg{width:1.25rem;height:1.25rem}@media print{@page{size:A4;margin:.5in}body{print-color-adjust:exact;-webkit-print-color-adjust:exact;padding:0}.no-print{display:none!important}.card{box-shadow:none!important;border:none!important}.invoice{font-size:12px}}
