/* Contained layout: everything stays inside the theme column (no viewport breakout),
   so it can never overflow on any screen. Hero / screenshots / CTA are rounded bands. */
.yocha-lp{overflow-x:clip;color:#22302f;line-height:1.62;font-size:17px;-webkit-font-smoothing:antialiased}
.yocha-lp *{box-sizing:border-box}
.yocha-lp h1,.yocha-lp h2,.yocha-lp h3,.yocha-lp .brand{font-family:'Quicksand',-apple-system,sans-serif;font-weight:700;letter-spacing:-.01em}
.yocha-lp .wrap{max-width:760px;margin:0 auto;padding:0 22px}
.yocha-lp .wave{display:none}
/* Scoped to the Yocha landing (body.page-id-14189): trims the theme's
   large section padding-top (96px) that left a big gap under the menu. */
body.page-id-14189 #content article .section{padding-top:24px!important}

/* ---------- HERO ---------- */
.yocha-lp .hero{position:relative;background:linear-gradient(150deg,#13a39c 0%,#17b18a 55%,#23bd86 100%);color:#fff;text-align:center;padding:48px 0 52px;border-radius:26px;overflow:hidden;margin-top:0}
.yocha-lp .hero::before{content:"";position:absolute;width:460px;height:460px;border-radius:50%;background:rgba(255,255,255,.07);top:-200px;right:-130px}
.yocha-lp .hero::after{content:"";position:absolute;width:320px;height:320px;border-radius:50%;background:rgba(255,255,255,.06);bottom:-150px;left:-110px}
.yocha-lp .hero .wrap{position:relative;z-index:2}
.yocha-lp .catwrap{width:140px;height:140px;margin:0 auto 18px;border-radius:50%;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(0,0,0,.12)}
.yocha-lp .catwrap img{width:110px;height:auto;display:block}
.yocha-lp h1{font-size:34px;line-height:1.14;margin:6px 0 16px;color:#fff}
.yocha-lp .lead{font-size:18px;color:rgba(255,255,255,.96);max-width:560px;margin:0 auto 8px}
.yocha-lp .pill{display:inline-block;background:rgba(255,255,255,.18);color:#fff;font-weight:600;font-size:13.5px;padding:7px 16px;border-radius:999px;margin:16px 8px 6px}
.yocha-lp .stores{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;align-items:center;margin:14px 0 0}
.yocha-lp .stores a{display:inline-flex;transition:transform .15s ease}
.yocha-lp .stores a:hover{transform:translateY(-2px)}
.yocha-lp .stores img.ios{height:46px;width:auto}
.yocha-lp .stores img.play{height:68px;width:auto}
.yocha-lp .trust{font-size:13.5px;color:rgba(255,255,255,.85);margin:16px 0 0}

/* ---------- SECTIONS ---------- */
.yocha-lp section{padding:46px 0}
.yocha-lp .eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:12.5px;font-weight:700;color:#15a8a0;text-align:center;margin:0 0 8px}
.yocha-lp h2{font-size:27px;text-align:center;color:#16302d;margin:0 0 26px}

/* ---------- QUOTE ---------- */
.yocha-lp .quote{position:relative;max-width:640px;margin:0 auto;background:#f3fbf8;border:1px solid #d9efe7;border-radius:22px;padding:38px 30px 28px;text-align:center}
.yocha-lp .quote .mark{font-family:Georgia,serif;font-size:80px;line-height:.4;color:#bfe7db;position:absolute;top:32px;left:22px}
.yocha-lp .quote p{font-size:21px;font-weight:700;color:#13514a;margin:0 0 12px;line-height:1.4;position:relative}
.yocha-lp .quote .src{font-size:13px;color:#5f7572;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.yocha-lp .quote .sub{font-size:15px;color:#566563;margin-top:14px;font-weight:400;line-height:1.55}

/* ---------- FEATURES ---------- */
.yocha-lp .feats{display:grid;grid-template-columns:1fr;gap:16px;max-width:780px;margin:0 auto}
.yocha-lp .feat{display:grid;grid-template-columns:auto 1fr;column-gap:16px;align-items:start;background:#fff;border:1px solid #e8efed;border-radius:18px;padding:24px 22px;box-shadow:0 4px 18px rgba(20,70,64,.05);transition:transform .18s ease,box-shadow .18s ease}
.yocha-lp .feat:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(20,70,64,.10)}
.yocha-lp .feat .ic{grid-column:1;grid-row:1 / span 2;align-self:start;width:50px;height:50px;border-radius:14px;background:linear-gradient(145deg,#19a89f,#22bd86);display:flex;align-items:center;justify-content:center;font-size:25px}
.yocha-lp .feat h3{grid-column:2;font-size:18px;color:#16302d;margin:0 0 6px}
.yocha-lp .feat p{grid-column:2;margin:0;color:#54635f;font-size:15px;line-height:1.55}

/* ---------- SCREENSHOTS ---------- */
.yocha-lp .shots-band{background:#f4fbf9;border-radius:26px;margin:6px 0}
.yocha-lp .shots{display:flex;gap:16px;overflow-x:auto;padding:8px 22px 20px;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}
.yocha-lp .shots::-webkit-scrollbar{height:8px}
.yocha-lp .shots::-webkit-scrollbar-thumb{background:#cfe6e0;border-radius:8px}
.yocha-lp .shots img{width:212px;height:460px;object-fit:cover;background:#e3efeb;border-radius:26px;border:5px solid #fff;flex:0 0 auto;scroll-snap-align:center;box-shadow:0 10px 30px rgba(20,70,64,.16)}
.yocha-lp .shothint{text-align:center;font-size:13.5px;color:#8fa19d;margin:4px 0 0}

/* ---------- FAQ ---------- */
.yocha-lp .faq{max-width:720px;margin:0 auto}
.yocha-lp .faq details{border:1px solid #e6efed;border-radius:16px;margin-bottom:13px;background:#fff;overflow:hidden;transition:box-shadow .18s}
.yocha-lp .faq details[open]{box-shadow:0 8px 24px rgba(20,70,64,.08)}
.yocha-lp .faq summary{cursor:pointer;font-weight:700;color:#16302d;font-size:17px;padding:18px 54px 18px 20px;position:relative;list-style:none;font-family:'Quicksand',sans-serif}
.yocha-lp .faq summary::-webkit-details-marker{display:none}
.yocha-lp .faq summary::after{content:"+";position:absolute;right:18px;top:50%;transform:translateY(-50%);width:28px;height:28px;line-height:26px;text-align:center;border-radius:50%;background:#eafaf4;color:#15a8a0;font-weight:700;font-size:20px}
.yocha-lp .faq details[open] summary::after{content:"\2013"}
.yocha-lp .faq .ans{padding:0 20px 18px;color:#54635f;font-size:15.3px;line-height:1.6}
.yocha-lp .faq .ans a{color:#138a7e;font-weight:700}

/* ---------- CLOSING ---------- */
.yocha-lp .closing{background:linear-gradient(150deg,#13a39c,#23bd86);color:#fff;text-align:center;padding:54px 0;border-radius:26px;margin:6px 0}
.yocha-lp .closing h2{color:#fff;margin-bottom:14px}
.yocha-lp .closing p{color:rgba(255,255,255,.96);max-width:520px;margin:0 auto 6px;font-size:17px}

@media(min-width:760px){
 .yocha-lp h1{font-size:50px}
 .yocha-lp h2{font-size:34px}
 .yocha-lp .hero{padding:64px 0 66px}
 .yocha-lp .catwrap{width:168px;height:168px}
 .yocha-lp .catwrap img{width:130px}
 .yocha-lp .feats{grid-template-columns:1fr 1fr;gap:20px}
}
