/* ==========================================================================
   RINGO商談代行 LP — styles
   林檎営業（Apple Corporation Ad）ブランドに準拠
   ========================================================================== */

* { margin: 0; padding: 0; box-sizing: border-box; }

:root {
    --primary-red: #FF3B3B;
    --dark-red: #E60000;
    --light-red: #FF6666;
    --black: #1a1a1a;
    --dark-gray: #333333;
    --gray: #666666;
    --light-gray: #f8f9fa;
    --white: #ffffff;

    --lh-display: 1.15;
    --lh-tight: 1.3;
    --lh-heading: 1.5;
    --lh-snug: 1.7;
    --lh-body: 1.85;

    --fs-display: clamp(2.6rem, 7vw, 4.6rem);
    --fs-hero-line: clamp(1.3rem, 3vw, 2rem);
    --fs-h2: clamp(1.7rem, 3.6vw, 2.4rem);
    --fs-h3: clamp(1.25rem, 2.2vw, 1.55rem);
    --fs-h4: clamp(1.1rem, 1.8vw, 1.25rem);
    --fs-lead: clamp(1rem, 1.6vw, 1.15rem);
    --fs-body: clamp(0.95rem, 1.4vw, 1.02rem);
    --fs-sm: clamp(0.86rem, 1.2vw, 0.94rem);
    --fs-xs: 0.78rem;
}

html { scroll-behavior: smooth; }

body {
    font-family: 'Shippori Mincho', serif;
    color: var(--black);
    font-size: var(--fs-body);
    line-height: var(--lh-body);
    letter-spacing: 0.01em;
    overflow-x: hidden;
    background: var(--white);
    font-feature-settings: "palt" 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6,
.hero-title, .hero-subtitle,
.section-title, .section-description {
    word-break: keep-all;
    overflow-wrap: anywhere;
    line-break: strict;
    text-wrap: balance;
}
p, li { text-wrap: pretty; }

a { color: inherit; text-decoration: none; }
strong { font-weight: 800; }
.highlight-red { color: var(--primary-red); font-weight: 800; }

.container {
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 clamp(16px, 4vw, 24px);
    width: 100%;
}

/* ---------- Buttons ---------- */
.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 16px 36px;
    border-radius: 999px;
    font-weight: 800;
    font-size: var(--fs-lead);
    letter-spacing: 0.03em;
    transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
    cursor: pointer;
    line-height: 1.2;
    text-align: center;
}
.button-primary {
    background: var(--primary-red);
    color: var(--white);
    box-shadow: 0 8px 24px rgba(255, 59, 59, 0.32);
}
.button-primary:hover { background: var(--dark-red); transform: translateY(-3px); box-shadow: 0 12px 30px rgba(255, 59, 59, 0.42); }
.button-secondary {
    background: var(--white);
    color: var(--black);
    border: 2px solid var(--black);
}
.button-secondary:hover { background: var(--black); color: var(--white); transform: translateY(-3px); }
.button-large { padding: 20px 56px; font-size: clamp(1.05rem, 1.8vw, 1.3rem); background: var(--white); color: var(--primary-red); box-shadow: 0 10px 30px rgba(0,0,0,0.18); }
.button-large:hover { transform: translateY(-3px); box-shadow: 0 14px 36px rgba(0,0,0,0.26); }

/* ---------- Header ---------- */
.header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 1000;
    padding: 14px 0;
    background: rgba(255, 255, 255, 0.92);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    transition: all 0.3s ease;
}
.header.scrolled { padding: 9px 0; box-shadow: 0 4px 20px rgba(0,0,0,0.06); }
.header-content { display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.logo { display: flex; align-items: center; gap: 12px; }
.logo-icon { font-size: 1.9rem; line-height: 1; }
.logo-text-wrapper { display: flex; flex-direction: column; line-height: 1.2; }
.logo-brand { font-weight: 800; font-size: 1.15rem; color: var(--black); }
.logo-sub { font-family: 'Montserrat', sans-serif; font-size: 0.62rem; letter-spacing: 0.08em; color: var(--gray); }
.nav { display: flex; align-items: center; gap: clamp(14px, 1.8vw, 26px); }
.nav-link { font-size: var(--fs-sm); font-weight: 700; color: var(--dark-gray); transition: color 0.2s ease; }
.nav-link:hover { color: var(--primary-red); }
.nav-link.cta-button {
    background: var(--primary-red);
    color: var(--white);
    padding: 10px 22px;
    border-radius: 999px;
    box-shadow: 0 6px 16px rgba(255, 59, 59, 0.28);
}
.nav-link.cta-button:hover { background: var(--dark-red); color: var(--white); }

/* ---------- Section common ---------- */
section { padding: clamp(60px, 9vw, 110px) 0; }
.section-header { text-align: center; max-width: 760px; margin: 0 auto clamp(40px, 6vw, 64px); }
.section-label {
    display: inline-block;
    font-family: 'Montserrat', sans-serif;
    font-size: var(--fs-xs);
    letter-spacing: 0.22em;
    font-weight: 900;
    color: var(--primary-red);
    margin-bottom: 14px;
}
.section-title { font-size: var(--fs-h2); font-weight: 800; line-height: var(--lh-heading); color: var(--black); }
.section-description { margin-top: 16px; font-size: var(--fs-lead); color: var(--gray); line-height: var(--lh-snug); }

/* ---------- Hero ---------- */
.hero {
    position: relative;
    padding-top: clamp(140px, 20vw, 200px);
    padding-bottom: clamp(70px, 12vw, 130px);
    background:
        radial-gradient(900px 500px at 85% -10%, rgba(255, 59, 59, 0.12), transparent 60%),
        radial-gradient(700px 500px at 0% 110%, rgba(255, 59, 59, 0.08), transparent 55%),
        linear-gradient(180deg, #fff 0%, #fff6f6 100%);
}
.hero-content { max-width: 880px; }
.hero-eyebrow {
    display: inline-block;
    font-family: 'Montserrat', sans-serif;
    font-size: var(--fs-xs);
    letter-spacing: 0.24em;
    font-weight: 900;
    color: var(--primary-red);
    margin-bottom: 22px;
}
.hero-title { display: flex; flex-direction: column; gap: 6px; margin-bottom: 26px; }
.hero-line { font-size: var(--fs-hero-line); font-weight: 700; line-height: var(--lh-tight); color: var(--black); }
.hero-line strong { color: var(--primary-red); }
.hero-main {
    font-size: var(--fs-display);
    font-weight: 800;
    line-height: var(--lh-display);
    color: var(--black);
    letter-spacing: 0.02em;
}
.hero-subtitle { font-size: var(--fs-lead); font-weight: 700; color: var(--dark-gray); margin-bottom: 18px; line-height: var(--lh-snug); }
.hero-description { font-size: var(--fs-body); color: var(--gray); line-height: var(--lh-body); margin-bottom: 32px; }
.hero-buttons { display: flex; flex-wrap: wrap; gap: 16px; }
.hero-note { margin-top: 16px; font-size: var(--fs-sm); color: var(--gray); }

/* ---------- Problem ---------- */
.problem { background: var(--light-gray); }
.problem-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: clamp(16px, 2.4vw, 24px);
}
.problem-card {
    background: var(--white);
    border-radius: 14px;
    padding: 30px 26px;
    border: 1px solid #eee;
    box-shadow: 0 4px 16px rgba(0,0,0,0.04);
    display: flex;
    align-items: flex-start;
    gap: 16px;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.problem-card:hover { transform: translateY(-4px); box-shadow: 0 12px 28px rgba(0,0,0,0.08); }
.problem-icon { font-size: 2rem; line-height: 1; flex-shrink: 0; }
.problem-text { font-size: var(--fs-body); line-height: var(--lh-snug); color: var(--dark-gray); }
.problem-cta { text-align: center; margin-top: clamp(36px, 5vw, 56px); }
.problem-cta-text { font-size: var(--fs-lead); font-weight: 700; margin-bottom: 22px; }

/* ---------- Service ---------- */
.service-lead { max-width: 860px; margin: 0 auto clamp(44px, 6vw, 64px); text-align: center; }
.service-lead p { font-size: var(--fs-lead); line-height: var(--lh-body); color: var(--dark-gray); margin-bottom: 18px; }
.service-features {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: clamp(18px, 2.6vw, 28px);
}
.service-feature {
    background: var(--white);
    border-radius: 16px;
    padding: 36px 28px;
    border: 1px solid #f0f0f0;
    box-shadow: 0 6px 22px rgba(0,0,0,0.05);
    text-align: center;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.service-feature:hover { transform: translateY(-6px); box-shadow: 0 16px 34px rgba(0,0,0,0.09); }
.service-feature-icon {
    width: 72px; height: 72px;
    margin: 0 auto 20px;
    display: flex; align-items: center; justify-content: center;
    font-size: 2.1rem;
    background: #fff1f1;
    border-radius: 50%;
}
.service-feature-title { font-size: var(--fs-h4); font-weight: 800; margin-bottom: 14px; line-height: var(--lh-heading); }
.service-feature-text { font-size: var(--fs-sm); color: var(--gray); line-height: var(--lh-snug); }

/* ---------- Scope ---------- */
.scope { background: var(--light-gray); }
.scope-flow {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: clamp(18px, 2.6vw, 26px);
}
.scope-step {
    background: var(--white);
    border-radius: 16px;
    padding: 32px 26px;
    border-top: 4px solid var(--primary-red);
    box-shadow: 0 6px 22px rgba(0,0,0,0.05);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.scope-step:hover { transform: translateY(-5px); box-shadow: 0 16px 32px rgba(0,0,0,0.09); }
.scope-step-num {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.85rem;
    font-weight: 900;
    letter-spacing: 0.1em;
    color: var(--primary-red);
    margin-bottom: 12px;
}
.scope-step-title { font-size: var(--fs-h4); font-weight: 800; margin-bottom: 18px; line-height: var(--lh-heading); }
.scope-list { list-style: none; }
.scope-list li {
    position: relative;
    padding-left: 22px;
    font-size: var(--fs-sm);
    color: var(--dark-gray);
    line-height: var(--lh-snug);
    margin-bottom: 10px;
}
.scope-list li::before {
    content: "🍎";
    position: absolute;
    left: 0;
    font-size: 0.7rem;
    top: 0.35em;
}

/* ---------- Reason ---------- */
.reason-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: clamp(18px, 2.6vw, 26px);
}
.reason-card {
    position: relative;
    background: var(--white);
    border-radius: 16px;
    padding: 38px 30px 32px;
    border: 1px solid #f0f0f0;
    box-shadow: 0 6px 22px rgba(0,0,0,0.05);
    overflow: hidden;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.reason-card:hover { transform: translateY(-5px); box-shadow: 0 16px 32px rgba(0,0,0,0.09); }
.reason-num {
    font-family: 'Montserrat', sans-serif;
    font-size: 3rem;
    font-weight: 900;
    line-height: 1;
    color: rgba(255, 59, 59, 0.16);
    margin-bottom: 6px;
}
.reason-title { font-size: var(--fs-h4); font-weight: 800; margin-bottom: 14px; line-height: var(--lh-heading); }
.reason-text { font-size: var(--fs-sm); color: var(--gray); line-height: var(--lh-snug); }

/* ---------- Stats ---------- */
.stats { background: var(--black); color: var(--white); }
.stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(20px, 4vw, 40px);
    text-align: center;
}
.stat-number {
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(2.6rem, 7vw, 4.2rem);
    font-weight: 900;
    line-height: 1;
    color: var(--primary-red);
}
.stat-label { margin-top: 12px; font-size: var(--fs-sm); color: rgba(255,255,255,0.8); letter-spacing: 0.05em; }

/* ---------- Flow ---------- */
.flow-list { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 0; }
.flow-item { display: flex; gap: 24px; position: relative; padding-bottom: clamp(28px, 4vw, 40px); }
.flow-item:not(:last-child)::before {
    content: "";
    position: absolute;
    left: 27px;
    top: 56px;
    bottom: 0;
    width: 2px;
    background: linear-gradient(180deg, var(--primary-red), rgba(255,59,59,0.15));
}
.flow-num {
    flex-shrink: 0;
    width: 56px; height: 56px;
    border-radius: 50%;
    background: var(--primary-red);
    color: var(--white);
    font-family: 'Montserrat', sans-serif;
    font-weight: 900;
    font-size: 1.4rem;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 6px 18px rgba(255,59,59,0.3);
    z-index: 1;
}
.flow-info { padding-top: 4px; }
.flow-info h4 { font-size: var(--fs-h4); font-weight: 800; margin-bottom: 8px; }
.flow-info p { font-size: var(--fs-sm); color: var(--gray); line-height: var(--lh-snug); }

/* ---------- FAQ ---------- */
.faq { background: var(--light-gray); }
.faq-list { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 14px; }
.faq-item {
    background: var(--white);
    border-radius: 12px;
    border: 1px solid #eee;
    box-shadow: 0 4px 14px rgba(0,0,0,0.04);
    overflow: hidden;
}
.faq-q {
    cursor: pointer;
    list-style: none;
    padding: 22px 56px 22px 26px;
    font-size: var(--fs-body);
    font-weight: 800;
    position: relative;
    line-height: var(--lh-heading);
}
.faq-q::-webkit-details-marker { display: none; }
.faq-q::before { content: "Q"; color: var(--primary-red); font-family: 'Montserrat', sans-serif; font-weight: 900; margin-right: 10px; }
.faq-q::after {
    content: "+";
    position: absolute;
    right: 24px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.5rem;
    color: var(--primary-red);
    transition: transform 0.25s ease;
}
.faq-item[open] .faq-q::after { transform: translateY(-50%) rotate(45deg); }
.faq-a {
    padding: 0 26px 24px;
    font-size: var(--fs-sm);
    color: var(--gray);
    line-height: var(--lh-body);
}

/* ---------- CTA band ---------- */
.cta-band {
    text-align: center;
    background:
        radial-gradient(700px 400px at 80% 0%, rgba(255,255,255,0.12), transparent 60%),
        linear-gradient(135deg, var(--primary-red), var(--dark-red));
    color: var(--white);
}
.cta-band-title { font-size: clamp(1.6rem, 4vw, 2.4rem); font-weight: 800; line-height: var(--lh-heading); margin-bottom: 16px; }
.cta-band-text { font-size: var(--fs-lead); margin-bottom: 32px; opacity: 0.95; }

/* ---------- Contact ---------- */
.contact-content { max-width: 880px; margin: 0 auto; }
.contact-methods {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 20px;
    margin-bottom: 48px;
}
.contact-method {
    text-align: center;
    background: var(--light-gray);
    border-radius: 14px;
    padding: 30px 24px;
}
.contact-method-icon { font-size: 2rem; margin-bottom: 12px; }
.contact-method-title { font-size: var(--fs-h4); font-weight: 800; margin-bottom: 8px; }
.contact-method-link { font-size: var(--fs-sm); color: var(--gray); word-break: break-all; }
a.contact-method-link:hover { color: var(--primary-red); }
.contact-form-wrapper {
    max-width: 800px;
    margin: 0 auto;
    padding: clamp(28px, 5vw, 44px);
    background: var(--white);
    border-radius: 14px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.07);
    border: 1px solid #eee;
}
.contact-form-title { font-size: var(--fs-h3); font-weight: 800; margin-bottom: 24px; text-align: center; }

/* ---------- Footer ---------- */
.footer { background: var(--black); color: var(--white); padding: clamp(50px, 7vw, 80px) 0 30px; }
.footer-content { text-align: center; }
.footer-logo { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 16px; }
.apple-icon { font-size: 1.9rem; }
.footer-logo-text-wrapper { display: flex; flex-direction: column; line-height: 1.2; text-align: left; }
.footer-logo-brand { font-weight: 800; font-size: 1.1rem; }
.footer-logo-sub { font-family: 'Montserrat', sans-serif; font-size: 0.62rem; letter-spacing: 0.08em; color: rgba(255,255,255,0.6); }
.footer-text { font-size: var(--fs-sm); color: rgba(255,255,255,0.75); margin-bottom: 40px; }
.footer-service-links { margin-bottom: 36px; }
.footer-service-title { font-size: var(--fs-sm); font-weight: 800; color: rgba(255,255,255,0.9); margin-bottom: 18px; letter-spacing: 0.05em; }
.footer-service-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px 24px; }
.footer-service-link { font-size: var(--fs-sm); color: rgba(255,255,255,0.75); transition: color 0.2s ease; }
.footer-service-link:hover { color: var(--primary-red); }
.footer-links { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px 24px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,0.12); }
.footer-link { font-size: var(--fs-sm); color: rgba(255,255,255,0.75); transition: color 0.2s ease; }
.footer-link:hover { color: var(--primary-red); }
.footer-bottom { margin-top: 36px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.12); text-align: center; }
.footer-bottom p { font-size: var(--fs-xs); color: rgba(255,255,255,0.55); }

/* ---------- Floating CTA ---------- */
.floating-cta {
    position: fixed;
    right: clamp(16px, 3vw, 28px);
    bottom: clamp(16px, 3vw, 28px);
    z-index: 900;
    background: var(--primary-red);
    color: var(--white);
    font-weight: 800;
    font-size: var(--fs-sm);
    padding: 14px 24px;
    border-radius: 999px;
    box-shadow: 0 10px 26px rgba(255,59,59,0.42);
    transition: transform 0.25s ease, background 0.25s ease;
}
.floating-cta:hover { background: var(--dark-red); transform: translateY(-3px); }

/* ---------- Scroll animation ---------- */
.problem-card, .service-feature, .scope-step, .reason-card, .stat-item, .flow-item {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}
.fade-in { opacity: 1 !important; transform: translateY(0) !important; }

/* ---------- Responsive ---------- */
/* ---------- Condition ---------- */
.condition-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: clamp(18px, 2.6vw, 28px);
    align-items: start;
}
.condition-card {
    background: var(--white);
    border-radius: 16px;
    padding: clamp(26px, 3vw, 36px);
    border: 1px solid #f0f0f0;
    box-shadow: 0 6px 22px rgba(0,0,0,0.05);
}
.condition-ok { border-top: 4px solid var(--primary-red); }
.condition-ng { border-top: 4px solid #c2c2c2; background: var(--light-gray); }
.condition-card-head {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: var(--fs-h4);
    font-weight: 800;
    margin-bottom: 20px;
    line-height: var(--lh-heading);
}
.condition-mark {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-family: 'Montserrat', sans-serif;
    font-weight: 900;
    color: var(--white);
    background: var(--primary-red);
}
.condition-ng .condition-mark { background: #9a9a9a; }
.condition-list { list-style: none; }
.condition-list li {
    position: relative;
    padding-left: 24px;
    font-size: var(--fs-sm);
    color: var(--dark-gray);
    line-height: var(--lh-snug);
    margin-bottom: 12px;
}
.condition-list li::before {
    content: "";
    position: absolute;
    left: 4px;
    top: 0.55em;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--primary-red);
}
.condition-ng .condition-list li::before { background: #9a9a9a; }
.condition-note {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px dashed #d5d5d5;
    font-size: var(--fs-xs);
    color: var(--gray);
    line-height: var(--lh-snug);
}

/* ---------- Pricing ---------- */
.pricing { background: var(--light-gray); }
.pricing-main {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(18px, 2.6vw, 26px);
    margin-bottom: clamp(24px, 3vw, 34px);
}
.pricing-rate {
    background: var(--black);
    color: var(--white);
    border-radius: 16px;
    padding: clamp(28px, 3.4vw, 40px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.12);
}
.pricing-rate-label {
    display: inline-block;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.8rem;
    font-weight: 900;
    letter-spacing: 0.1em;
    color: var(--light-red);
    margin-bottom: 12px;
}
.pricing-rate-amount {
    display: block;
    font-size: clamp(1.4rem, 3vw, 2rem);
    font-weight: 700;
    line-height: 1.2;
}
.pricing-rate-amount strong { font-size: clamp(2.2rem, 5vw, 3.2rem); color: var(--light-red); }
.pricing-rate-unit { font-size: 1.4rem; }
.pricing-rate-note { margin-top: 16px; font-size: var(--fs-sm); line-height: var(--lh-snug); opacity: 0.9; }
.pricing-example {
    background: var(--white);
    border-radius: 16px;
    padding: clamp(28px, 3.4vw, 40px);
    border: 1px solid #f0f0f0;
    box-shadow: 0 6px 22px rgba(0,0,0,0.05);
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.pricing-example-title { font-size: var(--fs-h4); font-weight: 800; margin-bottom: 12px; }
.pricing-example-lead { font-size: var(--fs-sm); color: var(--gray); line-height: var(--lh-snug); margin-bottom: 16px; }
.pricing-example-figure { font-size: clamp(1.2rem, 2.4vw, 1.6rem); font-weight: 800; }
.pricing-example-figure strong { color: var(--primary-red); font-size: clamp(1.6rem, 3.4vw, 2.2rem); }
.pricing-plans {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: clamp(18px, 2.6vw, 26px);
    margin-bottom: 24px;
}
.pricing-plan {
    background: var(--white);
    border-radius: 16px;
    padding: clamp(26px, 3vw, 34px);
    border: 1px solid #f0f0f0;
    border-left: 4px solid var(--primary-red);
    box-shadow: 0 6px 22px rgba(0,0,0,0.05);
}
.pricing-plan-head { font-size: var(--fs-h4); font-weight: 800; margin-bottom: 12px; line-height: var(--lh-heading); }
.pricing-plan-text { font-size: var(--fs-sm); color: var(--dark-gray); line-height: var(--lh-snug); }
.pricing-foot { text-align: center; font-size: var(--fs-xs); color: var(--gray); line-height: var(--lh-snug); }

@media (max-width: 768px) {
    .nav { display: none; }
    .stats-grid { grid-template-columns: 1fr; gap: 32px; }
    .hero-buttons { flex-direction: column; align-items: stretch; }
    .hero-buttons .button { width: 100%; }
    .pricing-main { grid-template-columns: 1fr; }
}
