:root {
  --ink: #0a0c12;
  --blue: #1236d9;
  --blue-deep: #071b79;
  --lime: #c7ff2f;
  --paper: #f4f2ec;
  --white: #fff;
  --muted: #686a70;
  --line: #d9d8d2;
  --display: "Space Grotesk", sans-serif;
  --body: "DM Sans", sans-serif;
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--ink); font-family: var(--body); }
button, input, select { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
a { color: inherit; text-decoration: none; }
svg { fill: none; stroke: currentColor; stroke-width: 1.8; }

.announcement {
  height: 32px; padding: 0 4vw; display: flex; align-items: center; justify-content: space-between;
  background: var(--lime); font-size: 11px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
}
.announcement a { text-decoration: underline; text-underline-offset: 3px; }
.site-header {
  height: 76px; padding: 0 4vw; display: flex; align-items: center; justify-content: space-between;
  background: var(--paper); border-bottom: 1px solid rgba(0,0,0,.1); position: relative; z-index: 20;
}
.logo { display: flex; align-items: center; gap: 9px; font: 700 24px var(--display); letter-spacing: -.06em; }
.logo svg { width: 32px; height: 27px; fill: var(--blue); stroke: none; }
.main-nav { display: flex; align-items: center; gap: 34px; font-size: 13px; font-weight: 600; }
.account-button { padding: 7px 10px; display: flex; align-items: center; gap: 7px; border: 0; background: transparent; cursor: pointer; font-size: 11px; font-weight: 700; }
.account-button svg { width: 19px; height: 19px; fill: none; stroke: currentColor; }
.account-nav-text { padding: 0 0 3px; border-bottom: 1px solid var(--ink); font-size: 13px; }
.main-nav a { position: relative; }
.main-nav a:after { content: ""; position: absolute; left: 0; right: 100%; bottom: -6px; height: 2px; background: var(--blue); transition: right .25s; }
.main-nav a:hover:after { right: 0; }
.header-actions { display: flex; gap: 8px; align-items: center; }
.icon-button, .menu-button { border: 0; background: transparent; cursor: pointer; position: relative; padding: 8px; }
.icon-button svg { width: 20px; height: 20px; }
.cart-count { position: absolute; right: 1px; top: 0; width: 16px; height: 16px; display: grid; place-items: center; border-radius: 50%; background: var(--blue); color: white; font-size: 9px; }
.menu-button { display: none; width: 36px; }
.menu-button span { display: block; height: 2px; width: 22px; margin: 5px 0; background: var(--ink); }

.hero { height: min(690px, calc(100vh - 108px)); min-height: 570px; position: relative; overflow: hidden; background: #02040b; color: white; }
.hero > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(2,4,11,.98) 0%, rgba(2,4,11,.85) 30%, rgba(2,4,11,.12) 66%, rgba(2,4,11,.08)); }
.hero-content { position: relative; z-index: 2; max-width: 1260px; height: 100%; margin: auto; padding: 9vh 4vw 125px; }
.eyebrow { margin: 0 0 24px; display: flex; align-items: center; gap: 9px; font-size: 11px; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; }
.eyebrow span { width: 23px; height: 2px; background: var(--lime); }
.eyebrow.dark span { background: var(--blue); }
h1, h2 { margin: 0; font-family: var(--display); letter-spacing: -.065em; line-height: .94; }
h1 { max-width: 650px; font-size: clamp(58px, 7vw, 98px); }
h1 em, h2 em { color: var(--lime); font-style: normal; }
.hero-copy { margin: 28px 0; color: #c4c8d3; font-size: 16px; line-height: 1.6; }
.hero-actions { display: flex; align-items: center; gap: 28px; }
.button { min-height: 48px; padding: 0 22px; display: inline-flex; align-items: center; justify-content: center; gap: 30px; border: 0; cursor: pointer; font-weight: 700; font-size: 13px; transition: transform .2s, background .2s; }
.button:hover { transform: translateY(-2px); }
.button-primary { background: var(--lime); color: var(--ink); }
.button-dark { background: var(--ink); color: white; }
.button-lime { background: var(--lime); }
.text-link { font-size: 13px; border-bottom: 1px solid #6d7180; padding-bottom: 5px; }
.trust-strip {
  position: absolute; z-index: 3; bottom: 0; left: 0; right: 0; min-height: 92px; padding: 0 4vw 0 46%;
  display: grid; grid-template-columns: repeat(4, 1fr); align-items: center; background: rgba(8,10,19,.78); backdrop-filter: blur(14px); border-top: 1px solid rgba(255,255,255,.16);
}
.trust-strip div { padding-left: 22px; border-left: 1px solid rgba(255,255,255,.18); }
.trust-strip strong, .trust-strip span { display: block; }
.trust-strip strong { font: 600 17px var(--display); }
.trust-strip span { margin-top: 4px; color: #9398a6; font-size: 10px; text-transform: uppercase; letter-spacing: .1em; }

.finder { position: relative; z-index: 5; width: min(1180px, 92vw); margin: -28px auto 0; box-shadow: 0 14px 38px rgba(19,21,26,.12); }
.finder form { padding: 12px; display: grid; grid-template-columns: 1.7fr .7fr .7fr auto; gap: 10px; background: white; }
.search-box { display: flex; align-items: center; gap: 9px; padding: 0 12px; background: #f3f3f0; }
.search-box svg { width: 19px; }
.search-box input, .finder select { width: 100%; min-height: 48px; border: 0; background: #f3f3f0; color: #3f4147; outline: none; }
.finder select { padding: 0 14px; border-left: 1px solid var(--line); }

.section { width: min(1180px, 92vw); margin: 0 auto; }
.catalog { padding: 100px 0 115px; }
.section-heading { display: flex; align-items: end; justify-content: space-between; margin-bottom: 34px; }
.section-heading .eyebrow { margin-bottom: 17px; color: var(--blue); }
h2 { font-size: clamp(42px, 5vw, 68px); }
.catalog h2 em, .how h2 em { color: var(--blue); }
.view-all { padding-bottom: 5px; border-bottom: 1px solid; font-size: 13px; font-weight: 700; }
.category-tabs { display: flex; gap: 6px; margin-bottom: 24px; overflow-x: auto; scrollbar-width: none; }
.tab { padding: 10px 16px; flex: 0 0 auto; border: 1px solid var(--line); background: transparent; font-size: 12px; font-weight: 700; cursor: pointer; }
.tab.active { background: var(--ink); color: white; border-color: var(--ink); }
.product-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.product-card { position: relative; background: white; transition: transform .25s, box-shadow .25s; }
.product-card:hover { transform: translateY(-5px); box-shadow: 0 18px 45px rgba(20,21,25,.1); }
.product-visual { height: 225px; display: grid; place-items: center; overflow: hidden; background: #e9e8e3; position: relative; }
.product-visual img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.product-card:hover .product-visual img { transform: scale(1.035); }
.condition { position: absolute; top: 12px; left: 12px; z-index: 2; padding: 6px 8px; color: white; background: var(--blue); font-size: 9px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.watch { position: absolute; top: 11px; right: 11px; z-index: 2; width: 32px; height: 32px; display: grid; place-items: center; border: 0; border-radius: 50%; background: white; cursor: pointer; }
.watch svg { width: 17px; }
.watch.active svg { fill: var(--blue); color: var(--blue); }
.product-info { padding: 17px; }
.product-brand { margin: 0 0 7px; color: var(--muted); font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; }
.product-info h3 { height: 42px; margin: 0; font: 600 16px/1.3 var(--display); letter-spacing: -.02em; }
.specs { margin: 11px 0 15px; color: var(--muted); font-size: 11px; }
.price-row { display: flex; justify-content: space-between; align-items: end; padding-top: 14px; border-top: 1px solid #ecece8; }
.price strong { display: block; font: 700 20px var(--display); }
.price del { color: #8f9196; font-size: 10px; }
.add-cart { width: 34px; height: 34px; display: grid; place-items: center; border: 0; background: var(--lime); cursor: pointer; font-size: 20px; transition: background .2s; }
.add-cart:hover { background: var(--ink); color: white; }
.product-actions { display: flex; align-items: center; gap: 7px; }
.buy-now { min-height: 34px; padding: 0 11px; border: 1px solid var(--ink); background: transparent; cursor: pointer; font-size: 10px; font-weight: 700; text-transform: uppercase; }
.buy-now:hover { background: var(--ink); color: white; }
.empty-state { padding: 50px; text-align: center; color: var(--muted); }

.sell-banner { min-height: 440px; padding: 66px 7%; overflow: hidden; position: relative; display: grid; grid-template-columns: 1fr 1.1fr; align-items: center; background: var(--blue); color: white; }
.sell-content { position: relative; z-index: 2; grid-column: 2; }
.sell-content h2 { font-size: clamp(48px, 5.2vw, 76px); }
.sell-content p:not(.eyebrow) { max-width: 470px; margin: 24px 0; color: #c8d0ff; line-height: 1.65; }
.sell-stats { position: absolute; bottom: 34px; right: 6%; display: flex; gap: 45px; }
.sell-stats strong, .sell-stats span { display: block; }
.sell-stats strong { font: 600 20px var(--display); }
.sell-stats span { color: #aab4ef; font-size: 10px; text-transform: uppercase; }
.sell-art { position: absolute; width: 50%; height: 100%; left: 0; top: 0; overflow: hidden; }
.orbit { position: absolute; border: 1px solid rgba(199,255,47,.35); border-radius: 50%; }
.orbit-one { width: 400px; height: 400px; left: -70px; top: 20px; }
.orbit-two { width: 280px; height: 280px; left: 20px; top: 80px; }
.laptop-shape { position: absolute; left: 7%; top: 26%; width: 70%; height: 48%; border: 10px solid #171b2b; border-radius: 8px; background: linear-gradient(135deg,#080b15,#202943); transform: rotate(-13deg); box-shadow: 0 35px 40px rgba(0,0,0,.32); }
.laptop-shape:after { content: ""; position: absolute; left: -12%; right: -12%; bottom: -25px; height: 18px; background: #aeb5bf; clip-path: polygon(5% 0,95% 0,100% 100%,0 100%); }
.laptop-shape span { position: absolute; inset: 13%; background: linear-gradient(135deg, var(--lime), #1a49ef 58%, #07112e); }

.brands { padding: 90px 0; text-align: center; }
.brands > p { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .13em; }
.brand-row { margin-top: 32px; display: flex; align-items: center; justify-content: space-between; gap: 20px; color: #42444a; font: 700 clamp(18px,2.2vw,29px) var(--display); }
.how { padding: 0 0 110px; }
.steps { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); }
.steps article { padding: 28px 8% 20px 0; border-right: 1px solid var(--line); }
.steps article + article { padding-left: 8%; }
.steps article:last-child { border-right: 0; }
.steps article > span { color: var(--blue); font-size: 11px; font-weight: 700; }
.steps h3 { margin: 42px 0 12px; font: 600 22px var(--display); }
.steps p { color: var(--muted); font-size: 13px; line-height: 1.65; }
footer { padding: 35px 4vw; display: flex; align-items: center; justify-content: space-between; background: var(--ink); color: white; font-size: 12px; }
.footer-logo svg { fill: var(--lime); }
.footer-links { display: flex; align-items: center; gap: 18px; }
.footer-links button, .footer-links a { padding: 0; border: 0; border-bottom: 1px solid #777b86; background: none; color: white; cursor: pointer; font-size: 11px; }
.toast { position: fixed; right: 24px; bottom: 24px; z-index: 50; padding: 13px 18px; background: var(--ink); color: white; font-size: 13px; transform: translateY(100px); opacity: 0; transition: .3s; }
.toast.show { transform: none; opacity: 1; }

body.modal-open { overflow: hidden; }
.modal-backdrop { position: fixed; inset: 0; z-index: 100; padding: 25px; display: grid; place-items: center; background: rgba(3,5,12,.76); backdrop-filter: blur(7px); }
.modal-backdrop[hidden] { display: none; }
.admin-modal { width: min(880px, 100%); max-height: calc(100vh - 50px); overflow-y: auto; position: relative; padding: 46px; background: var(--paper); box-shadow: 0 30px 80px rgba(0,0,0,.35); }
.modal-close { position: absolute; z-index: 2; right: 20px; top: 16px; width: 38px; height: 38px; border: 0; background: transparent; font-size: 30px; font-weight: 300; cursor: pointer; }
.admin-login { max-width: 590px; margin: 30px auto; }
.admin-login h2, .admin-dashboard h2 { font-size: clamp(40px, 6vw, 60px); }
.admin-login h2 em, .admin-dashboard h2 em { color: var(--blue); }
.admin-login > p:not(.eyebrow) { margin: 20px 0 28px; color: var(--muted); }
.admin-login label, .admin-form-grid > label { display: grid; gap: 8px; font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.password-row { display: grid; grid-template-columns: 1fr auto; gap: 8px; }
.admin-modal input, .admin-modal select { width: 100%; min-height: 48px; padding: 0 14px; border: 1px solid var(--line); border-radius: 0; background: white; outline: none; }
.admin-modal input:focus, .admin-modal select:focus { border-color: var(--blue); box-shadow: 0 0 0 2px rgba(18,54,217,.1); }
.login-hint { margin: 12px 0 0; color: var(--muted); font-size: 11px; }
.form-error { min-height: 18px; margin: 7px 0 0; color: #b51f34; font-size: 12px; }
.admin-header { display: flex; align-items: end; justify-content: space-between; margin-bottom: 30px; }
.admin-header .eyebrow { margin-bottom: 14px; }
.admin-logout { border: 0; border-bottom: 1px solid; padding: 5px 0; background: none; cursor: pointer; font-size: 12px; font-weight: 700; }
.admin-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.admin-form-grid .full-field { grid-column: 1 / -1; }
.admin-form-grid fieldset { margin: 0; padding: 16px; display: flex; flex-wrap: wrap; gap: 18px; border: 1px solid var(--line); }
.admin-form-grid legend { padding: 0 7px; font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.admin-form-grid fieldset label { display: flex; align-items: center; gap: 7px; font-size: 12px; }
.admin-form-grid input[type="checkbox"] { width: 16px; min-height: 16px; accent-color: var(--blue); }
.admin-submit-row { margin-top: 24px; display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.admin-submit-row p { color: var(--muted); font-size: 12px; }
.admin-products { margin-top: 38px; padding-top: 26px; border-top: 1px solid var(--line); }
.admin-products-heading { display: flex; align-items: center; justify-content: space-between; }
.admin-products-heading h3 { margin: 0; font: 600 17px var(--display); }
.admin-products-heading span { color: var(--muted); font-size: 11px; }
.admin-product-item { margin-top: 12px; padding: 10px; display: grid; grid-template-columns: 56px 1fr auto; gap: 13px; align-items: center; background: white; }
.admin-product-item img { width: 56px; height: 45px; object-fit: cover; background: #ddd; }
.admin-product-item strong, .admin-product-item span { display: block; }
.admin-product-item strong { font-size: 13px; }
.admin-product-item span { margin-top: 3px; color: var(--muted); font-size: 10px; }
.delete-product { width: 32px; height: 32px; border: 0; background: #f0efeb; color: #9c1830; cursor: pointer; font-size: 17px; }
.admin-item-actions { display: flex; align-items: center; gap: 6px; }
.edit-product, .admin-cancel-edit { padding: 8px 11px; border: 1px solid var(--line); background: white; cursor: pointer; font-size: 11px; font-weight: 700; }
.admin-cancel-edit { margin-right: auto; }
.order-item { margin-top: 12px; padding: 15px; display: grid; grid-template-columns: 1fr auto; gap: 18px; align-items: center; background: white; }
.order-item strong, .order-item span { display: block; }
.order-item span { margin-top: 4px; color: var(--muted); font-size: 11px; }
.order-item select { margin-top: 8px; min-height: 34px; border: 1px solid var(--line); background: var(--paper); font-size: 11px; }
.order-status { font-weight: 700; text-transform: capitalize; }
.reseller-entry { max-width: 660px; margin: 12px auto; }
.reseller-entry h2 { font-size: clamp(42px, 6vw, 62px); }
.reseller-entry h2 em { color: var(--blue); }
.entry-copy { color: var(--muted); }
.portal-tabs { margin: 28px 0 22px; display: grid; grid-template-columns: 1fr 1fr; border-bottom: 1px solid var(--line); }
.portal-tab, .account-tab, .reseller-tab { padding: 13px; border: 0; border-bottom: 3px solid transparent; background: transparent; cursor: pointer; font-weight: 700; }
.portal-tab.active, .account-tab.active, .reseller-tab.active { color: var(--blue); border-bottom-color: var(--blue); }
.portal-form { display: grid; gap: 17px; }
.portal-form > label { display: grid; gap: 8px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.terms-check { margin: 4px 0; display: flex !important; grid-column: 1 / -1; align-items: flex-start; gap: 10px !important; color: #4f5157; font-size: 12px !important; line-height: 1.5; text-transform: none !important; letter-spacing: 0 !important; }
.terms-check input { width: 17px; min-height: 17px; margin-top: 1px; accent-color: var(--blue); }
.reseller-status { max-width: 580px; margin: 40px auto; padding: 35px; text-align: center; background: white; }
.reseller-status .status-mark { width: 58px; height: 58px; margin: 0 auto 18px; display: grid; place-items: center; border-radius: 50%; background: #fff2c7; font-size: 25px; }
.reseller-status h3, .seller-terms-panel h3, .seller-listing-panel > h3 { font: 600 24px var(--display); }
.reseller-status p, .seller-terms-panel > p { color: var(--muted); line-height: 1.6; }
.seller-terms-panel { max-width: 650px; margin: 10px auto; }
.terms-box { max-height: 180px; margin: 24px 0 18px; padding: 20px; overflow-y: auto; border: 1px solid var(--line); background: white; }
.terms-box p { color: var(--muted); font-size: 12px; line-height: 1.65; }
.accept-terms:disabled { opacity: .45; cursor: not-allowed; transform: none; }
.seller-welcome { margin-bottom: 27px; padding: 13px 16px; display: flex; justify-content: space-between; background: #e7f1d0; font-size: 12px; }
.seller-welcome strong { color: #2f5a18; }
.fee-notice { margin: -16px 0 27px; padding: 13px 16px; display: flex; justify-content: space-between; gap: 18px; border: 1px solid var(--line); font-size: 11px; }
.fee-notice span { color: var(--muted); text-align: right; }
.application-item { margin-top: 12px; padding: 14px; display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: center; background: white; }
.application-item strong, .application-item span { display: block; }
.application-item span { margin-top: 4px; color: var(--muted); font-size: 11px; }
.application-actions { display: flex; gap: 7px; }
.approve-button, .reject-button { padding: 8px 11px; border: 0; cursor: pointer; font-size: 11px; font-weight: 700; }
.approve-button { background: var(--lime); }
.reject-button { background: #f1e4e5; color: #8b1e31; }
.cart-panel { width: min(560px, 100%); max-height: calc(100vh - 40px); overflow-y: auto; position: relative; padding: 44px; background: var(--paper); }
.cart-panel h2 { margin-bottom: 28px; font-size: 52px; }
.cart-panel h2 em { color: var(--blue); }
.cart-line { margin-bottom: 10px; padding: 11px; display: grid; grid-template-columns: 72px 1fr auto; gap: 13px; align-items: center; background: white; }
.cart-line img { width: 72px; height: 58px; object-fit: cover; }
.cart-line strong, .cart-line span { display: block; }
.cart-line strong { font-size: 13px; }
.cart-line span { margin-top: 4px; color: var(--muted); font-size: 11px; }
.remove-cart { border: 0; background: transparent; color: #a21f35; cursor: pointer; font-size: 20px; }
.cart-empty { padding: 35px 10px; color: var(--muted); text-align: center; }
.cart-summary { margin: 20px 0; padding-top: 18px; border-top: 1px solid var(--line); }
.cart-summary > div { display: flex; justify-content: space-between; font-size: 15px; }
.cart-summary strong { font: 700 22px var(--display); }
.cart-summary .cart-total { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line); }
.cart-summary p, .checkout-note { color: var(--muted); font-size: 10px; line-height: 1.5; }
#checkout-form label { display: grid; gap: 8px; font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
#checkout-form { display: grid; gap: 11px; }
#checkout-form input, #checkout-form select { width: 100%; min-height: 48px; padding: 0 14px; border: 1px solid var(--line); background: white; }
.checkout-button { width: 100%; margin-top: 12px; }
.checkout-button:disabled { opacity: .45; cursor: not-allowed; transform: none; }
.checkout-auth-gate { display: grid; gap: 10px; }
.checkout-auth-gate[hidden], #checkout-form[hidden] { display: none; }
.checkout-auth-gate h3 { margin: 0 0 7px; font: 600 17px var(--display); text-align: center; }
.checkout-auth-gate .button { width: 100%; }
.checkout-signin { background: var(--blue); color: white; }
.checkout-guest { border: 1px solid var(--line); background: white; color: var(--blue); }
.legal-modal { max-width: 680px; }
.legal-modal h2 { font-size: 48px; }
.legal-modal h2 em { color: var(--blue); }
.legal-copy { color: #4e5159; font-size: 13px; line-height: 1.75; }
.legal-copy h3 { margin-top: 25px; color: var(--ink); font: 600 18px var(--display); }
.product-detail { width: min(920px, 100%); max-height: calc(100vh - 40px); overflow-y: auto; position: relative; display: grid; grid-template-columns: 1.05fr .95fr; background: var(--paper); }
.detail-image-wrap { min-height: 570px; position: relative; background: #e7e6e1; }
.detail-image-wrap img { width: 100%; height: 100%; object-fit: cover; }
.detail-content { padding: 60px 44px 40px; }
.detail-content h2 { margin: 5px 0 18px; font-size: 42px; line-height: 1.02; }
.detail-price { display: flex; align-items: baseline; gap: 12px; }
.detail-price strong { font: 700 26px var(--display); }
.detail-price del { color: var(--muted); font-size: 12px; }
.detail-specs { margin: 28px 0; padding: 22px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.detail-specs h3 { margin: 0 0 14px; font: 600 16px var(--display); }
.spec-row { padding: 8px 0; display: flex; justify-content: space-between; gap: 20px; color: var(--muted); font-size: 12px; border-bottom: 1px solid #e5e3dd; }
.spec-row:last-child { border-bottom: 0; }
.spec-row strong { color: var(--ink); font-weight: 600; text-align: right; }
.detail-assurances { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 24px; }
.detail-assurances div { padding-right: 8px; border-right: 1px solid var(--line); }
.detail-assurances div:last-child { border-right: 0; }
.detail-assurances strong, .detail-assurances span { display: block; }
.detail-assurances strong { font: 600 13px var(--display); }
.detail-assurances span { margin-top: 4px; color: var(--muted); font-size: 9px; line-height: 1.3; text-transform: uppercase; }
.detail-purchase-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }
.detail-purchase-actions .button { width: 100%; gap: 16px; }
.product-card { cursor: pointer; }
.account-modal { max-width: 620px; }
.account-entry { max-width: 500px; margin: 15px auto; }
.account-entry h2, .account-welcome h2 { font-size: 52px; }
.account-entry h2 em, .account-welcome h2 em { color: var(--blue); }
.account-welcome { max-width: 500px; margin: 30px auto; text-align: center; }
.account-welcome .status-mark { width: 58px; height: 58px; margin: 0 auto 20px; display: grid; place-items: center; border-radius: 50%; background: var(--lime); font-size: 24px; }
.account-welcome p { margin: 18px 0 25px; color: var(--muted); line-height: 1.6; }
.account-text-action { justify-self: start; padding: 0; border: 0; border-bottom: 1px solid currentColor; background: transparent; color: var(--blue); cursor: pointer; font-size: 12px; }
.account-status { min-height: 18px; color: #245d20; font-size: 12px; line-height: 1.5; }
.admin-page { min-height: 100vh; background: #eceae4; }
.admin-page-header { height: 76px; padding: 0 4vw; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; background: var(--paper); border-bottom: 1px solid var(--line); }
.admin-page-header > span { color: var(--muted); font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.admin-page-header > a:last-child { justify-self: end; font-size: 12px; font-weight: 700; }
.admin-page-main { width: min(940px, 92vw); margin: 0 auto; padding: 70px 0 100px; }
.admin-page-login { width: min(520px, 100%); margin: 5vh auto; padding: 45px; background: var(--paper); box-shadow: 0 25px 60px rgba(0,0,0,.08); }
.admin-page-login h1 { color: var(--ink); font-size: 58px; }
.admin-page-login h1 em { color: var(--blue); }
.admin-page-login > p:not(.eyebrow) { color: var(--muted); line-height: 1.6; }
.admin-page-login form { display: grid; gap: 17px; margin-top: 28px; }
.admin-page-login label, .admin-page-card .admin-form-grid > label { display: grid; gap: 8px; font-size: 11px; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; }
.admin-page-login input, .admin-page-card input, .admin-page-card select { min-height: 48px; padding: 0 14px; border: 1px solid var(--line); background: white; }
.admin-page-dashboard > .admin-header { margin-bottom: 30px; }
.admin-page-card { padding: 30px; background: var(--paper); }
.admin-page-card + .admin-page-card { margin-top: 22px; }
.field-help { color: var(--muted); font-size: 10px; font-weight: 500; letter-spacing: 0; text-transform: none; }
.admin-page-card input[type="file"] { padding: 12px; background: white; }
.admin-page-card input[type="file"]::file-selector-button { margin-right: 12px; padding: 9px 13px; border: 0; background: var(--ink); color: white; cursor: pointer; font: 600 11px var(--body); }
.upload-preview { min-height: 90px; padding: 10px; display: flex; align-items: center; gap: 14px; border: 1px solid var(--line); background: white; }
.upload-preview[hidden] { display: none; }
.upload-preview img { width: 110px; height: 80px; object-fit: cover; background: #ddd; }
.upload-preview span { color: var(--muted); font-size: 12px; overflow-wrap: anywhere; }

@media (max-width: 900px) {
  .announcement-center { display: none; }
  .main-nav { display: none; position: absolute; left: 0; top: 76px; width: 100%; padding: 25px 4vw; flex-direction: column; align-items: flex-start; background: var(--paper); }
  .main-nav.open { display: flex; }
  .menu-button { display: block; }
  .header-actions .account-button span { display: none; }
  .hero-content { padding-top: 10vh; }
  .trust-strip { padding-left: 4vw; }
  .finder form { grid-template-columns: 1fr 1fr; }
  .search-box { grid-column: 1 / -1; }
  .product-grid { grid-template-columns: repeat(2, 1fr); }
  .sell-banner { grid-template-columns: .8fr 1.2fr; padding-right: 5%; }
}

@media (max-width: 600px) {
  .announcement { justify-content: center; }
  .announcement a { display: none; }
  .site-header { height: 66px; }
  .search-toggle { display: none; }
  .hero { height: 690px; }
  .hero > img { object-position: 65% center; opacity: .62; }
  .hero-overlay { background: linear-gradient(180deg, rgba(2,4,11,.2), rgba(2,4,11,.45) 38%, #02040b 76%); }
  .hero-content { padding: 270px 5vw 130px; display: flex; flex-direction: column; justify-content: center; }
  h1 { font-size: 54px; }
  .hero-copy br { display: none; }
  .trust-strip { grid-template-columns: 1fr 1fr; min-height: 104px; }
  .trust-strip div:nth-child(even) { border-right: 0; }
  .finder { margin-top: 0; width: 100%; }
  .finder form { grid-template-columns: 1fr; padding: 14px 5vw; }
  .search-box { grid-column: auto; }
  .finder select { display: none; }
  .catalog { padding: 74px 0 85px; }
  .section-heading { align-items: start; }
  .view-all { display: none; }
  h2 { font-size: 43px; }
  .product-grid { grid-template-columns: 1fr; }
  .product-visual { height: 290px; }
  .sell-banner { width: 100%; min-height: 680px; padding: 50px 6vw; display: block; }
  .sell-art { top: auto; bottom: 0; width: 100%; height: 44%; opacity: .8; }
  .sell-content { max-width: 100%; }
  .sell-stats { bottom: 24px; left: 6vw; right: auto; }
  .brand-row { flex-wrap: wrap; justify-content: center; gap: 24px 34px; }
  .steps { grid-template-columns: 1fr; }
  .steps article, .steps article + article { padding: 28px 0; border-right: 0; border-bottom: 1px solid var(--line); }
  .steps h3 { margin-top: 20px; }
  footer { flex-direction: column; gap: 18px; text-align: center; }
  .modal-backdrop { padding: 0; }
  .admin-modal { width: 100%; height: 100vh; max-height: none; padding: 62px 5vw 35px; }
  .admin-form-grid { grid-template-columns: 1fr; }
  .admin-form-grid .full-field { grid-column: auto; }
  .admin-submit-row { align-items: stretch; flex-direction: column; }
  .password-row { grid-template-columns: 1fr; }
  .product-detail { width: 100%; height: 100vh; max-height: none; grid-template-columns: 1fr; }
  .detail-image-wrap { min-height: 330px; }
  .detail-content { padding: 34px 5vw; }
}
