* { box-sizing: border-box; }
body { margin: 0; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color: #1f2933; background: #f7f5f0; line-height: 1.5; }
[hidden] { display: none !important; }
a { color: inherit; }
.site-header { padding: 56px min(7vw, 72px) 34px; background: #ffffff; border-bottom: 1px solid #ded8cc; }
.brand-lockup { display: inline-flex; align-items: center; gap: 10px; margin-bottom: 16px; text-decoration: none; font-weight: 900; font-size: 1rem; }
.brand-logo { display: block; width: 42px; height: 42px; object-fit: contain; }
.public-nav { display: flex; flex-wrap: wrap; gap: 8px; margin: 0 0 18px; }
.public-nav a { display: inline-flex; align-items: center; min-height: 34px; padding: 0 12px; border: 1px solid #ded8cc; border-radius: 999px; background: #fffdfa; color: #3f4a56; text-decoration: none; font-weight: 800; font-size: 0.9rem; }
.public-nav a.active { background: #1f2933; border-color: #1f2933; color: #fff; }
.eyebrow { margin: 0 0 10px; color: #806a4d; text-transform: uppercase; font-size: 0.78rem; letter-spacing: 0.08em; }
h1 { max-width: 980px; margin: 0; font-size: clamp(2rem, 4vw, 4rem); line-height: 1.05; letter-spacing: 0; }
.site-header p:not(.eyebrow) { max-width: 760px; font-size: 1.1rem; color: #4b5563; }
.header-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin-top: 18px; }
main { width: min(1180px, calc(100% - 32px)); margin: 0 auto; padding: 32px 0 56px; }
.trust-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 10px; margin-bottom: 18px; }
.trust-strip p { margin: 0; padding: 12px 14px; background: #fffdfa; border: 1px solid #ded8cc; border-radius: 8px; color: #3f4a56; font-weight: 700; font-size: 0.92rem; }
.public-counters { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; margin-bottom: 16px; }
.public-counters article { background: #fffdfa; border: 1px solid #ded8cc; border-radius: 8px; padding: 16px; }
.public-counters span { display: block; color: #64707d; font-size: 0.88rem; }
.public-counters strong { display: block; font-size: 2rem; line-height: 1.1; }
.catalogue-controls { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; align-items: end; margin-bottom: 22px; }
.catalogue-controls label:first-child { grid-column: span 2; }
.catalogue-controls label { display: grid; gap: 6px; color: #4b5563; font-size: 0.9rem; font-weight: 700; }
.catalogue-controls input, .catalogue-controls select { width: 100%; min-height: 42px; border: 1px solid #cfc7b8; border-radius: 6px; background: #fffdfa; color: #1f2933; padding: 0 12px; font: inherit; font-weight: 500; }
.catalogue-control-actions { display: flex; flex-wrap: wrap; gap: 8px; align-items: end; }
.catalogue-result-count { font-weight: 800; color: #1f2933; }
.catalogue-head { display: flex; align-items: end; justify-content: space-between; gap: 20px; margin-bottom: 18px; }
.catalogue-head h2 { margin: 0; font-size: 1.6rem; }
.catalogue-head p { margin: 0; color: #64707d; }
.record-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 16px; }
.record-card { background: #fffdfa; border: 1px solid #ded8cc; border-radius: 8px; padding: 18px; display: grid; gap: 10px; }
.record-image-link { display: block; margin: -18px -18px 2px; border-radius: 8px 8px 0 0; overflow: hidden; background: #ebe5da; }
.record-cover { display: block; width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.record-topline { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-start; gap: 8px 12px; min-width: 0; }
.record-topline-main { display: flex; flex: 0 1 auto; flex-wrap: wrap; align-items: center; gap: 8px; min-width: 0; }
.sku { color: #64707d; font-size: 0.9rem; }
.badge { border-radius: 999px; padding: 4px 10px; font-size: 0.78rem; font-weight: 700; }
.badge.available { background: #dbeafe; color: #174e88; }
.badge.reserved { background: #fde68a; color: #7c4a03; }
.badge.sold { background: #e5e7eb; color: #374151; }
.record-card h3 { margin: 0; font-size: 1.15rem; line-height: 1.25; letter-spacing: 0; }
.details, .grades { margin: 0; color: #64707d; }
.price { margin: 0; font-size: 1.25rem; font-weight: 800; }
.price-note, .contact-note, .service-note { margin: -6px 0 0; color: #64707d; font-size: 0.86rem; }
.service-note strong { color: #3f4a56; }
.sold-note { margin: 0; color: #3f4a56; font-weight: 700; }
.reservation-reassurance { display: grid; gap: 5px; margin: -2px 0 0; padding-left: 18px; color: #3f4a56; font-size: 0.86rem; line-height: 1.38; }
.reservation-reassurance li { margin: 0; }
.product-social-note { margin: 0; }
.public-instagram-link { display: inline-flex; align-items: center; gap: 8px; font-weight: 800; text-decoration: none; }
.public-instagram-link img { display: block; width: 21px; height: 21px; flex: 0 0 auto; object-fit: contain; }
.public-instagram-link:hover { text-decoration: underline; }
.public-instagram-link:focus-visible { outline: 2px solid rgba(31, 41, 51, 0.42); outline-offset: 3px; border-radius: 999px; }
.guitar-shipping-note { margin: 0; color: #3f4a56; font-size: 0.9rem; font-weight: 800; }
.guitar-public-badges { display: flex; flex-wrap: wrap; gap: 6px; margin: 2px 0; }
.guitar-detail-badges { margin-top: 12px; }
.guitar-public-badge { display: inline-flex; align-items: center; min-height: 28px; padding: 0 10px; border-radius: 999px; background: #ecfdf3; color: #166534; border: 1px solid #bbf7d0; font-size: 0.78rem; font-weight: 800; }
.actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 40px; padding: 0 14px; border-radius: 6px; text-decoration: none; font: inherit; font-weight: 700; border: 1px solid #1f2933; cursor: pointer; }
.button.primary { background: #1f2933; color: white; }
.button.ghost { background: white; color: #1f2933; }
.button:disabled, .button.disabled { opacity: 0.56; cursor: not-allowed; }
.fd-consent-banner { position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 60; display: flex; justify-content: center; pointer-events: none; }
.fd-consent-panel { width: min(760px, 100%); display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 16px; align-items: center; padding: 16px; background: #fffdfa; border: 1px solid #cfc7b8; border-radius: 8px; box-shadow: 0 18px 60px rgba(31, 41, 51, 0.22); pointer-events: auto; }
.fd-consent-copy { display: grid; gap: 4px; min-width: 0; }
.fd-consent-title { margin: 0; color: #1f2933; font-size: 1rem; font-weight: 900; }
.fd-consent-copy p:not(.fd-consent-title) { margin: 0; color: #4b5563; font-size: 0.92rem; }
.fd-consent-actions { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 8px; }
.fd-consent-button { display: inline-flex; align-items: center; justify-content: center; min-height: 38px; padding: 0 14px; border-radius: 6px; border: 1px solid #1f2933; font: inherit; font-weight: 800; cursor: pointer; }
.fd-consent-button-primary { background: #1f2933; color: #fff; }
.fd-consent-button-secondary { background: #fff; color: #1f2933; }
.fd-consent-notice { position: fixed; left: 50%; bottom: 18px; z-index: 61; transform: translateX(-50%); max-width: calc(100vw - 32px); padding: 10px 14px; border-radius: 8px; background: #1f2933; color: #fff; box-shadow: 0 12px 36px rgba(31, 41, 51, 0.24); font-size: 0.92rem; font-weight: 800; }
.public-footer-cookie-button { display: inline-flex; align-items: center; min-height: 30px; padding: 0; border: 0; background: transparent; color: #3f4a56; font: inherit; font-weight: 700; cursor: pointer; text-decoration: none; }
.public-footer-cookie-button:hover { text-decoration: underline; }
.cart-summary { display: inline-flex; flex-wrap: wrap; align-items: center; gap: 10px; padding: 8px 10px; background: #fffdfa; border: 1px solid #ded8cc; border-radius: 8px; color: #3f4a56; font-size: 0.88rem; font-weight: 700; }
.cart-open-button { min-height: 34px; padding: 0 10px; }
.cart-count { min-width: 22px; min-height: 22px; display: inline-flex; align-items: center; justify-content: center; margin-left: 6px; border-radius: 999px; background: #1f2933; color: #fff; font-size: 0.78rem; }
.mobile-cart-shortcut { display: none; }
.cart-panel { position: fixed; right: 16px; bottom: 16px; z-index: 20; width: min(480px, calc(100vw - 32px)); max-height: calc(100vh - 32px); overflow: auto; padding: 18px; background: #fffdfa; border: 1px solid #cfc7b8; border-radius: 8px; box-shadow: 0 18px 60px rgba(31, 41, 51, 0.22); }
.cart-panel-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 14px; }
.cart-panel h2 { margin: 0 0 4px; font-size: 1.2rem; letter-spacing: 0; }
.cart-panel p { margin: 0; color: #64707d; }
.cart-lines { display: grid; gap: 10px; margin: 14px 0; }
.cart-line { display: grid; grid-template-columns: 56px minmax(0, 1fr) auto; gap: 10px; align-items: center; padding: 10px; background: #fff; border: 1px solid #ede7dc; border-radius: 8px; }
.cart-line img, .cart-line-placeholder { width: 56px; height: 56px; border-radius: 6px; object-fit: cover; background: #ebe5da; }
.cart-line div { display: grid; gap: 2px; min-width: 0; }
.cart-line strong { font-size: 0.95rem; line-height: 1.25; }
.cart-line span, .cart-line a { color: #64707d; font-size: 0.84rem; }
.cart-service-option { display: grid; grid-template-columns: auto minmax(0, 1fr); column-gap: 6px; row-gap: 2px; align-items: start; margin-top: 6px; color: #3f4a56; font-size: 0.84rem; line-height: 1.3; }
.cart-service-option input { margin-top: 2px; }
.cart-service-option span { color: #3f4a56; font-weight: 700; }
.cart-service-option em { grid-column: 2; color: #64707d; font-style: normal; font-size: 0.8rem; }
.cart-empty { padding: 18px; background: #fff; border: 1px dashed #cfc7b8; border-radius: 8px; }
.cart-totals { display: grid; gap: 6px; padding-top: 12px; border-top: 1px solid #ded8cc; }
.cart-totals p { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; min-width: 0; color: #3f4a56; }
.cart-totals p span { min-width: 0; }
.cart-totals strong, .cart-advantage-details strong { color: #1f2933; white-space: nowrap; text-align: right; }
.cart-advantage { display: grid; gap: 6px; margin: 4px 0; padding: 10px; background: #f7f5f0; border: 1px solid #ded8cc; border-radius: 8px; }
.cart-advantage h3 { margin: 0; font-size: 0.98rem; letter-spacing: 0; }
.cart-advantage-summary { color: #1f2933 !important; font-weight: 800; }
.cart-advantage-toggle { justify-self: start; min-height: 32px; padding: 0 10px; font-size: 0.88rem; }
.cart-advantage-details { display: grid; gap: 6px; padding-top: 8px; border-top: 1px solid #ded8cc; }
.cart-advantage .cart-note { display: block; margin-top: 4px !important; }
.cart-note { margin-top: 10px !important; font-size: 0.88rem; }
.cart-stock-note { color: #3f4a56 !important; font-weight: 700; }
.cart-paypal-reassurance { color: #3f4a56 !important; }
.cart-paypal { display: grid; gap: 9px; margin-top: 14px; padding: 12px; background: #f1f5f9; border: 1px solid #cbd5e1; border-radius: 8px; }
.cart-paypal-heading { display: flex; align-items: center; justify-content: space-between; gap: 8px; color: #1f2933; }
.cart-paypal-heading strong { font-size: 0.98rem; }
.cart-paypal-heading span { display: inline-flex; align-items: center; min-height: 24px; padding: 0 8px; border-radius: 999px; background: #dbeafe; color: #1e40af; font-size: 0.76rem; font-weight: 800; text-transform: uppercase; }
.cart-paypal-status { color: #3f4a56 !important; font-weight: 700; }
.cart-fulfillment-banner { display: grid; gap: 4px; margin: 12px 0; padding: 10px 12px; background: #fff7ed; border: 1px solid #fed7aa; border-radius: 8px; color: #7c2d12; }
.cart-fulfillment-banner strong { color: #7c2d12; }
.cart-fulfillment-banner span { color: #7c2d12; font-size: 0.92rem; }
.cart-fulfillment-choice { display: grid; gap: 8px; margin: 2px 0; padding: 0; min-inline-size: 0; border: 0; }
.cart-fulfillment-choice legend { margin: 0 0 2px; padding: 0; color: #3f4a56; font-size: 0.86rem; font-weight: 800; }
.cart-fulfillment-option { display: grid; grid-template-columns: auto minmax(0, 1fr); gap: 10px; align-items: start; padding: 10px 12px; border: 1px solid #cbd5e1; border-radius: 8px; background: #fffdfa; color: #1f2933; font-size: 0.9rem; font-weight: 700; cursor: pointer; }
.cart-fulfillment-option:has(input:checked) { border-color: #1f2933; box-shadow: 0 0 0 2px rgba(31, 41, 51, 0.08); background: #fff; }
.cart-fulfillment-option input { margin-top: 3px; }
.cart-fulfillment-option span { display: grid; gap: 2px; min-width: 0; color: inherit; }
.cart-fulfillment-option strong { color: #1f2933; }
.cart-fulfillment-option em { color: #64707d; font-size: 0.82rem; font-style: normal; font-weight: 600; line-height: 1.35; }
.cart-shipping-form { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 10px; min-width: 0; }
.cart-shipping-form label { display: grid; gap: 5px; min-width: 0; }
.cart-shipping-wide { grid-column: 1 / -1; }
.cart-shipping-form span { color: #3f4a56; font-size: 0.84rem; font-weight: 800; }
.cart-shipping-form span em { color: #64707d; font-size: 0.82rem; font-style: normal; font-weight: 600; }
.cart-shipping-form input { width: 100%; min-width: 0; min-height: 42px; box-sizing: border-box; border: 1px solid #cfc7b8; border-radius: 6px; padding: 0 10px; font: inherit; color: #1f2933; background: #fffdfa; }
.cart-paypal-email { display: grid; gap: 5px; }
.cart-paypal-email span { color: #3f4a56; font-size: 0.86rem; font-weight: 800; }
.cart-paypal-email input { min-height: 42px; border: 1px solid #cfc7b8; border-radius: 6px; padding: 0 10px; font: inherit; color: #1f2933; background: #fffdfa; }
.cart-paypal-email input:focus { outline: 2px solid rgba(31, 41, 51, 0.2); border-color: #1f2933; }
.cart-paypal-total { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; color: #3f4a56 !important; }
.cart-paypal-total strong { color: #1f2933; white-space: nowrap; }
.cart-paypal-buttons { min-height: 44px; }
.cart-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.empty-state { grid-column: 1 / -1; padding: 28px; background: white; border: 1px solid #ded8cc; border-radius: 8px; }
.record-page { max-width: 1040px; }
.record-site-header { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 16px; }
.record-site-header .brand-lockup { margin-bottom: 0; }
.record-header-actions { display: flex; flex-wrap: wrap; justify-content: flex-end; align-items: center; gap: 10px; }
.back-link { display: inline-block; color: #4b5563; }
.product-detail-hero { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr); gap: 22px; align-items: start; background: #fffdfa; border: 1px solid #ded8cc; border-radius: 8px; padding: 22px; }
.product-hero-panel { display: grid; gap: 16px; align-content: start; min-width: 0; }
.product-title-block { min-width: 0; }
.product-title-block h1 { margin: 6px 0 8px; font-size: clamp(1.8rem, 4vw, 3rem); line-height: 1.05; letter-spacing: 0; }
.product-buy-box { display: grid; gap: 12px; justify-items: start; }
.product-buy-box strong { font-size: 1.7rem; }
.product-media { display: grid; gap: 10px; min-width: 0; }
.product-primary-media { margin: 0; display: grid; gap: 8px; }
.product-primary-media img { display: block; width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border-radius: 8px; border: 1px solid #ded8cc; background: #ebe5da; }
.product-media-instrument .product-primary-media img { aspect-ratio: 4 / 3; object-fit: contain; }
.product-primary-media figcaption { color: #64707d; font-size: 0.82rem; line-height: 1.35; }
.product-media-empty { min-height: 240px; align-content: center; justify-items: center; padding: 28px; border: 1px dashed #cfc7b8; border-radius: 8px; background: #fffdfa; color: #64707d; text-align: center; }
.photo-gallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); gap: 10px; margin-top: 0; }
.photo-gallery img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border-radius: 8px; border: 1px solid #ded8cc; background: #ebe5da; }
.product-media-instrument .photo-gallery img { object-fit: contain; }
.product-quick-facts { margin-top: 22px; padding: 18px; background: #fffdfa; border: 1px solid #ded8cc; border-radius: 8px; }
.product-quick-facts h2 { margin: 0 0 12px; font-size: 1.15rem; }
.product-quick-facts dl { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px 16px; margin: 0; }
.product-quick-facts dt { color: #64707d; font-weight: 800; }
.product-quick-facts dd { margin: 0; min-width: 0; color: #1f2933; font-weight: 700; }
.why-record, .condition-summary, .discogs-summary, .site-about { margin-top: 22px; padding: 18px; background: #fffdfa; border: 1px solid #ded8cc; border-radius: 8px; }
.why-record h2, .condition-summary h2, .discogs-summary h2, .site-about h2 { margin: 0 0 10px; font-size: 1.15rem; }
.why-record ul, .condition-summary ul { margin: 0; padding-left: 18px; }
.condition-summary li { margin: 4px 0; }
.condition-summary li span { color: #64707d; margin-right: 8px; }
.condition-summary li strong { color: #1f2933; }
.discogs-summary dl { display: grid; grid-template-columns: minmax(90px, 140px) minmax(0, 1fr); gap: 8px 14px; margin: 0; }
.discogs-summary dt { color: #64707d; font-weight: 800; }
.discogs-summary dd { margin: 0; min-width: 0; color: #1f2933; font-weight: 700; }
.local-vinyl-services { display: grid; gap: 16px; margin-top: 28px; padding: 20px; background: #fffdfa; border: 1px solid #ded8cc; border-radius: 8px; }
.services-teaser { grid-template-columns: minmax(0, 1fr) auto; align-items: center; }
.local-services-intro { display: grid; gap: 8px; }
.local-services-intro h2 { margin: 0; font-size: 1.35rem; letter-spacing: 0; }
.local-services-intro p { margin: 0; max-width: 860px; color: #4b5563; }
.local-services-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; }
.local-services-grid article { display: grid; gap: 8px; padding: 14px; background: #fff; border: 1px solid #ede7dc; border-radius: 8px; }
.local-services-grid h3 { margin: 0; font-size: 1rem; letter-spacing: 0; }
.local-services-grid ul { margin: 0; padding-left: 18px; color: #3f4a56; font-weight: 700; }
.local-services-grid p, .local-services-notice { margin: 0; color: #64707d; font-size: 0.9rem; }
.local-services-notice { color: #3f4a56; font-weight: 700; }
.tips-box { padding: 14px; background: #fff; border: 1px solid #ede7dc; border-radius: 8px; }
.tips-box p { margin: 0; color: #4b5563; }
.tips-box p + p { margin-top: 8px; }
.guitar-service-strip { display: grid; gap: 10px; margin-bottom: 18px; padding: 18px; background: #fffdfa; border: 1px solid #ded8cc; border-radius: 8px; }
.guitar-service-strip p { margin: 0; color: #3f4a56; font-weight: 700; }
.site-about { margin-top: 26px; }
.site-about p { max-width: 780px; margin: 0; color: #4b5563; }
.description { margin-top: 20px; padding-top: 18px; border-top: 1px solid #ded8cc; }
.technical-details { margin-top: 18px; padding-top: 18px; border-top: 1px solid #ded8cc; }
.technical-details ul { margin: 0; padding-left: 18px; color: #3f4a56; }
.technical-details li { margin: 6px 0; }
.technical-details table { width: 100%; border-collapse: collapse; background: #fffdfa; border: 1px solid #ded8cc; border-radius: 8px; overflow: hidden; }
.technical-details th, .technical-details td { padding: 10px 12px; border-bottom: 1px solid #ede7dc; text-align: left; vertical-align: top; }
.technical-details tr:last-child th, .technical-details tr:last-child td { border-bottom: 0; }
.technical-details th { width: 34%; color: #64707d; font-weight: 700; }
.info-page { max-width: 860px; }
.info-section { margin-top: 18px; padding: 18px; background: #fffdfa; border: 1px solid #ded8cc; border-radius: 8px; }
.info-section:first-child { margin-top: 0; }
.info-section h2 { margin: 0 0 10px; font-size: 1.18rem; letter-spacing: 0; }
.info-section p { margin: 0; color: #3f4a56; }
.info-section p + p { margin-top: 10px; }
.info-section ul { margin: 0; padding-left: 18px; color: #3f4a56; }
.info-section li { margin: 6px 0; }
.info-section dl { display: grid; grid-template-columns: minmax(140px, 220px) minmax(0, 1fr); gap: 8px 16px; margin: 0; }
.info-section dt { color: #64707d; font-weight: 800; }
.info-section dd { margin: 0; min-width: 0; color: #1f2933; }
.public-footer { box-sizing: border-box; width: min(1180px, calc(100% - 32px)); margin: 36px auto 34px; padding: 18px 0 0; border-top: 1px solid #ded8cc; display: grid; grid-template-columns: minmax(240px, 1fr) auto minmax(260px, 1fr); align-items: flex-start; gap: 14px 24px; color: #4b5563; font-size: 0.9rem; }
.public-footer-contact { display: flex; flex-wrap: wrap; align-items: center; gap: 6px 10px; min-width: min(100%, 320px); }
.public-footer-social { min-width: 0; }
.public-footer-instagram { min-height: 38px; padding: 6px 12px 6px 10px; justify-content: flex-start; overflow: visible; white-space: nowrap; background: rgba(255, 253, 250, 0.76); border: 1px solid rgba(31, 41, 51, 0.18); border-radius: 999px; box-shadow: none; }
.public-footer-instagram img { width: 30px; height: 30px; filter: drop-shadow(0 1px 0 rgba(255, 253, 250, 0.44)); }
.public-footer-instagram span { position: static; width: auto; height: auto; margin: 0; overflow: visible; clip: auto; white-space: nowrap; color: #1f2933; }
.public-footer strong { color: #1f2933; }
.public-footer a { color: #3f4a56; text-decoration: none; }
.public-footer a:hover { text-decoration: underline; }
.public-footer nav { min-width: 0; display: flex; flex-wrap: wrap; justify-content: flex-end; align-items: center; gap: 6px 10px; line-height: 1.6; }
.public-footer-separator { color: rgba(75, 85, 99, 0.62); }
@media (max-width: 680px) {
  .site-header { padding: 34px 18px 26px; }
  main { width: min(100% - 24px, 1180px); padding-top: 22px; }
  .fd-consent-banner { left: 12px; right: 12px; bottom: 12px; }
  .fd-consent-panel { grid-template-columns: 1fr; }
  .fd-consent-actions { justify-content: stretch; }
  .fd-consent-button { flex: 1 1 140px; }
  .catalogue-controls,
  .catalogue-controls.guitars-controls { grid-template-columns: 1fr; }
  .catalogue-controls label:first-child { grid-column: auto; }
  .catalogue-head { display: block; }
  .record-grid { grid-template-columns: 1fr; }
  .services-teaser { grid-template-columns: 1fr; }
  .info-section dl { grid-template-columns: 1fr; gap: 3px; }
  .public-footer { width: min(100% - 24px, 1180px); grid-template-columns: 1fr; }
  .public-footer-contact { min-width: 0; }
  .public-footer-social { min-width: 0; }
  .public-footer nav { justify-content: flex-start; }
  .product-detail-hero { grid-template-columns: 1fr; gap: 14px; padding: 14px; }
  .product-detail-hero > .product-media:not(.product-media-empty) { display: contents; }
  .product-detail-hero .product-primary-media { order: 1; }
  .product-detail-hero .product-hero-panel { order: 2; }
  .product-detail-hero .product-thumb-gallery { order: 3; }
  .product-title-block h1 { font-size: 1.62rem; line-height: 1.08; }
  .product-buy-box { gap: 9px; }
  .product-buy-box strong { font-size: 1.45rem; }
  .product-detail-hero .product-thumb-gallery {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding: 2px 0 6px;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
  }
  .product-detail-hero .product-thumb-gallery img {
    flex: 0 0 clamp(96px, 30vw, 128px);
    width: clamp(96px, 30vw, 128px);
    aspect-ratio: 1 / 1;
    scroll-snap-align: start;
  }
  .product-quick-facts dl { grid-template-columns: 1fr; }
  .discogs-summary dl { grid-template-columns: 1fr; gap: 4px; }
  .record-site-header { align-items: flex-start; flex-direction: column; }
  .record-header-actions { justify-content: flex-start; }
  .cart-line { grid-template-columns: 48px minmax(0, 1fr); }
  .cart-line .button { grid-column: 1 / -1; }
}

:root {
  color-scheme: light;
  --fd-color-ink: #111111;
  --fd-color-ink-soft: #2b2823;
  --fd-color-paper: #F5F1E8;
  --fd-color-paper-soft: #FFF9EE;
  --fd-color-paper-warm: #EFE5D6;
  --fd-color-accent: #B43A2F;
  --fd-color-accent-dark: #8E2E26;
  --fd-color-accent-soft: rgba(180, 58, 47, 0.10);
  --fd-color-muted: #7A746C;
  --fd-color-muted-strong: #5F5850;
  --fd-color-border: rgba(17, 17, 17, 0.16);
  --fd-font-body: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --fd-font-display: Georgia, "Times New Roman", serif;
  --fd-radius-sm: 6px;
  --fd-radius-md: 8px;
  --fd-radius-pill: 999px;
  --fd-shadow-soft: 0 14px 34px rgba(17, 17, 17, 0.06);
  --fd-shadow-lift: 0 20px 48px rgba(17, 17, 17, 0.10);
}

html,
body {
  max-width: 100%;
}

body {
  font-family: var(--fd-font-body);
  color: var(--fd-color-ink);
  background-color: var(--fd-color-paper);
  background-image:
    linear-gradient(180deg, rgba(255, 249, 238, 0.76), rgba(245, 241, 232, 0.94)),
    repeating-linear-gradient(90deg, rgba(17, 17, 17, 0.018) 0, rgba(17, 17, 17, 0.018) 1px, transparent 1px, transparent 7px);
}

h1,
.catalogue-head h2,
.record-card h3,
.cart-panel h2,
.cart-advantage h3,
.product-title-block h1,
.why-record h2,
.condition-summary h2,
.product-quick-facts h2,
.site-about h2,
.local-services-intro h2,
.local-services-grid h3,
.home-section-head h2,
.home-entry-card h3,
.home-final-cta h2 {
  font-family: var(--fd-font-display);
  color: var(--fd-color-ink);
  font-weight: 700;
  letter-spacing: 0;
}

.site-header {
  background: var(--fd-color-paper-soft);
  border-bottom: 1px solid var(--fd-color-border);
}

.public-home-hero {
  position: relative;
  padding: 26px min(5vw, 56px) 34px;
  overflow: hidden;
}

.public-home-hero::after {
  content: "";
  position: absolute;
  right: min(6vw, 72px);
  bottom: 0;
  left: min(6vw, 72px);
  height: 1px;
  background: linear-gradient(90deg, rgba(180, 58, 47, 0.42), rgba(17, 17, 17, 0.08), transparent);
}

.hero-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 24px;
}

.brand-lockup {
  color: var(--fd-color-ink);
  letter-spacing: 0;
}

.public-home-hero .brand-lockup {
  display: inline-grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  margin: 0;
}

.brand-logo {
  width: 50px;
  height: 50px;
  padding: 2px;
  border-radius: 50%;
  background: rgba(255, 249, 238, 0.72);
  box-shadow: 0 8px 18px rgba(17, 17, 17, 0.05);
}

.public-home-hero .brand-lockup span {
  max-width: 18rem;
  font-size: 1rem;
  line-height: 1.18;
}

.public-nav {
  gap: 9px;
  margin-bottom: 20px;
}

.public-home-hero .public-nav {
  align-self: center;
  margin: 0;
}

.public-nav a {
  min-height: 36px;
  padding: 0 13px;
  border-color: var(--fd-color-border);
  background: rgba(255, 249, 238, 0.78);
  color: var(--fd-color-ink-soft);
  box-shadow: 0 8px 22px rgba(17, 17, 17, 0.04);
  transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
}

.public-nav a:hover {
  border-color: rgba(180, 58, 47, 0.32);
  transform: translateY(-1px);
}

.public-nav a.active {
  background: var(--fd-color-accent);
  border-color: var(--fd-color-accent);
  color: var(--fd-color-paper-soft);
}

.hero-editorial {
  position: relative;
  display: grid;
  gap: 10px;
  max-width: 820px;
}

.hero-editorial::before {
  content: "";
  width: 58px;
  height: 2px;
  background: var(--fd-color-accent);
  opacity: 0.68;
}

.eyebrow {
  margin: 0;
  color: var(--fd-color-accent);
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: none;
}

h1 {
  max-width: 820px;
  font-size: 3rem;
  line-height: 1.04;
  letter-spacing: 0;
}

.hero-copy,
.site-header p:not(.eyebrow),
.local-services-intro p,
.site-about p,
.tips-box p,
.back-link {
  color: var(--fd-color-muted-strong);
}

.hero-copy {
  max-width: 640px;
  margin: 0;
  font-size: 1.04rem;
  line-height: 1.5;
}

.hero-location {
  display: inline-flex;
  align-items: center;
  justify-self: start;
  min-height: 30px;
  margin: 2px 0 0;
  padding: 0 10px;
  border-left: 2px solid var(--fd-color-accent);
  background: rgba(255, 249, 238, 0.62);
  color: var(--fd-color-muted-strong);
  font-size: 0.88rem;
  font-weight: 800;
}

.header-actions {
  gap: 12px;
  margin-top: 24px;
}

.home-hero-actions {
  align-items: center;
}

main {
  width: min(1200px, calc(100% - 32px));
  padding: 30px 0 64px;
}

.home-entrypoints,
.home-section,
.home-final-cta {
  margin-bottom: 34px;
}

.home-section-head {
  display: grid;
  gap: 6px;
  margin-bottom: 16px;
}

.home-section-head h2,
.home-final-cta h2 {
  margin: 0;
  font-size: 1.7rem;
  line-height: 1.1;
}

.home-section-head p,
.home-entry-card p,
.home-final-cta p {
  max-width: 66ch;
  margin: 0;
  color: var(--fd-color-muted-strong);
}

.home-entry-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.home-entry-card,
.home-final-cta {
  display: grid;
  gap: 12px;
  align-content: start;
  min-width: 0;
  padding: 18px;
  background: rgba(255, 249, 238, 0.9);
  border: 1px solid var(--fd-color-border);
  border-radius: var(--fd-radius-md);
  box-shadow: var(--fd-shadow-soft);
}

.home-entry-card span {
  color: var(--fd-color-accent);
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
}

.home-entry-card h3 {
  margin: 0;
  font-size: 1.28rem;
  line-height: 1.15;
}

.home-entry-card .button {
  justify-self: start;
  margin-top: 4px;
}

.home-selection-grid {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.home-inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.home-trust {
  margin-bottom: 26px;
}

.home-final-cta {
  margin-top: 26px;
}

.trust-strip,
.public-counters,
.catalogue-controls,
.record-grid,
.photo-gallery,
.local-services-grid {
  gap: 18px;
}

.trust-strip {
  margin-bottom: 24px;
}

.trust-strip p,
.public-counters article,
.record-card,
.cart-summary,
.empty-state,
.product-detail-hero,
.product-quick-facts,
.why-record,
.condition-summary,
.site-about,
.local-vinyl-services,
.guitar-service-strip {
  background: rgba(255, 249, 238, 0.9);
  border: 1px solid var(--fd-color-border);
  border-radius: var(--fd-radius-md);
  box-shadow: var(--fd-shadow-soft);
}

.trust-strip p {
  padding: 14px 16px;
  color: var(--fd-color-ink-soft);
  line-height: 1.48;
}

.trust-strip strong,
.guitar-service-strip p,
.local-services-grid ul,
.local-services-notice,
.sold-note,
.guitar-shipping-note,
.reservation-reassurance,
.cart-stock-note,
.cart-paypal-reassurance {
  color: var(--fd-color-ink-soft);
}

.public-counters {
  margin-bottom: 30px;
}

.public-counters article {
  padding: 16px;
}

.public-counters span,
.catalogue-head p,
.details,
.grades,
.price-note,
.contact-note,
.service-note,
.cart-panel p,
.cart-line span,
.cart-line a,
.cart-service-option em,
.condition-summary li span,
.local-services-grid p {
  color: var(--fd-color-muted);
}

.public-counters strong,
.cart-totals strong,
.cart-advantage-details strong,
.cart-paypal-total strong,
.condition-summary li strong {
  color: var(--fd-color-ink);
}

.catalogue-controls {
  margin: 4px 0 30px;
}

.catalogue-control-actions {
  align-self: end;
}

.catalogue-control-actions .button {
  min-height: 42px;
}

.catalogue-controls label {
  color: var(--fd-color-muted-strong);
}

.catalogue-controls input,
.catalogue-controls select,
.cart-paypal-email input {
  border-color: var(--fd-color-border);
  border-radius: var(--fd-radius-sm);
  background: var(--fd-color-paper-soft);
  color: var(--fd-color-ink);
}

.catalogue-controls input:focus,
.catalogue-controls select:focus,
.cart-paypal-email input:focus {
  outline: 2px solid rgba(180, 58, 47, 0.18);
  border-color: rgba(180, 58, 47, 0.48);
}

.catalogue-head {
  align-items: flex-end;
  margin: 0 0 20px;
  padding-top: 4px;
}

.catalogue-head h2 {
  font-size: 1.7rem;
  line-height: 1.1;
}

.catalogue-head p {
  max-width: 54ch;
  line-height: 1.55;
}

.catalogue-result-count {
  color: var(--fd-color-ink);
}

.record-grid {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.record-card {
  align-content: start;
  position: relative;
  padding: 16px;
  gap: 10px;
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.record-card.status-available {
  border-color: rgba(180, 58, 47, 0.18);
}

.record-card.status-reserved {
  border-color: rgba(155, 90, 28, 0.24);
}

.record-card.status-sold {
  background: rgba(245, 241, 232, 0.82);
}

.record-card.status-sold .record-image-link {
  opacity: 0.86;
}

.record-card.status-sold h3 a {
  color: var(--fd-color-muted-strong);
}

.record-card:hover {
  border-color: rgba(180, 58, 47, 0.26);
  box-shadow: var(--fd-shadow-lift);
  transform: translateY(-1px);
}

.record-image-link {
  margin: -16px -16px 4px;
  background: var(--fd-color-paper-warm);
}

.record-cover {
  aspect-ratio: 1 / 1;
}

.record-topline {
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 8px 12px;
  min-width: 0;
}

.record-topline-main {
  display: flex;
  flex: 0 1 auto;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.sku {
  color: var(--fd-color-muted);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.badge {
  border: 1px solid rgba(17, 17, 17, 0.10);
  border-radius: var(--fd-radius-pill);
  padding: 5px 11px;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
  white-space: nowrap;
}

.badge.product-type {
  padding: 4px 9px;
  font-size: 0.74rem;
  font-weight: 800;
  text-transform: none;
}

.badge.product-type.vinyl {
  background: #C9D6D5;
  border-color: #6F8C8B;
  color: #1F3A3E;
}

.badge.product-type.cd {
  background: #D8D0C3;
  border-color: #948673;
  color: #3B342D;
}

.badge.product-type.sacd {
  background: #D4C7D5;
  border-color: #8D7290;
  color: #3E2E40;
}

.badge.product-type.guitar {
  background: #D4B99F;
  border-color: #8E6748;
  color: #432B1B;
}

.badge.product-type.bass {
  background: #C8A98F;
  border-color: #7A5A43;
  color: #34251B;
}

.badge.available {
  background: #E2E7D2;
  border-color: #A7B38B;
  color: #2F3E24;
}

.badge.reserved {
  background: #F1DFC2;
  border-color: #C59A56;
  color: #65401C;
}

.badge.sold {
  background: #E8C4BA;
  border-color: #B46B5E;
  color: #6E2F28;
}

.record-topline .badge.available,
.record-topline .badge.reserved,
.record-topline .badge.sold {
  align-self: center;
  margin-left: 0;
}

.guitar-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  align-items: start;
}

.guitar-card {
  min-width: 0;
  padding: 18px;
  gap: 12px;
}

.guitar-card .record-image-link {
  margin: -18px -18px 6px;
}

.guitar-card .record-cover {
  aspect-ratio: 5 / 4;
  object-fit: contain;
  object-position: center;
  padding: 10px;
  box-sizing: border-box;
  background: var(--fd-color-paper-warm);
}

.guitar-card .record-topline {
  align-items: center;
}

.guitar-card .details {
  font-size: 0.86rem;
  line-height: 1.38;
}

.guitar-card .guitar-summary {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.guitar-card .guitar-shipping-note {
  display: none;
}

.guitar-card .guitar-public-badges {
  margin: 0;
}

.guitar-card .price {
  margin-top: 2px;
}

.guitar-card .price-note {
  margin-top: -6px;
  font-size: 0.8rem;
}

.guitar-card-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 7px;
  align-self: end;
  margin-top: auto;
}

.guitar-card-actions .button {
  width: 100%;
  min-height: 38px;
  padding: 0 12px;
}

.guitar-card-actions .guitar-contact-link {
  min-height: 34px;
  background: rgba(255, 249, 238, 0.62);
  border-color: var(--fd-color-border);
  box-shadow: none;
  color: var(--fd-color-muted-strong);
  font-size: 0.86rem;
  font-weight: 700;
}

.guitar-card-actions .guitar-contact-link:hover {
  border-color: rgba(180, 58, 47, 0.30);
  color: var(--fd-color-ink);
}

.record-card h3 {
  font-size: 1.22rem;
  line-height: 1.2;
}

.record-card h3 a {
  color: var(--fd-color-ink);
  text-decoration: none;
}

.details,
.grades {
  font-size: 0.88rem;
  line-height: 1.42;
}

.price {
  color: var(--fd-color-ink);
  font-size: 1.42rem;
  font-weight: 900;
  line-height: 1.1;
}

.price-note,
.contact-note,
.service-note {
  line-height: 1.45;
}

.service-note strong {
  color: var(--fd-color-ink-soft);
}

.reservation-reassurance {
  color: var(--fd-color-ink-soft);
}

.guitar-public-badge {
  background: rgba(95, 88, 80, 0.10);
  border-color: var(--fd-color-border);
  color: var(--fd-color-muted-strong);
}

.actions {
  gap: 8px;
  margin-top: 4px;
}

.button {
  min-height: 40px;
  padding: 0 15px;
  border-color: rgba(17, 17, 17, 0.28);
  border-radius: var(--fd-radius-pill);
  background: var(--fd-color-paper-soft);
  color: var(--fd-color-ink);
  box-shadow: 0 8px 18px rgba(17, 17, 17, 0.05);
  transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease, opacity 160ms ease;
}

.button:hover:not(:disabled):not(.disabled) {
  transform: translateY(-1px);
  border-color: rgba(180, 58, 47, 0.42);
}

.button.primary {
  background: var(--fd-color-accent);
  border-color: var(--fd-color-accent);
  color: var(--fd-color-paper-soft);
}

.button.ghost {
  background: rgba(255, 249, 238, 0.8);
  color: var(--fd-color-ink);
}

.disc-card h3 {
  display: -webkit-box;
  min-height: calc(2 * 1.2em);
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.disc-card .details,
.disc-card .grades {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}

.disc-card .price {
  margin-top: 2px;
  font-size: 1.46rem;
}

.disc-card .price-note {
  margin-top: -8px;
  font-size: 0.78rem;
}

.disc-card .actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(96px, 0.62fr);
  gap: 7px;
  align-self: end;
  margin-top: 0;
}

.disc-card.status-sold .actions {
  grid-template-columns: 1fr;
}

.disc-card .actions .button {
  min-height: 38px;
  padding: 0 12px;
  box-shadow: none;
  font-size: 0.88rem;
}

.disc-card .actions .button[data-cart-add] {
  font-weight: 800;
}

.disc-card .record-card-contact {
  background: rgba(255, 249, 238, 0.62);
  border-color: var(--fd-color-border);
  color: var(--fd-color-muted-strong);
  font-size: 0.84rem;
  font-weight: 700;
}

.cart-summary {
  color: var(--fd-color-ink-soft);
}

.cart-count {
  background: var(--fd-color-accent);
  color: var(--fd-color-paper-soft);
}

.cart-panel {
  background: var(--fd-color-paper-soft);
  border-color: var(--fd-color-border);
  box-shadow: 0 18px 60px rgba(17, 17, 17, 0.18);
}

.cart-line,
.cart-empty,
.cart-advantage,
.cart-paypal,
.local-services-grid article,
.tips-box {
  background: rgba(255, 249, 238, 0.78);
  border-color: var(--fd-color-border);
}

.cart-totals,
.cart-advantage-details,
.description,
.technical-details {
  border-color: var(--fd-color-border);
}

.cart-totals p,
.cart-service-option,
.cart-service-option span,
.cart-paypal-heading,
.cart-paypal-status,
.cart-fulfillment-choice legend,
.cart-fulfillment-option,
.cart-fulfillment-option strong,
.cart-fulfillment-option em,
.cart-shipping-form span,
.cart-paypal-email span,
.cart-paypal-total {
  color: var(--fd-color-ink-soft) !important;
}

.cart-paypal-heading span {
  background: var(--fd-color-accent-soft);
  color: var(--fd-color-accent-dark);
}

.cart-fulfillment-banner {
  background: rgba(180, 58, 47, 0.08);
  border-color: rgba(180, 58, 47, 0.20);
  color: var(--fd-color-accent-dark);
}

.cart-fulfillment-banner strong,
.cart-fulfillment-banner span {
  color: var(--fd-color-accent-dark);
}

.cart-fulfillment-option,
.cart-shipping-form input {
  border-color: var(--fd-color-border);
}

.cart-fulfillment-option:has(input:checked) {
  border-color: var(--fd-color-ink);
  box-shadow: 0 0 0 2px rgba(31, 41, 51, 0.08);
}

.empty-state {
  color: var(--fd-color-muted-strong);
}

.product-detail-hero {
  gap: 28px;
}

.product-buy-box strong {
  color: var(--fd-color-ink);
}

.photo-gallery img {
  border-color: var(--fd-color-border);
  background: var(--fd-color-paper-warm);
}

.technical-details table {
  background: var(--fd-color-paper-soft);
  border-color: var(--fd-color-border);
}

.technical-details th,
.technical-details td {
  border-color: rgba(17, 17, 17, 0.10);
}

.technical-details th {
  color: var(--fd-color-muted);
}

@media (max-width: 900px) {
  .public-home-hero {
    padding-top: 24px;
  }

  .hero-bar {
    gap: 16px;
    margin-bottom: 24px;
  }

  h1 {
    font-size: 2.46rem;
  }
}

@media (max-width: 1040px) {
  .guitar-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  html,
  body {
    max-width: 100%;
    overflow-x: hidden;
  }

  body {
    background-image: linear-gradient(180deg, rgba(255, 249, 238, 0.84), rgba(245, 241, 232, 0.96));
  }

  .public-home-hero,
  .site-header {
    padding: 14px 18px 16px;
    overflow: hidden;
  }

  .public-home-hero::after {
    right: 18px;
    left: 18px;
  }

  .hero-bar {
    display: grid;
    gap: 10px;
    margin-bottom: 12px;
  }

  .public-home-hero .brand-lockup {
    gap: 12px;
  }

  .brand-logo {
    width: 34px;
    height: 34px;
  }

  .public-home-hero .brand-lockup span {
    font-size: 0.92rem;
  }

  .hero-editorial {
    gap: 7px;
  }

  .hero-editorial::before {
    width: 46px;
  }

  h1 {
    max-width: 100%;
    font-size: 1.58rem;
    line-height: 1.05;
    overflow-wrap: break-word;
  }

  .eyebrow {
    font-size: 0.8rem;
    line-height: 1.25;
  }

  .eyebrow,
  .hero-copy,
  .hero-location,
  .site-header p:not(.eyebrow) {
    overflow-wrap: anywhere;
  }

  .hero-copy {
    font-size: 0.88rem;
    line-height: 1.32;
  }

  .site-header p:not(.eyebrow) {
    font-size: 0.92rem;
    line-height: 1.38;
  }

  .hero-location {
    display: block;
    min-height: 0;
    margin-top: 0;
    padding: 4px 0 4px 9px;
    font-size: 0.78rem;
    line-height: 1.28;
  }

  .public-nav {
    gap: 6px;
  }

  .public-nav a,
  .button {
    min-height: 36px;
  }

  .public-nav a {
    justify-content: center;
    min-width: 0;
    padding: 0 9px;
    font-size: 0.86rem;
    white-space: nowrap;
  }

  .header-actions {
    display: grid;
    grid-template-columns: 1fr;
    margin-top: 12px;
    width: 100%;
  }

  .public-home-hero .header-actions {
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.35fr);
    gap: 8px;
  }

  .public-home-hero .header-actions.home-hero-actions {
    display: flex;
    width: auto;
    max-width: 220px;
    align-items: stretch;
    gap: 7px;
  }

  .public-home-hero .header-actions.home-hero-actions > .button,
  .public-home-hero .header-actions.home-hero-actions .cart-open-button {
    min-height: 34px;
    padding: 0 8px;
    font-size: 0.78rem;
    white-space: nowrap;
  }

  main {
    width: min(100% - 24px, 1180px);
    padding: 16px 0 54px;
  }

  .home-entrypoints,
  .home-section,
  .home-final-cta {
    margin-bottom: 24px;
  }

  .home-section-head {
    gap: 4px;
    margin-bottom: 12px;
  }

  .home-section-head h2,
  .home-final-cta h2 {
    font-size: 1.38rem;
  }

  .home-entry-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .home-entry-card,
  .home-final-cta {
    gap: 10px;
    padding: 14px;
  }

  .home-entry-card h3 {
    font-size: 1.14rem;
  }

  .home-inline-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .home-trust {
    grid-template-columns: 1fr;
  }

  .local-services-grid,
  .photo-gallery {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .trust-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 14px;
  }

  .trust-strip p,
  .public-counters article,
  .record-card,
  .product-detail-hero,
  .product-quick-facts,
  .local-services-grid article {
    min-width: 0;
  }

  .trust-strip p {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
    padding: 8px 10px;
    font-size: 0.78rem;
    line-height: 1.28;
  }

  .public-counters {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 16px;
  }

  .public-counters article {
    padding: 10px 8px;
  }

  .public-counters span {
    font-size: 0.72rem;
    line-height: 1.18;
  }

  .public-counters strong {
    font-size: 1.55rem;
  }

  .guitar-service-strip {
    gap: 7px;
    margin-bottom: 14px;
    padding: 10px;
  }

  .guitar-service-strip p {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
    font-size: 0.78rem;
    line-height: 1.3;
  }

  .catalogue-controls,
  .catalogue-controls.guitars-controls {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-bottom: 16px;
  }

  .catalogue-controls label {
    gap: 4px;
    font-size: 0.78rem;
  }

  .catalogue-controls label:first-child {
    grid-column: 1 / -1;
  }

  .catalogue-controls input,
  .catalogue-controls select {
    min-height: 42px;
    padding: 0 10px;
  }

  .catalogue-head {
    display: grid;
    gap: 4px;
    margin-bottom: 12px;
  }

  .catalogue-head h2 {
    font-size: 1.55rem;
  }

  .catalogue-head p {
    font-size: 0.88rem;
    line-height: 1.38;
  }

  .catalogue-head p,
  .details,
  .grades,
  .price-note,
  .contact-note,
  .service-note,
  .record-card h3 {
    overflow-wrap: anywhere;
  }

  .record-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .record-card {
    padding: 16px;
  }

  .record-image-link {
    margin: -16px -16px 4px;
  }

  .guitar-card .record-image-link {
    margin: -16px -16px 6px;
  }

  .guitar-card .record-cover {
    padding: 8px;
  }

  .guitar-card .guitar-summary {
    -webkit-line-clamp: 2;
  }

  .record-topline {
    align-items: center;
  }

  .record-card h3 {
    font-size: 1.18rem;
  }

  .actions,
  .record-header-actions,
  .cart-actions {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
  }

  .button,
  .cart-open-button {
    width: 100%;
  }

  .disc-card .actions {
    grid-template-columns: minmax(0, 1fr) minmax(88px, 0.58fr);
  }

  .disc-card .actions .button {
    min-height: 36px;
    padding: 0 10px;
    font-size: 0.84rem;
  }

  .cart-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 8px;
    padding: 8px 10px;
  }

  .public-home-hero .cart-summary {
    width: auto;
    min-width: 168px;
    padding: 4px;
  }

  .public-home-hero .cart-summary > span {
    display: none;
  }

  .cart-summary .cart-open-button {
    justify-content: center;
    width: 100%;
    min-height: 34px;
    padding: 0 12px;
  }

  body.has-mobile-cart-shortcut {
    padding-bottom: calc(74px + env(safe-area-inset-bottom));
  }

  .mobile-cart-shortcut:not([hidden]) {
    position: fixed;
    right: 12px;
    bottom: calc(12px + env(safe-area-inset-bottom));
    left: 12px;
    z-index: 18;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 14px;
    border: 1px solid #cfc7b8;
    border-radius: 8px;
    background: #fffdfa;
    color: #1f2933;
    box-shadow: 0 14px 34px rgba(31, 41, 51, 0.16);
    font: inherit;
    font-size: 0.92rem;
    font-weight: 800;
    cursor: pointer;
  }

  .mobile-cart-shortcut:focus-visible {
    outline: 3px solid rgba(180, 58, 47, 0.36);
    outline-offset: 3px;
  }

  .cart-panel {
    right: 12px;
    bottom: 12px;
    width: calc(100vw - 24px);
    max-height: calc(100vh - 24px);
  }

  .cart-line {
    grid-template-columns: 52px minmax(0, 1fr);
  }

  .cart-shipping-form {
    grid-template-columns: 1fr;
  }
}
