:root{--bg: #f7f4ec;--bg-soft: #eef5e8;--surface: #fffdf8;--surface-strong: #ffffff;--surface-muted: #f2ede3;--text: #252820;--muted: #555f50;--subtle: #747d70;--line: #d8d0c1;--line-strong: #c8d8bd;--primary: #4f7335;--primary-dark: #2f5525;--primary-soft: #dfeada;--accent: #b66b45;--warning: #d5a24b;font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Yu Gothic,YuGothic,Segoe UI,sans-serif;color:var(--text);background:var(--bg)}*{box-sizing:border-box}html{scroll-behavior:smooth;background:var(--bg);overflow-x:hidden}body{position:relative;margin:0;min-width:320px;background:transparent;color:var(--text);font-size:16px;line-height:1.75;line-break:strict;overflow-wrap:normal;word-break:normal;hyphens:none;overflow-x:hidden}body.is-dialog-open{overflow:hidden}body:before{content:"";position:fixed;inset:0;z-index:-1;background:linear-gradient(#f7f4ec94,#f7f4ecb3),url(/images/decorations/leaf-bg.png) center top / cover no-repeat,var(--bg);pointer-events:none}img{max-width:100%;height:auto}a{color:var(--primary-dark);text-decoration:none}a:hover{text-decoration:underline}main{position:relative;z-index:1;width:min(1160px,100%);margin:0 auto;padding:0 18px 46px}.site-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:18px;width:min(1160px,calc(100% - 28px));margin:12px auto 0;padding:14px 16px;border:1px solid #d6decd;border-radius:18px;background:#fffdf8f0;backdrop-filter:blur(10px);box-shadow:0 10px 28px #2f312d0f}.brand{display:inline-flex;align-items:center;gap:9px;color:var(--text);font-size:1.02rem;font-weight:850}.brand-mark{width:32px;height:32px;border-radius:10px;display:block;object-fit:cover;background:var(--primary-soft);border:1px solid #d8e5ce}.header-nav,.footer-nav{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:.96rem;font-weight:800}.header-nav a,.footer-nav a{display:inline-flex;align-items:center;min-height:34px;border-radius:999px;padding:0 10px}.header-nav a:hover,.footer-nav a:hover{background:var(--primary-soft);text-decoration:none}.reveal{opacity:0;transform:translateY(18px);transition:opacity .56s ease,transform .56s ease}.reveal.is-visible{opacity:1;transform:translateY(0)}.feature-card.reveal,.problem-card.reveal,.step-card.reveal,.store-shot.reveal{transition-duration:.46s}@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}.hero{display:grid;grid-template-columns:minmax(0,.98fr) minmax(330px,1.02fr);gap:clamp(30px,5vw,66px);align-items:center;min-height:calc(100vh - 96px);padding:50px 0 54px}.app-hero{position:relative}.hero-copy{max-width:680px}.app-title-row{display:flex;align-items:center;gap:14px;margin-bottom:16px}.app-icon{width:64px;height:64px;flex:0 0 auto;border-radius:18px;object-fit:cover;background:var(--primary-soft);border:1px solid #d8e5ce}.eyebrow{margin:0 0 10px;color:var(--primary-dark);font-size:.95rem;font-weight:850;letter-spacing:0}.app-title-row .eyebrow,.section-heading .eyebrow,.speech-bubble .eyebrow,.final-cta-panel .eyebrow{display:inline-flex;align-items:center;min-height:32px;border-radius:999px;padding:0 12px;background:var(--primary-soft);border:1px solid var(--line-strong)}h1,h2,h3,p{overflow-wrap:break-word;word-break:auto-phrase}.phrase{display:inline;word-break:keep-all;overflow-wrap:normal}h1{margin:0;color:var(--text);font-size:clamp(2.75rem,7vw,5.25rem);line-height:1.03;letter-spacing:0;text-wrap:balance}h2{margin:0;color:var(--text);font-size:clamp(1.82rem,5vw,2.8rem);line-height:1.28;letter-spacing:0;text-wrap:balance}h3{margin:0 0 8px;color:var(--text);font-size:clamp(1rem,1.35vw,1.12rem);line-height:1.42;text-wrap:balance}.lead{margin:24px 0 12px;color:var(--primary-dark);font-size:clamp(1.2rem,3.5vw,1.8rem);font-weight:900;line-height:1.45}.body-text{max-width:620px;margin:0;color:var(--muted);font-size:1.08rem;font-weight:600;text-wrap:pretty}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}.button{display:inline-flex;align-items:center;justify-content:center;min-height:52px;border-radius:999px;padding:0 22px;border:1px solid var(--line);font-weight:850;font-size:1rem;text-align:center}.button.primary{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 12px 24px #4f733533}.button.secondary{background:#fff;color:var(--primary-dark);border-color:var(--line-strong)}.button.disabled{background:#ece7dc;color:var(--muted)}.hero-visual{position:relative;display:grid;justify-items:center;align-items:center;gap:18px;min-height:660px}.phone-mock{width:min(390px,100%);border-radius:38px;padding:13px;background:#2f312d;border:1px solid rgba(47,49,45,.22);box-shadow:0 24px 64px #2f312d2e}.phone-speaker{width:74px;height:6px;margin:0 auto 10px;border-radius:999px;background:#54574f}.phone-screen-shot{position:relative;aspect-ratio:9 / 19.2;overflow:hidden;border-radius:28px;background:var(--surface)}.phone-screen-shot img{position:relative;z-index:2;display:block;width:100%;height:100%;min-height:650px;object-fit:cover;background:var(--surface)}.section{padding:56px 0}.section-heading{max-width:720px;margin-bottom:28px}.section-heading.centered{max-width:760px;margin-right:auto;margin-left:auto;text-align:center}.section-heading p{color:var(--muted);font-size:1.02rem;font-weight:600}.problem-section,.how-section{border-radius:28px;padding-right:24px;padding-left:24px;background:#eef5e8e6;border:1px solid #dce8d5}.problem-grid,.feature-grid,.step-grid,.screenshot-grid{display:grid;gap:18px}.problem-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.feature-grid,.feature-grid-wide,.step-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.feature-card,.problem-card,.step-card,.screenshot-placeholder,.support-panel,.legal-content{border:1px solid var(--line);border-radius:20px;background:var(--surface);box-shadow:0 10px 26px #2f312d0b}.feature-card,.problem-card,.step-card{padding:22px}.feature-card p,.problem-card p,.step-card p{margin:0;color:var(--muted);font-size:clamp(.9rem,1.15vw,.98rem);font-weight:600;line-height:1.75;text-wrap:pretty;word-break:auto-phrase}.feature-card{border-color:#d9e3d1}.feature-mark{display:inline-flex;align-items:center;min-height:32px;margin-bottom:16px;border-radius:999px;padding:0 12px;background:var(--primary);color:#fff;font-size:.88rem;font-weight:900}.problem-card span,.step-number{display:inline-flex;align-items:center;justify-content:center;min-height:28px;margin-bottom:16px;border-radius:999px;padding:0 10px;background:var(--primary);color:#fff;font-size:.88rem;font-weight:850}.problem-card h3{margin-bottom:0;font-size:clamp(.98rem,1.35vw,1.12rem)}.step-card{display:grid;align-content:start;padding:18px}.step-image{position:relative;aspect-ratio:9 / 18.5;overflow:hidden;margin-bottom:22px;border-radius:30px;background:#2f312d;border:1px solid rgba(47,49,45,.22);padding:22px 9px 10px;box-shadow:0 14px 28px #2f312d1f}.step-image:before{content:"";position:absolute;top:9px;left:50%;width:58px;height:5px;border-radius:999px;background:#54574f;transform:translate(-50%)}.step-image img{position:relative;z-index:1;display:block;width:100%;height:100%;object-fit:cover;background:var(--surface-muted);border-radius:20px}.ecorashi-section{padding-top:64px;padding-bottom:64px}.ecorashi-guide{display:grid;grid-template-columns:220px minmax(0,1fr);align-items:center;gap:28px;max-width:980px;margin:0 auto}.ecorashi-portrait{display:grid;place-items:center;min-height:240px;overflow:hidden;border:1px solid var(--line-strong);border-radius:34px;background:var(--primary-soft)}.ecorashi-portrait img{width:min(220px,94%);height:min(220px,94%);object-fit:contain}.speech-bubble{position:relative;border:1px solid var(--line-strong);border-radius:24px;padding:clamp(22px,4vw,34px);background:var(--surface)}.speech-bubble p:last-child{margin-bottom:0;color:var(--muted);font-size:1.05rem;font-weight:600}.privacy-panel,.final-cta-panel{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:24px;align-items:center;border:1px solid var(--line-strong);border-radius:26px;padding:clamp(22px,5vw,34px);background:#fff;box-shadow:0 14px 34px #2f312d0f}.privacy-panel h2{color:var(--primary-dark)}.privacy-mark{display:inline-flex;align-items:center;min-height:34px;margin-bottom:14px;border-radius:999px;padding:0 13px;background:var(--primary);color:#fff;font-size:.9rem;font-weight:900}.privacy-copy p{margin:0 0 10px;color:var(--muted);font-size:1.02rem;font-weight:600}.privacy-copy a{display:inline-flex;align-items:center;min-height:40px;margin-top:4px;border-radius:999px;padding:0 14px;background:var(--primary-soft);border:1px solid var(--line-strong);font-weight:850}.screenshot-row{display:grid;grid-template-columns:repeat(3,minmax(230px,1fr));gap:18px;overflow-x:auto;padding-bottom:8px}.store-shot{min-width:230px;margin:0;border:1px solid var(--line-strong);border-radius:22px;padding:12px;background:var(--surface);box-shadow:0 10px 26px #2f312d0b}.screenshot-button{position:relative;display:block;width:100%;border:0;border-radius:16px;padding:0;background:transparent;cursor:zoom-in}.screenshot-button:focus-visible{outline:3px solid var(--primary);outline-offset:4px}.screenshot-button img{display:block;width:100%;aspect-ratio:9 / 16;border-radius:16px;object-fit:cover;background:var(--surface-muted);border:1px solid var(--line)}.zoom-hint{position:absolute;right:10px;bottom:10px;display:inline-flex;align-items:center;min-height:30px;border-radius:999px;padding:0 11px;background:#252820d1;color:#fff;font-size:.82rem;font-weight:850}.store-shot figcaption{padding:12px 4px 3px;color:var(--text);font-size:clamp(.9rem,1.1vw,1rem);font-weight:850;line-height:1.45;overflow-wrap:break-word;word-break:auto-phrase}.screenshot-dialog{width:min(430px,calc(100% - 28px));max-height:min(860px,calc(100dvh - 24px));overflow:auto;border:1px solid var(--line-strong);border-radius:24px;padding:16px;background:var(--surface);box-shadow:0 24px 70px #25282047}.screenshot-dialog[open]{position:fixed;inset:0;margin:auto}.screenshot-dialog::backdrop{background:#2528207a}.screenshot-dialog img{display:block;width:100%;max-height:calc(100dvh - 150px);border-radius:18px;object-fit:contain;background:var(--surface-muted)}.screenshot-dialog p{margin:12px 4px 0;color:var(--text);font-weight:850;text-align:center}.dialog-close{position:sticky;top:0;z-index:1;display:flex;align-items:center;justify-content:center;min-height:38px;margin:0 0 12px auto;border:1px solid var(--line-strong);border-radius:999px;padding:0 14px;background:#fff;color:var(--primary-dark);cursor:pointer;font:inherit;font-weight:850}.screenshot-placeholder{display:grid;place-items:center;min-height:220px;color:var(--muted);background:var(--surface-muted);font-weight:800}.final-cta{padding-bottom:22px}.final-cta-panel{grid-template-columns:1fr;justify-items:center;text-align:center;background:#edf6e8eb}.final-cta-panel h2{max-width:760px;color:var(--primary-dark)}.final-cta-panel .button.secondary{min-height:44px;color:var(--muted);box-shadow:none}.page-hero{padding:54px 0 24px}.page-hero h1{font-size:clamp(2.1rem,8vw,4.2rem)}.page-hero p:last-child{max-width:720px;color:var(--muted);font-weight:600}.legal-content,.support-panel{max-width:840px;padding:24px}.legal-content h2,.support-panel h2{margin:26px 0 8px;font-size:1.25rem}.legal-content h2:first-child,.support-panel h2:first-child{margin-top:0}.legal-content p,.legal-content li,.support-panel p{color:var(--muted);font-size:1rem;font-weight:600}.updated{margin-top:0;color:var(--primary-dark);font-weight:800}.compact{margin-top:16px}.small-link{margin:16px 0 0}.site-footer{position:relative;z-index:1;display:grid;gap:16px;width:min(1160px,calc(100% - 36px));margin:28px auto 20px;padding:26px 0 8px;border-top:1px solid var(--line-strong)}.footer-name,.copyright{margin:0;font-weight:850}.footer-name{color:var(--text);font-size:1.08rem}.footer-copy,.copyright{color:var(--muted)}.footer-copy{margin:4px 0 0;font-size:.98rem}@media(max-width:980px){.hero,.privacy-panel{grid-template-columns:1fr}.hero,.hero-visual{min-height:auto}.feature-grid-wide,.problem-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:820px){.feature-grid,.step-grid{grid-template-columns:1fr}.screenshot-row{grid-template-columns:repeat(2,minmax(230px,1fr))}.ecorashi-guide{grid-template-columns:1fr}.ecorashi-portrait{width:min(260px,100%);margin:0 auto}}@media(max-width:768px){main{padding-right:14px;padding-left:14px;padding-bottom:34px}.site-header{position:relative;top:auto;gap:8px;width:min(100% - 20px,1160px);margin-top:8px;padding:8px 10px;border-radius:14px;box-shadow:0 6px 16px #2f312d0b}.brand{gap:7px;font-size:.9rem;white-space:nowrap}.brand-mark{width:34px;height:34px;border-radius:10px}.header-nav{gap:3px;margin-left:auto;font-size:.78rem;white-space:nowrap}.header-nav a{min-height:28px;padding:0 6px}.hero{gap:24px;padding:28px 0 34px}.app-title-row{gap:10px;margin-bottom:12px}.app-icon{width:50px;height:50px;border-radius:14px}.eyebrow{font-size:.84rem}.app-title-row .eyebrow,.section-heading .eyebrow,.speech-bubble .eyebrow,.final-cta-panel .eyebrow{min-height:28px;padding:0 10px}h1{font-size:clamp(2.6rem,11vw,3.35rem);line-height:1.04}h2{font-size:clamp(1.72rem,7.4vw,2.08rem);line-height:1.3}h3{font-size:1.02rem}.lead{margin:16px 0 8px;font-size:clamp(1.14rem,5.2vw,1.36rem);line-height:1.45}.body-text{font-size:.98rem;line-height:1.75}.hero-actions{gap:9px;margin-top:22px}.button{min-height:44px;padding:0 16px;font-size:.92rem}.hero-visual{margin-top:0}.phone-mock{width:min(302px,86vw);border-radius:31px;padding:10px;box-shadow:0 14px 34px #2f312d24}.phone-speaker{width:56px;height:5px;margin-bottom:8px}.phone-screen-shot{border-radius:22px}.phone-screen-shot img{min-height:0}.section{padding:36px 0}.section-heading{margin-bottom:18px}.section-heading p{font-size:.96rem;line-height:1.7}.problem-section,.how-section{border-radius:20px;padding-right:14px;padding-left:14px}.problem-grid,.feature-grid,.feature-grid-wide,.step-grid{grid-template-columns:1fr;gap:12px}.feature-card,.problem-card,.step-card{border-radius:16px;padding:15px}.problem-card{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px}.problem-card span,.step-number{min-height:25px;margin-bottom:0;padding:0 9px;font-size:.78rem}.problem-card h3{font-size:.98rem;line-height:1.45}.feature-mark{min-height:28px;margin-bottom:10px;font-size:.8rem}.feature-card p,.problem-card p,.step-card p{font-size:.94rem;line-height:1.68}.step-card{justify-items:center;text-align:left}.step-card h3,.step-card p,.step-card .step-number{justify-self:stretch}.step-image{width:min(230px,76vw);margin-bottom:16px;border-radius:26px;padding:18px 8px 8px}.step-image img{border-radius:18px}.ecorashi-section{padding-top:36px;padding-bottom:36px}.ecorashi-guide{gap:16px}.ecorashi-portrait{min-height:190px;border-radius:24px}.ecorashi-portrait img{width:min(200px,92%);height:min(200px,92%)}.speech-bubble{border-radius:18px;padding:18px}.speech-bubble p:last-child,.privacy-copy p{font-size:.96rem}.privacy-panel,.final-cta-panel{gap:16px;border-radius:20px;padding:18px}.privacy-copy a{min-height:36px;padding:0 12px;font-size:.92rem}.screenshot-row{grid-template-columns:1fr;justify-items:center;gap:14px;overflow-x:visible}.store-shot{width:min(300px,86vw);min-width:0;border-radius:18px;padding:10px}.store-shot figcaption{font-size:.94rem;padding-top:10px}.final-cta{padding-bottom:12px}.final-cta-panel .hero-actions{justify-content:center}.site-footer{gap:12px;width:calc(100% - 28px);margin-top:12px;padding-top:20px}.footer-nav{gap:4px;font-size:.9rem}.footer-nav a{min-height:30px;padding:0 8px}}@media(max-width:620px){body:before{background:linear-gradient(#f7f4eca3,#f7f4ecc7),url(/images/decorations/leaf-bg.png) center top / auto 100vh no-repeat,var(--bg)}main{padding-right:14px;padding-left:14px}.site-header{align-items:center}.header-nav{width:auto;justify-content:flex-end}.hero{padding-top:24px}.app-title-row{align-items:center;flex-direction:row}.phone-mock{width:min(286px,84vw)}.phone-screen-shot,.phone-screen-shot img{min-height:0}.problem-section,.how-section{padding-right:14px;padding-left:14px}.problem-grid,.feature-grid-wide,.screenshot-row{grid-template-columns:1fr}.screenshot-dialog{width:calc(100% - 18px);max-width:none;max-height:calc(100dvh - 18px);border-radius:20px;padding:12px}.screenshot-dialog img{max-height:calc(100dvh - 124px);border-radius:14px}.legal-content,.support-panel{padding:18px}}@media(max-width:390px){.site-header{width:calc(100% - 14px);padding:7px 8px}.brand{font-size:.84rem}.brand-mark{width:30px;height:30px;border-radius:9px}.header-nav{gap:1px;font-size:.72rem}.header-nav a{min-height:26px;padding:0 5px}h1{font-size:2.48rem}h2{font-size:1.58rem}.button,.hero-actions{width:100%}.phone-mock{width:min(268px,82vw)}}
