*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Noto Sans JP','Meiryo UI',sans-serif;color:#1e293b;background:#fafdf8;line-height:1.75;-webkit-font-smoothing:antialiased;overflow-x:hidden;max-width:480px;margin:0 auto}
img{max-width:100%;display:block}a{text-decoration:none;color:inherit}button{border:none;cursor:pointer;font-family:inherit;background:none}
:root{--g:#22c55e;--g2:#16a34a;--g3:#15803d;--gl:#dcfce7;--gbg:#f0fdf4;--t1:#1e293b;--t2:#475569;--t3:#94a3b8;--fe:'Outfit',sans-serif;--fh:'Noto Sans JP',sans-serif}
.ctn{padding:0 20px}

@keyframes up{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}
@keyframes glow{0%,100%{filter:drop-shadow(0 4px 16px rgba(34,197,94,.2))}50%{filter:drop-shadow(0 4px 28px rgba(34,197,94,.5))}}
@keyframes shimmer{0%{left:-100%}100%{left:100%}}
.ao{opacity:0;transform:translateY(32px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}.ao.v{opacity:1;transform:none}

/* CTA */
.cta-img{width:100%;max-width:320px;display:block;margin:0 auto;animation:glow 3s ease-in-out infinite;cursor:pointer;transition:transform .15s}
.cta-img:active{transform:scale(.97)}
.cta-orange{max-width:260px;animation:none;filter:drop-shadow(0 4px 16px rgba(245,158,11,.3))}

/* 固定CTA */
.sticky{position:fixed;bottom:0;left:0;right:0;z-index:100;padding:10px 16px;transform:translateY(100%);transition:transform .45s ease}
.sticky.on{transform:translateY(0)}
.sticky-in{max-width:340px;margin:0 auto;background:rgba(255,255,255,.92);backdrop-filter:blur(24px);border-radius:60px;padding:4px;box-shadow:0 -2px 24px rgba(0,0,0,.08)}
.sticky-btn{display:block;width:100%;cursor:pointer}.sticky-cta-img{width:100%;border-radius:54px}

/* 全セクション共通 — PNG丸ごと＋CTAオーバーレイ */
.sec{position:relative}
.sec-img{width:100%;display:block}
.sec-cta{position:absolute;left:0;right:0;padding:0 24px;z-index:2}
.str-sec .sec-img{margin-bottom:-60px}
.str-cta-below{padding:0 24px 20px;background:transparent;position:relative;z-index:2}
.ctc-sec{padding-bottom:0;background:#e6e6f0}

/* ================================================================
   SERVICE / PRICING — ヘッダーPNG＋スワイプHTML＋フッターPNG
   ================================================================ */
.sec-split{overflow:visible}
.sec-split .sec-img{width:100%;display:block}

/* スワイプ共通 */
.swipe-area{padding:16px 0 20px}
.swipe-track{display:flex;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;gap:14px;padding:16px 20px 16px;scrollbar-width:none}
.swipe-track::-webkit-scrollbar{display:none}
.swipe-dots{display:flex;justify-content:center;gap:5px;padding:8px 0 4px}
.dot{width:6px;height:6px;border-radius:50%;background:#d1d5db;transition:all .3s}.dot.on{background:var(--g);width:18px;border-radius:3px}

/* タブオーバーレイ（PNG上の透明クリック領域） */
.svc-top-wrap{position:relative}
.svc-tab-overlay{position:absolute;bottom:0;left:0;right:0;height:17%;display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:4px;padding:0 5% 1% 5%;z-index:3}
.svc-tab-btn{background:transparent;border:none;cursor:pointer;border-radius:30px}

/* SERVICE背景 — カードエリアは白→楕円の薄黄色に遷移 */
.svc-bg{background:linear-gradient(180deg,#fff 85%,#ffffe3)}

/* SERVICEカード */
.sd{flex:0 0 88%;max-width:380px;scroll-snap-align:center}
.sd-img{width:100%;display:block;border-radius:20px}
.sd-card{display:flex;border-radius:20px;overflow:hidden;border:2.5px solid;min-height:240px}
.sd-left{flex:0 0 40%;display:flex;align-items:center;justify-content:center;padding:10px 6px 10px 10px}
.sd-left img{width:100%;border-radius:18px;box-shadow:0 4px 14px rgba(0,0,0,.08)}
.sd-right{flex:1;padding:16px 14px 16px 6px;display:flex;flex-direction:column;justify-content:center}
.sd-ic{width:32px;height:32px;object-fit:contain;margin-bottom:5px}
.sd-right h4{font-family:var(--fh);font-size:.9rem;font-weight:900;margin-bottom:7px;color:var(--t1)}
.sd-right ul{list-style:none;display:flex;flex-direction:column;gap:5px}
.sd-right li{font-size:.7rem;color:var(--t2);line-height:1.5;padding-left:14px;position:relative}
.sd-right li::before{content:'●';position:absolute;left:0;color:var(--g);font-size:.38rem;top:5px}
.sdc-green{border-color:#22c55e;background:linear-gradient(135deg,#f0fdf4,#fff)}
.sdc-yellow{border-color:#f59e0b;background:linear-gradient(135deg,#fffbeb,#fff)}
.sdc-blue{border-color:#3b82f6;background:linear-gradient(135deg,#eff6ff,#fff)}
.sdc-purple{border-color:#8b5cf6;background:linear-gradient(135deg,#faf5ff,#fff)}
.sdc-teal{border-color:#06b6d4;background:linear-gradient(135deg,#ecfeff,#fff)}

/* PRICINGトグルオーバーレイ */
.prc-top-wrap{position:relative}
.prc-toggle-overlay{position:absolute;bottom:0;left:0;right:0;height:21%;display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 12% 1%;z-index:3}
.prc-toggle-btn{background:transparent;border:none;cursor:pointer;border-radius:50px}

/* PRICING背景 — カードエリアは白 */
.prc-bg{background:#fff}
.prc-bg .swipe-track{padding-top:24px}

/* PRICINGカード */
.pc{flex:0 0 86%;max-width:340px;scroll-snap-align:center;background:#fff;border:2px solid #e2e8f0;border-radius:20px;padding:26px 20px;position:relative;box-shadow:0 4px 18px rgba(0,0,0,.04);text-align:center}
.pc-img{background:transparent;border:none;padding:0;box-shadow:none}
.pc-img img{width:100%;display:block;border-radius:20px}
.pc.rec{border-color:var(--g);box-shadow:0 6px 28px rgba(34,197,94,.1)}
.pc-free{position:absolute;top:-18px;left:-6px;width:62px;height:62px;background:linear-gradient(145deg,#fde047,#d4a017,#fbbf24);color:#fff;font-size:.7rem;font-weight:900;border-radius:50%;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.15;box-shadow:0 4px 14px rgba(212,160,23,.35);z-index:2;overflow:hidden}
.pc-free::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 3s infinite}
.pc-badge{position:absolute;top:-13px;right:14px;background:linear-gradient(135deg,#f97316,#fb923c);color:#fff;font-size:.6rem;font-weight:800;padding:4px 13px;border-radius:50px}
.pc-name{font-family:var(--fh);font-size:1rem;font-weight:900;margin-bottom:2px}
.pc-for{font-size:.68rem;color:var(--t3);margin-bottom:12px;line-height:1.5}
.pc-price{display:flex;align-items:baseline;justify-content:center;gap:3px;padding:12px 16px;border-radius:12px;margin-bottom:16px;background:linear-gradient(135deg,var(--gl),#b9f4d0)}
.pc-price-b{background:linear-gradient(135deg,#eff6ff,#dbeafe)}
.pc-num{font-family:var(--fe);font-size:2rem;font-weight:900;line-height:1}
.pc-yen{font-size:.78rem;font-weight:600;color:var(--t2)}.pc-yen small{font-size:.56rem;color:var(--t3)}
.pc-feats{display:flex;flex-direction:column;gap:7px;margin-bottom:18px;text-align:left}
.pf{display:flex;align-items:center;gap:7px;font-size:.76rem;font-weight:500}
.pf-c{width:18px;height:18px;background:var(--g);color:#fff;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:900;flex-shrink:0}
.pf-s{width:18px;height:18px;background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;border-radius:4px;display:inline-flex;align-items:center;justify-content:center;font-size:.58rem;flex-shrink:0}
.cta-sm{max-width:260px}

/* FOOTER */
.ftr{padding:30px 0;background:#6b7280;text-align:center}
.ftr-name{font-family:var(--fe);font-size:1.05rem;font-weight:800;color:#fff;margin-bottom:14px}
.ftr-links{display:flex;justify-content:center;gap:22px;margin-bottom:14px}
.ftr-links a{font-size:.68rem;color:rgba(255,255,255,.55);font-weight:500}.ftr-links a:hover{color:rgba(255,255,255,.85)}
.ftr-copy{font-size:.52rem;color:rgba(255,255,255,.28);line-height:2}

/* DEMO MODAL */
.demo-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:300;align-items:center;justify-content:center;padding:16px}.demo-overlay.open{display:flex}
.demo-content{background:#fff;border-radius:20px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;padding:24px 20px;position:relative;animation:up .35s ease}
.demo-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:#f1f5f9;font-size:1.2rem;color:var(--t2);display:flex;align-items:center;justify-content:center;z-index:2}
.demo-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.demo-cat{font-size:.72rem;font-weight:800;padding:4px 12px;border-radius:20px;color:#fff}
.demo-cat.cat-store{background:var(--g)}.demo-cat.cat-follow{background:#3b82f6}.demo-cat.cat-reserve{background:#f59e0b}.demo-cat.cat-revisit{background:#ec4899}.demo-cat.cat-chase{background:#8b5cf6}.demo-cat.cat-done{background:var(--g2)}
.demo-who-badge{font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:20px}
.demo-who-badge.who-customer{background:var(--gl);color:var(--g3)}.demo-who-badge.who-staff{background:#dbeafe;color:#1d4ed8}.demo-who-badge.who-auto{background:#f3e8ff;color:#7c3aed}
.demo-step-num{font-family:var(--fe);font-size:.7rem;color:var(--t3);margin-bottom:10px}
.demo-screen-wrap{text-align:center;margin-bottom:14px;min-height:200px;display:flex;align-items:center;justify-content:center}
.demo-screen{max-height:380px;max-width:100%;width:auto;border-radius:16px;box-shadow:0 4px 20px rgba(0,0,0,.1)}
.demo-comment{font-size:.88rem;color:var(--t1);line-height:1.8;padding:14px 16px;background:var(--gbg);border-radius:12px;border-left:3px solid var(--g);margin-bottom:16px}
.demo-nav{display:flex;align-items:center;justify-content:space-between;gap:8px}
.demo-prev,.demo-next{font-size:.78rem;font-weight:700;color:var(--g2);border:1.5px solid var(--gl);border-radius:10px;padding:8px 16px;white-space:nowrap;transition:all .2s}
.demo-prev:hover,.demo-next:hover{background:var(--gbg)}.demo-prev:disabled,.demo-next:disabled{opacity:.3;cursor:default}
.demo-next.demo-cta{background:var(--g);color:#fff;border-color:var(--g)}
.demo-dots{display:flex;gap:3px;justify-content:center;flex-wrap:wrap;max-width:180px}
.demo-dot{width:6px;height:6px;border-radius:50%;background:#d1d5db;transition:all .25s;flex-shrink:0}.demo-dot.on{background:var(--g);width:14px;border-radius:3px}.demo-dot.done{background:var(--gl)}
.demo-final{text-align:center;padding:20px 0}.demo-final-logo{height:36px;margin:0 auto 16px}
.demo-final p{font-size:.82rem;color:var(--t2);line-height:1.7;margin-bottom:16px}
.demo-screen-duo{display:flex;gap:12px;justify-content:center;align-items:flex-end}
.demo-screen-duo .demo-illust{max-height:240px;border-radius:0;box-shadow:none}
.modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:200;align-items:center;justify-content:center;padding:16px}.modal-overlay.open{display:flex}
.modal-content{background:#fff;border-radius:16px;max-width:480px;width:100%;max-height:85vh;display:flex;flex-direction:column;position:relative;animation:up .3s ease}
.modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:#f1f5f9;font-size:1.3rem;color:var(--t2);display:flex;align-items:center;justify-content:center;z-index:1}
.modal-body{overflow-y:auto;padding:32px 20px 28px;-webkit-overflow-scrolling:touch}
.modal-body h2{font-size:1.1rem;font-weight:900;margin-bottom:16px;color:var(--t1);padding-right:30px}
.modal-body h3{font-size:.88rem;font-weight:800;margin:20px 0 8px;color:var(--t1)}
.modal-body p,.modal-body li{font-size:.74rem;line-height:1.85;color:var(--t2)}
.modal-body ul{padding-left:18px;margin-bottom:8px}
.modal-body table{width:100%;border-collapse:collapse;margin:10px 0;font-size:.7rem}
.modal-body th,.modal-body td{border:1px solid #e2e8f0;padding:8px 10px;text-align:left;line-height:1.6}
.modal-body th{background:#f8fafc;font-weight:700;color:var(--t1)}.modal-body td{color:var(--t2)}
