*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #f0f0f0;--color-surface: #ffffff;--color-primary: #4a90d9;--color-primary-dk: #357abd;--color-dark: #1a1a1a;--color-muted: #6b7280;--color-danger: #e53e3e;--color-success: #38a169;--color-warning: #d69e2e;--color-border: #d1d5db;--color-badge: #e53e3e;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 28px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;--font-size-base: 16px;--max-width: 480px;--header-h: 56px}html,body{height:100%;background:var(--color-bg);font-family:var(--font);font-size:var(--font-size-base);color:var(--color-dark);-webkit-font-smoothing:antialiased}#app{max-width:var(--max-width);margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.text-muted{color:var(--color-muted)}.text-center{text-align:center}.text-bold{font-weight:700}.mt-xs{margin-top:4px}.mt-sm{margin-top:8px}.mt-md{margin-top:16px}.mt-lg{margin-top:24px}.page{display:flex;flex-direction:column;flex:1;padding:16px;gap:16px}.topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--color-bg);border-bottom:1px solid var(--color-border);min-height:var(--header-h)}.topbar__title{font-size:1.1rem;font-weight:700}.topbar__left,.topbar__right{display:flex;align-items:center;gap:8px;min-width:80px}.topbar__right{justify-content:flex-end}.quote-badge{position:relative;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;cursor:pointer;text-decoration:none}.quote-badge__icon{font-size:1.6rem;line-height:1}.quote-badge__count{position:absolute;top:0;left:0;background:var(--color-badge);color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.quote-badge__count[data-count="0"]{display:none}.btn-back{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--color-dark);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;text-decoration:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;text-decoration:none;width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-primary-dk)}.btn--dark{background:var(--color-dark);color:#fff}.btn--dark:hover:not(:disabled){background:#333}.btn--outline{background:transparent;color:var(--color-dark);border:1.5px solid var(--color-border)}.btn--outline:hover:not(:disabled){background:var(--color-border)}.btn--danger{background:var(--color-danger);color:#fff}.btn--success{background:var(--color-success);color:#fff}.btn--lg{padding:18px 24px;font-size:1.15rem;border-radius:var(--radius-xl)}.category-grid{display:flex;flex-direction:column;gap:12px}.category-card{display:flex;align-items:center;justify-content:center;padding:20px;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);font-size:1.1rem;font-weight:600;cursor:pointer;text-align:center;text-decoration:none;color:var(--color-dark);transition:background .15s}.category-card:hover{background:#f5f5f5}.item-list{display:flex;flex-direction:column;gap:16px}.item-row{display:grid;grid-template-columns:80px 1fr;gap:12px;background:var(--color-surface);border-radius:var(--radius-md);padding:12px}.item-row__img{width:80px;height:80px;object-fit:cover;border-radius:var(--radius-sm);background:#d1d5db;flex-shrink:0}.item-row__img--placeholder{display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--color-muted)}.item-row__info{display:flex;flex-direction:column;gap:4px}.item-row__name{font-weight:700;font-size:1rem}.item-row__dims{font-size:.85rem;color:var(--color-muted)}.item-row__price{font-size:.9rem;font-weight:600}.item-row__controls{display:flex;align-items:center;gap:6px;margin-top:6px}.qty-display{width:48px;text-align:center;font-size:1rem;font-weight:600;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);padding:4px 0;background:var(--color-surface)}.qty-btn{width:32px;height:32px;border:none;border-radius:var(--radius-sm);background:var(--color-border);font-size:1.2rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.qty-btn:hover:not(:disabled){background:#b0b7c0}.qty-btn:disabled{opacity:.35;cursor:not-allowed}.btn-add-cart{margin-left:auto;padding:6px 14px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:700;font-size:1.1rem;cursor:pointer;min-width:40px;height:32px;display:flex;align-items:center;justify-content:center}.btn-add-cart:hover{background:var(--color-primary-dk)}.quote-list{display:flex;flex-direction:column;gap:12px}.quote-card{background:var(--color-surface);border-radius:var(--radius-md);padding:14px 16px;display:flex;flex-direction:column;gap:6px;cursor:pointer;border-left:4px solid transparent;text-decoration:none;color:inherit}.quote-card--draft{border-left-color:var(--color-primary)}.quote-card--approved{border-left-color:var(--color-success)}.quote-card--expired{border-left-color:var(--color-muted);opacity:.7}.quote-card__status{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.status--draft{color:var(--color-primary)}.status--approved{color:var(--color-success)}.status--expired{color:var(--color-muted)}.quote-card__total{font-size:1.1rem;font-weight:700}.quote-card__meta{font-size:.8rem;color:var(--color-muted)}.cart-line{background:var(--color-surface);border-radius:var(--radius-md);padding:14px 16px;display:flex;flex-direction:column;gap:8px}.cart-line__top{display:flex;justify-content:space-between;align-items:flex-start}.cart-line__name{font-weight:700}.cart-line__sub{font-weight:700;font-size:1rem;color:var(--color-primary)}.cart-line__meta{font-size:.85rem;color:var(--color-muted)}.cart-line__controls{display:flex;align-items:center;gap:8px}.cart-total{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-top:2px solid var(--color-border);font-size:1.2rem;font-weight:800}.cart-expiry{font-size:.85rem;color:var(--color-muted);text-align:center}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-weight:600;font-size:.95rem}.form-input{padding:12px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:1rem;background:var(--color-surface);width:100%;outline:none}.form-input:focus{border-color:var(--color-primary)}.toggle-group{display:flex;align-items:center;gap:12px;font-size:.95rem}.toggle{position:relative;width:48px;height:26px}.toggle input{opacity:0;width:0;height:0}.toggle__track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-border);border-radius:13px;cursor:pointer;transition:background .2s}.toggle input:checked+.toggle__track{background:var(--color-primary)}.toggle__track:after{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s}.toggle input:checked+.toggle__track:after{transform:translate(22px)}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{padding:12px 20px;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;color:#fff;box-shadow:0 4px 16px #0003;animation:toast-in .2s ease;pointer-events:none}.toast--success{background:var(--color-success)}.toast--error{background:var(--color-danger)}.toast--info{background:var(--color-primary)}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.spinner{width:36px;height:36px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite;margin:32px auto}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;justify-content:center;align-items:center;flex:1}.hero{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:24px;padding:32px 16px;text-align:center}.hero__logo{width:120px;height:120px;object-fit:contain;border-radius:var(--radius-lg)}.hero__logo--placeholder{width:120px;height:120px;background:var(--color-dark);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.6rem;font-weight:800}.hero__title{font-size:1.8rem;font-weight:800;line-height:1.2}.hero__sub{color:var(--color-muted);font-size:1rem}.hero__photo{width:90px;height:90px;border-radius:50%;object-fit:cover;background:var(--color-border)}.hero__actions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:320px}.section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);padding:4px 0}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;text-align:center;color:var(--color-muted)}.empty-state__icon{font-size:3rem}.public-quote{padding:24px 16px;display:flex;flex-direction:column;gap:20px;max-width:var(--max-width);margin:0 auto}.public-quote__header{text-align:center}.public-quote__company{font-weight:800;font-size:1.3rem}.public-quote__id{font-size:.8rem;color:var(--color-muted)}.expired-banner{background:var(--color-warning);color:#fff;padding:12px 16px;border-radius:var(--radius-md);font-weight:700;text-align:center}.bespoke-price-preview{background:var(--color-surface);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:6px}.bespoke-price-preview__label{font-size:.85rem;color:var(--color-muted)}.bespoke-price-preview__amount{font-size:1.8rem;font-weight:800;color:var(--color-primary)}@media print{.topbar,.btn-back,.btn--primary,.toast-container{display:none!important}body{background:#fff}.public-quote{padding:0}}
