/* ============================================================================
   MR. LAUNDRY — HOME PAGE
   Depends on design-system.css + layout.css.
   ============================================================================ */

/* ---------------------------------------------------------------------------
   HERO (split: copy + media)
--------------------------------------------------------------------------- */
.home-hero { position: relative; overflow: hidden; padding-block: clamp(2.5rem, 7vw, 5.5rem) clamp(2.5rem, 6vw, 4.5rem); }
.home-hero::before {
    content: ""; position: absolute; inset: 0; z-index: -2;
    background:
        radial-gradient(900px 480px at 78% -6%, var(--glow), transparent 60%),
        radial-gradient(640px 380px at 6% 12%, var(--neon-soft), transparent 70%);
}
.home-hero::after {
    content: ""; position: absolute; inset: 0; z-index: -1; opacity: .55;
    background-image: linear-gradient(var(--grid-line) 1px, transparent 1px),
                      linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
    background-size: 46px 46px;
    -webkit-mask: radial-gradient(circle at 70% 0, #000, transparent 72%);
            mask: radial-gradient(circle at 70% 0, #000, transparent 72%);
}
.home-hero .container { display: grid; gap: clamp(2rem, 5vw, 3.5rem); align-items: center; }
.home-hero h1 { font-size: var(--fs-3xl); margin-top: var(--sp-4); }
.home-hero .hero-lead { font-size: var(--fs-md); color: var(--ink-muted); max-width: 52ch; margin-top: var(--sp-4); }
.home-hero .cta-row { display: flex; gap: var(--sp-3); flex-wrap: wrap; margin-top: var(--sp-6); }
.home-hero .trust-inline { display: flex; gap: var(--sp-5); flex-wrap: wrap; margin-top: var(--sp-6); color: var(--ink-muted); font-size: var(--fs-sm); }
.home-hero .trust-inline b { color: var(--ink); font-family: var(--font-display); }

.hero-media { position: relative; }
.hero-media .frame {
    border-radius: var(--r-xl); overflow: hidden; border: 1px solid var(--glass-border);
    box-shadow: var(--shadow-lg); aspect-ratio: 4 / 5;
}
.hero-media .frame img { width: 100%; height: 100%; object-fit: cover; }
.hero-chip {
    position: absolute; display: flex; align-items: center; gap: 10px;
    padding: .7rem 1rem; border-radius: var(--r-md);
    background: var(--glass-bg); -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
    border: 1px solid var(--glass-border); box-shadow: var(--shadow-md);
    font-weight: 700; font-size: var(--fs-sm); color: var(--ink);
}
.hero-chip .big { font-family: var(--font-display); color: var(--accent); font-size: var(--fs-lg); line-height: 1; }
.hero-chip--tl { top: 8%; left: -6%; }
.hero-chip--br { bottom: 8%; right: -6%; animation: float 5s var(--ease) infinite; }

@media (min-width: 920px) {
    .home-hero .container { grid-template-columns: 1.05fr .95fr; }
}

/* ---------------------------------------------------------------------------
   TRUST STATS
--------------------------------------------------------------------------- */
.stats-band { background: var(--bg-alt); }
.stats-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-5); text-align: center; }
.stat .n { font-family: var(--font-display); font-size: var(--fs-2xl); font-weight: 800; line-height: 1; }
.stat .l { color: var(--ink-muted); font-weight: 600; font-size: var(--fs-sm); margin-top: var(--sp-2); }
@media (min-width: 760px) { .stats-grid { grid-template-columns: repeat(4, 1fr); } }

/* ---------------------------------------------------------------------------
   WHY US
--------------------------------------------------------------------------- */
.why-grid { display: grid; gap: var(--sp-5); margin-top: var(--sp-7); grid-template-columns: 1fr; }
.why-item { display: flex; gap: var(--sp-4); align-items: flex-start; }
.why-item .ico {
    flex: 0 0 auto; width: 52px; height: 52px; border-radius: var(--r-md);
    background: var(--neon-soft); border: 1px solid var(--border-strong); color: var(--accent);
    display: flex; align-items: center; justify-content: center; font-size: 1.5rem;
}
.why-item h3 { font-size: var(--fs-md); margin-bottom: 4px; }
.why-item p { font-size: var(--fs-sm); }
@media (min-width: 760px) { .why-grid { grid-template-columns: repeat(3, 1fr); } }

/* ---------------------------------------------------------------------------
   SERVICES
--------------------------------------------------------------------------- */
.svc-card { display: flex; flex-direction: column; overflow: hidden; padding: 0; }
.svc-card .media { aspect-ratio: 16 / 10; overflow: hidden; }
.svc-card .media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--t-slow) var(--ease); }
.svc-card.card--hover:hover .media img { transform: scale(1.06); }
.svc-card .body { padding: clamp(1.2rem, 2.5vw, 1.6rem); }
.svc-card h3 { font-size: var(--fs-md); margin-bottom: var(--sp-2); }
.svc-card p { font-size: var(--fs-sm); }
.svc-card .more { display: inline-block; margin-top: var(--sp-3); font-weight: 700; font-size: var(--fs-sm); color: var(--accent); }

/* ---------------------------------------------------------------------------
   HOW IT WORKS
--------------------------------------------------------------------------- */
.steps { display: grid; gap: var(--sp-5); margin-top: var(--sp-7); grid-template-columns: 1fr; counter-reset: step; }
.step { position: relative; }
.step .num {
    width: 48px; height: 48px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
    font-family: var(--font-display); font-weight: 800; font-size: var(--fs-md);
    background: var(--accent-grad); color: var(--on-accent); margin-bottom: var(--sp-3);
    box-shadow: 0 8px 22px var(--glow);
}
.step h3 { font-size: var(--fs-md); margin-bottom: var(--sp-2); }
.step p { font-size: var(--fs-sm); }
@media (min-width: 760px) { .steps { grid-template-columns: repeat(3, 1fr); } }

/* ---------------------------------------------------------------------------
   TESTIMONIALS
--------------------------------------------------------------------------- */
.reviews { display: grid; gap: var(--sp-5); margin-top: var(--sp-7); grid-template-columns: 1fr; }
.review { }
.review .stars { color: var(--c-star); letter-spacing: 3px; font-size: 1.1rem; margin-bottom: var(--sp-3); }
.review blockquote { margin: 0; font-size: var(--fs-md); color: var(--ink); font-style: italic; }
.review cite { display: block; margin-top: var(--sp-3); font-style: normal; font-weight: 700; color: var(--ink-muted); font-size: var(--fs-sm); }
@media (min-width: 760px) { .reviews { grid-template-columns: repeat(2, 1fr); } }

/* ---------------------------------------------------------------------------
   FAQ (native accordion)
--------------------------------------------------------------------------- */
.faq-list { max-width: 820px; margin: var(--sp-7) auto 0; display: flex; flex-direction: column; gap: var(--sp-3); }
.faq-item { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; }
.faq-item > summary {
    list-style: none; cursor: pointer; padding: 1.1rem 1.3rem;
    font-family: var(--font-display); font-weight: 700; font-size: var(--fs-base); color: var(--ink);
    display: flex; justify-content: space-between; align-items: center; gap: 1rem;
}
.faq-item > summary::-webkit-details-marker { display: none; }
.faq-item > summary::after { content: "+"; color: var(--accent); font-size: 1.4rem; line-height: 1; transition: transform var(--t) var(--ease); }
.faq-item[open] > summary::after { transform: rotate(45deg); }
.faq-item .a { padding: 0 1.3rem 1.2rem; color: var(--ink-muted); font-size: var(--fs-sm); }

/* ---------------------------------------------------------------------------
   CTA BAND
--------------------------------------------------------------------------- */
.cta-band { position: relative; overflow: hidden; text-align: center; border-radius: var(--r-xl); padding: clamp(2.5rem, 6vw, 4rem) var(--gutter); margin-block: var(--sp-9); background: var(--surface); border: 1px solid var(--border-strong); box-shadow: var(--shadow-lg); }
.cta-band::before { content: ""; position: absolute; inset: 0; z-index: -1; background: radial-gradient(700px 300px at 50% 0, var(--glow), transparent 65%); }
.cta-band h2 { font-size: var(--fs-2xl); }
.cta-band p { max-width: 52ch; margin: var(--sp-3) auto var(--sp-6); color: var(--ink-muted); }
.cta-band .cta-row { display: flex; gap: var(--sp-3); justify-content: center; flex-wrap: wrap; }
