/* Homepage sections. Shared header/footer/button/base styles live in site-shell.css. */
.play { width: 18px; height: 18px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid #bbb7b2; border-radius: 50%; font-size: 7px; }

.hero {
    position: relative;
    padding: 95px 0 0;
    background: linear-gradient(110deg, #fffdfa 0%, #fffdfa 70%, #fff8e9 100%);
}
.hero-glow { position: absolute; width: 520px; height: 520px; right: 0; top: -250px; background: radial-gradient(circle, rgba(255, 207, 101, .22), transparent 68%); pointer-events: none; }
.hero-grid { display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 100px; padding-bottom: 100px; }
.hero-copy { display: flex; flex-direction: column; align-items: flex-start; justify-content: center; }
.eyebrow { width: fit-content; margin: 0 0 18px; padding: 7px 15px 7px 11px; display: inline-flex; align-items: center; gap: 8px; color: #1a73e8; background: #e8f0fe; border: 1px solid #d2e3fc; border-radius: 20px; font-family: "Roboto", Arial, sans-serif; text-transform: uppercase; letter-spacing: .055em; font-size: 9px; font-weight: 700; }
.eyebrow img { width: 16px; height: 16px; object-fit: contain; display: block; }
.eyebrow span { background: linear-gradient(135deg, #4285f4 0 28%, #34a853 28% 50%, #fbbc04 50% 72%, #ea4335 72% 100%); background-clip: text; -webkit-background-clip: text; color: transparent; font-size: 9px; }
.hero h1 { margin: 0 0 18px; }
.hero h1 em { position: relative; font-style: normal; white-space: nowrap; }
.hero h1 em::after { content: ""; position: absolute; left: 0; right: 0; bottom: -5px; height: 4px; border-radius: 5px; background: #ff474f; transform: rotate(-1deg); }
.hero-text { max-width: 500px; margin: 0 0 27px; color: #68666a; font-size: 13px; }
.hero-copy .button-row { width: 100%; margin-top: 30px; }
.hero-copy .button-row .button-primary { width: 100%; max-width: 420px; min-height: 54px; border-radius: 12px; font-size: 14px; }
.hero-proof { max-width: 520px; margin-top: 25px; }
.proof-rating { display: flex; align-items: center; justify-content: flex-start; gap: 12px; color: #737179; font-size: 12px; }
.proof-rating .stars { color: #ffb800; letter-spacing: 2px; font-size: 18px; line-height: 1; }
.proof-rating strong { color: #151416; }
.proof-points { margin-top: 15px; display: flex; align-items: center; justify-content: flex-start; gap: 22px; color: #6f6d75; font-size: 13px; white-space: nowrap; }
.proof-points span { display: inline-flex; align-items: center; gap: 7px; }
.proof-points b { color: #12b878; font-size: 18px; line-height: 1; }
.hero-visual { min-height: 380px; display: flex; align-items: center; justify-content: center; position: relative; }
.sun { position: absolute; width: 76px; height: 76px; right: 46px; top: 34px; border-radius: 50%; background: #ffa300; }
.browser-card { width: 430px; height: 270px; position: relative; z-index: 1; border-radius: 15px; background: #fff; box-shadow: 0 24px 55px rgba(25, 21, 15, .14); overflow: hidden; }
.browser-bar { height: 48px; display: flex; align-items: center; gap: 6px; padding: 0 18px; background: #fff; }
.browser-bar i { width: 7px; height: 7px; border-radius: 50%; background: #ffaaa8; }
.browser-tabs { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; padding: 0 18px; }
.browser-tabs span { height: 44px; border-radius: 10px; background: #ffe2a3; }
.browser-tabs span:nth-child(2) { background: #afe8f5; }
.browser-tabs span:nth-child(3) { background: #ffc6c4; }
.browser-content { height: 160px; margin: 13px 18px 0; position: relative; }
.browser-content svg { width: auto; height: 100%; }
.browser-content path { fill: none; stroke-width: 3; stroke-linecap: round; }
.line-yellow { stroke: #ffc82e; }
.line-red { stroke: #ff474f; }
.browser-content circle { fill: #ff474f; }
.summary { position: absolute; right: 2px; bottom: 14px; width: 58px; height: 58px; padding: 13px 10px; border-radius: 12px; background: #121113; }
.summary span { display: block; height: 4px; margin-bottom: 7px; border-radius: 4px; background: #ffca26; }
.stats { display: grid; grid-template-columns: repeat(3, 1fr); position: relative; z-index: 5; margin-bottom: -48px; border: 1px solid #dedad6; border-radius: 13px; background: #fff; box-shadow: 0 18px 35px rgba(27, 24, 20, .12); }
.stats div { min-height: 122px; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 28px 25px; text-align: center; }
.stats div + div { border-left: 1px solid #e2dfdb; }
.stats strong { font-size: 38px; line-height: 1; font-weight: 800; letter-spacing: -.025em; color: #151416; }
.stats span { margin-top: 10px; color: #7b7882; font-size: 13px; font-weight: 600; letter-spacing: .005em; }

.section { padding: 95px 0; }
.section-soft { background: #fbf8f3; }
.how-section { padding-top: 56px; }
.section-heading { max-width: 760px; margin-bottom: 45px; }
.section-heading.centered { margin-left: auto; margin-right: auto; text-align: center; }
.section-heading.left { max-width: 760px; }
.overline { margin: 0 0 14px; color: #777277; text-transform: uppercase; letter-spacing: .18em; font-size: 9px; font-weight: 800; }
.overline.red { color: #ff474f; }
.section-heading h2, .dark-cta h2, .budget-cta h2 { margin: 0 0 13px; }
.section-heading > p:last-child, .dark-cta p:last-child, .budget-cta p { margin: 0; color: #777378; font-size: 12px; }
.cards { display: grid; gap: 18px; }
.three-col { grid-template-columns: repeat(3, 1fr); }
.four-col { grid-template-columns: repeat(4, 1fr); }
.cards article { padding: 26px 24px; border: 1px solid #e4e0dc; border-radius: 14px; background: #fff; box-shadow: 0 10px 22px rgba(25, 22, 18, .06); }
.cards h3 { margin: 12px 0 8px; line-height: 1.35; }
.cards p { margin: 0; color: #716e72; font-size: 11px; line-height: 1.6; }
.steps article { min-height: 185px; transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.steps article:hover { transform: translateY(-7px); border-color: #ffd0cd; box-shadow: 0 20px 38px rgba(36, 30, 24, .16); }
.steps article > span { width: 31px; height: 31px; display: inline-flex; align-items: center; justify-content: center; color: #ff474f; background: #fff0ef; border-radius: 50%; font-size: 10px; font-weight: 800; }
.dark-cta { min-height: 164px; margin-top: 70px; padding: 32px 36px; display: flex; align-items: center; justify-content: space-between; gap: 45px; position: relative; overflow: hidden; color: #fff; background: #160d0a; border-radius: 14px; }
.dark-cta > * { position: relative; z-index: 1; }
.dark-cta > div:not(.cta-orb) { max-width: 720px; }
.dark-cta h2 { margin-bottom: 5px; color: #fff; }
.dark-cta p:last-child { color: #c9c2be; font-size: 11px; }
.cta-orb { width: 220px; height: 220px; position: absolute; z-index: 0; right: -70px; top: -30px; border-radius: 50%; background: #74301f; }

.creator-section { padding: 105px 0 95px; background: #fffdfa; overflow: hidden; }
.creator-heading { margin-bottom: 54px; }
.section-pill { display: inline-block; margin-bottom: 20px; padding: 5px 11px; border-radius: 20px; background: #efede9; font-size: 9px; font-weight: 800; }
.category-marquee { width: 100%; overflow: hidden; display: grid; gap: 12px; padding: 4px 0 12px; -webkit-mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent); mask-image: linear-gradient(90deg, transparent, #000 7%, #000 93%, transparent); }
.category-track { width: max-content; display: flex; animation: category-scroll 28s linear infinite; }
.category-track.marquee-right { animation-direction: reverse; animation-duration: 32s; }
.category-group { display: flex; gap: 9px; padding-right: 9px; }
.category-group span { min-width: 112px; min-height: 34px; padding: 8px 15px; border: 1px solid #dedbd7; border-radius: 22px; background: #fff; box-shadow: 0 5px 12px rgba(25, 22, 18, .04); text-align: center; white-space: nowrap; font-size: 10px; font-weight: 700; display: inline-flex; align-items: center; justify-content: center; gap: 7px; }
.category-group span { gap: 9px; }
.category-marquee:hover .category-track { animation-play-state: paused; }
@keyframes category-scroll { to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .category-track { animation-play-state: paused; } }

.benefits article { min-height: 200px; overflow: hidden; transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.benefits article:hover { transform: translateY(-7px); border-color: #ffd0cd; box-shadow: 0 20px 38px rgba(36, 30, 24, .16); }
.feature-icon { width: 42px; height: 42px; display: inline-flex; align-items: center; justify-content: center; color: #ff474f; background: #fff0ef; border-radius: 50%; font-size: 17px; overflow: hidden; }
.feature-icon img { width: 22px !important; height: 22px !important; max-width: 22px !important; max-height: 22px !important; object-fit: contain; display: block; }
.ads-section { padding-bottom: 85px; }
.dark-cards article { min-height: 160px; color: #fff; background: #15100e; border-color: #15100e; box-shadow: none; }
.dark-cards h3 { color: #fff; }
.dark-cards p { color: #bdb7b4; }
.dark-icon { color: #ff474f; font-size: 17px; }
.dark-icon img { width: 16px; height: 16px; object-fit: contain; }
.policy-section { background: #fff; }
.policy-heading { margin-bottom: 48px; }
.policy-heading h2 { text-transform: none; }
.policy-label { margin: 0 0 22px; display: flex; align-items: center; justify-content: center; gap: 10px; text-align: center; font-size: 16px; font-weight: 800; }
.policy-no { min-width: 54px; height: 26px; padding: 0 14px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; color: #fff; background: #ff474f; box-shadow: 0 10px 18px rgba(255, 71, 79, .2); font-size: 11px; letter-spacing: .12em; }
.policy-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.policy-grid article { min-height: 230px; padding: 28px 25px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; border: 1px solid #e5e1dd; border-radius: 16px; background: #fffdfa; box-shadow: 0 10px 24px rgba(27, 23, 18, .05); transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease; }
.policy-grid article:hover { transform: translateY(-7px); border-color: #ffbdb9; box-shadow: 0 20px 38px rgba(36, 30, 24, .14); }
.policy-icon { width: 82px; height: 82px; display: flex; align-items: center; justify-content: center; margin-bottom: 23px; color: #fff; background: linear-gradient(145deg, #ff4b52, #ff8d55); border: 8px solid #fff0ed; border-radius: 24px; box-shadow: 0 12px 25px rgba(255, 71, 79, .2); font-size: 24px; font-weight: 900; }
.policy-grid h3 { margin: 0 0 9px; }
.policy-grid p { margin: 0; color: #777378; font-size: 11px; line-height: 1.6; }
.budget-cta { min-height: 170px; margin-top: 68px; padding: 32px 55px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; border-radius: 14px; background: linear-gradient(100deg, #ffd14d, #ffb378); }
.budget-cta h2 { margin-bottom: 6px; }
.budget-cta p { color: #725d4d; font-size: 10px; }
.budget-cta .button { margin-top: 22px; }
.post-faq-cta { padding: 0 0 105px; background: #fbf8f3; }
.post-faq-cta .budget-cta { margin-top: 0; }

.faq-section { padding-top: 110px; padding-bottom: 105px; }
.faq-container { max-width: 680px; }
.faq-section .section-heading h2 { font-size: 40px; }
.accordion details { margin-bottom: 9px; padding: 0 18px; border: 1px solid #e1ded9; border-radius: 11px; background: #fff; }
.accordion details[open] { border-color: #ffb7b4; box-shadow: 0 8px 20px rgba(255, 71, 79, .08); }
.accordion summary { padding: 17px 2px; display: flex; align-items: center; justify-content: space-between; list-style: none; cursor: pointer; font-size: 15px; font-weight: 800; }
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary::after { content: "\2304"; color: #888; font-size: 15px; }
.accordion details[open] summary::after { content: "\2303"; color: #ff474f; }
.accordion details p { margin: 0; padding: 0 0 16px; color: #777378; font-size: 15px; }

.sr-only { width: 1px; height: 1px; padding: 0; margin: -1px; position: absolute; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.contact-section { padding: 105px 0; background: #fff; }
.contact-grid { display: grid; grid-template-columns: .9fr 1.1fr; align-items: center; gap: 110px; }
.contact-kicker { margin: 0 0 22px; display: flex; align-items: center; gap: 11px; color: #4778f7; text-transform: uppercase; letter-spacing: .16em; font-size: 12px; font-weight: 800; }
.contact-kicker span { width: 8px; height: 8px; border-radius: 50%; background: #4778f7; }
.contact-copy h2 { margin: 0 0 20px; line-height: 1; letter-spacing: -.04em; }
.contact-intro { max-width: 430px; margin: 0 0 34px; color: #747783; font-size: 17px; }
.contact-detail { margin-top: 18px; display: flex; align-items: center; gap: 16px; }
.contact-icon { width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; border-radius: 13px; font-size: 25px; }
.contact-icon img { width: 22px; height: 22px; object-fit: contain; }
.mail-icon { color: #3974f5; background: #eef3ff; }
.time-icon { color: #14a557; background: #eaf9ef; }
.contact-detail div { display: flex; flex-direction: column; }
.contact-detail small { color: #969aa8; font-size: 12px; font-weight: 700; }
.contact-detail a, .contact-detail strong { color: #24252a; font-size: 14px; font-weight: 700; }
.contact-form { padding: 34px; display: grid; gap: 16px; border: 1px solid #e7e9ef; border-radius: 20px; background: #fff; box-shadow: 0 24px 55px rgba(30, 42, 70, .09); }
.contact-form input, .contact-form textarea { width: 100%; border: 1px solid #dfe3ed; border-radius: 13px; background: #fff; color: #151416; font: inherit; outline-style: none; transition: border-color .2s, box-shadow .2s; }
.contact-form input { height: 57px; padding: 0 19px; }
.contact-form textarea { min-height: 132px; padding: 17px 19px; resize: vertical; }
.contact-form input:focus, .contact-form textarea:focus { border-color: #ffca3b; box-shadow: 0 0 0 3px rgba(255, 202, 59, .16); }
.contact-form input::placeholder, .contact-form textarea::placeholder { color: #a6abba; }
.contact-form button { min-height: 58px; border: 0; border-radius: 13px; background: #f9c73e; color: #2a2415; cursor: pointer; font-size: 15px; font-weight: 800; box-shadow: 0 12px 25px rgba(249, 199, 62, .2); transition: transform .2s, box-shadow .2s; }
.contact-form button:hover { transform: translateY(-2px); box-shadow: 0 17px 30px rgba(249, 199, 62, .3); }

@media (max-width: 1024px) {
    .hero { padding-top: 65px; }
    .hero-grid { grid-template-columns: 1fr; gap: 35px; padding-bottom: 55px; }
    .hero-copy { align-items: center; text-align: center; }
    .eyebrow { margin-inline: auto; }
    .hero-text { margin-inline: auto; }
    .button-row { justify-content: center; }
    .hero-copy .button-row .button-primary { width: 100%;
        max-width: 420px; }
    .hero-visual { min-height: 330px; }
    .stats { margin-bottom: 0; }
    .how-section { padding-top: 90px; }
    .four-col { grid-template-columns: repeat(2, 1fr); }
    .policy-grid { grid-template-columns: repeat(2, 1fr); }
    .contact-grid { grid-template-columns: 1fr; gap: 50px; }
}

@media (max-width: 768px) {
    .hero { padding-top: 48px; }
    .hero-copy .button-row .button-primary { max-width: 320px; min-height: 52px; }
    .hero-proof { margin-inline: auto; }
    .proof-rating { flex-direction: column; gap: 9px; }
    .proof-points { flex-wrap: wrap; gap: 10px 18px; white-space: normal; }
    .hero-visual { min-height: 260px; }
    .browser-card { width: 100%; height: 230px; transform: none; }
    .browser-content { height: 125px; }
    .sun { right: 4px; top: 10px; }
    .stats { grid-template-columns: 1fr; }
    .stats div { min-height: 78px; }
    .stats div + div { border-left: 0; border-top: 1px solid #e2dfdb; }
    .section { padding: 70px 0; }
    .section-heading h2 br, .section-heading p br { display: none; }
    .three-col, .four-col { grid-template-columns: 1fr; }
    .policy-grid { grid-template-columns: 1fr; }
    .policy-grid article { min-height: 0; }
    .policy-label { font-size: 14px; }
    .steps article, .benefits article, .dark-cards article { min-height: 0; }
    .dark-cta { margin-top: 45px; padding: 30px 24px; display: block; }
    .dark-cta .button { margin-top: 22px; }
    .category-track { animation-duration: 20s; }
    .category-track.marquee-right { animation-duration: 24s; }
    .budget-cta { padding: 32px 22px; }
    .contact-section { padding: 70px 0; }
    .contact-intro { font-size: 15px; }
    .contact-form { padding: 20px; }
}

@media (max-width: 768px) {
    .hero { padding-top: 54px; }
    .hero-grid { gap: 28px; padding-bottom: 44px; }
    .hero-copy .button-row { margin-top: 22px; }
    .hero-copy .button-row .button-primary { min-height: 52px; font-size: 14px; }
    .hero-text { font-size: 14px; line-height: 1.65; }
    .proof-rating { align-items: flex-start; flex-direction: column; gap: 8px; font-size: 13px; }
    .proof-points { flex-wrap: wrap; gap: 14px 18px; white-space: normal; }
    .stats { grid-template-columns: 1fr; margin-bottom: 0; }
    .stats div { min-height: 72px; }
    .stats div + div { border-left: 0; border-top: 1px solid #e2dfdb; }
}