.discovery-search-wrap { padding-top: 32px; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 16px; }
.discovery-search { width: min(820px, 100%); height: 60px; margin-inline: auto; display: grid; grid-template-columns: minmax(240px, 1fr) 1px minmax(170px, 220px) 52px; align-items: center; overflow: hidden; border: 0; border-radius: var(--radius-control); background: var(--surface-soft); box-shadow: none; }
.discovery-search:focus-within { background: var(--surface); }
.discovery-query, .discovery-location { min-width: 0; height: 100%; display: flex; align-items: center; }
.discovery-search input { min-width: 0; width: 100%; height: 100%; padding: 0 16px; border: 0; outline: 0; color: var(--text); background: transparent; font-size: 16px; }
.discovery-search input::placeholder { color: var(--text-muted); opacity: 1; }
.discovery-divider { width: 1px; height: 50%; background: var(--border); }
.discovery-location svg { flex: 0 0 21px; width: 21px; height: 21px; margin-left: 13px; color: var(--text-muted); }
.discovery-location input { padding-left: 8px; }
.discovery-submit { align-self: stretch; display: grid; place-items: center; border: 0; border-radius: 0 var(--radius-control) var(--radius-control) 0; color: var(--text-on-dark); background: var(--search-action-idle); transition: background var(--transition-ui); }
.discovery-submit:hover, .discovery-submit:active { background: var(--brand-primary); }
.discovery-submit svg { width: 20px; }
.discovery-clear { flex: 0 0 auto; display: inline-flex; align-items: center; color: var(--brand-primary-dark); background: transparent; font-size: 14px; font-weight: 700; }
.discovery-clear:hover { color: var(--brand-primary); }
.search-suggestions-panel { width: min(820px, 100%); margin: 8px auto 0; padding: 8px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); box-shadow: 0 12px 28px color-mix(in srgb, var(--brand-secondary) 10%, transparent); text-align: left; z-index: 10; }
.discovery-search-wrap .search-suggestions-panel, .results-search-wrap .search-suggestions-panel { flex: 1 0 100%; }
.search-suggestion-group { padding: 6px; display: grid; gap: 4px; }
.search-suggestion-group > span { padding: 4px 8px; color: var(--text-muted); font-size: 11px; font-weight: 900; letter-spacing: .8px; text-transform: uppercase; }
.search-suggestion-item { min-height: 48px; padding: 9px 10px; display: grid; gap: 2px; border-radius: var(--radius-control); }
.search-suggestion-item:hover { color: var(--brand-primary-dark); background: var(--surface-soft); }
.search-suggestion-item strong { color: var(--text); font: 700 15px/1.25 var(--font-display); }
.search-suggestion-item small { color: var(--text-muted); font-size: 12px; }
.search-suggestion-empty { padding: 14px; color: var(--text-muted); font-size: 14px; text-align: center; }
.page-intro { padding: 60px 0 52px; }
.page-intro h1, .simple-form-page h1, .auth-message h1 { max-width: 780px; margin: 0; font: 800 clamp(36px, 4.5vw, 58px)/1.08 var(--font-display); letter-spacing: -2px; }
.page-intro h1, .simple-form-page h1 { color: var(--brand-secondary); }
.page-intro h1 em, .auth-message h1 em { color: var(--brand-primary); font-style: normal; }
.page-intro > p { max-width: 760px; margin: 18px 0 0; font-size: 18px; }
.page-intro--wide h1 { max-width: 100%; }
.page-intro--wide > p { max-width: 100%; }
.about-page-head { padding-top: 50px; }
.about-page-head .page-intro { padding: 50px 0; text-align: center; }
.about-page-head .page-intro h1 { max-width: 900px; margin-inline: auto; font-size: clamp(36px, 4.5vw, 58px); font-weight: 800; line-height: 1.08; letter-spacing: -2px; }
.about-page-head .page-intro h1 em { display: block; margin-top: 2px; }
.about-page-head .page-intro > p { margin-inline: auto; }
.about-tabs { display: flex; flex-wrap: wrap; gap: 6px; padding: 6px; border: 0; border-radius: var(--radius-panel); background: var(--surface-soft); }
.about-tab { min-height: 42px; padding: 10px 16px; flex: 1 1 135px; display: inline-flex; align-items: center; justify-content: center; border-radius: var(--radius-control); color: var(--brand-secondary); font-size: 14px; font-weight: 800; text-align: center; transition: color var(--transition-ui), background var(--transition-ui); }
.about-tab:hover { color: var(--brand-primary-dark); background: var(--surface); }
.about-tab.is-active { color: var(--text-on-dark); background: var(--brand-primary); }
.about-mobile-tabs { display: none; }
.legal-tabs .about-tab { flex: 1 1 240px; }
.legal-content { display: grid; gap: 18px; }
.legal-content article { padding: 28px 30px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.legal-content h2 { margin: 0 0 10px; color: var(--text); font: 700 24px/1.25 var(--font-display); }
.legal-content p { max-width: 840px; margin: 0; line-height: 1.7; }
.discovery-layout { display: grid; grid-template-columns: 260px 1fr; gap: 42px; align-items: start; }
.filter-panel { padding: 25px; border: 1px solid var(--border); border-radius: var(--radius-panel); position: sticky; top: 18px; background: var(--surface); }
.product-sidebar { position: sticky; top: 18px; display: grid; gap: 32px; align-self: start; }
.product-sidebar .filter-panel { position: static; top: auto; }
.filter-title { display: flex; justify-content: space-between; align-items: flex-start; gap: 14px; margin-bottom: 14px; }
.filter-title h2 { margin: 0; font: 700 20px var(--font-display); }
.filter-title a { color: var(--brand-primary-dark); font-size: 13px; font-weight: 700; }
.filter-location-summary { margin: 0 0 20px; padding: 13px 14px; border-radius: var(--radius-control); color: var(--text-muted); background: var(--surface-soft); font-size: 13px; font-weight: 700; line-height: 1.35; }
.filter-location-summary strong { color: var(--brand-secondary); }
.filter-change-location { width: max-content; margin: -10px 0 7px; display: inline-flex; color: var(--brand-primary); font-size: 13px; font-weight: 800; }
.filter-change-location:hover { color: var(--brand-primary-hover); }
.filter-section-divider { height: 1px; margin: 0 0 17px; background: var(--border); }
.filter-panel form > label:not(.check-row), .filter-field, .auth-form > label, .auth-panel label { margin-bottom: 17px; display: block; color: var(--brand-secondary); font-size: 13px; font-weight: 700; }
.filter-panel input:not([type="checkbox"]), .filter-panel select, .auth-form input { width: 100%; height: 39px; margin-top: 7px; padding: 0 12px; border: 1px solid var(--border); border-radius: var(--radius-control); outline: 0; color: var(--text); background: var(--surface); font-weight: 400; }
.filter-panel input:focus, .filter-panel select:focus, .auth-form input:focus { border-color: var(--brand-primary); box-shadow: 0 0 0 3px var(--focus-ring); }
.distance-stepper { height: 39px; margin-top: 7px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); overflow: hidden; border: 1px solid var(--border); border-radius: var(--radius-control); background: var(--surface); }
.distance-stepper:focus-within { border-color: var(--brand-primary); box-shadow: 0 0 0 3px var(--focus-ring); }
.distance-stepper button { display: grid; place-items: center; border: 0; color: var(--brand-primary-dark); background: transparent; font-size: 18px; font-weight: 900; line-height: 1; cursor: pointer; transition: color var(--transition-ui), background var(--transition-ui); }
.distance-stepper button:first-child { border-right: 1px solid color-mix(in srgb, var(--border) 76%, transparent); }
.distance-stepper button:last-child { border-left: 1px solid color-mix(in srgb, var(--border) 76%, transparent); }
.distance-stepper button:hover { color: var(--brand-secondary); background: var(--surface-soft); }
.filter-panel .distance-stepper .distance-input { width: 100%; height: 100%; margin: 0; padding: 0 8px; border: 0; border-radius: 0; outline: 0; box-shadow: none; background: transparent; text-align: center; font-weight: 800; appearance: textfield; }
.filter-panel .distance-stepper .distance-input:focus { border: 0; outline: 0; box-shadow: none; background: transparent; }
.distance-stepper .distance-input::-webkit-outer-spin-button, .distance-stepper .distance-input::-webkit-inner-spin-button { margin: 0; appearance: none; }
.check-row { display: flex; align-items: center; gap: 9px; margin: 13px 0; font-size: 14px; cursor: pointer; }
.check-row input { accent-color: var(--brand-primary-dark); width: 17px; height: 17px; }
.filter-panel .button { margin-top: 12px; }
.request-cta-card { margin: 0; padding: 25px; display: grid; gap: 7px; border: 0; border-radius: var(--radius-panel); background: var(--surface-soft); }
.request-cta-card strong { color: var(--brand-secondary); font: 800 17px/1.2 var(--font-display); }
.request-cta-card p { margin: 0; color: var(--text-muted); font-size: 13px; line-height: 1.45; }
.request-cta-card .button { margin-top: 6px; background: var(--brand-primary); }
.request-cta-card .button:hover { background: var(--brand-primary-hover); }
.needs-hero h1 { max-width: 100%; }
.needs-cta-card { padding: 34px 36px; display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; gap: 34px; border: 0; border-radius: var(--radius-panel); background: var(--surface-soft); }
.needs-cta-card p { max-width: 820px; margin: 0; color: var(--brand-secondary); font-size: 20px; font-weight: 700; line-height: 1.55; }
.needs-cta-card p span { color: var(--brand-primary); font-weight: 800; }
.needs-cta-card .button { min-width: 154px; justify-self: end; background: var(--brand-primary); }
.needs-cta-card .button:hover { background: var(--brand-primary-hover); }
.needs-explainer { margin-top: 24px; }
.needs-browse { margin-top: 42px; }
.needs-explainer h2, .needs-browse h2 { margin: 0; color: var(--brand-secondary); font: 800 30px/1.15 var(--font-display); }
.needs-steps-disclosure { border-bottom: 1px solid var(--border); }
.needs-steps-trigger { width: 100%; min-height: 46px; padding: 0 0 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; border: 0; color: var(--brand-primary); background: transparent; font: 800 20px/1.2 var(--font-display); text-align: left; cursor: pointer; }
.needs-steps-trigger svg { width: 20px; height: 20px; color: var(--brand-primary); stroke: currentColor; stroke-width: 2.3; stroke-linecap: round; stroke-linejoin: round; fill: none; transition: transform var(--transition-ui); }
.needs-steps-trigger[aria-expanded="true"] svg { transform: rotate(180deg); }
.needs-step-list { max-height: 0; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 32px; overflow: hidden; transition: max-height .24s ease, padding .24s ease; list-style: none; }
.needs-steps-trigger[aria-expanded="true"] + .needs-step-list { padding: 4px 0 32px; }
.needs-step-list li { min-height: 96px; padding: 16px 12px; display: grid; grid-template-columns: 38px minmax(0, 1fr); gap: 8px; align-items: center; border: 1px solid var(--border); border-radius: var(--radius-control); background: var(--surface); }
.needs-step-list > li:first-child { margin-top: 4px; }
.needs-step-list span { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 50%; color: var(--brand-primary); background: var(--surface-soft); font-size: 17px; font-weight: 900; line-height: 1; }
.needs-step-list strong { display: block; color: var(--brand-secondary); font: 800 16px/1.2 var(--font-display); }
.needs-step-list p { margin: 4px 0 0; color: var(--text-muted); font-size: 14px; line-height: 1.45; }
.needs-browse-head { margin-bottom: 18px; display: flex; justify-content: space-between; gap: 20px; }
.needs-browse-head p { max-width: 760px; margin: 8px 0 0; color: var(--text-muted); line-height: 1.55; }
.needs-browse .profile-empty-block { padding: 0; margin-top: -10px; }
.needs-browse .profile-empty-block p { margin: 0; }
.needs-login-block a { color: var(--brand-primary); font-weight: 900; }
.needs-recent { padding-top: 32px; border-top: 1px solid var(--border); }
.needs-filter-bar { margin-bottom: 24px; display: grid; grid-template-columns: minmax(180px, 1.25fr) repeat(3, minmax(145px, 1fr)) auto; align-items: end; gap: 12px; }
.needs-filter-bar label { display: grid; gap: 7px; color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.needs-filter-bar input, .needs-filter-bar select { min-height: 42px; padding: 10px 12px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--text); background: var(--surface); }
.needs-card-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.need-card { padding: 18px; display: grid; gap: 15px; border: 1px solid var(--border); border-radius: var(--radius-card); background: var(--surface); }
.need-card h3 { margin: 0; color: var(--brand-secondary); font: 800 20px/1.15 var(--font-display); }
.need-card p, .need-card span, .need-card time { margin: 0; color: var(--text-muted); font-size: 13px; font-weight: 700; }
.need-card dl { margin: 0; display: grid; gap: 10px; }
.need-card dl div { display: grid; gap: 2px; }
.need-card dt { color: var(--text-muted); font-size: 11px; font-weight: 900; letter-spacing: .7px; text-transform: uppercase; }
.need-card dd { margin: 0; color: var(--brand-secondary); font-size: 14px; font-weight: 800; line-height: 1.3; }
.need-card .button { width: fit-content; min-height: 38px; padding: 8px 16px; color: var(--brand-primary-dark); }
.need-card em { width: fit-content; padding: 6px 9px; border-radius: 999px; color: var(--brand-primary-dark); background: var(--brand-primary-faint); font-size: 12px; font-style: normal; font-weight: 900; }
.needs-table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.needs-table { width: 100%; min-width: 760px; border-collapse: collapse; }
.needs-table th, .needs-table td { padding: 14px 16px; border-bottom: 1px solid var(--border); color: var(--brand-secondary); text-align: left; vertical-align: middle; }
.needs-table th { color: var(--text-muted); font-size: 11px; font-weight: 900; letter-spacing: .7px; text-transform: uppercase; }
.needs-table tbody tr:last-child td { border-bottom: 0; }
.needs-table td { font-size: 14px; font-weight: 700; }
.needs-table td strong { color: var(--brand-secondary); font: 800 15px/1.25 var(--font-display); }
.needs-table td a { color: var(--brand-primary-dark); font-weight: 900; }
.needs-login-block .button, .profile-empty-block .button { margin-top: 12px; background: var(--brand-primary); }
.price-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.results-head { display: flex; justify-content: space-between; align-items: end; margin-bottom: 24px; }
.results-head .eyebrow { margin-bottom: 6px; }
.results-head h2 { margin: 0; font: 700 29px var(--font-display); letter-spacing: -1px; }
.results-search-head { margin-bottom: 32px; display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 20px; align-items: center; }
.results-search-wrap { min-width: 0; display: flex; align-items: center; gap: 16px; }
.results-search-wrap .discovery-search { width: 100%; margin: 0; }
.result-count { color: var(--text-muted); font-size: 12px; font-weight: 700; }
.card-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 32px; align-items: stretch; }
.store-card { min-height: 244px; height: 100%; padding: 22px; display: grid; grid-template-columns: 84px 1fr; gap: 18px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); transition: border-color var(--transition-ui), transform var(--transition-ui); }
.store-card:hover, .product-card:hover { border-color: var(--brand-primary); transform: translateY(-2px); box-shadow: none; }
.store-card-aside { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.store-card-aside .status { justify-content: center; }
.logo-placeholder { width: 84px; height: 84px; display: grid; place-items: center; border-radius: var(--radius-panel); color: var(--brand-primary-dark); background: var(--brand-primary-faint); font: 800 30px var(--font-display); }
.logo-placeholder img { width: 100%; height: 100%; object-fit: cover; border-radius: inherit; }
.card-top { min-height: 22px; display: flex; justify-content: space-between; gap: 12px; align-items: center; }
.category-label { color: var(--brand-primary); font-size: 11px; font-weight: 800; letter-spacing: .7px; text-transform: uppercase; }
.status { display: inline-flex; gap: 5px; align-items: center; font-size: 11px; font-weight: 700; white-space: nowrap; }
.status::before { content: ""; width: 6px; height: 6px; border-radius: 50%; }
.status.open { color: var(--brand-primary); }.status.open::before { background: var(--brand-primary); }
.status.closed { color: var(--status-closed); }.status.closed::before { background: var(--status-closed-dot); }
.card-body { min-width: 0; display: flex; flex-direction: column; align-items: flex-start; }
.card-body h3 { margin: 10px 0 5px; font: 700 20px var(--font-display); letter-spacing: -.5px; }
.location-copy, .delivery-copy, .store-name { margin: 4px 0; color: var(--text-muted); font-size: 13px; }
.delivery-copy { margin: 13px 0; color: var(--brand-secondary); }
.store-card .card-body h3 { margin-bottom: 2px; }
.store-card .location-copy { margin: 0 0 7px; }
.store-card .card-body > p:not(.location-copy):not(.delivery-copy) { margin: 6px 0 7px; line-height: 1.45; }
.store-card .delivery-copy { margin: 5px 0 0; }
.store-card .card-actions { margin-top: 14px; }
.card-actions.store-card-actions { justify-content: flex-end; flex-wrap: nowrap; gap: 12px; }
.card-actions.store-card-actions .button { flex: 0 0 clamp(108px, calc((100% - 12px) / 2), 132px); width: clamp(108px, calc((100% - 12px) / 2), 132px); margin-top: 0; }
.card-actions.store-card-actions .button-primary { background: var(--brand-primary); }
.card-actions.store-card-actions .button-primary:hover { background: var(--brand-primary-hover); }
.tick { color: var(--brand-primary-dark); font-weight: 800; }
.card-body .button { min-height: 39px; padding: 8px 14px; margin-top: 7px; font-size: 13px; }
.store-owner-cta { padding: 45px 48px; display: flex; align-items: center; justify-content: space-between; gap: 30px; border-radius: var(--radius-card); }
.store-owner-cta .eyebrow { font-size: 14px; }
.store-owner-cta h2 { margin: 0; font: 700 37px var(--font-display); letter-spacing: -1.7px; }
.store-owner-cta p { margin: 8px 0 0; }
.store-owner-actions { display: flex; gap: 12px; white-space: nowrap; }
.store-owner-cta--dark { margin-top: 75px; color: var(--text-on-dark); background: var(--brand-secondary-dark); }
.store-owner-cta--dark .eyebrow { color: var(--brand-primary-soft); }
.store-owner-cta--dark p { color: var(--footer-text); }
.store-owner-cta--light { margin-top: 40px; border: 1px solid var(--border); background: var(--surface); }
.button-outline-light { color: var(--text-on-dark); border-color: var(--footer-muted); }
.button-light { color: var(--brand-secondary-dark); background: var(--surface); }
.product-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 32px; }
.product-card { min-height: 100%; overflow: hidden; display: flex; flex-direction: column; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); transition: border-color var(--transition-ui), transform var(--transition-ui); }
.product-image { height: 170px; display: grid; place-items: center; position: relative; overflow: hidden; color: var(--brand-secondary); background: linear-gradient(145deg, var(--brand-primary-faint), var(--brand-primary-soft)); font: 700 12px var(--font-display); letter-spacing: 1px; text-transform: uppercase; }
.product-image::after { content: ""; width: 70px; height: 70px; position: absolute; border: 1px solid var(--brand-outline); transform: rotate(35deg); }
.product-image img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 1; }
.product-card .card-body { flex: 1; padding: 18px; }
.product-card .card-top { min-height: 18px; }
.product-card .card-body h3 { margin: 7px 0 4px; line-height: 1.2; }
.product-card .price { margin: 5px 0 4px; line-height: 1.15; }
.product-card .store-name { margin: 2px 0; line-height: 1.25; }
.product-card .location-copy { margin: 4px 0 0; line-height: 1.35; }
.product-card .button-primary { background: var(--brand-primary); }
.product-card .button-primary:hover { background: var(--brand-primary-hover); }
.product-card .card-actions { flex-wrap: nowrap; gap: 18px; }
.product-card .card-actions .button { flex: 1 1 0; min-width: 0; }
.price { margin: 9px 0 6px; color: var(--text); font: 800 19px var(--font-display); }
.store-name { color: var(--brand-secondary); font-weight: 700; }
.empty-state { grid-column: 1/-1; padding: 60px 25px; text-align: center; border: 1px dashed var(--border-strong); border-radius: var(--radius-panel); background: var(--surface-soft); }
.empty-state h3 { margin: 0; color: var(--text); font: 700 24px var(--font-display); }
.empty-state p { max-width: 520px; margin: 10px auto 0; }
.empty-state .button { margin-top: 20px; }
.detail-page { padding-top: 52px; }
.back-link { display: inline-flex; margin-bottom: 28px; color: var(--brand-primary-dark); font-weight: 700; }
.detail-layout { display: grid; grid-template-columns: minmax(280px, .85fr) minmax(0, 1.15fr); gap: clamp(32px, 4vw, 56px); align-items: center; }
.store-detail-layout { grid-template-columns: auto minmax(0, 1fr); column-gap: 60px; }
.detail-media { min-height: 430px; display: grid; place-items: center; position: relative; overflow: hidden; border-radius: var(--radius-card); background: linear-gradient(145deg, var(--brand-primary-faint), var(--brand-primary-soft)); }
.detail-media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.store-detail-media { width: 450px; height: 360px; max-width: 100%; min-height: 0; aspect-ratio: 5 / 4; justify-self: start; }
.store-detail-media span { color: var(--brand-primary-dark); font: 800 clamp(62px, 8.5vw, 110px) var(--font-display); }
.product-detail-media > span { color: var(--brand-secondary); font: 700 13px var(--font-display); letter-spacing: 1.4px; text-transform: uppercase; }
.detail-meta { display: flex; align-items: center; gap: 18px; }
.detail-copy h1 { margin: 16px 0 12px; font: 700 clamp(38px, 4.4vw, 58px)/1.05 var(--font-display); letter-spacing: -2px; }
.detail-copy > p { max-width: 650px; margin: 0 0 16px; font-size: 18px; }
.detail-location { margin-bottom: 10px !important; color: var(--brand-secondary) !important; font-weight: 600; }
.detail-price { margin: 0 0 22px; color: var(--brand-primary-dark) !important; font: 800 30px var(--font-display) !important; }
.detail-facts { margin: 32px 0 0; display: flex; flex-wrap: wrap; gap: 22px 34px; }
.detail-facts div { display: grid; gap: 3px; }
.detail-facts .detail-fact { min-width: 0; grid-template-columns: 36px minmax(0, 1fr); gap: 9px 10px; align-items: center; }
.detail-fact dt { grid-row: 1; }
.detail-fact dd { grid-row: 1; align-self: center; }
.detail-fact-icon { width: 34px; height: 34px; display: inline-grid; place-items: center; border-radius: 50%; color: var(--text-muted); background: var(--surface-soft); }
.detail-fact-icon svg { width: 18px; height: 18px; stroke-width: 2; }
.detail-facts dt, .detail-store > span { color: var(--text-muted); font-size: 12px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase; }
.detail-facts dd { margin: 0; color: var(--brand-secondary); font-weight: 700; }
.detail-store { margin-top: 32px; padding: 20px; display: grid; gap: 3px; border-left: 3px solid var(--brand-primary); background: var(--surface-soft); }
.detail-store a { color: var(--brand-secondary); font: 700 20px var(--font-display); }
.detail-store small { color: var(--text-muted); }
.detail-related { padding-top: 85px; }
.about-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--border); border-left: 1px solid var(--border); }
.about-grid article { min-height: 240px; padding: 28px 32px; display: flex; flex-direction: column; border-right: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.about-card-icon { width: 28px; height: 28px; display: grid; place-items: center; color: var(--brand-primary); }
.about-card-icon svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.about-grid h2 { margin: 0 0 12px; display: flex; align-items: center; justify-content: space-between; gap: 18px; font: 700 28px var(--font-display); }
.about-grid h2 .about-card-icon { flex: 0 0 28px; margin-left: auto; }
.about-grid p { margin: 0 0 18px; line-height: 1.65; }
.about-card-action { width: fit-content; margin-top: auto; padding: 9px 13px; display: inline-flex; align-items: center; gap: 8px; border-radius: var(--radius-control); background: var(--surface-soft); color: var(--text); font-weight: 700; font-size: 14px; transition: color .2s ease, background-color .2s ease, transform .2s ease; }
.about-card-action span { font-size: 17px; line-height: 1; transition: transform .2s ease; }
.about-card-action:hover { background: var(--brand-primary); color: #fff; transform: translateY(-1px); }
.about-card-action:hover span { transform: translateX(3px); }
.about-detail-content { padding-top: 12px; display: grid; grid-template-columns: minmax(280px, .9fr) minmax(0, 1.1fr); gap: 72px; align-items: start; }
.about-detail-copy { padding-top: 4px; }
.about-detail-copy h2 { max-width: 540px; margin: 0; color: var(--brand-secondary); font: 700 34px/1.18 var(--font-display); letter-spacing: -1px; }
.about-detail-copy p { max-width: 560px; margin: 16px 0 0; font-size: 17px; }
.about-detail-list { display: grid; gap: 12px; }
.about-detail-list article { min-height: 126px; padding: 22px 24px; display: grid; grid-template-columns: 34px 1fr; gap: 18px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.about-detail-list span { color: var(--footer-muted); font: 800 12px var(--font-display); }
.about-detail-list p { margin: 0; color: var(--text-body); line-height: 1.65; }
.resource-main-media img { width: 100%; height: auto; display: block; border-radius: var(--radius-panel); }
.resources-needs { padding-top: 96px; display: grid; grid-template-columns: minmax(280px, .9fr) minmax(0, 1.1fr); gap: 72px; align-items: start; }
.resources-section-copy h2, .resources-section h2, .resources-scale h2, .resources-infrastructure h2 { margin: 0; color: var(--brand-secondary); font: 700 34px/1.18 var(--font-display); letter-spacing: -1.2px; }
.resources-section-copy > p, .resources-section-head > p, .resources-infrastructure p { margin: 18px 0 0; font-size: 18px; line-height: 1.72; }
.resources-needs-cards { display: grid; gap: 16px; }
.resources-needs-cards article { min-height: 126px; padding: 24px 26px; display: flex; flex-direction: column; justify-content: center; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); transition: border-color var(--transition-ui), transform var(--transition-ui); }
.resources-needs-cards article:hover { border-color: var(--brand-primary); transform: translateY(-2px); }
.resources-tech-grid article:hover { transform: translateY(-2px); }
.resources-needs-cards h3, .resources-tech-grid h3, .resources-scale-grid h3 { margin: 0 0 9px; color: var(--text); font: 700 21px/1.3 var(--font-display); }
.resources-needs-cards p, .resources-tech-grid p, .resources-scale-grid p { margin: 0; line-height: 1.68; }
.resources-section { padding-top: 96px; }
.resources-section-head { max-width: 900px; }
.resources-tech-grid { margin-top: 36px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 36px 40px; }
.resources-tech-grid article { min-width: 0; padding: 6px 0; display: grid; grid-template-columns: 96px minmax(0, 1fr); gap: 20px; align-items: center; transition: transform var(--transition-ui); }
.resources-tech-grid img { width: 96px; height: 96px; display: block; object-fit: contain; }
.resources-scale { margin-top: 96px; padding: 52px 56px; border-radius: var(--radius-panel); background: var(--surface-soft); }
.resources-scale-body { max-width: 900px; margin: 14px 0 0; font-size: 18px; line-height: 1.72; }
.resources-scale-grid { margin-top: 28px; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.resources-scale-grid article { min-height: 150px; padding: 24px; display: flex; flex-direction: column; justify-content: center; border: 0; border-radius: var(--radius-panel); background: var(--surface); }
.resources-scale-grid h3 { font-size: 19px; }
.resources-infrastructure { margin-top: 96px; padding: 0; display: grid; grid-template-columns: minmax(280px, .9fr) minmax(0, 1.1fr); gap: 72px; }
.resources-infrastructure p:first-child { margin-top: 0; }
.resources-conclusion { margin-top: 100px; padding: 76px 0; text-align: center; background: var(--brand-primary-faint); }
.resources-conclusion h2 { max-width: 980px; margin: 0 auto; color: var(--brand-secondary); font: 700 clamp(36px, 4.6vw, 56px)/1.12 var(--font-display); letter-spacing: -2px; }
.resources-conclusion p { max-width: 900px; margin: 20px auto 0; font-size: 18px; line-height: 1.72; }
.resources-conclusion p + p { margin-top: 10px; }
.pricing-intro { max-width: 900px; text-align: center; }
.pricing-pill { min-height: 34px; margin-bottom: 18px; padding: 8px 16px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; color: var(--text-on-dark); background: var(--brand-primary); font-size: 12px; font-weight: 800; letter-spacing: .9px; text-transform: uppercase; }
.pricing-intro h2, .pricing-difference h2, .pricing-final-cta h2 { margin: 0; color: var(--brand-secondary); font: 700 34px/1.18 var(--font-display); letter-spacing: -1.2px; }
.pricing-intro p { max-width: 760px; margin: 16px auto 0; font-size: 18px; line-height: 1.72; }
.pricing-intro--journey { padding-top: 34px; }
.pricing-console { padding-top: 38px; }
.pricing-tab-switch { width: fit-content; margin: 0 auto; padding: 6px; display: flex; gap: 5px; border-radius: 999px; background: var(--surface-soft); }
.pricing-tab-switch button { min-width: 136px; min-height: 42px; padding: 10px 20px; border: 0; border-radius: 999px; color: var(--brand-secondary); background: transparent; font-weight: 900; transition: color var(--transition-ui), background var(--transition-ui), box-shadow var(--transition-ui); }
.pricing-tab-switch button:hover { color: var(--brand-primary-dark); background: color-mix(in srgb, var(--surface) 72%, transparent); }
.pricing-tab-switch button.is-active { color: var(--text-on-dark); background: var(--brand-primary); box-shadow: none; }
.pricing-journey-note { width: min(860px, 100%); margin: 24px auto 0; display: flex; align-items: center; justify-content: center; gap: clamp(18px, 3.2vw, 42px); color: var(--text-muted); font-size: 14px; font-weight: 800; text-align: center; }
.pricing-journey-note button { padding: 0; border: 0; color: color-mix(in srgb, var(--text-muted) 62%, white); background: transparent; font: inherit; font-weight: 800; white-space: nowrap; transition: color var(--transition-ui), opacity var(--transition-ui); }
.pricing-journey-note button:hover { color: var(--brand-primary-dark); }
.pricing-journey-note button.is-active { color: var(--brand-primary); }
.pricing-tab-panel { margin-top: 34px; }
.pricing-tab-panel[hidden] { display: none; }
.pricing-card-grid { display: grid; gap: 22px; align-items: start; }
.pricing-card-grid--presence { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.pricing-card-grid--commerce { width: min(850px, 100%); margin-inline: auto; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.pricing-journey-card { min-width: 0; display: flex; flex-direction: column; border: 1px solid var(--border); border-radius: 16px; background: var(--surface); transition: border-color var(--transition-ui), transform var(--transition-ui), box-shadow var(--transition-ui); overflow: hidden; }
.pricing-journey-card:hover { border-color: var(--brand-primary); transform: translateY(-2px); box-shadow: none; }
.pricing-journey-card--featured { border-color: color-mix(in srgb, var(--brand-primary) 78%, var(--border)); background: linear-gradient(180deg, color-mix(in srgb, var(--brand-primary-faint) 72%, var(--surface)), var(--surface) 46%); }
.pricing-card-main { min-height: 410px; padding: 28px; display: flex; flex: 1 1 auto; flex-direction: column; }
.pricing-journey-card--wide .pricing-card-main { min-height: 390px; }
.pricing-card-copy { min-height: 136px; display: flex; flex-direction: column; }
.pricing-card-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.pricing-card-head h3 { margin: 0; color: var(--text); font: 850 28px/1.1 var(--font-display); letter-spacing: 0; }
.pricing-card-billing-toggle { min-width: 118px; padding: 3px; display: flex; border: 0; border-radius: 999px; background: var(--surface-soft); }
.pricing-card-billing-toggle button { flex: 1 1 0; min-height: 26px; padding: 4px 8px; border: 0; border-radius: 999px; color: var(--text-muted); background: transparent; font-size: 11px; font-weight: 900; line-height: 1; transition: color var(--transition-ui), background var(--transition-ui), box-shadow var(--transition-ui); }
.pricing-card-billing-toggle button:hover { color: var(--brand-primary-dark); }
.pricing-card-billing-toggle button.is-active { color: var(--text-on-dark); background: var(--brand-primary); box-shadow: none; }
.pricing-card-copy > span { margin-top: 12px; color: var(--brand-primary-dark); font-size: 12px; font-weight: 900; letter-spacing: .8px; line-height: 1.45; text-transform: uppercase; }
.pricing-card-copy > p { margin: 16px 0 0; color: var(--text-body); font-size: 16px; line-height: 1.55; }
.pricing-card-price-block { min-height: 94px; padding-top: 20px; display: flex; flex-direction: column; justify-content: flex-start; border-top: 1px solid var(--border); }
.pricing-card-rate { display: flex; align-items: baseline; gap: 7px; }
.pricing-card-price { display: block; color: var(--text); font: 850 38px/1 var(--font-display); letter-spacing: 0; text-transform: capitalize; }
.pricing-card-period { color: var(--text-muted); font-size: 13px; font-weight: 800; }
.pricing-card-was { width: fit-content; margin-top: 8px; color: var(--text-muted); font-size: 13px; font-weight: 800; text-decoration: line-through; text-decoration-thickness: 1px; }
.pricing-card-action.button { width: 100%; min-height: 48px; margin-top: 14px; color: var(--brand-primary-dark); border-color: var(--border-strong); background: var(--surface); box-shadow: none; }
.pricing-card-action.button:hover, .pricing-journey-card:hover .pricing-card-action.button { color: var(--text-on-dark); border-color: var(--brand-primary); background: var(--brand-primary); }
.pricing-highlights { min-height: 76px; margin: 22px 0 0; padding: 0; display: grid; gap: 8px; list-style: none; }
.pricing-highlights li { display: grid; grid-template-columns: 14px minmax(0, 1fr); gap: 8px; color: var(--text-body); font-size: 14px; line-height: 1.4; }
.pricing-highlights li::before { content: ""; width: 6px; height: 6px; margin-top: .6em; border-radius: 50%; background: var(--brand-primary); }
.pricing-feature-toggle { width: 100%; min-height: 52px; padding: 14px 28px; display: flex; align-items: center; gap: 10px; border: 0; border-top: 1px solid var(--border); color: var(--brand-primary-dark); background: var(--surface); font-weight: 900; text-align: left; }
.pricing-feature-toggle:hover { background: var(--brand-primary-faint); }
.pricing-toggle-icon { width: 9px; height: 9px; border-right: 2px solid currentColor; border-bottom: 2px solid currentColor; transform: rotate(45deg); transition: transform .22s ease; }
.pricing-feature-toggle[aria-expanded="true"] .pricing-toggle-icon { transform: rotate(225deg); }
.pricing-toggle-hide { display: none; }
.pricing-feature-toggle[aria-expanded="true"] .pricing-toggle-show { display: none; }
.pricing-feature-toggle[aria-expanded="true"] .pricing-toggle-hide { display: inline; }
.pricing-feature-panel { height: 0; overflow: hidden; opacity: 0; transition: height .24s ease, opacity .2s ease; }
.pricing-feature-panel.is-open { opacity: 1; }
.pricing-feature-panel > p { margin: 0; padding: 18px 28px 0; color: var(--brand-primary-dark); font-weight: 900; }
.pricing-feature-panel ul { margin: 0; padding: 18px 28px 28px; display: grid; gap: 10px; list-style: none; }
.pricing-feature-panel li { display: grid; grid-template-columns: 18px minmax(0, 1fr); gap: 9px; color: var(--text-body); line-height: 1.45; }
.pricing-feature-panel li::before { content: "\2713"; color: var(--brand-primary); font-weight: 900; }
.pricing-plans { padding-top: 48px; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 22px; align-items: stretch; }
.pricing-plan { min-width: 0; padding: 28px; display: flex; flex-direction: column; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); transition: border-color var(--transition-ui), transform var(--transition-ui); }
.pricing-plan:hover { border-color: var(--brand-primary); transform: translateY(-2px); }
.pricing-plan--listing { grid-column: 1 / -1; padding: 30px; display: grid; grid-template-columns: minmax(220px, .78fr) minmax(0, 1.5fr) minmax(220px, .82fr); gap: 30px; align-items: stretch; border: 0; background: var(--surface-soft); }
.pricing-plan--listing:hover { border-color: transparent; }
.pricing-plan--featured { border-color: var(--brand-primary); background: linear-gradient(180deg, var(--brand-primary-faint), var(--surface) 44%); }
.pricing-plan-head { padding-bottom: 20px; border-bottom: 1px solid var(--border); }
.pricing-plan--listing .pricing-plan-head { padding-bottom: 0; border-bottom: 0; }
.pricing-plan h3 { margin: 0; color: var(--text); font: 700 25px/1.2 var(--font-display); letter-spacing: -.7px; }
.pricing-plan h3 .pricing-title-icon { width: 20px; height: 20px; margin-left: 8px; display: inline-flex; align-items: center; justify-content: center; vertical-align: -.12em; color: var(--brand-primary); font: 800 20px/1 var(--font-display); }
.pricing-plan-head > span:not(.pricing-free-badge) { min-height: 22px; margin-top: 12px; display: block; color: var(--brand-primary-dark); font-size: 13px; font-weight: 800; letter-spacing: .6px; text-transform: uppercase; }
.pricing-plan-head .pricing-free-badge { width: fit-content; min-height: 34px; margin-top: 22px; padding: 8px 18px; border-radius: 999px; color: var(--text-on-dark); background: var(--brand-primary); font-size: 13px; font-weight: 900; letter-spacing: .8px; box-shadow: none; }
.pricing-plan-head p { margin: 12px 0 0; color: var(--brand-secondary); line-height: 1.55; }
.pricing-plan--listing .pricing-plan-head p { margin-bottom: 22px; }
.pricing-price { margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--border); }
.pricing-price-mode p, .pricing-price-contact { margin: 0; }
.pricing-price-mode p { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; }
.pricing-save { min-height: 24px; padding: 5px 8px; display: inline-flex; align-items: center; border-radius: 5px; color: var(--brand-secondary-dark); background: var(--brand-primary-soft); font-size: 12px; font-weight: 900; line-height: 1; text-transform: uppercase; }
.pricing-price s { color: var(--brand-secondary); font-size: 13px; font-weight: 700; }
.pricing-price strong { margin-top: 8px; display: block; color: var(--text); font: 800 40px/1 var(--font-display); letter-spacing: -1.6px; }
.pricing-period { margin-top: 4px; display: block; color: var(--text-muted); font-size: 13px; font-weight: 700; }
.pricing-price-yearly { display: none; }
.pricing-plans:has(.pricing-billing-toggle input[value="yearly"]:checked) .pricing-price-monthly { display: none; }
.pricing-plans:has(.pricing-billing-toggle input[value="yearly"]:checked) .pricing-price-yearly { display: block; }
.pricing-price-contact { display: flex; flex-direction: column; align-items: flex-start; }
.pricing-price-contact strong { font-size: 34px; }
.pricing-plan ul { margin: 22px 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.pricing-plan--listing ul { margin: 0; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px 18px; }
.pricing-plan li { display: grid; grid-template-columns: 16px minmax(0, 1fr); gap: 9px; line-height: 1.45; }
.pricing-plan li::before { content: ""; width: 7px; height: 7px; margin-top: .55em; border-radius: 50%; background: var(--brand-primary); }
.pricing-best { margin: auto 0 20px; color: var(--brand-secondary); line-height: 1.55; }
.pricing-plan-action { display: flex; flex-direction: column; align-items: stretch; justify-content: space-between; gap: 22px; }
.pricing-plan--listing .pricing-best { margin: 0; align-self: start; }
.pricing-best strong { color: var(--text); }
.pricing-plan .button { width: 100%; }
.pricing-plan--listing .button { margin-top: auto; align-self: end; }
.pricing-free-action { color: var(--brand-primary); border: 0; background: var(--surface); }
.pricing-free-action:hover { color: var(--text-on-dark); background: var(--brand-primary); }
.pricing-billing-toggle { grid-column: 1 / -1; width: fit-content; margin: 26px auto 8px; padding: 6px; display: inline-flex; gap: 4px; border-radius: 999px; background: var(--surface-soft); }
.pricing-billing-toggle label { cursor: pointer; }
.pricing-billing-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.pricing-billing-toggle span { min-width: 108px; min-height: 40px; padding: 10px 18px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; color: var(--brand-secondary); font-size: 14px; font-weight: 800; transition: color var(--transition-ui), background var(--transition-ui); }
.pricing-billing-toggle input:checked + span { color: var(--text-on-dark); background: var(--brand-primary); }
.pricing-billing-toggle label:hover span { color: var(--brand-primary-dark); background: var(--surface); }
.pricing-billing-toggle input:checked + span:hover { color: var(--text-on-dark); background: var(--brand-primary); }
.pricing-difference { margin-top: 96px; padding: 56px; display: grid; grid-template-columns: minmax(280px, .9fr) minmax(0, 1.1fr); gap: 58px; align-items: start; border-radius: var(--radius-panel); background: var(--surface-soft); }
.pricing-difference-copy h3 { margin: 18px 0 0; color: var(--brand-primary-dark); font: 800 14px var(--font-display); letter-spacing: .9px; text-transform: uppercase; }
.pricing-difference-copy p { margin: 18px 0 0; font-size: 18px; line-height: 1.72; }
.pricing-support-grid { display: grid; gap: 16px; }
.pricing-support-grid article { min-height: 126px; padding: 24px 26px; display: flex; flex-direction: column; justify-content: center; border-radius: var(--radius-panel); background: var(--surface); }
.pricing-support-grid h3 { margin: 0 0 9px; color: var(--text); font: 700 21px/1.3 var(--font-display); }
.pricing-support-grid p { margin: 0; line-height: 1.68; }
.pricing-final-cta { margin-top: 96px; padding: 76px 0; text-align: center; background: var(--brand-primary-faint); }
.pricing-final-cta p { max-width: 830px; margin: 18px auto 0; font-size: 18px; line-height: 1.72; }
.pricing-final-actions { margin-top: 28px; display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; }
.solutions-feature { padding-top: 12px; }
.solutions-feature-intro { display: grid; grid-template-columns: minmax(280px, .7fr) minmax(0, 1.3fr); gap: 40px; align-items: center; }
.solutions-feature-copy h2, .solutions-section > h2 { margin: 0; color: var(--brand-secondary); font: 700 34px/1.18 var(--font-display); letter-spacing: -1.2px; }
.solutions-feature-copy p { max-width: 470px; margin: 18px 0 0; font-size: 18px; line-height: 1.72; }
.solutions-feature-media { width: 100%; height: auto; display: block; border-radius: var(--radius-panel); }
.solutions-stack { margin-top: 48px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 40px; }
.solutions-stack article { min-height: 190px; padding: 22px; display: grid; grid-template-columns: 140px minmax(0, 1fr); gap: 24px; align-items: center; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); transition: border-color var(--transition-ui), transform var(--transition-ui); }
.solutions-stack article:hover { border-color: var(--brand-primary); transform: translateY(-2px); }
.solutions-stack img { width: 140px; height: 140px; display: block; object-fit: cover; border-radius: var(--radius-control); }
.solutions-stack span, .solutions-benefit-grid span, .solutions-process span { color: var(--footer-muted); font: 800 12px var(--font-display); }
.solutions-stack h3, .solutions-benefit-grid h3, .solutions-process h3 { margin: 20px 0 10px; color: var(--text); font: 700 22px/1.25 var(--font-display); }
.solutions-stack p, .solutions-benefit-grid p, .solutions-process p { margin: 0; line-height: 1.68; }
.solutions-section { padding-top: 96px; }
.solutions-section > h2 { max-width: 760px; margin-bottom: 32px; }
.solutions-process-section { margin-top: 96px; padding: 84px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.solutions-process-section > h2 { margin-bottom: 40px; }
.solutions-benefits-section { padding-top: 84px; }
.solutions-benefit-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 40px; }
.solutions-benefit-grid article { min-height: 180px; padding: 20px; display: grid; grid-template-columns: 140px minmax(0, 1fr); gap: 24px; align-items: center; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.solutions-benefit-media { width: 140px; height: auto; display: block; object-fit: contain; border-radius: var(--radius-control); }
.solutions-benefit-grid h3 { margin: 0 0 8px; font-size: 20px; }
.solutions-process { margin: 0; padding: 0; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0; list-style: none; }
.solutions-process li { min-width: 0; padding: 0 24px 8px; text-align: center; }
.solutions-process li + li { border-left: 1px solid var(--border); }
.solutions-step-media { width: 75%; height: auto; aspect-ratio: 1; margin: 0 auto 24px; display: block; object-fit: contain; border-radius: var(--radius-panel); }
.solutions-process span { display: block; }
.solutions-process h3 { margin: 14px 0 9px; font-size: 20px; }
.solutions-impact { margin-top: 100px; padding: 76px 0; text-align: center; background: var(--brand-primary-faint); }
.solutions-impact h2 { margin: 0 auto; max-width: 820px; color: var(--brand-secondary); font: 700 clamp(36px, 4.6vw, 56px)/1.12 var(--font-display); letter-spacing: -2px; }
.solutions-impact p { max-width: 780px; margin: 20px auto 0; font-size: 18px; line-height: 1.72; }
.solutions-impact p + p { margin-top: 10px; }
.platform-commerce { padding-top: 12px; display: grid; grid-template-columns: minmax(280px, .9fr) minmax(0, 1.1fr); gap: 72px; align-items: start; }
.platform-commerce h2, .platform-section > h2, .platform-reality h2 { margin: 0; color: var(--brand-secondary); font: 700 34px/1.18 var(--font-display); letter-spacing: -1.2px; }
.platform-commerce-copy > p { margin: 18px 0 0; font-size: 18px; line-height: 1.72; }
.platform-commerce-cards { display: grid; gap: 16px; }
.platform-commerce-cards article { min-height: 126px; padding: 24px 26px; display: grid; grid-template-columns: 38px 1fr; gap: 18px; align-items: start; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); transition: border-color var(--transition-ui), transform var(--transition-ui); }
.platform-commerce-cards article:hover { border-color: var(--brand-primary); transform: translateY(-2px); }
.platform-commerce-cards span { color: var(--footer-muted); font: 800 12px var(--font-display); }
.platform-commerce-cards h3, .platform-category-grid h3, .platform-principle-grid h3, .platform-journey h3 { margin: 0 0 9px; color: var(--text); font: 700 21px/1.3 var(--font-display); }
.platform-commerce-cards p, .platform-category-grid p, .platform-principle-grid p, .platform-journey p { margin: 0; line-height: 1.68; }
.platform-reality { margin-top: 100px; padding: 0; }
.platform-reality-layout { display: grid; grid-template-columns: minmax(280px, .72fr) minmax(0, 1.28fr); gap: 40px; align-items: center; }
.platform-reality-layout p { max-width: 620px; margin: 18px 0 0; font-size: 18px; line-height: 1.72; }
.platform-reality-media { width: 100%; height: auto; display: block; }
.platform-section { padding-top: 96px; }
.platform-section > h2 { max-width: 760px; margin-bottom: 32px; }
.platform-store-section { margin-top: 96px; padding: 56px 58px; border-radius: var(--radius-panel); background: var(--surface-soft); }
.platform-store-section > h2 { margin-bottom: 0; }
.platform-store-subline { max-width: 800px; margin: 14px 0 0; font-size: 18px; line-height: 1.72; }
.platform-category-grid { margin-top: 40px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 40px; }
.platform-category-grid article { min-width: 0; display: grid; grid-template-columns: 120px minmax(0, 1fr); gap: 20px; align-items: center; }
.platform-category-media { width: 120px; height: auto; display: block; object-fit: contain; }
.platform-principle-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 18px; }
.platform-principles-section > h2 { max-width: 100%; }
.platform-principle-grid article { padding: 24px; border-top: 2px solid var(--brand-primary); background: var(--surface-soft); }
.platform-principle-grid h3 { font-size: 19px; }
.platform-journey { margin: 0; padding: 0; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 0; list-style: none; }
.platform-journey-section > h2 { margin-bottom: 16px; }
.platform-journey li { padding: 4px 24px 8px; position: relative; }
.platform-journey li + li::before { content: ""; width: 2px; height: 68%; position: absolute; left: 0; top: 50%; background: var(--brand-primary); transform: translateY(-50%); }
.platform-journey h3 { margin-top: 0; }
.platform-closing { margin-top: 100px; padding: 76px 0; text-align: center; background: var(--brand-primary-faint); }
.platform-closing h2 { max-width: 980px; margin: 0 auto; color: var(--brand-secondary); font: 700 clamp(36px, 4.6vw, 56px)/1.12 var(--font-display); letter-spacing: -2px; }
.platform-closing p { max-width: 980px; margin: 20px auto 0; font-size: 18px; line-height: 1.72; }
.company-hero-media { max-width: 1080px; margin: 0 auto 38px; }
.company-hero-media img { width: 100%; height: auto; display: block; border-radius: var(--radius-panel); }
.company-overview-copy { width: 100%; margin: 0; padding-bottom: 84px; border-bottom: 1px solid var(--border); }
.company-overview-copy p { margin: 0; font-size: 18px; line-height: 1.76; }
.company-overview-copy p + p { margin-top: 18px; }
.company-split { padding: 84px 0; display: grid; grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr); gap: 64px; align-items: center; border-bottom: 1px solid var(--border); }
.company-split h2, .company-section h2, .company-cta h2 { margin: 0; color: var(--brand-secondary); font: 700 34px/1.18 var(--font-display); letter-spacing: -1.2px; }
.company-why-media img { width: 100%; height: auto; display: block; border-radius: var(--radius-panel); }
.company-why-content h2 { margin-bottom: 20px; }
.company-copy { max-width: 740px; }
.company-copy p { margin: 0 0 18px; font-size: 18px; line-height: 1.76; }
.company-copy p:last-child { margin-bottom: 0; }
.company-section { padding: 84px 0 0; }
.company-section > h2 { max-width: 760px; margin-bottom: 40px; }
.company-card-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 0; }
.company-card-grid article { min-width: 0; padding: 0 32px 8px; text-align: center; }
.company-card-grid article + article { border-left: 1px solid var(--border); }
.company-growth-media { width: 100%; height: auto; display: block; margin: 0 auto 26px; transition: transform var(--transition-ui); }
.company-card-grid article:hover .company-growth-media { transform: translateY(-3px); }
.company-audience-grid article { padding: 28px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); transition: border-color var(--transition-ui), transform var(--transition-ui); }
.company-audience-grid article:hover { border-color: var(--brand-primary); transform: translateY(-2px); }
.company-card-grid h3, .company-audience-grid h3 { margin: 0 0 12px; color: var(--text); font: 700 22px var(--font-display); letter-spacing: -.5px; }
.company-card-grid p, .company-audience-grid p { margin: 0; line-height: 1.68; }
.company-card-grid p { max-width: 330px; margin-inline: auto; }
.company-audience-grid { margin-top: 48px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 40px; }
.company-audience-grid article { min-height: 220px; padding: 0; display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); align-items: stretch; overflow: hidden; }
.company-audience-grid img { width: 100%; height: 100%; padding: 0; display: block; object-fit: contain; }
.company-audience-copy { padding: 28px; display: flex; flex-direction: column; justify-content: center; }
.company-audience-grid h3 { margin: 0 0 12px; }
.company-audience-grid p { margin: 0; }
.company-audience-grid article:nth-child(2) { background: var(--surface); }
.company-vision { margin-top: 90px; padding: 76px 0; text-align: center; background: var(--brand-primary-faint); }
.company-vision h2 { margin: 0 auto; max-width: 820px; color: var(--brand-secondary); font: 700 clamp(36px, 4.6vw, 56px)/1.12 var(--font-display); letter-spacing: -2px; }
.company-vision p { max-width: 780px; margin: 20px auto 0; font-size: 18px; line-height: 1.72; }
.company-cta { margin-top: 84px; padding: 34px 36px; display: flex; align-items: center; justify-content: space-between; gap: 28px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.company-cta p { max-width: 680px; margin: 10px 0 0; }
.company-cta-actions { display: flex; flex-wrap: wrap; gap: 12px; white-space: nowrap; }
.contact-layout { display: grid; grid-template-columns: minmax(280px, .9fr) minmax(0, 1.1fr); gap: 42px; align-items: start; }
.contact-details h2, .contact-form h2 { margin: 0; color: var(--brand-secondary); font: 700 30px/1.2 var(--font-display); letter-spacing: -1px; }
.contact-details > div:first-child p { max-width: 520px; margin: 12px 0 0; font-size: 17px; }
.contact-method-grid { margin-top: 24px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; }
.contact-method-grid article { min-height: 154px; padding: 20px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.contact-method-grid span, .contact-form label, .inquiry-grid span { color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.contact-card-head { min-height: 30px; margin-bottom: 16px; display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.contact-card-head > span:first-child { color: var(--brand-primary); letter-spacing: .8px; text-transform: uppercase; }
.contact-method-grid .contact-icon { width: 30px; height: 30px; flex: 0 0 30px; display: grid; place-items: center; color: var(--brand-primary); background: transparent; }
.contact-icon svg { width: 22px; height: 22px; fill: currentColor; stroke: none; }
.contact-icon svg path { fill: currentColor; stroke: none; }
.contact-method-grid strong { display: block; color: var(--text); font: 800 18px var(--font-display); }
.contact-method-grid a { color: var(--brand-primary-dark); }
.contact-method-grid p { margin: 8px 0 0; font-size: 14px; line-height: 1.55; }
.contact-whatsapp-card { grid-column: 1 / -1; min-height: 0 !important; }
.contact-whatsapp-card label { display: block; margin-top: 18px; color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.contact-whatsapp-card textarea { width: 100%; min-height: 112px; margin-top: 7px; padding: 12px; border: 1px solid var(--border); border-radius: var(--radius-control); outline: 0; color: var(--text); background: var(--surface); resize: vertical; }
.contact-whatsapp-card textarea:focus { border-color: var(--brand-primary); box-shadow: 0 0 0 3px var(--focus-ring); }
.contact-whatsapp-message { margin-top: 18px !important; }
.contact-whatsapp-card .button { width: 100%; margin-top: 12px; color: var(--text-on-dark); }
.contact-whatsapp-card .button:hover { color: var(--text-on-dark); }
.contact-form .button-primary, .contact-whatsapp-card .button-primary { background: var(--brand-primary); }
.contact-form .button-primary:hover, .contact-whatsapp-card .button-primary:hover { background: var(--brand-primary-hover); }
.contact-form { padding: 28px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.contact-form-head { margin-bottom: 24px; }
.inquiry-grid { margin: 0 0 24px; padding: 0; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; border: 0; }
.inquiry-grid label { cursor: pointer; }
.contact-form .inquiry-grid label { margin-bottom: 0; }
.inquiry-grid input { position: absolute; width: 1px; height: 1px; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); opacity: 0; pointer-events: none; }
.inquiry-grid span { min-height: 48px; padding: 12px 14px; display: flex; align-items: center; justify-content: center; border: 0; border-radius: var(--radius-control); background: var(--surface-soft); text-align: center; transition: color var(--transition-ui), background var(--transition-ui); }
.inquiry-grid input:checked + span { color: var(--text-on-dark); border-color: var(--brand-primary); background: var(--brand-primary); }
.contact-field-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; }
.contact-form label { display: block; margin-bottom: 24px; }
.contact-form .contact-field-grid label { margin-bottom: 0; }
.contact-message-field { margin-top: 24px; }
.contact-form > label:last-of-type { margin-bottom: 24px; }
.contact-form input, .contact-form textarea { width: 100%; margin-top: 7px; padding: 0 12px; border: 1px solid var(--border); border-radius: var(--radius-control); outline: 0; color: var(--text); background: var(--surface); font-weight: 400; }
.contact-form input { height: 46px; }
.contact-form .inquiry-grid input { width: 1px; height: 1px; margin: -1px; padding: 0; border: 0; }
.contact-form textarea { min-height: 132px; padding-top: 12px; resize: vertical; }
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--brand-primary); box-shadow: 0 0 0 3px var(--focus-ring); }
.contact-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.contact-actions .button { flex: 1 1 170px; }
.auth-page { min-height: 560px; padding-block: 60px 110px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 64px; align-items: start; }
.auth-owner-panel { max-width: 560px; padding-block: 18px; align-self: center; }
.auth-owner-panel h2 { margin: 0; color: var(--brand-secondary); font: 800 32px/1.15 var(--font-display); letter-spacing: -.8px; }
.auth-owner-panel p { margin: 10px 0 18px; max-width: 560px; color: var(--text-body); font-size: 17px; line-height: 1.55; }
.auth-owner-panel .button { min-height: 42px; padding-inline: 18px; border-radius: 999px; color: var(--brand-primary-dark); }
.auth-form-wrap { width: 100%; padding: 92px 48px; border-radius: var(--radius-panel); background: var(--surface-soft); }
.auth-form { width: 100%; margin: 0; padding: 32px; border: 0; border-radius: var(--radius-panel); background: var(--surface); box-shadow: none; }
.auth-form h2 { margin: 0; font: 800 28px/1.15 var(--font-display); letter-spacing: -.6px; }.auth-form > p { margin: 8px 0 26px; }
.auth-card-head { margin-bottom: 24px; display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.auth-tabs { flex: 0 0 auto; padding: 3px; display: inline-grid; grid-template-columns: 1fr 1fr; gap: 3px; border: 0; border-radius: 999px; background: var(--surface-soft); }
.auth-tab { min-width: 74px; min-height: 30px; padding: 6px 13px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; color: var(--brand-secondary); font-size: 11px; font-weight: 800; letter-spacing: 0; text-align: center; }
.auth-tab:hover { color: var(--brand-primary-dark); background: color-mix(in srgb, var(--surface) 72%, transparent); }
.auth-tab.is-active { color: var(--brand-primary-dark); background: var(--surface); font-weight: 900; box-shadow: 0 1px 4px color-mix(in srgb, var(--brand-secondary) 12%, transparent); }
.auth-panel { margin: 0; }
.auth-form .button-primary { background: var(--brand-primary); }
.auth-form .button-primary:hover { background: var(--brand-primary-hover); }
.auth-panel + .auth-panel { margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--border); }
.auth-panel-compact { padding: 16px; border-radius: var(--radius-control); background: var(--surface-soft); }
.auth-submit-row { margin-top: 18px; display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; }
.auth-signup-prompt { margin: 10px 0 0; color: var(--text-muted); font-size: 13px; font-weight: 500; }
.auth-signup-prompt a { color: var(--brand-primary-dark); font-weight: 900; }
.auth-submit-stack { display: grid; justify-items: end; gap: 9px; }
.auth-login-button { min-width: 132px; min-height: 42px; padding-inline: 28px; background: var(--brand-primary); }
.auth-login-button:hover { background: var(--brand-primary-hover); }
.auth-forgot-link { color: var(--text-muted); font-size: 13px; font-weight: 700; text-align: right; }
.auth-forgot-link-outside { margin-top: 14px; display: block; }
.auth-links { margin-top: 15px; display: flex; align-items: center; justify-content: space-between; gap: 14px; color: var(--brand-primary-dark); font-size: 13px; font-weight: 800; }
.auth-links span { color: var(--text-muted); font-weight: 500; }
.auth-links span a { color: var(--brand-primary-dark); font-weight: 800; }
.auth-links a:hover, .auth-signup-prompt a:hover, .auth-forgot-link:hover, .form-foot a:hover { color: var(--brand-primary-dark); }
.auth-stepper { margin: 0 0 22px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
.auth-stepper span { min-height: 34px; display: grid; place-items: center; border-radius: var(--radius-control); color: var(--text-muted); background: var(--surface-soft); font-size: 12px; font-weight: 900; }
.auth-stepper span.is-active { color: var(--text-on-dark); background: var(--brand-primary); }
.form-foot a { color: var(--brand-primary-dark); font-weight: 700; }
.auth-form .form-foot { margin: 20px 0 0; text-align: center; font-size: 13px; }
.form-error, .form-success { margin-bottom: 18px; padding: 11px; border-radius: var(--radius-control); font-size: 13px; font-weight: 700; }
.form-error { color: var(--error); background: var(--error-surface); }
.form-success { color: var(--brand-primary-dark); background: var(--brand-primary-faint); }
.grolocals-layout { padding-top: 60px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 64px; align-items: start; }
.grolocals-main { min-width: 0; }
.grolocals-hero-copy { padding-top: 0; }
.grolocals-hero h1 { max-width: 760px; margin: 0; color: var(--brand-secondary); font: 800 clamp(40px, 4.5vw, 58px)/1.06 var(--font-display); letter-spacing: -2px; }
.grolocals-hero-copy h1 { max-width: 780px; margin: 0; color: var(--brand-secondary); font: 800 clamp(36px, 4.5vw, 58px)/1.08 var(--font-display); letter-spacing: -2px; }
.grolocals-hero h1 em { color: var(--brand-primary); font-style: normal; }
.grolocals-hero-copy h1 em { color: var(--brand-primary); font-style: normal; }
.grolocals-hero-copy > p { max-width: 760px; margin: 18px 0 0; color: var(--text-body); font-size: 18px; line-height: 1.55; }
.grolocals-login-shell { padding: 92px 48px; border-radius: var(--radius-panel); background: var(--surface-soft); }
.grolocals-login-card { padding: 32px; }
.grolocals-login-toggle { position: absolute; opacity: 0; pointer-events: none; }
.grolocals-login-card .auth-tab { cursor: pointer; }
#grolocals-login-password:checked ~ .auth-card-head .grolocals-password-tab,
#grolocals-login-otp:checked ~ .auth-card-head .grolocals-otp-tab { color: var(--brand-primary-dark); background: var(--surface); font-weight: 900; box-shadow: 0 1px 4px color-mix(in srgb, var(--brand-secondary) 12%, transparent); }
.grolocals-login-panel { display: none; }
#grolocals-login-password:checked ~ .grolocals-password-panel,
#grolocals-login-otp:checked ~ .grolocals-otp-panel { display: block; }
.grolocals-login-panel input:disabled { color: var(--text-muted); background: var(--surface); opacity: 1; cursor: not-allowed; }
.grolocals-login-card > p { margin: 16px 0 0; color: var(--text-muted); font-size: 13px; line-height: 1.45; }
.store-login-toggle { position: absolute; opacity: 0; pointer-events: none; }
.store-login-card .auth-tab { cursor: pointer; }
#store-login-password:checked ~ .auth-card-head .store-password-tab,
#store-login-otp:checked ~ .auth-card-head .store-otp-tab { color: var(--brand-primary-dark); background: var(--surface); font-weight: 900; box-shadow: 0 1px 4px color-mix(in srgb, var(--brand-secondary) 12%, transparent); }
.store-login-panel { display: none; }
#store-login-password:checked ~ .store-password-panel,
#store-login-otp:checked ~ .store-otp-panel { display: block; }
.store-login-panel input:disabled { color: var(--text-muted); background: var(--surface); opacity: 1; cursor: not-allowed; }
.store-signup-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.store-signup-grid label { min-width: 0; display: grid; gap: 7px; color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.store-signup-grid input, .store-signup-grid select { width: 100%; min-width: 0; padding: 11px 12px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--text); background: var(--surface); font: inherit; font-weight: 400; }
.store-signup-grid input:focus, .store-signup-grid select:focus { border-color: var(--brand-primary); box-shadow: 0 0 0 3px var(--focus-ring); outline: 0; }
.store-signup-wide { grid-column: 1 / -1; }
.store-signup-otp { grid-column: 1 / -1; }
.store-signup-actions { margin-top: 18px; display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.25fr); gap: 12px; }
.store-workspace-page .profile-page-head p { max-width: 780px; margin: 12px 0 0; color: var(--text-body); font-size: 17px; line-height: 1.55; }
.store-workspace-list { display: grid; gap: 14px; }
.store-workspace-card { min-width: 0; padding: 18px; display: grid; grid-template-columns: minmax(180px, 1.4fr) repeat(4, minmax(88px, .8fr)) auto; gap: 14px; align-items: center; border: 1px solid var(--border); border-radius: var(--radius-control); background: var(--surface); }
.store-workspace-card-main { min-width: 0; }
.store-workspace-card h3 { margin: 0 0 4px; color: var(--brand-secondary); font: 800 20px/1.2 var(--font-display); letter-spacing: -.3px; }
.store-workspace-card p { margin: 0; color: var(--text-body); font-size: 14px; line-height: 1.45; }
.store-workspace-card span { display: block; margin-bottom: 5px; color: var(--text-muted); font-size: 11px; font-weight: 900; letter-spacing: .8px; text-transform: uppercase; }
.store-workspace-card strong { color: var(--brand-secondary); font-weight: 900; }
.store-workspace-card-actions { display: flex; justify-content: flex-end; gap: 10px; }
.store-workspace-card-actions .button { min-height: 38px; padding-inline: 16px; }
.store-overview-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.store-overview-grid article { min-height: 104px; padding: 18px; display: grid; align-content: space-between; border: 1px solid var(--border); border-radius: var(--radius-control); background: var(--surface); }
.store-overview-grid span, .store-settings-list span { color: var(--text-muted); font-size: 12px; font-weight: 800; }
.store-overview-grid strong { color: var(--brand-secondary); font: 800 24px/1.15 var(--font-display); }
.store-profile-form textarea { width: 100%; min-width: 0; padding: 11px 12px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--text); background: var(--surface); font: inherit; font-weight: 400; resize: vertical; }
.store-profile-form textarea:focus { border-color: var(--brand-primary); box-shadow: 0 0 0 3px var(--focus-ring); outline: 0; }
.store-profile-readonly .profile-field-wide, .profile-field-wide { grid-column: 1 / -1; }
.store-settings-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.store-settings-list article { min-height: 86px; padding: 16px; display: grid; gap: 6px; border: 1px solid var(--border); border-radius: var(--radius-control); background: var(--surface); }
.store-settings-list strong { color: var(--brand-secondary); font-weight: 900; }
.grolocals-interest { padding-top: 48px; }
.grolocals-form { max-width: 900px; padding: 24px 0 0; border: 0; border-radius: 0; background: transparent; }
.grolocals-form-head { margin-bottom: 22px; }
.grolocals-form h2 { margin: 0; color: var(--brand-secondary); font: 800 30px/1.15 var(--font-display); letter-spacing: -1px; }
.grolocals-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.grolocals-form label { min-width: 0; display: grid; gap: 7px; color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.grolocals-field-wide { grid-column: 1 / -1; }
.grolocals-form input, .grolocals-form select, .grolocals-form textarea { width: 100%; min-width: 0; padding: 11px 12px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--text); background: var(--surface); font: inherit; font-weight: 400; }
.grolocals-form textarea { min-height: 112px; resize: vertical; }
.grolocals-form input:focus, .grolocals-form select:focus, .grolocals-form textarea:focus { border-color: var(--brand-primary); box-shadow: 0 0 0 3px var(--focus-ring); outline: 0; }
.grolocals-form .button { width: 100%; margin-top: 18px; }
.grolocals-partners { padding-top: 58px; }
.grolocals-disclosure { border-bottom: 1px solid var(--border); }
.grolocals-disclosure-trigger { width: 100%; min-height: 46px; padding: 0 0 22px; display: flex; align-items: center; justify-content: space-between; gap: 16px; border: 0; color: var(--brand-primary); background: transparent; font: 800 20px/1.2 var(--font-display); text-align: left; cursor: pointer; }
.grolocals-disclosure-trigger > span { width: auto; height: auto; min-width: 0; flex: 1 1 auto; display: block; border-radius: 0; background: transparent; text-align: left; }
.grolocals-disclosure-trigger svg { width: 20px; height: 20px; color: var(--brand-primary); stroke: currentColor; stroke-width: 2.3; stroke-linecap: round; stroke-linejoin: round; fill: none; transition: transform var(--transition-ui); }
.grolocals-disclosure-trigger[aria-expanded="true"] svg { transform: rotate(180deg); }
.grolocals-disclosure-panel { max-height: 0; margin: 0; padding: 0; overflow: hidden; transition: max-height .24s ease, padding .24s ease; }
.grolocals-disclosure-trigger[aria-expanded="true"] + .grolocals-disclosure-panel { padding: 2px 0 26px; }
.grolocals-card-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
.grolocals-card-grid article { min-height: 0; padding: 22px 24px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); transition: border-color var(--transition-ui), transform var(--transition-ui); }
.grolocals-card-grid article:hover { border-color: var(--brand-primary); transform: translateY(-2px); }
.grolocals-card-grid h3 { margin: 0; color: var(--brand-secondary); font: 800 21px/1.25 var(--font-display); }
.grolocals-card-grid p { margin: 12px 0 0; color: var(--text-body); line-height: 1.6; }
.grolocals-how { padding-top: 48px; }
.grolocals-how-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; list-style: none; }
.grolocals-how li { min-height: 92px; padding: 18px; display: grid; grid-template-columns: 34px minmax(0, 1fr); gap: 12px; align-items: center; border: 1px solid var(--border); border-radius: var(--radius-control); background: var(--surface); }
.grolocals-how-list > li > span { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%; color: var(--brand-primary); background: var(--surface-soft); font-weight: 900; }
.grolocals-how strong { color: var(--brand-secondary); font: 800 15px/1.25 var(--font-display); }
.simple-form-page { min-height: 650px; padding-block: 85px; display: grid; grid-template-columns: 1fr 430px; align-items: center; gap: 90px; }.simple-form-page > div > p { max-width: 600px; font-size: 18px; }
.phase-card h2 { margin-bottom: 12px; }
.phase-card .button { margin-top: 8px; }
.card-actions, .detail-actions { width: 100%; margin-top: auto; display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.card-actions .button { flex: 1 1 120px; }
.detail-actions { margin-top: 26px; }
.store-detail-actions { width: 100%; margin-top: 26px; gap: 16px; align-items: center; justify-content: space-between; }
.store-detail-action-group { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.store-detail-actions .button { min-height: 42px; padding: 9px 18px; flex: 0 0 auto; border-radius: var(--radius-panel); white-space: nowrap; }
.store-detail-actions .button-primary { background: var(--brand-primary); }
.store-detail-actions .button-primary:hover { background: var(--brand-primary-hover); }
.store-direction-link { min-height: 42px; display: inline-flex; align-items: center; justify-content: flex-end; gap: 4px; margin-left: auto; color: var(--brand-primary); font-weight: 800; white-space: nowrap; }
.store-direction-link svg { width: 17px; height: 17px; stroke-width: 2; }
.store-direction-link:hover { color: var(--brand-primary-dark); }
.gallery-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.gallery-grid figure { margin: 0; overflow: hidden; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.gallery-grid img { width: 100%; aspect-ratio: 4 / 3; display: block; object-fit: cover; }
.gallery-grid figcaption { padding: 10px 12px; color: var(--text-muted); font-size: 13px; }
.trust-reviews .results-head { align-items: center; }
.trust-score { min-height: 34px; padding: 8px 12px; display: inline-flex; align-items: center; border-radius: 999px; color: var(--brand-primary-dark); background: var(--brand-primary-faint); font-size: 12px; font-weight: 900; letter-spacing: .7px; text-transform: uppercase; }
.trust-review-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; align-items: stretch; }
.trust-card { min-width: 0; padding: 24px; display: flex; flex-direction: column; align-items: flex-start; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.trust-card-label { color: var(--brand-primary-dark); font-size: 12px; font-weight: 900; letter-spacing: .8px; text-transform: uppercase; }
.trust-card strong { margin-top: 12px; color: var(--text); font: 800 25px/1.1 var(--font-display); }
.trust-card strong span { color: var(--brand-primary); letter-spacing: 1px; }
.trust-card p { margin: 8px 0 0; }
.trust-card small { margin-top: 8px; color: var(--text-muted); font-size: 12px; font-weight: 700; }
.trust-card .button { min-height: 38px; margin-top: auto; padding: 8px 13px; font-size: 13px; }
.trust-card-wide { grid-column: auto; }
.web-review-list { width: 100%; margin-top: 10px; display: grid; gap: 12px; }
.web-review-source { padding: 14px; display: flex; justify-content: space-between; gap: 16px; align-items: center; border-radius: var(--radius-control); background: var(--surface-soft); }
.web-review-source h3 { margin: 0; color: var(--text); font: 700 18px var(--font-display); }
.web-review-source strong { margin-top: 8px; display: block; font-size: 18px; }
.web-review-source p { margin-top: 4px; font-size: 13px; }
.trust-ai-placeholder { width: fit-content; margin-top: 16px; padding: 10px 12px; display: inline-flex; gap: 8px; align-items: center; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--text-muted); background: var(--surface-soft); font-size: 13px; }
.trust-ai-placeholder span { color: var(--brand-secondary); font-weight: 800; }
.trust-ai-placeholder strong { color: var(--brand-primary-dark); font-weight: 800; }
.trust-reviews-modern { padding: 34px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); background: transparent; }
.trust-reviews-head { align-items: center; }
.review-showcase { margin-top: 22px; display: grid; grid-template-columns: minmax(0, 1fr) 300px; background: var(--surface); }
.review-rail { min-width: 0; padding: 32px; display: grid; grid-auto-columns: minmax(240px, 32%); grid-auto-flow: column; gap: 18px; overflow-x: auto; background: var(--surface-soft); scrollbar-color: var(--brand-secondary) var(--border); }
.review-preview-card { min-height: 260px; padding: 24px; display: flex; flex-direction: column; border: 0; border-radius: var(--radius-panel); background: var(--surface); }
.review-preview-card h3 { margin: 16px 0 0; color: var(--text); font: 800 17px/1.25 var(--font-display); }
.review-preview-card p { margin-top: 12px; color: var(--text-body); line-height: 1.58; }
.review-preview-card footer { margin-top: auto; display: flex; justify-content: space-between; gap: 12px; color: var(--text-muted); font-size: 13px; }
.review-preview-card footer strong { color: var(--brand-primary-dark); }
.review-preview-empty { justify-content: center; }
.review-summary-panel { padding: 34px 32px; display: flex; flex-direction: column; justify-content: center; align-items: flex-start; background: var(--surface); }
.review-summary-panel > strong { color: var(--text); font: 900 48px/1 var(--font-display); letter-spacing: -1.6px; }
.review-summary-panel p { margin-top: 9px; color: var(--text); font-weight: 700; }
.review-summary-panel > span { margin-top: 26px; color: var(--text); font: 900 30px/1 var(--font-display); }
.review-summary-panel em { margin-top: 8px; color: var(--brand-primary-dark); font-style: normal; font-weight: 900; }
.review-summary-panel .button { width: 100%; margin-top: 28px; border-radius: 999px; }
.review-stars { display: inline-flex; gap: 2px; color: var(--border-strong); letter-spacing: 1px; }
.review-stars .is-filled { color: var(--text); }
.trust-signal-grid { margin-top: 32px; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 32px; align-items: stretch; }
.trust-signal-card { min-width: 0; padding: 18px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.trust-signal-card span { color: var(--brand-primary-dark); font-size: 12px; font-weight: 900; letter-spacing: .7px; text-transform: uppercase; }
.trust-signal-card strong { display: block; margin-top: 10px; color: var(--text); font: 800 22px/1.1 var(--font-display); }
.trust-signal-card p, .trust-signal-card small { display: block; margin-top: 7px; color: var(--text-body); font-size: 13px; line-height: 1.45; }
.trust-signal-card a { margin-top: 10px; display: inline-flex; color: var(--brand-primary-dark); font-size: 13px; font-weight: 900; }
.trust-signal-wide { grid-column: span 2; }
.trust-source-list { margin-top: 10px; display: grid; gap: 10px; }
.trust-source-list div + div { padding-top: 10px; border-top: 1px solid var(--border); }
.reviews-page { padding-top: 52px; }
.reviews-page-head { margin-bottom: 28px; display: flex; justify-content: space-between; gap: 24px; align-items: flex-end; }
.reviews-page-head h1 { margin: 0; color: var(--brand-secondary); font: 700 clamp(38px, 5vw, 60px)/1.04 var(--font-display); letter-spacing: -2px; }
.reviews-page-head p { max-width: 680px; margin: 12px 0 0; color: var(--text-body); }
.reviews-layout { display: grid; grid-template-columns: 360px minmax(0, 1fr); gap: 36px; align-items: start; }
.reviews-summary { position: sticky; top: 24px; padding: 28px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.reviews-score { text-align: center; }
.reviews-score strong { color: var(--text); font: 900 58px/1 var(--font-display); letter-spacing: -2px; }
.reviews-score p { margin-top: 8px; color: var(--text-body); font-size: 14px; }
.rating-breakdown { margin: 24px 0; padding: 22px 0; display: grid; gap: 14px; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.rating-breakdown div { display: grid; grid-template-columns: 44px minmax(0, 1fr) 36px; gap: 10px; align-items: center; color: var(--text-body); font-size: 14px; }
.rating-breakdown i { height: 8px; overflow: hidden; border-radius: 999px; background: var(--border); }
.rating-breakdown b { height: 100%; display: block; border-radius: inherit; background: var(--brand-secondary); }
.rating-breakdown em { color: var(--text-muted); font-style: normal; text-align: right; }
.reviews-toolbar { margin-bottom: 18px; padding-bottom: 16px; display: flex; flex-wrap: wrap; gap: 12px; align-items: end; border-bottom: 1px solid var(--border); }
.reviews-toolbar label { min-width: 170px; display: grid; gap: 6px; color: var(--brand-secondary); font-size: 13px; font-weight: 900; }
.reviews-toolbar select { min-height: 42px; padding: 10px; border: 1px solid var(--border); border-radius: var(--radius-control); background: var(--surface-soft); font: inherit; }
.reviews-list { display: grid; gap: 0; }
.review-list-card { padding: 28px 0; border-bottom: 1px solid var(--border); }
.review-list-top { display: flex; justify-content: space-between; gap: 18px; align-items: center; }
.review-list-top time { color: var(--text-muted); font-size: 13px; }
.review-list-card h2 { margin: 16px 0 0; color: var(--text); font: 800 20px/1.2 var(--font-display); letter-spacing: 0; }
.review-list-card p { max-width: 850px; margin-top: 10px; color: var(--text-body); line-height: 1.65; }
.review-list-card footer { margin-top: 18px; display: flex; flex-wrap: wrap; gap: 16px; align-items: center; color: var(--text-muted); font-size: 13px; }
.review-list-card footer strong { color: var(--brand-primary-dark); }
.review-list-card footer em { margin-left: auto; color: var(--brand-secondary); font-style: normal; font-weight: 900; }
.write-review-panel { margin-top: 54px; padding: 34px; display: grid; grid-template-columns: minmax(220px, .45fr) minmax(0, 1fr); gap: 34px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface-soft); }
.write-review-panel h2 { margin: 0; color: var(--brand-secondary); font: 800 30px/1.12 var(--font-display); letter-spacing: -1px; }
.write-review-panel p { margin-top: 10px; }
.review-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.review-form-grid label { display: grid; gap: 7px; color: var(--brand-secondary); font-size: 13px; font-weight: 900; }
.review-field-wide { grid-column: 1 / -1; }
.review-form-grid input, .review-form-grid select, .review-form-grid textarea { width: 100%; min-width: 0; padding: 11px 12px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--text); background: var(--surface); font: inherit; }
.review-form-grid small { color: var(--error); font-size: 12px; }
.write-review-panel form .button { margin-top: 16px; }
.map-placeholder { min-height: 344px; margin-top: 80px; padding: 34px 36px; border: 1px dashed var(--border-strong); border-radius: var(--radius-panel); background: var(--surface-soft); }
.map-placeholder h2 { margin: 0; color: var(--brand-secondary); font: 700 28px/1.18 var(--font-display); letter-spacing: -1px; }
.map-placeholder p { margin: 6px 0 0; color: var(--text-body); line-height: 1.6; }
.store-profile-sections { margin-top: 72px; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); column-gap: 60px; row-gap: 60px; align-items: stretch; }
.store-section-card { padding: 30px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.store-about-section, .store-products-sold-section, .store-products-section, .store-features-section, .store-location-section, .trust-reviews, .nearby-stores-section { grid-column: 1 / -1; }
.store-about-section, .store-products-sold-section, .store-products-section, .store-gallery-section { padding: 0; border: 0; border-radius: 0; background: transparent; }
.store-features-section { padding-right: 0; padding-left: 0; border-width: 1px 0; border-radius: 0; }
.store-section-card h2 { margin: 0; color: var(--brand-secondary); font: 700 28px/1.18 var(--font-display); letter-spacing: -1px; }
.store-section-card p { margin: 6px 0 0; color: var(--text-body); line-height: 1.6; }
.store-section-title { min-width: 0; }
.store-section-title h2 { margin: 0; color: var(--brand-secondary); font: 700 28px/1.18 var(--font-display); letter-spacing: -1px; }
.store-section-title p { max-width: 760px; margin: 6px 0 0; color: var(--text-body); font-size: 16px; font-weight: 400; line-height: 1.6; }
.store-section-head, .store-section-title-row, .store-location-head { display: flex; justify-content: space-between; gap: 24px; align-items: flex-start; }
.store-about-copy { max-width: 860px; }
.store-about-copy.is-collapsed { display: -webkit-box; overflow: hidden; -webkit-box-orient: vertical; -webkit-line-clamp: 3; }
.store-read-more, .store-hours-toggle { margin-top: 12px; padding: 0; border: 0; color: var(--brand-primary-dark); background: transparent; font-weight: 900; }
.store-info-chips, .store-feature-grid { margin-top: 20px; display: flex; flex-wrap: wrap; gap: 10px; }
.store-info-chips span, .store-feature-grid span { min-height: 34px; padding: 8px 12px; display: inline-flex; align-items: center; gap: 8px; border-radius: var(--radius-control); color: var(--brand-secondary); background: var(--surface-soft); font-size: 13px; font-weight: 800; }
.store-info-chips span::before, .store-feature-grid span::before { content: ""; width: 7px; height: 7px; flex: 0 0 7px; border-radius: 50%; background: var(--brand-primary); }
.products-sold-preview-grid { margin-top: 18px; display: flex; flex-wrap: wrap; gap: 10px; }
.product-sold-chip { min-height: 38px; padding: 9px 13px; display: inline-flex; align-items: center; gap: 10px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--brand-secondary); background: var(--surface); font-size: 14px; font-weight: 800; }
.product-sold-chip.has-image { min-height: 54px; padding: 6px 12px 6px 6px; }
.product-sold-chip img { width: 42px; height: 42px; flex: 0 0 42px; border-radius: var(--radius-control); object-fit: cover; background: var(--surface-soft); }
.store-hours-section { height: 100%; overflow: hidden; border: 0; background: linear-gradient(180deg, color-mix(in srgb, var(--brand-primary-faint) 34%, var(--surface)), var(--surface)); }
.store-hours-section .store-section-head { align-items: center; }
.store-hours-section .store-section-title p { color: var(--text-body); font-size: 16px; line-height: 1.6; }
.store-hours-status { min-height: 32px; padding: 7px 11px; display: inline-flex; align-items: center; gap: 7px; border-radius: 999px; font-size: 12px; font-weight: 900; letter-spacing: .5px; text-transform: uppercase; white-space: nowrap; }
.store-hours-status::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.store-hours-status.is-open { color: var(--brand-primary); background: var(--brand-primary-faint); }
.store-hours-status.is-closed { color: var(--status-closed); background: var(--surface-soft); }
.store-hours-today { margin-top: 18px; padding: 8px 0; display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 14px; align-items: center; }
.store-hours-today span { color: var(--text-muted); font-size: 12px; font-weight: 900; letter-spacing: .8px; text-transform: uppercase; }
.store-hours-today strong { color: var(--brand-secondary); font: 800 18px/1.15 var(--font-display); white-space: nowrap; }
.store-hours-toggle { width: 100%; min-height: 44px; margin-top: 12px; padding: 10px 13px; display: flex; align-items: center; justify-content: space-between; gap: 14px; border: 1px solid var(--border); border-radius: var(--radius-panel); color: var(--brand-primary-dark); background: var(--surface); font-weight: 900; transition: border-color var(--transition-ui), background var(--transition-ui); }
.store-hours-toggle:hover { border-color: var(--brand-primary); background: var(--brand-primary-faint); }
.store-hours-toggle svg { width: 18px; height: 18px; transition: transform var(--transition-ui); }
.store-hours-toggle[aria-expanded="true"] svg { transform: rotate(180deg); }
.store-weekly-hours { margin-top: 12px; padding: 8px; display: grid; gap: 6px; border-radius: var(--radius-panel); background: var(--surface); }
.store-weekly-hours[hidden], .store-weekly-hours:not(.is-expanded) { display: none; }
.store-weekly-hours.is-expanded { display: grid; }
.store-weekly-hours div { min-height: 40px; padding: 10px 12px; display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 18px; align-items: center; border-radius: var(--radius-control); color: var(--text-body); }
.store-weekly-hours span { color: var(--brand-secondary); font-weight: 800; }
.store-weekly-hours strong { color: var(--text-muted); font-size: 14px; white-space: nowrap; }
.store-weekly-hours .is-today { color: var(--brand-primary-dark); background: var(--brand-primary-faint); }
.store-weekly-hours .is-today span, .store-weekly-hours .is-today strong { color: var(--brand-primary-dark); }
.store-gallery-section { align-self: start; display: flex; flex-direction: column; justify-content: flex-start; }
.store-gallery-section .store-section-title-row { margin-bottom: 20px; align-items: center; gap: 16px; }
.store-gallery-showcase { min-height: 250px; display: grid; place-items: center; position: relative; overflow: visible; border-radius: var(--radius-panel); background: transparent; }
.store-gallery-showcase::before { display: none; }
.store-gallery-frame { width: 46%; aspect-ratio: 4 / 3; margin: 0; position: absolute; overflow: hidden; border: 5px solid var(--surface); border-radius: var(--radius-control); background: linear-gradient(145deg, var(--brand-primary-faint), var(--surface-soft)); box-shadow: 0 12px 24px color-mix(in srgb, var(--brand-secondary) 12%, transparent); }
.store-gallery-frame img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.store-gallery-frame::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--brand-secondary) 8%, transparent)); }
.store-gallery-frame-1 { z-index: 4; transform: translateY(3px); }
.store-gallery-frame-2 { z-index: 3; transform: translateX(-38%) rotate(-7deg) scale(.86); }
.store-gallery-frame-3 { z-index: 2; transform: translateX(38%) rotate(7deg) scale(.86); }
.store-gallery-frame-4 { z-index: 1; transform: translateY(24px) scale(.78); opacity: .82; }
.store-gallery-frame.has-more::before { content: "+"; width: 36px; height: 36px; display: grid; place-items: center; position: absolute; right: 10px; bottom: 10px; z-index: 2; border-radius: 50%; color: var(--text-on-dark); background: color-mix(in srgb, var(--brand-secondary) 72%, transparent); font-weight: 900; }
.store-products-section .popular-product-grid { margin-top: 18px; }
.popular-product-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 14px; }
.popular-product-card { min-height: 100%; }
.popular-product-card .product-image { height: 128px; }
.popular-product-card .card-body { padding: 14px; display: flex; flex: 1; flex-direction: column; align-items: flex-start; }
.popular-product-card h2, .popular-product-card h3 { margin: 10px 0 0; color: var(--brand-secondary); font: 800 17px/1.18 var(--font-display); letter-spacing: 0; }
.popular-product-card .price { margin: 8px 0 12px; font-size: 17px; }
.popular-product-card .button { width: 100%; min-height: 38px; margin-top: auto; padding: 8px 10px; font-size: 13px; }
.inline-empty-message { grid-column: 1 / -1; margin: 0; padding: 16px 0; color: var(--text-muted); font-weight: 700; }
.store-section-title-row .button, .store-location-head .button { flex: 0 0 auto; min-height: 40px; padding: 8px 14px; font-size: 13px; }
.store-location-head .store-section-title p { font-weight: 400; }
.store-map-preview { min-height: 230px; margin-top: 22px; padding: 22px; display: flex; flex-direction: column; justify-content: flex-end; border-radius: var(--radius-panel); color: var(--brand-secondary); background: linear-gradient(145deg, var(--surface-soft), var(--brand-primary-faint)); }
.store-map-preview strong { font: 800 24px var(--font-display); }
.store-map-preview span { margin-top: 5px; color: var(--text-body); }
.nearby-stores-section { padding: 0; border: 0; border-radius: 0; background: transparent; }
.nearby-stores-section .store-section-title { margin-bottom: 18px; }
.nearby-store-grid { display: grid; grid-template-columns: repeat(3, minmax(340px, 1fr)); gap: 32px; align-items: start; }
.nearby-store-card { align-self: start; min-height: 0; height: auto; grid-template-columns: 70px minmax(0, 1fr); gap: 15px; }
.nearby-store-card .logo-placeholder { width: 70px; height: 70px; }
.nearby-store-card .card-body h3 { font-size: 20px; line-height: 1.2; }
.nearby-store-card .card-actions.store-card-actions { justify-content: flex-start; flex-wrap: nowrap; }
.nearby-store-card .card-actions.store-card-actions .button { flex: 0 0 118px; width: 118px; }
.gallery-page { padding-top: 52px; }
.gallery-page-head { margin-bottom: 28px; display: flex; justify-content: space-between; gap: 24px; align-items: flex-end; }
.gallery-page-head h1 { margin: 0; color: var(--brand-secondary); font: 700 clamp(38px, 5vw, 58px)/1.05 var(--font-display); letter-spacing: -2px; }
.gallery-page-head p { max-width: 620px; margin: 10px 0 0; }
.gallery-page-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.gallery-page-grid figure { min-height: 250px; margin: 0; display: grid; place-items: end start; position: relative; overflow: hidden; border-radius: var(--radius-panel); background: linear-gradient(145deg, var(--brand-primary-faint), var(--surface-soft)); }
.gallery-page-grid img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.gallery-page-grid figcaption { position: relative; z-index: 1; margin: 14px; padding: 8px 11px; border-radius: var(--radius-control); color: var(--brand-secondary); background: color-mix(in srgb, var(--surface) 88%, transparent); font-size: 13px; font-weight: 900; }
.products-sold-page { padding-top: 52px; }
.products-sold-page-head { margin-bottom: 24px; display: flex; justify-content: space-between; gap: 24px; align-items: flex-end; }
.products-sold-page-head h1 { margin: 0; color: var(--brand-secondary); font: 700 clamp(36px, 5vw, 56px)/1.05 var(--font-display); letter-spacing: -2px; }
.products-sold-page-head p { max-width: 620px; margin: 10px 0 0; color: var(--text-body); }
.popular-products-page { padding-top: 52px; }
.popular-products-page-head { margin-bottom: 24px; display: flex; justify-content: space-between; gap: 24px; align-items: flex-end; }
.popular-products-page-head h1 { margin: 0; color: var(--brand-secondary); font: 700 clamp(36px, 5vw, 56px)/1.05 var(--font-display); letter-spacing: -2px; }
.popular-products-page-head p { max-width: 620px; margin: 10px 0 0; color: var(--text-body); }
.products-sold-toolbar { margin-bottom: 16px; padding: 16px; display: grid; grid-template-columns: minmax(220px, 1fr) minmax(160px, 220px) minmax(130px, 180px) auto auto; gap: 12px; align-items: end; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.popular-products-toolbar { margin-bottom: 16px; padding: 16px; display: grid; grid-template-columns: minmax(220px, 1fr) minmax(150px, 190px) minmax(140px, 180px) minmax(150px, 190px) auto auto; gap: 12px; align-items: end; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.products-sold-toolbar label { display: grid; gap: 6px; color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.popular-products-toolbar label { display: grid; gap: 6px; color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.products-sold-toolbar input, .products-sold-toolbar select, .popular-products-toolbar input, .popular-products-toolbar select { width: 100%; min-height: 42px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--text); background: var(--surface-soft); font: inherit; }
.products-sold-toolbar input, .popular-products-toolbar input { padding: 10px 12px; }
.products-sold-toolbar select, .popular-products-toolbar select { padding: 10px; }
.products-sold-grid { margin-top: 16px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.product-sold-card { min-width: 0; min-height: 118px; padding: 14px; display: flex; gap: 14px; align-items: center; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.product-sold-card img { width: 76px; height: 76px; flex: 0 0 76px; border-radius: var(--radius-control); object-fit: cover; background: var(--surface-soft); }
.product-sold-card h2 { margin: 4px 0 0; color: var(--brand-secondary); font: 800 18px/1.18 var(--font-display); letter-spacing: 0; }
.product-sold-card p { margin: 7px 0 0; color: var(--text-body); font-size: 14px; line-height: 1.5; }
.pagination { margin-top: 24px; display: flex; justify-content: center; gap: 14px; align-items: center; color: var(--text-muted); font-size: 14px; font-weight: 800; }
.merchant-page, .merchant-form-page { padding: 58px 0 30px; }
.merchant-form-page { display: grid; grid-template-columns: minmax(280px, .64fr) minmax(0, 1.36fr); gap: 56px; align-items: start; }
.merchant-form-intro h1, .merchant-head h1 { margin: 0; color: var(--brand-secondary); font: 700 clamp(36px, 4vw, 54px)/1.1 var(--font-display); letter-spacing: -1.8px; }
.merchant-form-intro p, .merchant-head p { max-width: 620px; margin: 14px 0 0; font-size: 17px; }
.merchant-note { padding: 14px 16px; border-radius: var(--radius-control); background: var(--brand-primary-faint); color: var(--brand-primary-dark); font-weight: 700; }
.merchant-trust-list { margin-top: 22px; display: grid; gap: 10px; }
.merchant-trust-list span { min-height: 42px; padding: 11px 14px; display: flex; align-items: center; gap: 10px; border: 1px solid var(--border); border-radius: var(--radius-control); background: var(--surface); color: var(--brand-secondary); font-weight: 700; }
.merchant-trust-list span::before { content: ""; width: 8px; height: 8px; flex: 0 0 8px; border-radius: 50%; background: var(--brand-primary); }
.merchant-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 24px; }
.merchant-head-actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: flex-end; }
.business-nav { margin: 0 0 28px; padding: 6px; display: flex; flex-wrap: wrap; gap: 6px; border-radius: var(--radius-panel); background: var(--surface-soft); }
.business-nav a { min-height: 42px; padding: 10px 14px; display: inline-flex; align-items: center; border-radius: var(--radius-control); color: var(--brand-secondary); font-weight: 800; font-size: 14px; }
.business-nav a:hover { color: var(--brand-primary-dark); background: var(--surface); }
.business-nav a[aria-current="page"] { color: var(--text-on-dark); background: var(--brand-primary); }
.merchant-form { padding: 30px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.merchant-form-wide { max-width: 900px; }
.merchant-form-section { padding: 0 0 28px; margin-bottom: 28px; border-bottom: 1px solid var(--border); }
.merchant-form-section:last-of-type { margin-bottom: 0; }
.merchant-section-head { margin-bottom: 18px; display: grid; grid-template-columns: 34px minmax(0, 1fr); gap: 14px; align-items: start; }
.merchant-section-head > span { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%; color: var(--text-on-dark); background: var(--brand-primary); font-size: 12px; font-weight: 800; }
.merchant-section-head h2 { margin: 0; color: var(--brand-secondary); font: 700 22px/1.2 var(--font-display); }
.merchant-section-head p { margin: 6px 0 0; color: var(--text-muted); font-size: 14px; line-height: 1.55; }
.merchant-field-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px 22px; }
.merchant-field-grid label { min-width: 0; display: grid; gap: 7px; color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.merchant-field-grid small { color: var(--text-muted); font-size: 12px; font-weight: 500; line-height: 1.45; }
.merchant-field-wide { grid-column: 1 / -1; }
.merchant-form input, .merchant-form select, .merchant-form textarea { width: 100%; min-width: 0; padding: 11px 12px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--text); background: var(--surface); font-weight: 400; }
.merchant-form input[type="file"] { min-height: 48px; padding: 10px; color: var(--text-muted); background: var(--surface-soft); }
.merchant-form input[type="checkbox"] { width: 18px; height: 18px; padding: 0; accent-color: var(--brand-primary-dark); }
.merchant-toggle { min-height: 58px; padding: 14px 16px; display: grid !important; grid-template-columns: minmax(0, 1fr) auto; gap: 6px 12px !important; align-items: center; border: 1px solid var(--border); border-radius: var(--radius-control); background: var(--surface-soft); }
.merchant-toggle small { grid-column: 1 / -1; }
.merchant-form input:focus, .merchant-form select:focus, .merchant-form textarea:focus, .merchant-search input:focus { border-color: var(--brand-primary); box-shadow: 0 0 0 3px var(--focus-ring); outline: 0; }
.merchant-form-actions { margin-top: 28px; display: flex; flex-wrap: wrap; gap: 12px; }
.form-error-inline { color: var(--error); font-size: 12px; }
.completion-panel { margin-bottom: 18px; padding: 24px; display: grid; grid-template-columns: minmax(0, 1fr) minmax(220px, .36fr); gap: 24px; align-items: center; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface-soft); }
.completion-panel h2 { margin: 0; color: var(--brand-secondary); font: 700 28px var(--font-display); }
.completion-panel p { margin: 8px 0 0; }
.completion-meter { height: 12px; overflow: hidden; border-radius: 999px; background: var(--surface); }
.completion-meter span { height: 100%; display: block; border-radius: inherit; background: var(--brand-primary); }
.metric-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 16px; }
.metric-grid article, .merchant-list article, .confirm-box { padding: 22px; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.metric-grid span, .merchant-list span { color: var(--brand-primary-dark); font-size: 12px; font-weight: 800; letter-spacing: .8px; text-transform: uppercase; }
.metric-grid strong { display: block; margin-top: 10px; color: var(--text); font: 800 32px var(--font-display); }
.metric-grid p, .merchant-list p, .confirm-box p { margin: 6px 0 0; }
.merchant-search { margin-bottom: 18px; display: flex; gap: 10px; }
.merchant-search input { min-height: 46px; flex: 1; padding: 0 12px; border: 1px solid var(--border); border-radius: var(--radius-control); }
.merchant-table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: var(--radius-panel); background: var(--surface); }
.merchant-table { width: 100%; border-collapse: collapse; min-width: 780px; }
.merchant-table th, .merchant-table td { padding: 14px 16px; border-bottom: 1px solid var(--border); text-align: left; vertical-align: middle; }
.merchant-table th { color: var(--brand-secondary); font-size: 12px; letter-spacing: .7px; text-transform: uppercase; }
.merchant-table img, .table-thumb { width: 44px; height: 44px; display: grid; place-items: center; border-radius: var(--radius-control); object-fit: cover; background: var(--brand-primary-faint); color: var(--brand-primary-dark); font-weight: 800; }
.merchant-actions { display: flex; gap: 12px; }
.merchant-actions a { color: var(--brand-primary-dark); font-weight: 800; }
.merchant-list { display: grid; gap: 14px; }
.status-pill { min-height: 28px; padding: 6px 10px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; color: var(--text-muted); background: var(--surface-soft); font-size: 12px; font-weight: 800; }
.status-pill-open { color: var(--brand-primary-dark); background: var(--brand-primary-faint); }
.profile-page { padding: 50px 0 42px; }
.profile-page-head { margin-bottom: 34px; padding-bottom: 0; border-bottom: 0; }
.profile-page-head h1 { margin: 0; color: var(--brand-secondary); font: 800 clamp(34px, 3.8vw, 50px)/1.08 var(--font-display); letter-spacing: -1.4px; }
.profile-messages { max-width: 860px; }
.profile-layout { display: grid; grid-template-columns: 240px minmax(0, 1fr); gap: 42px; align-items: start; }
.profile-summary-card { padding: 0; display: grid; gap: 18px; position: sticky; top: 18px; background: transparent; }
.profile-card { border: 0; border-radius: 0; background: transparent; }
.profile-avatar { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 50%; color: var(--text-on-dark); background: var(--brand-primary); font: 900 18px/1 var(--font-display); }
.profile-summary-card h2 { margin: 0; color: var(--brand-secondary); font: 800 24px/1.15 var(--font-display); letter-spacing: -.4px; }
.profile-summary-card p { margin: 5px 0 0; overflow-wrap: anywhere; font-size: 14px; }
.profile-section-trigger { display: none; }
.profile-section-nav { display: grid; gap: 4px; }
.profile-section-nav form { margin: 0; }
.profile-section-nav a, .profile-section-nav button { width: 100%; min-height: 40px; padding: 10px 12px; display: flex; align-items: center; border: 0; border-radius: var(--radius-control); color: var(--brand-secondary); background: transparent; font: inherit; font-size: 14px; font-weight: 800; text-align: left; cursor: pointer; }
.profile-section-nav a:hover, .profile-section-nav button:hover { color: var(--brand-primary-dark); background: var(--surface-soft); }
.profile-section-nav a[aria-current="page"] { color: var(--text-on-dark); background: var(--brand-primary); }
.profile-readonly-grid span { color: var(--text-muted); font-size: 11px; font-weight: 900; letter-spacing: .8px; text-transform: uppercase; }
.profile-readonly-grid strong { color: var(--brand-secondary); font-weight: 800; overflow-wrap: anywhere; }
.profile-badges { display: flex; flex-wrap: wrap; gap: 8px; }
.profile-facts { margin: 0; display: grid; gap: 12px; }
.profile-facts div { padding-top: 14px; border-top: 0; }
.profile-facts dt, .profile-info-list dt { color: var(--text-muted); font-size: 12px; font-weight: 900; letter-spacing: .8px; text-transform: uppercase; }
.profile-facts dd, .profile-info-list dd { margin: 5px 0 0; color: var(--brand-secondary); font-weight: 800; }
.profile-main { display: grid; gap: 34px; }
.profile-card { padding: 28px 0 0; }
.profile-main .profile-card:first-child { padding-top: 0; border-top: 0; }
.profile-section { margin-top: 0; }
.profile-card-head { margin-bottom: 18px; display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; }
.profile-card-head h2 { margin: 0; color: var(--brand-secondary); font: 800 24px/1.2 var(--font-display); letter-spacing: -.4px; }
.profile-card-head p { margin: 6px 0 0; font-size: 14px; }
.profile-card-head .button { min-height: 38px; padding: 8px 14px; white-space: nowrap; }
.profile-field-grid, .profile-readonly-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.profile-field-grid label { min-width: 0; display: grid; gap: 7px; color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.profile-mobile-locked { min-width: 0; display: grid; gap: 7px; color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.profile-mobile-locked strong { min-height: 43px; padding: 11px 12px; display: flex; align-items: center; border-radius: var(--radius-control); color: var(--text-muted); background: var(--surface-soft); font-weight: 400; }
.profile-field-wide { grid-column: 1 / -1; }
.profile-field-grid input, .profile-field-grid select { width: 100%; min-width: 0; padding: 11px 12px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--text); background: var(--surface); font-weight: 400; }
.profile-field-grid input[readonly] { color: var(--text-muted); background: var(--surface-soft); }
.profile-field-grid input:focus, .profile-field-grid select:focus { border-color: var(--brand-primary); box-shadow: 0 0 0 3px var(--focus-ring); outline: 0; }
.profile-field-grid small { color: var(--text-muted); font-size: 12px; font-weight: 500; line-height: 1.45; }
.profile-readonly-grid > div { min-height: 74px; padding: 0 0 14px; display: grid; align-content: start; gap: 6px; border-bottom: 0; }
.profile-readonly-grid small { color: var(--text-muted); font-size: 12px; font-weight: 500; line-height: 1.45; }
.profile-detail-mobile, .profile-detail-secondary-mobile { min-height: auto !important; padding-bottom: 0 !important; }
.profile-mobile-action { min-width: 0; display: grid; align-content: start; gap: 6px; }
.profile-mobile-action { justify-items: start; text-align: left; }
.profile-mobile-action small { margin: 0; }
.profile-inline-action { width: fit-content; margin-top: 4px; color: var(--brand-primary); font-size: 13px; font-weight: 900; }
.profile-inline-action:hover { color: var(--brand-primary-hover); }
.profile-edit-action { grid-column: 2; min-height: auto !important; padding-bottom: 0 !important; justify-items: start; }
.profile-edit-action .button { min-width: 108px; min-height: 34px; padding: 7px 22px; color: var(--brand-primary); }
.profile-mobile-change { margin-top: 24px; padding-top: 18px; display: grid; gap: 14px; }
.profile-mobile-change form { max-width: 560px; display: grid; gap: 14px; }
.profile-mobile-change label { display: grid; gap: 7px; color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.profile-mobile-change input { width: 100%; min-width: 0; padding: 11px 12px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--text); background: var(--surface); font-weight: 400; }
.profile-mobile-change input[readonly] { color: var(--text-muted); background: var(--surface-soft); }
.profile-actions { margin-top: 22px; display: flex; flex-wrap: wrap; gap: 12px; }
.profile-address-form { display: grid; gap: 14px; }
.profile-check-row { width: fit-content; display: inline-flex; align-items: center; gap: 9px; color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.profile-check-row input { width: 17px; height: 17px; accent-color: var(--brand-primary); }
.profile-address-list { display: grid; gap: 14px; }
.profile-address-card { padding: 18px; border: 1px solid var(--border); border-radius: var(--radius-card); background: var(--surface); }
.profile-address-card-head { margin-bottom: 10px; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.profile-address-card h3 { margin: 0; color: var(--brand-secondary); font: 800 20px/1.2 var(--font-display); }
.profile-address-card-head span { padding: 5px 8px; border-radius: 999px; color: var(--brand-primary-dark); background: var(--brand-primary-faint); font-size: 11px; font-weight: 900; letter-spacing: .7px; text-transform: uppercase; }
.profile-address-card p { margin: 3px 0; color: var(--brand-secondary); font-weight: 600; line-height: 1.45; }
.profile-address-actions { margin-top: 14px; display: flex; align-items: center; gap: 16px; }
.profile-address-actions form { margin: 0; }
.profile-address-actions a, .profile-address-actions button { padding: 0; border: 0; color: var(--brand-primary); background: transparent; font: inherit; font-size: 13px; font-weight: 900; cursor: pointer; }
.profile-address-actions a:hover, .profile-address-actions button:hover { color: var(--brand-primary-hover); }
.profile-address-add-button { min-height: 42px; color: var(--brand-secondary); border-color: transparent; background: var(--surface-soft); }
.profile-address-add-button:hover { color: var(--brand-secondary); border-color: transparent; background: var(--surface-muted); }
.profile-info-list { margin: 0; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.profile-info-list div { min-height: 74px; padding: 0 0 14px; border-bottom: 0; }
.profile-password-form { max-width: 760px; margin-top: 24px; display: grid; gap: 16px; }
.profile-password-form h3 { margin: 0; color: var(--brand-secondary); font: 800 20px/1.2 var(--font-display); letter-spacing: -.2px; }
.profile-password-form .profile-field-grid { align-items: end; }
.profile-password-form .profile-actions { margin-top: 0; }
.profile-password-actions { align-self: end; }
.profile-password-actions .button { min-height: 43px; color: var(--brand-primary-dark); background: var(--brand-primary-faint); }
.profile-password-actions .button:hover { color: var(--text-on-dark); background: var(--brand-primary); }
.profile-password-control { position: relative; display: block; }
.profile-password-control input { padding-right: 46px; }
.profile-password-toggle { width: 34px; height: 34px; padding: 7px; display: grid; place-items: center; position: absolute; right: 5px; top: 50%; transform: translateY(-50%); border: 0; border-radius: var(--radius-control); color: var(--text-muted); background: transparent; cursor: pointer; }
.profile-password-toggle:hover, .profile-password-toggle:focus-visible, .profile-password-toggle.is-visible { color: var(--brand-primary-dark); background: var(--surface-soft); }
.profile-password-toggle svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.profile-danger-zone { margin-top: 52px; display: grid; justify-items: start; gap: 12px; }
.profile-danger-zone h3 { margin: 0; color: var(--brand-secondary); font: 800 20px/1.2 var(--font-display); letter-spacing: -.2px; }
.profile-empty-block { display: grid; justify-items: start; gap: 14px; }
.profile-empty-block p { margin: 0; color: var(--text-muted); }
.profile-request-list { display: grid; gap: 12px; }
.profile-request-list article { min-height: 72px; padding: 14px 0; display: grid; grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr) auto auto; gap: 14px; align-items: center; }
.profile-request-list strong { color: var(--brand-secondary); font-weight: 900; overflow-wrap: anywhere; }
.profile-request-list span, .profile-request-list time { color: var(--text-muted); font-size: 13px; font-weight: 700; }
.profile-request-list em { width: fit-content; padding: 6px 9px; border-radius: 999px; color: var(--brand-primary-dark); background: var(--brand-primary-faint); font-size: 12px; font-style: normal; font-weight: 900; }
.profile-wallet-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.profile-wallet-grid article { min-height: 104px; padding: 16px; display: grid; align-content: center; gap: 8px; border: 1px solid var(--border); border-radius: var(--radius-control); background: var(--surface); }
.profile-wallet-grid span { color: var(--text-muted); font-size: 12px; font-weight: 900; letter-spacing: .7px; text-transform: uppercase; }
.profile-wallet-grid strong { color: var(--brand-primary-dark); font: 900 28px/1 var(--font-display); }
.profile-wallet-activity { margin-top: 28px; display: grid; gap: 8px; }
.profile-wallet-activity h3 { margin: 0; color: var(--brand-secondary); font: 800 20px/1.2 var(--font-display); letter-spacing: -.2px; }
.profile-wallet-activity p { margin: 0; color: var(--text-muted); }
.profile-mini-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.profile-mini-grid a { min-height: 96px; padding: 16px 0; display: grid; align-content: center; gap: 7px; border-bottom: 0; }
.profile-mini-grid a:hover { color: var(--brand-primary-dark); }
.profile-mini-grid strong { color: var(--brand-primary-dark); font: 900 30px/1 var(--font-display); }
.profile-mini-grid span { color: var(--brand-secondary); font-weight: 800; }
.profile-account-actions { margin-top: 0; justify-content: space-between; }
.profile-danger-placeholder { color: var(--error); opacity: .56; cursor: not-allowed; }
.profile-empty-note { margin: 6px 0 0; color: var(--text-muted); font-size: 14px; }
.request-page { padding: 52px 0 80px; }
.request-page-head { max-width: 760px; margin-bottom: 28px; }
.request-page-head h1 { margin: 0; color: var(--brand-secondary); font: 800 clamp(38px, 4vw, 56px)/1.04 var(--font-display); letter-spacing: -1.8px; }
.request-page-head p { margin: 10px 0 0; color: var(--text-body); font-size: 18px; }
.request-form { max-width: 860px; padding: 0; display: grid; gap: 20px; }
.request-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.request-form label { min-width: 0; display: grid; gap: 7px; color: var(--brand-secondary); font-size: 13px; font-weight: 800; }
.request-form input, .request-form textarea { width: 100%; min-width: 0; padding: 11px 12px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--text); background: var(--surface); font: inherit; font-weight: 400; }
.request-form textarea { min-height: 120px; resize: vertical; }
.request-form input:focus, .request-form textarea:focus { border-color: var(--brand-primary); box-shadow: 0 0 0 3px var(--focus-ring); outline: 0; }
.request-form select { width: 100%; min-width: 0; padding: 12px 13px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--text); background: var(--surface); font-weight: 600; }
.request-form select:focus { border-color: var(--brand-primary); box-shadow: 0 0 0 3px var(--focus-ring); outline: 0; }
.need-items-block { margin-top: 26px; display: grid; gap: 14px; }
.need-item-list { display: grid; gap: 12px; }
.need-item-row { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr auto; align-items: end; gap: 10px; }
.need-item-remove { min-height: 42px; padding: 10px 12px; border: 0; border-radius: var(--radius-control); color: var(--brand-secondary); background: var(--surface-soft); font-weight: 800; cursor: pointer; }
.need-item-remove:hover { background: var(--surface-muted); }
.request-field-wide { grid-column: 1 / -1; }
.request-form-actions { display: flex; flex-wrap: wrap; gap: 12px; }
@media (max-width: 1000px) {
  .product-grid { grid-template-columns: repeat(2, 1fr); }
  .grolocals-layout { grid-template-columns: 1fr; gap: 36px; }
  .grolocals-hero-copy { padding-top: 0; }
  .grolocals-login-shell { padding: 48px; }
  .popular-product-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .popular-products-toolbar { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .popular-products-toolbar .button { width: 100%; }
  .review-showcase { grid-template-columns: 1fr; }
  .review-summary-panel { align-items: center; text-align: center; }
  .trust-signal-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .reviews-layout, .write-review-panel { grid-template-columns: 1fr; }
  .reviews-summary { position: static; }
  .nearby-store-grid { grid-template-columns: repeat(2, minmax(320px, 1fr)); }
  .metric-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .profile-layout { grid-template-columns: 1fr; }
  .profile-summary-card { position: static; }
  .about-grid { grid-template-columns: repeat(2, 1fr); }
  .solutions-feature-intro { gap: 32px; }
  .solutions-process { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .solutions-process li { padding-bottom: 32px; }
  .solutions-process li:nth-child(odd) { border-left: 0; }
  .solutions-process li:nth-child(n+3) { padding-top: 32px; border-top: 1px solid var(--border); }
  .platform-commerce { gap: 48px; }
  .platform-principle-grid, .platform-journey { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .platform-journey li:nth-child(odd)::before { display: none; }
  .platform-journey li:nth-child(n+3) { padding-top: 32px; border-top: 1px solid var(--border); }
  .pricing-card-grid--presence { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .pricing-card-grid--presence .pricing-journey-card--featured { width: min(50%, 430px); grid-column: 1 / -1; justify-self: center; }
  .pricing-card-main { min-height: 390px; }
  .pricing-plans { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .pricing-plan { grid-column: auto; }
  .pricing-plan--listing { grid-column: 1 / -1; grid-template-columns: minmax(220px, .8fr) minmax(0, 1.2fr); }
  .pricing-plan-action { grid-column: 1 / -1; }
  .pricing-plan--listing .pricing-best { margin-top: 2px; }
  .resources-tech-grid, .resources-scale-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .auth-page { grid-template-columns: 1fr; gap: 36px; }
  .auth-form-wrap { padding: 48px; }
  .needs-step-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .discovery-search-wrap { padding-top: 22px; }
  .grolocals-layout { padding-top: 50px; }
  .grolocals-hero-copy h1 { letter-spacing: -1.5px; }
  .grolocals-hero-copy > p { font-size: 18px; }
  .grolocals-login-shell { padding: 28px; }
  .grolocals-login-card { padding: 24px; }
  .grolocals-form { padding: 22px; }
  .grolocals-form-grid, .grolocals-how-list { grid-template-columns: 1fr; }
  .discovery-search { height: auto; grid-template-columns: minmax(0, 1fr) 52px; }
  .discovery-query { grid-column: 1 / -1; height: 54px; border-bottom: 1px solid var(--border); }
  .discovery-divider { display: none; }
  .discovery-location { grid-column: 1; grid-row: 2; height: 52px; }
  .discovery-submit { grid-column: 2; grid-row: 2; }
  .discovery-search-wrap, .results-search-wrap { flex-wrap: wrap; justify-content: flex-start; }
  .results-search-head { grid-template-columns: 1fr; }
  .results-search-head .result-count { justify-self: start; }
  .page-intro { padding-top: 55px; }.page-intro h1 { letter-spacing: -2px; }
  .needs-step-list { grid-template-columns: 1fr; gap: 12px; }
  .needs-card-grid, .needs-filter-bar, .need-item-row { grid-template-columns: 1fr; }
  .needs-cta-card { padding: 24px; grid-template-columns: 1fr; gap: 16px; }
  .needs-cta-card .button { width: 100%; justify-self: stretch; }
  .needs-filter-bar .button { width: 100%; }
  .about-page-head { padding-top: 32px; }.about-page-head .page-intro { padding-top: 34px; text-align: left; }
  .about-page-head .page-intro h1, .about-page-head .page-intro > p { margin-inline: 0; }
  .about-page-head > .about-tabs { display: none; }
  .pricing-tab-switch { width: 100%; }
  .pricing-tab-switch button { flex: 1 1 0; min-width: 0; }
  .pricing-journey-note { flex-wrap: wrap; justify-content: center; gap: 10px 18px; font-size: 13px; }
  .pricing-card-grid--presence, .pricing-card-grid--commerce { width: 100%; grid-template-columns: 1fr; }
  .pricing-card-grid--presence .pricing-journey-card--featured { width: 100%; grid-column: auto; }
  .pricing-card-main, .pricing-journey-card--wide .pricing-card-main { min-height: 0; padding: 24px; }
  .pricing-card-copy { min-height: 0; }
  .pricing-feature-toggle { padding-inline: 24px; }
  .pricing-feature-panel > p { padding-inline: 24px; }
  .pricing-feature-panel ul { padding-inline: 24px; }
  .about-mobile-tabs { display: block; border-radius: var(--radius-control); background: var(--surface-soft); }
  .about-mobile-tabs summary { min-height: 50px; padding: 5px; display: grid; grid-template-columns: minmax(0, 1fr) 46px; gap: 4px; align-items: stretch; list-style: none; cursor: pointer; }
  .about-mobile-tabs summary::-webkit-details-marker { display: none; }
  .about-mobile-current, .about-mobile-toggle { display: flex; align-items: center; justify-content: center; border-radius: var(--radius-control); font-size: 14px; font-weight: 800; }
  .about-mobile-current { min-width: 0; color: var(--text-on-dark); background: var(--brand-primary); }
  .about-mobile-toggle { color: var(--brand-primary-dark); background: var(--surface); }
  .about-mobile-toggle svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round; transition: transform var(--transition-ui); }
  .about-mobile-tabs[open] .about-mobile-toggle svg { transform: rotate(180deg); }
  .about-mobile-menu { padding: 4px 5px 6px; display: grid; grid-template-columns: 1fr 1fr; gap: 4px; }
  .about-mobile-menu a { min-height: 34px; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-control); color: var(--brand-secondary); background: transparent; font-size: 14px; font-weight: 800; }
  .about-mobile-menu a.is-active { color: var(--brand-secondary); background: transparent; }
  .about-mobile-menu a:hover { color: var(--brand-primary-dark); background: var(--surface); }
  .about-mobile-menu a.is-active:hover { color: var(--brand-primary-dark); background: var(--surface); }
  .discovery-layout { grid-template-columns: 1fr; gap: 35px; }
  .product-sidebar { position: static; }
  .filter-panel { position: static; }
  .card-grid, .product-grid { grid-template-columns: 1fr; }
  .popular-product-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
  .popular-products-toolbar { grid-template-columns: 1fr; }
  .popular-product-card .product-image { height: 112px; }
  .popular-product-card .card-body { padding: 12px; }
  .popular-product-card h2, .popular-product-card h3 { font-size: 15px; }
  .trust-reviews-modern { padding: 28px 0; }
  .review-rail { padding: 18px; grid-auto-columns: minmax(220px, 86%); }
  .review-summary-panel { padding: 24px; }
  .trust-signal-grid { grid-template-columns: 1fr; }
  .trust-signal-wide { grid-column: auto; }
  .reviews-page-head { align-items: flex-start; flex-direction: column; }
  .reviews-toolbar { align-items: stretch; flex-direction: column; }
  .reviews-toolbar label, .reviews-toolbar .button { width: 100%; }
  .review-list-top { align-items: flex-start; flex-direction: column; gap: 8px; }
  .review-list-card footer em { width: 100%; margin-left: 0; }
  .write-review-panel { padding: 24px; }
  .review-form-grid { grid-template-columns: 1fr; }
  .nearby-store-grid { grid-template-columns: 1fr; }
  .nearby-store-card .card-actions.store-card-actions { flex-wrap: wrap; }
  .store-owner-cta { padding: 35px 25px; align-items: flex-start; flex-direction: column; }
  .about-grid { grid-template-columns: 1fr; }
  .about-detail-content { grid-template-columns: 1fr; gap: 30px; }
  .about-detail-list article { grid-template-columns: 1fr; gap: 10px; }
  .solutions-feature { padding-top: 0; }
  .solutions-feature-intro { grid-template-columns: 1fr; gap: 30px; }
  .solutions-stack, .solutions-benefit-grid, .solutions-process { grid-template-columns: 1fr; }
  .solutions-stack { margin-top: 34px; }
  .solutions-stack article { grid-template-columns: 110px minmax(0, 1fr); gap: 20px; }
  .solutions-stack img { width: 110px; height: 110px; }
  .solutions-section { padding-top: 68px; }
  .solutions-process-section { margin-top: 68px; padding: 62px 0; }
  .solutions-benefits-section { padding-top: 62px; }
  .solutions-process li { padding: 0 0 34px; border-left: 0; }
  .solutions-process li + li { padding-top: 34px; border-top: 1px solid var(--border); border-left: 0; }
  .solutions-impact { margin-top: 72px; padding: 58px 0; }
  .platform-commerce, .platform-reality-layout { grid-template-columns: 1fr; gap: 34px; }
  .platform-reality { margin-top: 72px; padding: 0; }
  .platform-section { padding-top: 68px; }
  .platform-store-section { margin-top: 72px; padding: 34px 24px; }
  .platform-category-grid, .platform-principle-grid, .platform-journey { grid-template-columns: 1fr; }
  .platform-journey li { padding: 0 0 34px; }
  .platform-journey li + li { padding-top: 34px; border-top: 0; }
  .platform-journey li:nth-child(n+2) { border-top: 0; }
  .platform-journey li:nth-child(n+2)::before { width: 68%; height: 2px; display: block; left: 50%; top: 0; transform: translateX(-50%); }
  .platform-closing { margin-top: 72px; padding: 58px 0; }
  .resources-needs, .resources-infrastructure { grid-template-columns: 1fr; gap: 34px; }
  .resources-needs, .resources-section { padding-top: 68px; }
  .resources-tech-grid, .resources-scale-grid { grid-template-columns: 1fr; }
  .resources-scale { margin-top: 72px; padding: 34px 24px; }
  .resources-infrastructure { margin-top: 68px; padding: 0; }
  .resources-conclusion { margin-top: 72px; padding: 58px 0; }
  .pricing-plans { padding-top: 34px; grid-template-columns: 1fr; }
  .pricing-plan { padding: 24px; }
  .pricing-plan--listing { grid-template-columns: 1fr; gap: 22px; }
  .pricing-plan--listing ul { grid-template-columns: 1fr; }
  .pricing-plan-action { grid-column: auto; }
  .pricing-billing-toggle { width: 100%; }
  .pricing-billing-toggle label { flex: 1 1 0; }
  .pricing-billing-toggle span { width: 100%; min-width: 0; }
  .pricing-difference { margin-top: 72px; padding: 34px 24px; grid-template-columns: 1fr; gap: 28px; }
  .pricing-final-cta { margin-top: 72px; padding: 58px 0; }
  .pricing-final-actions { flex-direction: column; }
  .pricing-final-actions .button { width: 100%; }
  .company-split, .company-card-grid, .company-audience-grid { grid-template-columns: 1fr; }
  .company-hero-media { margin-bottom: 30px; }
  .company-overview-copy { padding-bottom: 62px; }
  .company-split { gap: 22px; padding: 62px 0; }
  .company-section { padding-top: 62px; }
  .company-card-grid article { padding: 0 0 34px; }
  .company-card-grid article + article { padding-top: 34px; border-top: 1px solid var(--border); border-left: 0; }
  .company-growth-media { max-width: 460px; margin-bottom: 22px; }
  .company-audience-grid { margin-top: 40px; }
  .company-audience-grid article { grid-template-columns: 1fr; }
  .company-audience-grid img { height: auto; }
  .company-vision { margin-top: 66px; padding: 58px 0; }
  .company-cta { margin-top: 62px; padding: 30px 24px; align-items: flex-start; flex-direction: column; }
  .company-cta-actions { width: 100%; }.company-cta-actions .button { flex: 1 1 170px; }
  .contact-layout { grid-template-columns: 1fr; gap: 30px; }
  .contact-method-grid, .contact-field-grid { grid-template-columns: 1fr; }
  .auth-page { padding-block: 48px 78px; grid-template-columns: 1fr; gap: 34px; }
  .auth-form-wrap { order: 1; padding: 28px; }
  .auth-owner-panel { order: 2; max-width: 100%; padding-block: 0; }
  .store-signup-grid, .store-signup-actions, .store-workspace-card, .store-overview-grid, .store-settings-list { grid-template-columns: 1fr; }
  .store-workspace-card-actions { justify-content: flex-start; flex-wrap: wrap; }
  .store-signup-wide, .store-signup-otp, .profile-field-wide { grid-column: auto; }
  .simple-form-page { grid-template-columns: 1fr; gap: 45px; padding-block: 65px; }
  .detail-layout { grid-template-columns: 1fr; gap: 35px; }
  .detail-media { min-height: 330px; }
  .store-detail-layout { column-gap: 0; gap: 28px; }
  .store-detail-media { width: 100%; height: auto; min-height: 0; aspect-ratio: 5 / 4; }
  .detail-copy { min-width: 0; }
  .detail-copy h1 { font-size: clamp(34px, 9vw, 44px); letter-spacing: -1.4px; }
  .detail-copy > p, .detail-location { overflow-wrap: anywhere; }
  .detail-facts { margin-top: 26px; display: grid; gap: 12px; }
  .detail-facts .detail-fact { width: 100%; }
  .detail-fact dd { min-width: 0; overflow-wrap: anywhere; }
  .store-detail-actions { gap: 12px; align-items: flex-start; }
  .store-detail-action-group { min-width: 0; flex: 1 1 100%; }
  .store-direction-link { margin-left: auto; }
  .store-profile-sections { margin-top: 50px; grid-template-columns: 1fr; row-gap: 44px; }
  .store-section-card { padding: 22px; }
  .store-section-card h2 { font-size: 24px; }
  .store-section-head, .store-section-title-row, .store-location-head { flex-direction: column; gap: 14px; }
  .store-section-title-row .button, .store-location-head .button { width: 100%; }
  .store-hours-today { align-items: flex-start; flex-direction: column; gap: 4px; }
  .store-weekly-hours div { grid-template-columns: 1fr; gap: 2px; }
  .store-gallery-showcase { min-height: 210px; }
  .store-gallery-frame { width: 52%; }
  .gallery-page-head { align-items: flex-start; flex-direction: column; }
  .gallery-page-grid { grid-template-columns: 1fr; }
  .gallery-page-grid figure { min-height: 220px; }
  .popular-products-page-head { align-items: flex-start; flex-direction: column; }
  .products-sold-page-head { align-items: flex-start; flex-direction: column; }
  .products-sold-toolbar, .products-sold-grid { grid-template-columns: 1fr; }
  .products-sold-toolbar .button { width: 100%; }
  .product-sold-card { align-items: flex-start; }
  .store-feature-grid, .store-info-chips { gap: 8px; }
  .store-map-preview { min-height: 210px; }
  .detail-related { padding-top: 65px; }
  .merchant-form-page { grid-template-columns: 1fr; gap: 28px; }
  .merchant-head { align-items: flex-start; flex-direction: column; }
  .merchant-head-actions { width: 100%; justify-content: flex-start; }
  .merchant-field-grid, .gallery-grid, .trust-review-grid { grid-template-columns: 1fr; }
  .web-review-source { align-items: flex-start; flex-direction: column; }
  .completion-panel { grid-template-columns: 1fr; }
  .metric-grid { grid-template-columns: 1fr; }
  .profile-summary-card { position: relative; z-index: 20; }
  .profile-section-trigger { width: 100%; min-height: 46px; padding: 11px 13px; display: flex; align-items: center; justify-content: space-between; gap: 12px; border: 1px solid var(--border); border-radius: var(--radius-control); color: var(--brand-secondary); background: var(--surface-soft); font: inherit; font-size: 14px; font-weight: 900; text-align: left; }
  .profile-section-trigger:hover, .profile-section-trigger:focus-visible { color: var(--brand-primary-dark); background: var(--surface); }
  .profile-section-trigger-caret { width: 0; height: 0; flex: 0 0 auto; border-left: 5px solid transparent; border-right: 5px solid transparent; border-top: 6px solid currentColor; transition: transform var(--transition-ui); }
  .profile-summary-card.is-profile-menu-open .profile-section-trigger-caret { transform: rotate(180deg); }
  .profile-section-nav { display: none; position: absolute; left: 0; right: 0; top: calc(100% + 8px); z-index: 30; padding: 6px; border: 1px solid var(--border); border-radius: var(--radius-control); background: var(--surface); box-shadow: none; }
  .profile-summary-card.is-profile-menu-open .profile-section-nav { display: grid; }
  .profile-section-nav a, .profile-section-nav button { min-height: 42px; }
  .profile-field-grid, .profile-readonly-grid, .profile-info-list, .profile-mini-grid, .profile-request-list article, .profile-wallet-grid, .request-form-grid { grid-template-columns: 1fr; }
  .profile-readonly-grid > div:last-child { grid-column: auto; }
  .profile-edit-action { grid-column: auto; justify-items: stretch; }
  .profile-edit-action .button { width: 100%; }
  .request-field-wide { grid-column: auto; }
  .profile-card-head { align-items: stretch; flex-direction: column; }
  .profile-card-head .button { width: 100%; }
  .profile-password-actions .button { width: 100%; }
  .profile-account-actions { flex-direction: column; }
  .profile-account-actions .button, .profile-account-actions form { width: 100%; }
  .merchant-search { flex-direction: column; }
}
@media (max-width: 450px) {
  .auth-card-head { align-items: flex-start; flex-direction: column; gap: 14px; }
  .auth-tabs { width: 100%; }
  .auth-tab { min-width: 0; }
  .auth-submit-row { align-items: stretch; flex-direction: column; gap: 12px; }
  .auth-signup-prompt { margin-top: 0; }
  .auth-submit-stack { justify-items: stretch; }
  .auth-login-button { width: 100%; }
  .auth-forgot-link { text-align: right; }
  .solutions-stack article { grid-template-columns: 82px minmax(0, 1fr); gap: 16px; padding: 16px; }
  .solutions-stack img { width: 82px; height: 82px; }
  .solutions-benefit-grid article { grid-template-columns: 96px minmax(0, 1fr); gap: 16px; padding: 16px; }
  .solutions-benefit-media { width: 96px; }
  .store-card { grid-template-columns: 64px 1fr; padding: 17px; }.logo-placeholder { width: 64px; height: 64px; }
  .results-head { align-items: flex-start; gap: 12px; }.result-count { white-space: nowrap; }
  .inquiry-grid { grid-template-columns: 1fr; }.contact-form { padding: 22px; }
  .merchant-form { padding: 22px; }
  .merchant-section-head { grid-template-columns: 1fr; }
  .merchant-section-head > span { width: 30px; height: 30px; }
  .store-card-actions { flex-wrap: wrap; }
  .merchant-form-actions .button, .merchant-head-actions .button, .card-actions .button { width: 100%; }
  .store-card-actions .button { width: auto; }
  .store-owner-actions { width: 100%; flex-direction: column; }.auth-form { padding: 27px 20px; }.price-row { grid-template-columns: 1fr; }
}
