/* ── Reset & Base ── */*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}:root{ --color-bg:#fafaf9; --color-surface:#ffffff; --color-text:#1a1a1a; --color-text-secondary:#6b6b6b; --color-accent:#2c2c2c; --color-accent-hover:#444444; --color-border:#e8e8e8; --color-sold-badge:#b91c1c; --color-success:#166534; --font-sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif; --font-serif:'Playfair Display',Georgia,serif; --shadow-sm:0 1px 3px rgba(0,0,0,0.06); --shadow-md:0 4px 12px rgba(0,0,0,0.08); --shadow-lg:0 8px 30px rgba(0,0,0,0.1); --radius:8px; --max-width:1100px; --nav-height:64px;}html{scroll-behavior:smooth}body{ font-family:var(--font-sans); background:var(--color-bg); color:var(--color-text); line-height:1.6; -webkit-font-smoothing:antialiased;}/* ── Screen-reader only (visually hidden,accessible to crawlers/assistive tech) ── */.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;}/* ── Skip to main content link ── */.skip-link{ position:absolute; top:-100%; left:0; padding:10px 20px; background:var(--color-accent); color:#fff; font-size:0.875rem; font-weight:500; text-decoration:none; z-index:9999; border-radius:0 0 var(--radius) 0; transition:top 0.15s ease;}.skip-link:focus{ top:0; outline:2px solid #fff; outline-offset:-4px;}/* ── Navigation ── */.nav{ position:fixed; top:0; left:0; right:0; height:var(--nav-height); background:rgba(255,255,255,0.92); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-bottom:1px solid var(--color-border); z-index:1000; display:flex; align-items:center; justify-content:center;}.nav-inner{ width:100%; max-width:var(--max-width); padding:0 24px; display:flex; align-items:center; justify-content:space-between;}.nav-logo{ font-family:var(--font-serif); font-size:1.1rem; font-weight:500; letter-spacing:-0.02em; color:var(--color-text); white-space:nowrap; text-decoration:none;}.nav-links{ display:flex; gap:32px; list-style:none;}.nav-links a{ text-decoration:none; color:var(--color-text-secondary); font-size:0.875rem; font-weight:500; letter-spacing:0.02em; text-transform:uppercase; transition:color 0.2s; cursor:pointer; position:relative;}.nav-links a:hover,.nav-links a.active{ color:var(--color-text);}.nav-links a.active::after{ content:''; position:absolute; bottom:-4px; left:0; right:0; height:1.5px; background:var(--color-text);}.nav-contact{ font-size:0.8rem; color:var(--color-text-secondary);}.nav-contact a{ color:var(--color-text-secondary); text-decoration:none; transition:color 0.2s;}.nav-contact a:hover{color:var(--color-text)}/* Mobile nav */.nav-toggle{ display:none; background:none; border:none; cursor:pointer; padding:10px; min-width:44px; min-height:44px;}/* Phone number nav item — hidden on desktop,visible in mobile dropdown */.nav-phone-mobile{ display:none;}.nav-toggle span{ display:block; width:22px; height:2px; background:var(--color-text); margin:5px 0; transition:all 0.3s;}/* ── Credibility Strip ── */.credibility-strip{ background:var(--color-accent); color:rgba(255,255,255,0.9); text-align:center; padding:10px 24px; font-size:0.8rem; font-weight:500; letter-spacing:0.04em; display:flex; justify-content:center; align-items:center; gap:24px; flex-wrap:wrap; margin-top:var(--nav-height);}.credibility-strip span{ white-space:nowrap;}.credibility-strip .credibility-sep{ opacity:0.35; font-size:0.6rem;}/* ── Main Content ── */main{padding-top:0}body:not(:has(.credibility-strip)) main{padding-top:var(--nav-height)}.page{ animation:fadeIn 0.3s ease;}@keyframes fadeIn{ from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)}}/* ── Hero / Header Section ── */.hero{ text-align:center; padding:64px 24px 40px; max-width:var(--max-width); margin:0 auto;}.hero h1{ font-family:var(--font-serif); font-size:2.5rem; font-weight:500; letter-spacing:-0.03em; margin-bottom:12px; line-height:1.2;}.hero .tagline{ font-size:1rem; color:var(--color-text-secondary); font-weight:300; max-width:640px; margin:0 auto 0; line-height:1.7;}/* ── Hero Sell CTA ── */.hero-sell-cta{ text-align:center; margin:0;}.hero-or-divider{ display:flex; align-items:center; gap:12px; max-width:160px; margin:24px auto 20px; color:var(--color-text-secondary);}.hero-or-divider::before,.hero-or-divider::after{ content:''; flex:1; height:1px; background:var(--color-border);}.hero-or-divider span{ font-size:0.72rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--color-text-secondary);}.hero-sell-cta p{ font-size:0.9rem; color:var(--color-text-secondary); margin-bottom:12px;}.hero-sell-cta a{ display:inline-block; padding:12px 28px; font-family:var(--font-sans); font-size:0.85rem; font-weight:500; letter-spacing:0.03em; color:#fff; background:var(--color-accent); border:1.5px solid var(--color-accent); border-radius:var(--radius); text-decoration:none; transition:background 0.2s,border-color 0.2s;}.hero-sell-cta a:hover{ background:var(--color-accent-hover); border-color:var(--color-accent-hover);}.divider{ width:48px; height:1px; background:var(--color-border); margin:0 auto 28px;}.divider-text{ display:flex; align-items:center; justify-content:center; gap:16px; max-width:var(--max-width); margin:0 auto 28px; padding:0 24px;}.divider-text::before,.divider-text::after{ content:''; flex:1; max-width:48px; height:1px; background:var(--color-border);}.divider-text span{ font-family:var(--font-serif); font-size:1rem; font-weight:500; color:var(--color-text); white-space:nowrap; letter-spacing:-0.01em;}/* ── Newsletter Embed ── */.newsletter-embed{ max-width:560px; margin:32px auto; padding:0 24px; text-align:center;}.newsletter-embed .newsletter-heading{ font-family:var(--font-serif); font-size:1rem; font-weight:500; color:var(--color-text); max-width:480px; margin:0 auto 20px; line-height:1.6;}.newsletter-form{ display:flex; gap:0; max-width:480px; margin:0 auto;}.newsletter-form input[type="email"]{ flex:1; padding:12px 16px; font-family:var(--font-sans); font-size:0.95rem; border:1px solid var(--color-border); border-right:none; border-radius:var(--radius) 0 0 var(--radius); background:var(--color-surface); color:var(--color-text); outline:none; transition:border-color 200ms ease;}.newsletter-form input[type="email"]:focus{ border-color:var(--color-accent);}.newsletter-form input[type="email"]::placeholder{ color:var(--color-text-secondary);}.newsletter-form button{ padding:12px 24px; font-family:var(--font-sans); font-size:0.95rem; font-weight:500; color:#ffffff; background:var(--color-accent); border:1px solid var(--color-accent); border-radius:0 var(--radius) var(--radius) 0; cursor:pointer; white-space:nowrap; transition:background 200ms ease;}.newsletter-form button:hover{ background:var(--color-accent-hover);}.newsletter-success{ display:none; font-size:0.95rem; color:var(--color-success); margin-top:12px;}/* ── Page Intro ── */.page-intro{ max-width:560px; margin:0 auto 32px; padding:0 24px; text-align:center; font-size:0.95rem; color:var(--color-text-secondary); line-height:1.7;}/* ── Section Label ── */.section-label{ max-width:var(--max-width); margin:0 auto; padding:0 24px 24px; font-size:0.8rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--color-text-secondary); font-weight:500;}/* ── Cards Grid ── */.cards-grid{ max-width:var(--max-width); margin:0 auto; padding:0 24px 80px; display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:24px;}.card{ background:var(--color-surface); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-sm); transition:box-shadow 0.3s,transform 0.3s;}.card:hover{ box-shadow:var(--shadow-md); transform:translateY(-2px);}/* ── Image Carousel ── */.carousel{ position:relative; width:100%; aspect-ratio:4/3; overflow:hidden; background:#f0f0f0; touch-action:pan-y; cursor:pointer;}.carousel-track{ display:flex; height:100%; transition:transform 0.35s cubic-bezier(0.4,0,0.2,1); will-change:transform;}.carousel-track picture{ width:100%; height:100%; flex-shrink:0; display:block;}.carousel-track img{ width:100%; height:100%; object-fit:cover; display:block; -webkit-user-drag:none; user-select:none;}.carousel-btn{ position:absolute; top:50%; transform:translateY(-50%); width:44px; height:44px; border-radius:50%; background:rgba(255,255,255,0.85); backdrop-filter:blur(4px); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity 0.2s,background 0.2s; z-index:2; box-shadow:0 1px 4px rgba(0,0,0,0.15);}.carousel:hover .carousel-btn{opacity:1}.carousel-btn:hover{background:rgba(255,255,255,1)}/* Show carousel arrows on touch devices (no hover capability) */@media (hover:none){ .carousel .carousel-btn{opacity:0.7} .carousel .carousel-btn:active{opacity:1}}.carousel-btn.prev{left:10px}.carousel-btn.next{right:10px}.carousel-btn svg{ width:18px; height:18px; stroke:var(--color-text); stroke-width:2.5; fill:none; stroke-linecap:round; stroke-linejoin:round;}/* Dots */.carousel-dots{ position:absolute; bottom:10px; left:50%; transform:translateX(-50%); display:flex; gap:6px; z-index:2;}.carousel-dots .dot{ width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,0.5); border:none; padding:0; cursor:pointer; transition:background 0.2s,transform 0.2s; -webkit-appearance:none; appearance:none;}.carousel-dots .dot.active{ background:rgba(255,255,255,0.95); transform:scale(1.25);}/* Counter badge (e.g. "3 / 12") */.carousel-counter{ position:absolute; top:10px; left:10px; background:rgba(0,0,0,0.5); color:white; font-size:0.7rem; font-weight:500; padding:3px 8px; border-radius:100px; z-index:2; letter-spacing:0.03em;}/* Single image — no carousel controls */.carousel.single .carousel-btn,.carousel.single .carousel-dots,.carousel.single .carousel-counter{display:none}.card-image-placeholder{ width:100%; aspect-ratio:4/3; background:linear-gradient(135deg,#f5f5f4,#e7e5e4); display:flex; align-items:center; justify-content:center; color:var(--color-text-secondary); font-size:0.85rem; overflow:hidden;}.card-image-placeholder picture{ width:100%; height:100%; display:block;}.card-image-placeholder img{ width:100%; height:100%; object-fit:cover;}.card-body{padding:20px}.card-brand{ font-size:0.75rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--color-text-secondary); margin-bottom:4px; font-weight:500;}.card-title{ font-family:var(--font-serif); font-size:1.15rem; font-weight:500; margin-bottom:8px; line-height:1.3;}.card-description{ font-size:0.875rem; color:var(--color-text-secondary); margin-bottom:16px; line-height:1.5;}.card-specs{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:16px;}.spec-tag{ font-size:0.75rem; padding:4px 10px; background:var(--color-bg); border-radius:100px; color:var(--color-text-secondary);}.card-price{ font-size:1.25rem; font-weight:600; margin-bottom:12px;}.card-cta{ display:inline-block; font-size:0.8rem; text-transform:uppercase; letter-spacing:0.06em; color:var(--color-accent); font-weight:500; cursor:pointer; text-decoration:none; transition:color 0.2s;}.card-cta:hover{color:var(--color-accent-hover)}/* ── Sold Badge ── */.card-meta{ display:flex; align-items:center; gap:8px; margin-bottom:4px;}.sold-badge{ display:inline-block; background:var(--color-sold-badge); color:white; font-size:0.65rem; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; padding:2px 8px; border-radius:100px; line-height:1.6; flex-shrink:0; margin-left:auto;}/* ── Coming Soon Badge ── */.coming-soon-badge{ display:inline-block; background:var(--color-accent); color:white; font-size:0.65rem; font-weight:600; text-transform:uppercase; letter-spacing:0.1em; padding:2px 8px; border-radius:100px; line-height:1.6; flex-shrink:0;}.card-price--muted{ font-size:0.8rem; font-weight:400; color:var(--color-text-secondary); margin-bottom:0;}/* ── Sell Page ── */.sell-hero{ text-align:center; padding:64px 24px 16px; max-width:640px; margin:0 auto;}.sell-hero h1,.sell-hero h2{ font-family:var(--font-serif); font-size:2rem; font-weight:500; margin-bottom:16px;}.sell-hero p{ color:var(--color-text-secondary); font-size:1rem; line-height:1.7;}.sell-content{ max-width:580px; margin:40px auto 64px; padding:0 24px;}.sell-card{ background:var(--color-surface); border-radius:var(--radius); padding:36px; box-shadow:var(--shadow-sm);}.sell-card h2,.sell-card h3{ font-family:var(--font-serif); font-size:1.15rem; font-weight:500; margin-bottom:12px;}.sell-section-heading{ font-family:var(--font-serif); font-size:1.15rem; font-weight:500; text-align:center; margin:36px 0 12px;}.sell-content .brands-list{ font-size:0.95rem; color:var(--color-text-secondary); line-height:1.8; text-align:center; margin-bottom:0;}.sell-content .sell-list{ list-style:none; margin-bottom:0; width:fit-content; margin-left:auto; margin-right:auto;}.sell-content .sell-list li{ position:relative; padding-left:20px; font-size:0.95rem; color:var(--color-text-secondary); line-height:1.8;}.sell-content .sell-list li::before{ content:'\2022'; position:absolute; left:0; color:var(--color-text-secondary);}.sell-card ul{ list-style:none; margin-bottom:20px;}.sell-card ul li{ position:relative; padding-left:20px; font-size:0.95rem; color:var(--color-text-secondary); line-height:1.8;}.sell-card ul li::before{ content:'\2022'; position:absolute; left:0; color:var(--color-text-secondary);}.sell-card .closing{ font-size:0.95rem; color:var(--color-text-secondary); line-height:1.7; margin-bottom:24px;}.sell-contact{ display:flex; flex-direction:column; gap:8px; padding-top:20px; border-top:1px solid var(--color-border);}.sell-contact a{ font-size:0.95rem; color:var(--color-text); text-decoration:none; font-weight:500; transition:color 0.2s;}.sell-contact a:hover{color:var(--color-accent-hover)}.sell-contact .label{ font-size:0.75rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--color-text-secondary); font-weight:500;}/* ── Sell Steps ── */.sell-steps{ margin-top:8px;}.sell-step{ display:flex; gap:16px; padding:18px 0; border-bottom:1px solid var(--color-border);}.sell-step:first-child{ border-top:1px solid var(--color-border);}.sell-step-num{ font-size:0.75rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--color-text-secondary); font-weight:500; flex-shrink:0; padding-top:2px; width:16px;}.sell-step strong{ display:block; font-size:0.95rem; font-weight:600; color:var(--color-text); margin-bottom:4px;}.sell-step p{ font-size:0.95rem; color:var(--color-text-secondary); line-height:1.7; margin:0;}.sell-proof{ text-align:center; font-size:0.95rem; color:var(--color-text-secondary); line-height:1.7; margin-top:28px;}/* ── Reviews ── */.reviews-inner{ max-width:var(--max-width); margin:0 auto; padding:0 24px 72px;}.reviews-aggregate{ display:flex; align-items:center; gap:16px; margin-bottom:36px;}.reviews-aggregate-score{ font-family:var(--font-serif); font-size:3rem; font-weight:500; line-height:1; letter-spacing:-0.03em;}.reviews-aggregate-detail{ display:flex; flex-direction:column; gap:4px;}.reviews-stars{ display:flex; gap:2px;}.review-star{ font-size:1rem; color:var(--color-border);}.review-star.filled{ color:#b45309;}.reviews-aggregate-meta{ font-size:0.8rem; color:var(--color-text-secondary);}.reviews-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:20px;}.review-card{ background:var(--color-surface); border-radius:var(--radius); padding:28px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; gap:16px; transition:box-shadow 0.3s,transform 0.3s; height:290px; overflow:hidden;}.review-card:hover{ box-shadow:var(--shadow-md); transform:translateY(-2px);}.review-card-header{ display:flex; align-items:center; gap:14px;}.review-avatar{ width:42px; height:42px; border-radius:50%; background:var(--color-accent); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:600; font-size:1rem; flex-shrink:0; letter-spacing:0.02em;}.review-header-info{ display:flex; flex-direction:column; gap:2px;}.review-author{ font-size:0.9rem; font-weight:600; color:var(--color-text); letter-spacing:0.01em;}.review-card-stars{ display:flex; gap:2px;}.review-card-stars .review-star{ font-size:0.8rem;}.review-text{ font-size:0.9rem; color:var(--color-text-secondary); line-height:1.7; flex:1;}/* ── Empty State ── */.empty-state{ text-align:center; padding:80px 24px; color:var(--color-text-secondary);}.empty-state p{font-size:1rem}/* ── Footer ── */footer{ text-align:center; padding:32px 24px; font-size:0.8rem; color:var(--color-text-secondary); border-top:1px solid var(--color-border);}footer p{margin:2px 0}/* ── Lightbox ── */.lightbox{ display:none; position:fixed; inset:0; z-index:9999; background:rgba(0,0,0,0.92); align-items:center; justify-content:center; cursor:zoom-out;}.lightbox.open{display:flex}.lightbox img{ max-width:92vw; max-height:90vh; object-fit:contain; border-radius:4px;}.lightbox-close{ position:absolute; top:8px; right:12px; background:none; border:none; color:white; font-size:2rem; cursor:pointer; line-height:1; opacity:0.7; transition:opacity 0.2s; /* Minimum 44×44px touch target (iOS HIG) */ min-width:44px; min-height:44px; display:flex; align-items:center; justify-content:center;}.lightbox-close:hover{opacity:1}.lightbox-nav{ position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,0.15); border:none; color:white; width:48px; height:48px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background 0.2s;}.lightbox-nav:hover{background:rgba(255,255,255,0.3)}.lightbox-nav.prev{left:16px}.lightbox-nav.next{right:16px}.lightbox-nav svg{ width:22px; height:22px; stroke:white; stroke-width:2.5; fill:none; stroke-linecap:round; stroke-linejoin:round;}.lightbox-counter{ position:absolute; bottom:20px; left:50%; transform:translateX(-50%); color:rgba(255,255,255,0.7); font-size:0.85rem;}/* ── Responsive ── */@media (max-width:768px){ .nav-links,.nav-contact{display:none} .nav-links.open{ display:flex; flex-direction:column; position:absolute; top:var(--nav-height); left:0; right:0; background:rgba(255,255,255,0.98); backdrop-filter:blur(12px); padding:24px; gap:20px; border-bottom:1px solid var(--color-border); animation:fadeIn 0.2s ease;} .nav-toggle{display:block} /* Show phone number at bottom of mobile drawer */ .nav-phone-mobile{ display:list-item; border-top:1px solid var(--color-border); padding-top:16px; margin-top:4px;} .nav-phone-mobile a{ font-size:0.95rem; font-weight:600; letter-spacing:0; text-transform:none; color:var(--color-text);} .hero h1{font-size:1.8rem} .hero .tagline{font-size:0.95rem} .cards-grid{ grid-template-columns:1fr; padding:0 16px 60px;} .section-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0} .sell-hero h1, .sell-hero h2{font-size:1.6rem} .sell-card{padding:24px} .reviews-inner{padding:0 0 60px;position:relative} .reviews-inner .reviews-aggregate{padding:0 16px} .reviews-grid{ display:flex; overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; gap:16px; padding:0 16px; scrollbar-width:none; -webkit-mask-image:linear-gradient(to right,transparent,black 16px,black calc(100% - 16px),transparent); mask-image:linear-gradient(to right,transparent,black 16px,black calc(100% - 16px),transparent);} .reviews-grid::-webkit-scrollbar{display:none} .reviews-grid .review-card{ min-width:280px; max-width:280px; flex-shrink:0; scroll-snap-align:center; height:340px;} /* On mobile,always show carousel arrows */ .carousel .carousel-btn{opacity:1} /* Credibility strip — allow wrap,keep readable */ .credibility-strip{ font-size:0.75rem; padding:8px 16px; gap:10px; flex-wrap:wrap;} .credibility-strip .credibility-sep{font-size:0.55rem} /* Divider text — tighter on mobile */ .divider-text span{font-size:0.9rem} /* Newsletter — stack on narrow screens */ .newsletter-embed{margin:24px auto;padding:0 16px} .newsletter-embed .newsletter-heading{font-size:0.9rem;margin-bottom:16px} .newsletter-form{max-width:100%} .newsletter-form input[type="email"]{font-size:0.85rem;padding:10px 12px} .newsletter-form button{font-size:0.85rem;padding:10px 18px} /* Retail compare on mobile */ .listing-retail-compare{font-size:0.9rem} /* Value pill:prevent horizontal overflow;allow wrap and soften radius */ .listing-value-pill{ display:flex; flex-wrap:wrap; max-width:100%; border-radius:var(--radius); font-size:0.75rem;}}@media (max-width:400px){ .hero h1{font-size:1.5rem} .hero{padding:48px 16px 32px} /* Extra-small:condense credibility strip but keep readable */ .credibility-strip{ font-size:0.72rem; gap:8px; padding:8px 12px;} /* Extra-small:shrink pill text further so it fits on 320px screens */ .listing-value-pill{font-size:0.68rem}}/* ── Breadcrumb ── */.breadcrumb{ max-width:var(--max-width); margin:0 auto; padding:20px 24px 0; font-size:0.8rem; color:var(--color-text-secondary); display:flex; align-items:center; flex-wrap:wrap; gap:0;}.breadcrumb a{ color:var(--color-text-secondary); text-decoration:none; transition:color 0.2s;}.breadcrumb a:hover{color:var(--color-text)}.breadcrumb-sep{margin:0 8px;opacity:0.5}.breadcrumb-current{color:var(--color-text)}/* ── Individual Listing Page ── */.listing-hero{ max-width:var(--max-width); margin:0 auto; padding:32px 24px 24px;}.listing-layout{ display:block;}.listing-carousel{ margin-bottom:32px;}.listing-carousel .carousel{ border-radius:var(--radius); overflow:hidden; aspect-ratio:16/9;}/* Always show arrows on listing page carousels */.listing-carousel .carousel .carousel-btn{ opacity:0.7; width:42px; height:42px; background:rgba(0,0,0,0.3);}.listing-carousel .carousel .carousel-btn:hover{ opacity:1; background:rgba(0,0,0,0.5);}.listing-carousel .carousel .carousel-btn svg{ stroke:white;}/* Hide dots on listing carousel (thumbnails replace them) */.listing-carousel .carousel-dots{display:none}/* Anchor images to bottom so furniture is always fully visible in the crop */.listing-carousel .carousel-track img{object-position:center bottom}/* ── Thumbnail Strip ── */.listing-thumbnails{ display:flex; gap:8px; margin-top:12px; overflow-x:auto; scrollbar-width:none; -ms-overflow-style:none; max-width:100%;}.listing-thumbnails::-webkit-scrollbar{display:none}.listing-thumb{ flex:0 0 72px; width:72px; height:54px; border-radius:4px; overflow:hidden; cursor:pointer; border:2px solid transparent; opacity:0.55; transition:opacity 0.2s,border-color 0.2s;}.listing-thumb.active{ border-color:var(--color-accent); opacity:1;}.listing-thumb:hover{opacity:1}.listing-thumb img{ width:100%; height:100%; object-fit:cover; display:block;}.listing-thumb-more{ display:flex; align-items:center; justify-content:center; font-size:0.8rem; font-weight:600; color:var(--color-text-secondary); background:#f0f0f0; opacity:0.85;}.listing-thumb-more:hover{opacity:1;background:#e5e5e5}.listing-brand{ font-size:0.75rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--color-text-secondary); margin-bottom:8px; font-weight:500;}.listing-heading-row{ display:flex; justify-content:space-between; align-items:flex-start; gap:20px; margin-bottom:24px;}.listing-title{ font-family:var(--font-serif); font-size:1.8rem; font-weight:500; line-height:1.2; margin-bottom:0; letter-spacing:-0.02em; flex:1;}.listing-heading-row .listing-value-pill{ margin:0; flex-shrink:0; align-self:center;}.listing-description{ font-size:0.95rem; color:var(--color-text-secondary); line-height:1.8; margin-bottom:12px; white-space:pre-line;}.listing-ctas{ margin-bottom:28px;}.listing-retail-compare{ font-family:var(--font-serif); font-size:1rem; font-weight:500; color:var(--color-text); margin:28px 0;}/* Two-part retail value pill — "Est. Retail:$X" | "Buy it Today:$Y" */.listing-value-pill{ display:inline-flex; align-items:stretch; border:1px solid var(--color-border); border-radius:100px; overflow:hidden; margin:28px 0; font-size:0.8rem; font-weight:500; letter-spacing:0.01em;}.listing-value-pill .pill-retail{ padding:7px 14px 7px 16px; background:var(--color-bg); color:var(--color-text-secondary);}.listing-value-pill .pill-now{ padding:7px 16px 7px 14px; background:var(--color-accent); color:#ffffff; font-weight:600;}/* Construction features list */.listing-features{ list-style:none; margin-bottom:24px;}.listing-features li{ font-size:0.9rem; color:var(--color-text-secondary); line-height:1.6; padding:3px 0 3px 16px; position:relative;}.listing-features li::before{ content:'•'; position:absolute; left:0; top:2px; font-size:0.75rem; color:var(--color-text-secondary); opacity:0.6;}/* Collapsible meta sections (Description,Features,Condition,Includes) */.listing-collapsible{ margin-top:20px; margin-bottom:20px; border-bottom:1px solid var(--color-border); padding-bottom:4px;}.listing-collapsible summary.listing-meta-label{ display:flex; align-items:center; gap:6px; font-size:0.7rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--color-text-secondary); font-weight:600; margin-bottom:0; cursor:pointer; list-style:none; padding:8px 0; user-select:none;}.listing-collapsible summary.listing-meta-label::-webkit-details-marker{display:none}.listing-collapsible summary.listing-meta-label::before{ content:'▶'; font-size:0.5rem; transition:transform 0.2s ease; display:inline-block;}.listing-collapsible[open] > summary.listing-meta-label::before{ transform:rotate(90deg);}.listing-collapsible[open] > summary.listing-meta-label{ margin-bottom:5px;}.listing-collapsible .listing-description,.listing-collapsible .listing-features,.listing-collapsible .listing-meta-text{ margin-bottom:12px;}/* Legacy non-collapsible meta sections (guides etc.) */.listing-meta-item{ margin-top:20px; margin-bottom:20px;}.listing-meta-label{ display:block; font-size:0.7rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--color-text-secondary); font-weight:600; margin-bottom:5px;}.listing-meta-text{ font-size:0.9rem; color:var(--color-text-secondary); line-height:1.7; white-space:pre-line; margin:0;}.listing-specs{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:32px;}.listing-price{ font-size:1.6rem; font-weight:600; margin-bottom:20px;}.listing-cta{ display:inline-block; padding:14px 32px; background:var(--color-accent); color:white; text-decoration:none; border-radius:var(--radius); font-size:0.875rem; font-weight:500; letter-spacing:0.04em; transition:background 0.2s; margin-right:16px;}.listing-cta:hover{background:var(--color-accent-hover)}.listing-cta--secondary{ background:transparent; color:var(--color-accent); border:1px solid var(--color-border); padding:13px 32px;}.listing-cta--secondary:hover{ background:var(--color-bg); color:var(--color-accent-hover);}.listing-back{ display:inline-block; font-size:0.8rem; text-transform:uppercase; letter-spacing:0.06em; color:var(--color-text-secondary); text-decoration:none; transition:color 0.2s;}.listing-back:hover{color:var(--color-text)}/* ── Sticky CTA bar — listing pages,mobile only ── */.listing-sticky-cta{ display:none;}@media (max-width:768px){ .listing-sticky-cta{ display:flex; position:fixed; bottom:0; left:0; right:0; z-index:500; gap:0; border-top:1px solid rgba(0,0,0,0.12); box-shadow:0 -4px 20px rgba(0,0,0,0.1);} .listing-sticky-cta a{ flex:1; padding:16px 12px; text-align:center; font-size:0.875rem; font-weight:600; text-decoration:none; letter-spacing:0.01em;} .listing-sticky-cta .sticky-cta-primary{ background:var(--color-accent); color:#fff;} .listing-sticky-cta .sticky-cta-secondary{ background:#fff; color:var(--color-text); border-left:1px solid var(--color-border);} /* Add bottom padding to page content so sticky bar doesn't obscure it */ .listing-sticky-cta ~ footer, body:has(.listing-sticky-cta) .newsletter-embed{ padding-bottom:env(safe-area-inset-bottom,0px);} body:has(.listing-sticky-cta) footer{ padding-bottom:calc(56px + env(safe-area-inset-bottom,0px));}}@media (max-width:768px){ .listing-heading-row{flex-direction:column;gap:12px} .listing-title{font-size:1.4rem} .listing-hero{padding:20px 16px 16px} .listing-carousel{margin-bottom:20px} /* Taller crop on mobile — 4/3 gives more vertical room */ .listing-carousel .carousel{aspect-ratio:4/3} /* Larger thumbnail tap targets on mobile */ .listing-thumb{ flex:0 0 80px; width:80px; height:60px;} /* Prevent long words in description and meta sections from causing horizontal overflow */ .listing-description, .listing-meta-text{ overflow-wrap:break-word; word-break:break-word;} /* Tighten spacing on the new Features / Condition / Includes sections */ .listing-meta-item{margin-top:16px;margin-bottom:16px} .listing-meta-label{margin-bottom:6px} .listing-features li{font-size:0.875rem} /* Stack CTA buttons vertically,full width */ .listing-cta{ display:block; width:100%; text-align:center; margin-right:0; margin-bottom:12px; box-sizing:border-box;} /* Smaller price on mobile */ .listing-price{font-size:1.35rem} /* Tighter specs on mobile */ .listing-specs{margin-bottom:24px} /* Back link — block and centred,with clear breathing room after CTAs */ .listing-back{ display:block; text-align:center; margin-top:20px;} /* Breadcrumb — prevent long titles from overflowing the flex row */ .breadcrumb{flex-wrap:wrap} .breadcrumb-current{ overflow-wrap:break-word; word-break:break-word; max-width:100%;}}/* ── Service Area Note ── */.service-area-note{ max-width:var(--max-width); margin:0 auto; padding:0 24px 56px; text-align:center; font-size:0.85rem; color:var(--color-text-secondary); line-height:1.7;}/* ── FAQ Section (homepage + listing) ── */.faq-section{ max-width:var(--max-width); margin:0 auto; padding:0 24px 72px;}.faq-list{ display:flex; flex-direction:column;}.faq-item{ padding:20px 0; border-bottom:1px solid var(--color-border);}.faq-item:first-child{border-top:1px solid var(--color-border)}h3.faq-question,.faq-question{ font-family:var(--font-sans); font-size:0.95rem; font-weight:600; color:var(--color-text); margin-bottom:8px; line-height:1.4;}.faq-answer{ font-size:0.9rem; color:var(--color-text-secondary); line-height:1.7;}.faq-answer a{ color:var(--color-accent); text-decoration:underline; text-underline-offset:2px; transition:color 0.2s;}.faq-answer a:hover{ color:var(--color-accent-hover);}/* ── About Page ── */.about-hero{ text-align:center; padding:64px 24px 48px; max-width:var(--max-width); margin:0 auto;}.about-hero h1{ font-family:var(--font-serif); font-size:2.2rem; font-weight:500; letter-spacing:-0.03em; margin-bottom:12px; line-height:1.2;}.about-hero p{ font-size:1rem; color:var(--color-text-secondary); font-weight:300; max-width:560px; margin:0 auto; line-height:1.7;}.about-content{ max-width:var(--max-width); margin:0 auto; padding:0 24px 24px;}.about-section{ margin-bottom:56px;}.about-section h2{ font-family:var(--font-serif); font-size:1.4rem; font-weight:500; margin-bottom:16px; letter-spacing:-0.02em;}.about-section p{ font-size:0.95rem; color:var(--color-text-secondary); line-height:1.8; margin-bottom:12px;}.about-brands{ display:flex; flex-wrap:wrap; gap:8px; margin-top:16px;}.about-brand-tag{ font-size:0.8rem; padding:5px 12px; background:var(--color-surface); border:1px solid var(--color-border); border-radius:100px; color:var(--color-text-secondary);}/* ── Guide / Article Pages ── */.guide-article{ max-width:var(--max-width); margin:0 auto; padding:48px 24px 48px;}.guide-header{ margin-bottom:40px; border-bottom:1px solid var(--color-border); padding-bottom:32px;}.guide-category{ font-size:0.75rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--color-text-secondary); margin-bottom:12px;}.guide-header h1{ font-family:var(--font-serif); font-size:clamp(1.75rem,4vw,2.4rem); font-weight:500; line-height:1.25; margin-bottom:12px; letter-spacing:-0.02em;}.guide-meta{ font-size:0.85rem; color:var(--color-text-secondary);}.guide-body p{ font-size:1.0625rem; line-height:1.75; margin-bottom:1.4rem;}.guide-body h2{ font-family:var(--font-serif); font-size:1.45rem; font-weight:500; margin:2.5rem 0 1rem; letter-spacing:-0.01em;}.guide-body h3{ font-size:1.05rem; font-weight:600; margin:1.75rem 0 0.6rem;}.guide-body ul,.guide-body ol{ padding-left:1.5rem; margin-bottom:1.4rem;}.guide-body li{ margin-bottom:0.5rem; font-size:1.0625rem; line-height:1.75;}.guide-body a{ color:var(--color-text); text-decoration:underline; text-underline-offset:3px; transition:color 0.2s;}.guide-body a:hover{color:var(--color-text-secondary)}.guide-body .listing-cta,.guide-body .listing-cta:hover{color:white}.guide-callout{ background:var(--color-surface); border:1px solid var(--color-border); border-left:3px solid var(--color-accent); padding:1.25rem 1.5rem; margin:2rem auto; max-width:850px; border-radius:2px;}.guide-callout p{ margin-bottom:0; font-size:0.975rem; color:var(--color-text-secondary);}.guide-callout strong{color:var(--color-text)}.guide-cta{ background:var(--color-surface); border:1px solid var(--color-border); padding:2rem; margin:3rem auto 0; max-width:850px; text-align:center; border-radius:var(--radius);}.guide-cta p{ font-size:0.975rem; color:var(--color-text-secondary); margin-bottom:1rem;}/* Guides index page */.guides-list{ max-width:var(--max-width); margin:0 auto; padding:0 24px 72px;}.guide-card{ display:block; text-decoration:none; color:inherit; padding:28px 0; border-bottom:1px solid var(--color-border); transition:opacity 0.2s;}.guide-card:first-child{border-top:1px solid var(--color-border)}.guide-card:hover{opacity:0.7}.guide-card-category{ font-size:0.7rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:var(--color-text-secondary); margin-bottom:6px;}.guide-card-title{ font-family:var(--font-serif); font-size:1.25rem; font-weight:500; margin-bottom:8px; letter-spacing:-0.01em;}.guide-card-excerpt{ font-size:0.9rem; color:var(--color-text-secondary); line-height:1.6;}/* Scoped overrides:faq-section and section-label inside guide articles */.guide-table-wrap{ overflow-x:auto; margin:1.75rem auto 2rem; max-width:850px; -webkit-overflow-scrolling:touch;}.guide-table{ width:100%; border-collapse:collapse; font-size:0.95rem; line-height:1.5;}.guide-table th,.guide-table td{ text-align:left; padding:0.65rem 1rem; border:1px solid var(--color-border); vertical-align:top;}.guide-table thead th{ background:var(--color-surface); font-weight:600; color:var(--color-text); font-size:0.875rem; letter-spacing:0.01em;}.guide-table tbody tr:nth-child(even){ background:var(--color-surface);}.guide-table tbody td:first-child{ white-space:nowrap; color:var(--color-text-secondary);}.guide-article .faq-section{ max-width:none; padding:0; margin-top:2.5rem;}.guide-article .section-label{ padding:0 0 20px;}@media (max-width:768px){ .guide-article{padding:32px 16px 32px} .guide-header h1{font-size:1.5rem} .guide-body p,.guide-body li{font-size:1rem} .guide-body h2{font-size:1.25rem} .guide-body h3{font-size:1rem} .guide-callout{padding:1rem 1.25rem} .guide-cta{padding:1.5rem} .guides-list{padding:0 16px 60px} .guide-table tbody td:first-child{white-space:normal} .breadcrumb{padding:16px 16px 0} .about-hero{padding:40px 16px 32px}}/* Card title link — stretched to make entire card clickable */.card-title-link{ text-decoration:none; color:inherit;}.card-title-link::after{ content:''; position:absolute; inset:0; z-index:1;}.card-title-link:hover{text-decoration:underline}/* Card needs relative positioning for the stretched link */.card{position:relative}/* Lift entire carousel stacking context above the stretched card link */.card .carousel{z-index:2}@media (max-width:768px){ .about-hero h1{font-size:1.7rem}}/* ── Reduced Motion ── */@media (prefers-reduced-motion:reduce){ html{scroll-behavior:auto} *,*::before,*::after{ animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important;}}/* ── Focus-Visible ── */:focus-visible{ outline:2px solid var(--color-accent); outline-offset:2px;}.nav-links a:focus-visible,.breadcrumb a:focus-visible,.guide-body a:focus-visible,.faq-answer a:focus-visible,footer a:focus-visible{ outline:2px solid var(--color-accent); outline-offset:2px; border-radius:2px;}.carousel-btn:focus-visible,.carousel-dots .dot:focus-visible,.lightbox-close:focus-visible,.lightbox-nav:focus-visible{ outline:2px solid #fff; outline-offset:2px;}.newsletter-form button:focus-visible,.listing-cta:focus-visible,.hero-sell-cta a:focus-visible{ outline:2px solid var(--color-accent); outline-offset:2px;}.card-title-link:focus-visible{ outline:2px solid var(--color-accent); outline-offset:4px; border-radius:var(--radius);}/* ═══════════════════════════════════════════════════════════ Sell page v2 — hero weight,fit grid,method,CTA buttons ═══════════════════════════════════════════════════════════ *//* Hero — elevate main promise,soften negation line */.sell-hero .sell-hero-promise{ color:var(--color-text); font-size:1.1rem; font-weight:500; line-height:1.55; margin-bottom:10px;}.sell-hero .sell-hero-sub{ color:var(--color-text-secondary); font-size:0.95rem; font-weight:400; line-height:1.6; letter-spacing:0.01em;}/* Fit Grid — What we buy / Not a fit */.sell-fit-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px; max-width:860px; margin:40px auto 8px; padding:0 24px;}.sell-fit-col{ background:var(--color-surface); border-radius:var(--radius); padding:28px; box-shadow:var(--shadow-sm);}.sell-fit-col h2{ font-family:var(--font-serif); font-size:1.15rem; font-weight:500; margin-bottom:6px; color:var(--color-text);}.sell-fit-col .sell-fit-subhead{ font-size:0.85rem; color:var(--color-text-secondary); line-height:1.6; margin-bottom:18px;}.sell-fit-col ul{ list-style:none; padding:0; margin:0;}.sell-fit-col ul li{ position:relative; padding-left:22px; font-size:0.92rem; color:var(--color-text); line-height:1.9;}.sell-fit-buy ul li::before{ content:'\2713'; position:absolute; left:0; top:0; color:var(--color-success); font-weight:600; font-size:0.95rem;}.sell-fit-skip ul li::before{ content:'\00D7'; position:absolute; left:0; top:-1px; color:var(--color-sold-badge); font-weight:600; font-size:1.15rem; line-height:1.5;}@media (max-width:640px){ .sell-fit-grid{ grid-template-columns:1fr; gap:14px; margin-top:24px; padding:0 16px;} .sell-fit-col{padding:22px}}/* Method + comparison callout */.sell-method{ max-width:580px; margin:0 auto 16px;}.sell-method > p{ font-size:0.95rem; color:var(--color-text-secondary); line-height:1.75; margin-bottom:4px;}.sell-method strong{ color:var(--color-text); font-weight:600;}.sell-comparison{ margin-top:24px; padding:20px 24px; border-left:3px solid var(--color-accent); background:var(--color-surface); border-radius:0 var(--radius) var(--radius) 0; box-shadow:var(--shadow-sm);}.sell-comparison p{ font-size:0.92rem; color:var(--color-text-secondary); line-height:1.7; margin:0 0 10px;}.sell-comparison p:last-child{margin-bottom:0}.sell-comparison p strong{ color:var(--color-text); font-weight:600; font-size:0.95rem;}/* Send details — lead paragraph + checklist + CTA buttons */.sell-send-lead{ max-width:580px; margin:-4px auto 20px; text-align:center; font-size:0.95rem; color:var(--color-text-secondary); line-height:1.7;}.sell-checklist{ max-width:580px; margin:0 auto 28px; padding:20px 24px; background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius); box-shadow:var(--shadow-sm);}.sell-checklist-label{ font-size:0.75rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--color-text-secondary); font-weight:500; margin-bottom:12px;}.sell-checklist ul{ list-style:none; padding:0; margin:0;}.sell-checklist ul li{ position:relative; padding-left:22px; font-size:0.93rem; color:var(--color-text); line-height:1.85;}.sell-checklist ul li::before{ content:'\2713'; position:absolute; left:0; top:0; color:var(--color-success); font-weight:600; font-size:0.9rem;}.sell-cta-buttons{ max-width:580px; margin:0 auto 40px; display:grid; grid-template-columns:1fr 1fr; gap:12px;}.sell-cta-button{ display:flex; flex-direction:column; align-items:center; gap:4px; padding:18px 20px; background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius); text-decoration:none; transition:border-color 200ms ease,box-shadow 200ms ease,transform 200ms ease; box-shadow:var(--shadow-sm);}.sell-cta-button:hover{ border-color:var(--color-accent); box-shadow:var(--shadow-md); transform:translateY(-1px);}.sell-cta-primary{ background:var(--color-accent); border-color:var(--color-accent);}.sell-cta-primary:hover{ background:var(--color-accent-hover); border-color:var(--color-accent-hover);}.sell-cta-label{ font-size:0.72rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--color-text-secondary); font-weight:500;}.sell-cta-value{ font-size:1rem; color:var(--color-text); font-weight:500; word-break:break-word; text-align:center;}.sell-cta-primary .sell-cta-label{color:rgba(255,255,255,0.7)}.sell-cta-primary .sell-cta-value{color:#ffffff}@media (max-width:640px){ .sell-cta-buttons{grid-template-columns:1fr;padding:0 16px} .sell-send-lead{padding:0 16px} .sell-checklist{margin-left:16px;margin-right:16px} .sell-comparison{padding:18px 20px} .sell-hero .sell-hero-promise{font-size:1.02rem} .sell-hero .sell-hero-sub{font-size:0.9rem}}/* Sell-page FAQ scoping — pulls in tighter than the homepage FAQ */.sell-faq{ padding-bottom:32px; max-width:580px;}