/* ===== minpaku eSIM — AIRALO-leaning variant (warm cream + orange accent + sky-blue secondary) ===== */
:root{
  /* "blue" スロット = スカイブルー（サブ・装飾） */
  --blue:#3aa6bd; --blue-d:#2b8a9e; --blue-100:#e7f5f8; --blue-50:#f3fafc;
  /* "coral" スロット = Airaloオレンジ（プライマリ・CTA） */
  --coral:#ff8832; --coral-d:#ef6f12; --coral-50:#fff2e6;
  --ink:#14181f; --ink-2:#4a525c; --ink-3:#5e6a78; --line:#ece8e3;
  --bg:#ffffff; --bg-soft:#faf5f2; --cream:#fff7f0; --ok:#17b06b;
  --radius:20px; --radius-s:14px; --shadow:0 12px 32px rgba(60,40,20,.08);
  --shadow-lg:0 24px 56px rgba(60,40,20,.12); --maxw:1180px;
  --font:"Plus Jakarta Sans","Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic",sans-serif;
  --display:"Plus Jakarta Sans","Hiragino Kaku Gothic ProN",sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.65;-webkit-font-smoothing:antialiased;font-size:16px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.ic-svg{flex:none;vertical-align:middle}
section{position:relative}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line)}
.nav .row{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{display:flex;align-items:center;gap:10px}
.brand .logo{width:36px;height:36px;border-radius:11px;display:block}
.brand .wm{font-family:var(--display);font-weight:700;letter-spacing:-.01em;font-size:19px;color:var(--ink)}
.brand .wm b{color:var(--blue);font-weight:700}
.nav nav{display:flex;gap:30px;align-items:center}
.nav nav a{font-size:14.5px;color:var(--ink-2);font-weight:500}
.nav nav a:hover,.nav nav a.on{color:var(--blue)}
.nav .tools{display:flex;gap:12px;align-items:center}
.langsel{display:inline-flex;align-items:center;gap:6px;border:1.5px solid var(--line);border-radius:999px;padding:7px 11px 7px 13px;color:var(--ink-3);background:#fff}
.langsel select{border:none;background:transparent;font-family:inherit;font-size:13.5px;font-weight:700;color:var(--ink);cursor:pointer;outline:none}
.cart-btn{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:700;border:1.5px solid var(--line);padding:9px 16px;border-radius:999px;color:var(--ink)}
.cart-btn svg{color:var(--coral)}
.burger{display:none}

/* buttons — primary = coral */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:600;font-size:15px;padding:14px 26px;border-radius:999px;cursor:pointer;border:2px solid transparent;transition:.18s}
.btn.primary{background:var(--coral);color:#fff;box-shadow:0 10px 24px rgba(255,107,94,.34)}
.btn.primary:hover{background:var(--coral-d);transform:translateY(-2px)}
.btn.ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.btn.ghost:hover{border-color:var(--blue);color:var(--blue)}
.btn.blue{background:var(--blue);color:#fff;box-shadow:0 10px 24px rgba(47,107,255,.3)}
.btn.blue:hover{background:var(--blue-d);transform:translateY(-2px)}
.btn.block{width:100%;justify-content:center}

/* hero (illustration, no photo) */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,#fff3e8 0%,#faf5f2 60%,#fff 100%)}
.hero .blob{position:absolute;border-radius:50%;filter:blur(2px);opacity:.5;z-index:0}
.hero .b1{width:420px;height:420px;background:#ffe6cf;top:-120px;right:-80px}
.hero .b2{width:300px;height:300px;background:#e7f5f8;bottom:-120px;left:-60px;opacity:.7}
.hero .inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:70px 24px 96px;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--blue-d);background:var(--blue-100);padding:8px 15px;border-radius:999px}
.hero h1{font-family:var(--display);font-size:52px;line-height:1.12;font-weight:700;letter-spacing:-.02em;margin:20px 0 0;color:var(--ink)}
.hero h1 em{font-style:normal;color:var(--coral)}
.hero p.lead{font-size:18px;color:var(--ink-2);margin-top:18px;max-width:480px}
.hero .cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.hero .trust{display:flex;gap:22px;margin-top:34px;flex-wrap:wrap}
.hero .trust .t{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink-2);font-weight:600}
.hero .trust .t svg{color:var(--blue)}
.hero .art{position:relative;display:flex;justify-content:center;align-items:center}
.hero .art img,.hero .art svg{width:100%;max-width:520px;height:auto;filter:drop-shadow(0 24px 48px rgba(28,42,80,.16))}

/* quick picker */
.picker{position:relative;z-index:5;margin:-44px auto 0;max-width:940px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:22px;display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:14px;align-items:end}
.picker .f label{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--ink-3);margin-bottom:8px}
.picker .f label svg{color:var(--coral)}
.picker select{width:100%;padding:14px;border:1.5px solid var(--line);border-radius:14px;font-size:15px;font-family:inherit;background:#fff;color:var(--ink);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237b8499' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}

/* section heads */
.sec{padding:84px 0}
.sec.soft{background:var(--bg-soft)}
.sec.cream{background:var(--cream)}
.kicker{font-family:var(--display);font-size:13px;font-weight:700;letter-spacing:.06em;color:var(--coral);text-transform:uppercase}
.sec h2,.page-hero h1{font-family:var(--display)}
.sec h2{font-size:36px;font-weight:700;letter-spacing:-.02em;margin:10px 0 0;color:var(--ink)}
.sec .sub{color:var(--ink-3);font-size:17px;margin-top:12px;max-width:560px}
.head-row{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:38px}
/* 案内キャラ挿絵（見出し横の小さなアクセント） */
.head-illust{height:150px;width:auto;flex:none;align-self:flex-end;pointer-events:none}
.head-lead{display:flex;align-items:flex-end;gap:18px}
@media(max-width:820px){.head-illust{display:none}}

/* plan card — rounded, friendly */
.grid{display:grid;gap:22px}
.grid.c3{grid-template-columns:repeat(3,1fr)}
.grid.c4{grid-template-columns:repeat(4,1fr)}
.pcard{background:#fff;border:1.5px solid var(--line);border-radius:var(--radius);padding:24px;transition:.2s;display:flex;flex-direction:column;position:relative;overflow:hidden}
.pcard:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:#f3d9bf}
.pcard .top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.badge{font-size:11px;font-weight:800;letter-spacing:.03em;padding:6px 12px;border-radius:999px;display:inline-flex;align-items:center;gap:5px}
/* タイプ→色: 完全無制限=オレンジ / 速度制限=スカイブルー / 容量=グリーン（UI全体で統一） */
.badge.unlim{background:#fff1e3;color:#d9660f}
.badge.capped{background:#e7f5f8;color:#2b8a9e}
.badge.fixed{background:#e6f7ee;color:#0e8a4d}
.pcard .days{font-family:var(--display);font-size:42px;font-weight:800;letter-spacing:-.02em;line-height:1;color:var(--ink)}
.pcard .days small{font-size:16px;font-weight:600;color:var(--ink-3);margin-left:4px}
.pcard .ttl{font-size:16px;font-weight:700;margin-top:7px}
.pcard .specs{margin-top:16px;border-top:1.5px dashed var(--line);padding-top:15px;display:flex;flex-direction:column;gap:9px}
.pcard .specs .s{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--ink-2)}
.pcard .specs .s svg{color:var(--coral)}
.pcard .price{margin-top:18px;display:flex;align-items:baseline;gap:5px}
.pcard .price b{font-family:var(--display);font-size:27px;font-weight:700;letter-spacing:-.01em}
.pcard .price .yen{font-size:15px;font-weight:700}
.pcard .price .per{font-size:12px;color:var(--ink-3)}
.pcard .cta{margin-top:16px}
.ribbon{position:absolute;top:16px;right:-32px;transform:rotate(45deg);background:var(--coral);color:#fff;font-size:10px;font-weight:800;letter-spacing:.06em;padding:5px 36px}

/* trust logos */
.logos{display:flex;gap:40px;align-items:center;justify-content:center;flex-wrap:wrap}
.logos .l{font-weight:700;color:var(--ink-3);font-size:15px;display:flex;align-items:center;gap:9px}
.logos .l svg{color:var(--blue)}

/* steps with illustrated number bubbles */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;counter-reset:s}
.step{background:#fff;border:1.5px solid var(--line);border-radius:var(--radius);padding:30px;text-align:center}
.step .il{width:96px;height:96px;margin:0 auto 18px}
.step h3{font-family:var(--display);font-size:18px;font-weight:600;margin-bottom:8px}
.step p{font-size:14.5px;color:var(--ink-3)}

/* feature split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split .media{border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;background:linear-gradient(135deg,#fff0e3,#fff1ef);display:flex;align-items:center;justify-content:center;padding:36px}
.split .media svg,.split .media img{width:100%;max-width:360px;height:auto}
.flist{display:flex;flex-direction:column;gap:18px;margin-top:24px}
.flist .f{display:flex;gap:14px}
.flist .f .ic{flex:none;width:46px;height:46px;border-radius:14px;background:var(--coral-50);color:var(--coral);display:grid;place-items:center}
.flist .f .ic svg{color:var(--coral)}
.flist .f h3{font-family:var(--display);font-size:16px;font-weight:600}
.flist .f p{font-size:14px;color:var(--ink-3)}

/* blog cards */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.bcard{border:1.5px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;transition:.2s;display:flex;flex-direction:column}
.bcard:hover{box-shadow:var(--shadow);transform:translateY(-4px);border-color:#f3d9bf}
.bcard .thumb{aspect-ratio:16/9;background:linear-gradient(135deg,#ffe6cf,#fff1ef);position:relative;overflow:hidden}
.bcard .thumb img{width:100%;height:100%;object-fit:cover}
.bcard .tag{position:absolute;top:13px;left:13px;background:#fff;color:var(--coral-d);font-size:11px;font-weight:800;padding:5px 11px;border-radius:999px}
.bcard .body{padding:20px;display:flex;flex-direction:column;gap:9px;flex:1}
.bcard h3{font-family:var(--display);font-size:16.5px;font-weight:600;line-height:1.4}
.bcard .meta{margin-top:auto;font-size:12.5px;color:var(--ink-3);display:flex;align-items:center;gap:7px}
.bcard .meta svg{color:var(--ink-3)}

/* filters */
.filters{position:sticky;top:70px;z-index:40;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:16px 0}
.filters .row{display:flex;gap:22px;align-items:center;flex-wrap:wrap}
.tabs{display:inline-flex;background:var(--bg-soft);border:1.5px solid var(--line);border-radius:999px;padding:5px}
.tabs button{border:none;background:transparent;padding:9px 17px;border-radius:999px;font-family:var(--display);font-size:13.5px;font-weight:600;color:var(--ink-3);cursor:pointer;white-space:nowrap}
.tabs button.on{background:var(--coral);color:#fff}
.fgroup{display:flex;align-items:center;gap:10px}
.fgroup label{font-size:12.5px;font-weight:700;color:var(--ink-3)}
.fgroup select{padding:10px 13px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:13.5px;background:#fff;cursor:pointer}
.count{margin-left:auto;font-size:13.5px;color:var(--ink-3);font-weight:600}

/* page hero / docs */
.page-hero{background:var(--bg-soft);border-bottom:1px solid var(--line);padding:48px 0 36px}
.page-hero .kicker{margin-bottom:8px}
.page-hero h1{font-size:34px;font-weight:700;letter-spacing:-.02em}
.doc{max-width:760px;margin:0 auto;padding:54px 24px 90px}
.doc h2{font-family:var(--display);font-size:22px;font-weight:600;margin:34px 0 12px}
.doc h2:first-child{margin-top:0}
.doc p,.doc li{font-size:15.5px;color:var(--ink-2);line-height:1.85;margin-bottom:12px}
.doc ul{padding-left:22px;margin-bottom:14px}.doc .updated{font-size:13px;color:var(--ink-3);margin-bottom:30px}
.doc table.kv{width:100%;border-collapse:collapse;margin:6px 0 18px}
.doc table.kv td{border:1px solid var(--line);padding:12px 15px;font-size:14.5px;vertical-align:top}
.doc table.kv td:first-child{background:var(--bg-soft);font-weight:700;white-space:nowrap;width:34%;color:var(--ink);border-radius:0}

/* faq */
.faq details{border-bottom:1.5px solid var(--line);padding:16px 0}
.faq summary{font-family:var(--display);font-weight:600;font-size:15.5px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--coral);font-weight:800;font-size:20px;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq p{font-size:14.5px;color:var(--ink-3);margin-top:12px}

/* detail */
.detail{padding:48px 0 84px}
.crumbs{font-size:13px;color:var(--ink-3);margin-bottom:24px}
.crumbs a:hover{color:var(--coral)}
.dwrap{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.visual{border-radius:var(--radius);overflow:hidden;background:url(/img/motif-signal.svg) center/cover no-repeat,linear-gradient(135deg,#ff8832,#ef6f12);color:#fff;padding:40px;min-height:340px;display:flex;flex-direction:column;justify-content:space-between;position:relative}
.visual.capped{background:url(/img/motif-signal.svg) center/cover no-repeat,linear-gradient(135deg,#3aa6bd,#2b8a9e)}
.visual.fixed{background:url(/img/motif-signal.svg) center/cover no-repeat,linear-gradient(135deg,#22b07d,#149c63)}
.visual .vtop{display:flex;justify-content:space-between;align-items:flex-start}
.visual .vbig{font-family:var(--display);font-size:74px;font-weight:800;letter-spacing:-.03em;line-height:.95}
.visual .vbig small{font-size:24px}
.visual .vmeta{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.visual .chip{background:rgba(255,255,255,.18);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.buybox{border:1.5px solid var(--line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow);position:sticky;top:90px}
.buybox .pr{display:flex;align-items:baseline;gap:6px}
.buybox .pr b{font-family:var(--display);font-size:38px;font-weight:700;letter-spacing:-.02em}
.buybox .pr .yen{font-size:20px;font-weight:700}
.buybox .specrow{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.buybox .specrow span:first-child{color:var(--ink-3)}.buybox .specrow b{font-weight:700}
.buybox .pay{display:flex;align-items:center;justify-content:center;gap:6px}
.incl{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.incl .i{display:flex;gap:9px;font-size:14px;color:var(--ink-2)}.incl .i .c{color:var(--ok)}

/* article */
.article{max-width:760px;margin:0 auto;padding:0 24px 90px}
.article .ahero{border-radius:var(--radius);overflow:hidden;aspect-ratio:16/9;margin:32px 0 28px;box-shadow:var(--shadow)}
.article .ahero img{width:100%;height:100%;object-fit:cover}
.article .ameta{display:flex;align-items:center;gap:12px;font-size:13.5px;color:var(--ink-3);margin-bottom:8px}
.article .acat{background:var(--coral-50);color:var(--coral-d);font-size:11px;font-weight:800;padding:5px 11px;border-radius:999px}
.article h1{font-family:var(--display);font-size:34px;font-weight:700;letter-spacing:-.02em;line-height:1.2}
.article .lead{font-size:18px;color:var(--ink-2);margin:18px 0 0;line-height:1.8}
.article h2{font-family:var(--display);font-size:22px;font-weight:600;margin:34px 0 12px}
.article p{font-size:16px;color:var(--ink-2);line-height:1.9;margin-bottom:16px}
.article ul{padding-left:22px;margin-bottom:16px}.article li{font-size:16px;color:var(--ink-2);line-height:1.8;margin-bottom:8px}
.article .callout{background:var(--coral-50);border-radius:var(--radius-s);padding:18px 22px;margin:22px 0;font-size:15px;color:var(--ink-2)}

/* cart */
.cartwrap{display:grid;grid-template-columns:1fr 360px;gap:36px;align-items:start;padding:48px 0 90px}
.citem{display:flex;gap:16px;border:1.5px solid var(--line);border-radius:var(--radius);padding:20px;margin-bottom:14px;align-items:center}
.citem .cv{width:84px;height:84px;border-radius:18px;background:url(/img/motif-signal.svg) center/cover no-repeat,linear-gradient(135deg,#ff8832,#ef6f12);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:none}
.citem .cv.capped{background:url(/img/motif-signal.svg) center/cover no-repeat,linear-gradient(135deg,#3aa6bd,#2b8a9e)}
.citem .cv.fixed{background:url(/img/motif-signal.svg) center/cover no-repeat,linear-gradient(135deg,#22b07d,#149c63)}
.citem .cv b{font-family:var(--display);font-size:24px;font-weight:700;line-height:1}.citem .cv small{font-size:11px;opacity:.85}
.citem .cmain{flex:1}.citem .cmain h3{font-family:var(--display);font-size:16px;font-weight:600}
.citem .cmain .meta{font-size:13px;color:var(--ink-3);margin-top:3px}
.citem .qty{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:999px;margin-top:8px}
.citem .qty button{width:32px;height:32px;border:none;background:#fff;cursor:pointer;color:var(--ink-2);font-size:16px;border-radius:999px}
.citem .qty span{padding:0 12px;font-weight:700;font-size:14px}
.citem .cprice{font-family:var(--display);font-weight:700;font-size:18px;text-align:right;white-space:nowrap}
.citem .rm{display:block;font-size:12px;color:var(--ink-3);margin-top:8px;cursor:pointer;text-align:right}
.summary{border:1.5px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);position:sticky;top:90px}
.summary h3{font-family:var(--display);font-size:17px;font-weight:600;margin-bottom:16px}
.summary .row{display:flex;justify-content:space-between;font-size:14.5px;padding:9px 0;color:var(--ink-2)}
.summary .row.total{border-top:1.5px solid var(--line);margin-top:8px;padding-top:14px;font-family:var(--display);font-size:19px;font-weight:700;color:var(--ink)}
.summary .coupon{display:flex;gap:8px;margin:14px 0}
.summary .coupon input{flex:1;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:14px}
.summary .coupon button{padding:12px 17px;border:1.5px solid var(--line);background:#fff;border-radius:12px;font-weight:700;font-size:13.5px;cursor:pointer}

/* destinations band */
.band{position:relative;overflow:hidden;background:linear-gradient(120deg,#ff8832,#ef6f12)}
.band .inner{position:relative;z-index:2;padding:64px 0;color:#fff}
.band h2{font-family:var(--display);font-size:34px;font-weight:700;letter-spacing:-.02em;max-width:520px}
.band p{font-size:17px;color:#fff0e0;margin:12px 0 24px;max-width:460px}
.band .deco{position:absolute;right:-40px;bottom:-40px;width:340px;opacity:.9;z-index:1}

/* footer — light & warm (Airalo風) */
.foot{background:#fbf4ec;color:var(--ink-2);padding:58px 0 30px;border-top:1px solid var(--line)}
.foot .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;padding-bottom:34px;border-bottom:1px solid var(--line)}
.foot h2,.foot h5{font-family:var(--display);color:var(--ink);font-size:13px;font-weight:700;letter-spacing:.04em;margin-bottom:14px;text-transform:uppercase}
.foot a{display:block;font-size:14px;color:var(--ink-2);margin-bottom:9px}.foot a:hover{color:var(--coral)}
.foot .brand .wm{color:var(--ink)}.foot .brand .wm b{color:var(--coral)}
.foot-brand{margin-bottom:12px}.foot .ftag{font-size:14px;max-width:280px;color:var(--ink-3)}
.foot .copy{padding-top:22px;font-size:12.5px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--ink-3)}

.proto-tag{position:fixed;bottom:16px;left:16px;z-index:99;background:var(--ink);color:#fff;font-size:11px;font-weight:700;padding:7px 13px;border-radius:999px;opacity:.85}

/* chatbot — coral */
.cbot{position:fixed;right:20px;bottom:20px;z-index:80}
.cbot .fab{width:60px;height:60px;border-radius:50%;background:var(--coral);color:#fff;border:none;cursor:pointer;box-shadow:0 12px 30px rgba(255,107,94,.45);display:grid;place-items:center;transition:.18s}
.cbot .fab:hover{background:var(--coral-d);transform:scale(1.06)}
.cbot .panel{position:absolute;right:0;bottom:76px;width:330px;background:#fff;border-radius:22px;box-shadow:var(--shadow-lg);overflow:hidden;display:none;border:1px solid var(--line)}
.cbot.open .panel{display:block}
.cbot .phead{background:var(--coral);color:#fff;padding:16px 18px;display:flex;align-items:center;gap:10px}
.cbot .phead .av{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.22);display:grid;place-items:center}
.cbot .phead b{font-family:var(--display);font-size:15px;display:block}.cbot .phead small{font-size:11.5px;opacity:.9}
.cbot .pbody{padding:16px;display:flex;flex-direction:column;gap:10px;max-height:300px;background:var(--bg-soft)}
.cbot .msg{font-size:13.5px;padding:11px 14px;border-radius:15px;max-width:85%;line-height:1.5}
.cbot .msg.bot{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px}
.cbot .msg.me{background:var(--coral);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.cbot .chips{display:flex;flex-wrap:wrap;gap:7px}
.cbot .chip{font-size:12px;border:1.5px solid #ffd4cf;color:var(--coral-d);background:#fff;border-radius:999px;padding:7px 12px;cursor:pointer}
.cbot .pfoot{padding:11px 14px;border-top:1px solid var(--line);font-size:12px;color:var(--ink-3);display:flex;align-items:center;gap:7px;background:#fff}

.mobile-nav{display:none}
@media(max-width:960px){
  .hero .inner{grid-template-columns:1fr;gap:8px;text-align:left}
  .hero .art{order:-1;max-width:380px;margin:0 auto}
  .hero h1{font-size:40px}
  .split{grid-template-columns:1fr;gap:30px}
  .grid.c4{grid-template-columns:1fr 1fr}.grid.c3{grid-template-columns:1fr 1fr}.steps{grid-template-columns:1fr}
  .picker{grid-template-columns:1fr 1fr}.picker .btn{grid-column:1/-1}
  .dwrap{grid-template-columns:1fr}.buybox{position:static}
  .cartwrap{grid-template-columns:1fr}.summary{position:static}
  .foot .top{grid-template-columns:1fr 1fr}.blog-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .hero h1{font-size:32px}.sec{padding:56px 0}.sec h2{font-size:27px}
  .grid.c4,.grid.c3,.blog-grid{grid-template-columns:1fr}.picker{grid-template-columns:1fr}
  .count{width:100%;margin-left:0}.foot .top{grid-template-columns:1fr 1fr}
}

/* people illustration cuts */
.step .ill{width:180px;height:180px;object-fit:contain;margin:0 auto 10px;display:block;mix-blend-mode:multiply}
.split .media img{mix-blend-mode:normal}
@media(max-width:600px){.step .ill{width:150px;height:150px}}

/* ============================================================
   CASUAL v2 — cuter, more distinct from premium (color blocks,
   stacked rounded panels, chunky buttons, sticker UI)
   ============================================================ */
:root{ --radius:30px; --radius-s:18px; --yellow:#ffc24b; --mint:#19c39a; }

/* chunky buttons with bounce */
.btn{padding:16px 30px;font-size:15.5px;font-weight:700;border-radius:999px}
.btn.primary{box-shadow:0 14px 28px rgba(255,107,94,.38)}
.btn.primary:hover{transform:translateY(-3px) scale(1.02)}
.btn.ghost{border-width:2px}

/* pastel color-blocked, stacked rounded panels */
.sec.mint{background:#e9faf3}
.sec.peach{background:#fff1ea}
.sec.lav{background:#f1edff}
.sec.butter{background:#fff7e2}
.sec.sky{background:#e9f3ff}
.sec.panel{border-radius:46px 46px 0 0;margin-top:-34px;padding-top:74px;position:relative;z-index:2}
.sec.panel + .sec.panel{margin-top:-46px}

/* kicker as sticker pill */
.kicker{display:inline-block;background:var(--coral-50);color:var(--coral-d);padding:6px 14px;border-radius:999px;text-transform:none;letter-spacing:.02em;font-size:12.5px}
.sec.mint .kicker{background:#d4f5e9;color:#0e8a63}
.sec.lav .kicker{background:#e6ddff;color:#6a3fd0}
.sec.butter .kicker{background:#ffe9b8;color:#b5791b}

/* bigger friendlier headings */
.hero h1{font-size:58px}
.sec h2{font-size:40px}

/* plan cards — chunkier, type-colored top accent via :has() */
.pcard{border:2px solid #eef0f7;border-radius:28px;padding-top:26px}
.pcard::before{content:"";position:absolute;top:0;left:0;right:0;height:7px;background:var(--coral)}
.pcard:has(.badge.unlim)::before{background:var(--blue)}
.pcard:has(.badge.capped)::before{background:var(--yellow)}
.pcard:has(.badge.fixed)::before{background:var(--mint)}
.pcard:hover{transform:translateY(-6px)}
.pcard .days{font-size:46px}
.badge{padding:7px 13px;font-size:11.5px}

/* sticker-y trust pills in hero */
.hero .trust .t{background:#fff;padding:9px 15px;border-radius:999px;box-shadow:0 6px 16px rgba(28,42,80,.08)}

/* how it works — mint panel, dotted connector, bigger people */
.steps{position:relative}
.steps::before{content:"";position:absolute;top:120px;left:16%;right:16%;height:3px;background-image:linear-gradient(90deg,#bfe9d8 0 60%,transparent 0);background-size:18px 3px;z-index:0}
.step{background:#fff;border:none;box-shadow:0 10px 30px rgba(28,42,80,.06);position:relative;z-index:1;border-radius:28px}
.step .ill{width:210px;height:210px}

/* feature media bubble */
.split .media{border-radius:40px}

/* blog cards rounder */
.bcard{border-radius:26px;border:2px solid #eef0f7}
.bcard:hover{transform:translateY(-6px)}

/* band — big rounded floating panel */
.band{border-radius:46px;max-width:1140px;margin:30px auto;overflow:hidden}
.band .inner{padding:72px 56px}

/* hero floating sticker tags */
.hero .art{position:relative}
.sticker{position:absolute;background:#fff;border-radius:16px;padding:10px 14px;font-family:var(--display);font-weight:700;font-size:13.5px;box-shadow:0 12px 26px rgba(28,42,80,.14);display:flex;align-items:center;gap:7px;z-index:3}
.sticker svg{flex:none}
.sticker.s1{top:6%;left:-4%;color:var(--blue)}
.sticker.s1 svg{color:var(--blue)}
.sticker.s2{top:42%;right:-6%;color:var(--coral)}
.sticker.s2 svg{color:var(--coral)}
.sticker.s3{bottom:6%;left:4%;color:#0e8a63}
.sticker.s3 svg{color:var(--mint)}
@media(max-width:960px){.sticker{display:none}.hero h1{font-size:42px}.steps::before{display:none}}
@media(max-width:600px){.hero h1{font-size:34px}.sec h2{font-size:28px}}

/* ============================================================
   CASUAL v2 — softer floating nav + friendly footer
   ============================================================ */
/* floating pill nav */
.nav{background:transparent;border:none;backdrop-filter:none;padding-top:14px}
.nav .row{background:#fff;border-radius:999px;height:62px;padding:0 14px 0 22px;box-shadow:0 10px 30px rgba(28,42,80,.10);border:1px solid #f0f2f8}
.nav nav a{font-weight:600;padding:8px 12px;border-radius:999px;transition:.15s}
.nav nav a:hover{background:var(--coral-50);color:var(--coral-d)}
.langsel{border-radius:999px;border-width:1.5px}
.cart-btn{background:var(--coral-50);border:1.5px solid #ffd9d3;color:var(--coral-d);font-weight:700}
.cart-btn svg{color:var(--coral)}
@media(max-width:600px){.nav .row{height:58px;padding:0 10px 0 16px}}

/* friendly footer */
.foot{background:#f4ece1;color:var(--ink-2);padding:0 0 30px;border-radius:46px 46px 0 0;margin-top:0;position:relative}
/* newsletter card overlapping the top */
.news{position:relative;margin-top:-96px;padding:0 24px;z-index:3}
.news-card{max-width:980px;margin:0 auto;background:linear-gradient(120deg,#ff8832,#ef6f12);border-radius:32px;padding:34px 40px;display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;box-shadow:0 22px 44px rgba(239,111,18,.26)}
.news-card h3{font-family:var(--display);color:#fff;font-size:23px;font-weight:800;letter-spacing:-.01em}
.news-card p{color:#ffe6cf;font-size:14px;margin-top:5px}
.news-form{display:flex;gap:10px;flex:1;min-width:280px;max-width:440px}
.news-form input{flex:1;border:none;border-radius:999px;padding:15px 20px;font-family:inherit;font-size:14.5px;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.news-form .btn{white-space:nowrap}
.foot-main{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px;padding-top:54px;padding-bottom:32px;border-bottom:1px solid var(--line)}
.foot h2,.foot h5{font-family:var(--display);color:var(--ink);font-size:13px;font-weight:700;letter-spacing:.04em;margin-bottom:14px}
.foot a{display:block;font-size:14px;color:var(--ink-2);margin-bottom:10px}.foot a:hover{color:var(--coral)}
.foot .brand .wm{color:var(--ink)}.foot .brand .wm b{color:var(--coral)}
.foot .ftag{font-size:14px;max-width:280px;color:var(--ink-3);margin:12px 0 16px}
.socs{display:flex;gap:10px}
.soc{width:38px;height:38px;border-radius:50%;background:rgba(20,24,31,.06);display:grid !important;place-items:center;color:var(--ink-3);margin:0 !important;transition:.15s}
.soc:hover{background:var(--coral);color:#fff;transform:translateY(-2px)}
.foot-copy{padding-top:22px;font-size:12.5px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--ink-3)}
@media(max-width:760px){.foot-main{grid-template-columns:1fr 1fr}.news-card{padding:26px 26px;text-align:center;justify-content:center}.news-form{max-width:none}}

/* フォント = Plus Jakarta Sans（上位のAiralo指定が後方overrideで潰れていたのを修正） */
:root{
  --font:"Plus Jakarta Sans","Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic",sans-serif;
  --display:"Plus Jakarta Sans","Hiragino Kaku Gothic ProN",sans-serif;
}
body{font-weight:500}
.hero h1{font-weight:800;letter-spacing:-.02em}
.sec h2{font-weight:700;letter-spacing:-.015em}
.btn{font-weight:600;letter-spacing:.01em}

/* hero dynamic "From ¥X" price (動的最安) */
.hero-price{display:inline-flex;align-items:baseline;gap:8px;margin-top:18px;background:#fff;border:1.5px solid var(--line);border-radius:999px;padding:9px 18px;box-shadow:0 8px 20px rgba(28,42,80,.07)}
.hero-price .hp-label{font-size:12.5px;font-weight:700;color:var(--ink-3)}
.hero-price .hp-amt{font-family:var(--display);font-size:24px;font-weight:700;color:var(--coral);letter-spacing:-.01em;line-height:1}
.hero-price .hp-yen{font-size:15px;font-weight:700}
.hero-price .hp-meta{font-size:12.5px;font-weight:600;color:var(--ink-3)}
@media(max-width:600px){.hero-price .hp-amt{font-size:21px}}

/* ===== モバイル崩れ修正パス ===== */
html,body{overflow-x:clip;max-width:100%}
@media(max-width:760px){
  /* プランのフィルタを画面追従させない＋窮屈さ解消 */
  .filters{position:static;backdrop-filter:none}
  .filters .row{flex-wrap:wrap;gap:12px}
  .tabs{max-width:100%;overflow-x:auto}
  .count{margin-left:0;width:auto}
  /* ニュースレター: SPはみ出し防止（入力＋ボタンを縦積み） */
  .news-form{flex-wrap:wrap;min-width:0}
  .news-form input{min-width:0;width:100%}
  .news-form .btn{width:100%;justify-content:center}
}
@media(max-width:600px){
  .hero h1{font-size:30px;overflow-wrap:break-word;word-break:normal}
  .hero .inner{padding:44px 20px 66px}
  .wrap{padding:0 18px}
  .dwrap,.cartwrap{gap:24px}
  .buybox,.summary,.visual{padding:24px}
}

/* ===== Award級モバイルナビ＆ハンバーガー ===== */
.nav-scrim,.mobile-nav{display:none}
@media(max-width:860px){
  /* 浮遊ピル→ソリッドな追従バー（安定・被り解消） */
  .nav{background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line);padding-top:0;z-index:60}
  .nav .row{background:transparent;box-shadow:none;border:none;border-radius:0;height:60px;padding:0 16px;gap:10px;position:relative;z-index:62}
  .brand{flex-shrink:0}
  .brand .wm{font-size:18px}
  .nav nav{display:none}        /* デスクトップリンク→メニューへ */
  .cart-btn{display:none}       /* カート→メニューへ */
  .tools{gap:8px;flex-shrink:0}
  .langsel{padding:7px 9px}
  /* 3本線ハンバーガー（X にモーフ） */
  .burger{display:inline-flex !important;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:44px;background:#fff;border:1.5px solid var(--line);border-radius:13px;cursor:pointer;padding:0;transition:border-color .2s}
  .burger span{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s cubic-bezier(.22,1,.36,1),opacity .2s}
  body.nav-open .burger{border-color:var(--coral)}
  body.nav-open .burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.nav-open .burger span:nth-child(2){opacity:0;transform:scaleX(.4)}
  body.nav-open .burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  /* 背景スクリム */
  .nav-scrim{display:block;position:fixed;inset:0;background:rgba(20,24,31,.34);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:opacity .32s ease,visibility .32s;z-index:55}
  body.nav-open .nav-scrim{opacity:1;visibility:visible}
  /* スライドダウン・メニュー */
  .mobile-nav{display:flex;position:fixed;top:0;left:0;right:0;flex-direction:column;gap:0;background:#fff;border-radius:0 0 28px 28px;padding:74px 22px 26px;box-shadow:0 30px 70px rgba(20,24,31,.2);transform:translateY(-102%);transition:transform .42s cubic-bezier(.22,1,.36,1);z-index:56}
  body.nav-open .mobile-nav{transform:translateY(0)}
  .mobile-nav a{padding:16px 6px;font-family:var(--display);font-size:19px;font-weight:700;color:var(--ink);border-bottom:1px solid var(--line);opacity:0;transform:translateY(-10px);transition:opacity .3s ease,transform .35s cubic-bezier(.22,1,.36,1),color .15s}
  .mobile-nav a:last-child{border-bottom:none}
  .mobile-nav a.on,.mobile-nav a:active{color:var(--coral)}
  body.nav-open .mobile-nav a{opacity:1;transform:translateY(0)}
  body.nav-open .mobile-nav a:nth-child(1){transition-delay:.06s}
  body.nav-open .mobile-nav a:nth-child(2){transition-delay:.10s}
  body.nav-open .mobile-nav a:nth-child(3){transition-delay:.14s}
  body.nav-open .mobile-nav a:nth-child(4){transition-delay:.18s}
  body.nav-open .mobile-nav a:nth-child(5){transition-delay:.22s}
  body.nav-open .mobile-nav a:nth-child(6){transition-delay:.26s}
}
/* ヒーロー: SPで画像をテキスト背面に回す（上に分離させない） */
@media(max-width:760px){
  .hero .inner{position:relative}
  .hero .art{order:0;position:absolute;inset:0;z-index:0;margin:0;max-width:none;opacity:.24;justify-content:center;align-items:flex-start;pointer-events:none}
  .hero .art img{width:126%;max-width:600px;filter:none}
  .hero .inner>div:first-child{position:relative;z-index:2}
}

/* ===== 微調整パス（KV / 特徴イラスト / SP 2カラム） ===== */
/* 特徴セクション: 足元をマスクでフェード消し（頭も要素も切らない・大きめOK） */
.sec.peach{position:relative;overflow:visible}
.split{align-items:center}
.split .feat-media{position:static;min-height:0;overflow:visible;aspect-ratio:auto;padding:0;display:flex;align-items:flex-end;justify-content:center}
.split .feat-media img{position:static;width:100%;max-width:560px;height:auto;display:block;-webkit-mask-image:linear-gradient(to bottom,#000 84%,transparent 100%);mask-image:linear-gradient(to bottom,#000 84%,transparent 100%)}
@media(max-width:760px){
  .split{gap:0}
  .split .feat-media{margin-top:-6px}
  .split .feat-media img{width:104%;max-width:540px}
}

/* ヒーロー(KV) SP: 背面イラストを下へ寄せる＋トラストpill縮小＋縦詰め */
@media(max-width:760px){
  .hero .art{align-items:flex-end;opacity:.22}
  .hero .art img{width:118%;max-width:560px}
}
@media(max-width:600px){
  .hero .inner{padding:30px 20px 40px}
  .hero h1{font-size:29px}
  .hero p.lead{font-size:15.5px;margin-top:12px}
  .hero .cta{margin-top:20px}
  .hero .trust{gap:8px;margin-top:16px;flex-wrap:wrap}
  .hero .trust .t{font-size:11px;padding:6px 9px;gap:5px}
  .hero .trust .t svg{width:13px;height:13px}
}

/* SP: プランカードを2カラム（商品が一覧で見える） */
@media(max-width:600px){
  .grid.c4,.grid.c3{grid-template-columns:1fr 1fr;gap:12px}
  .pcard{padding:15px;border-radius:18px}
  .pcard .days{font-size:32px}
  .pcard .days small{font-size:13px}
  .pcard .ttl{font-size:14px}
  .pcard .price b{font-size:22px}
  .pcard .specs{margin-top:12px;padding-top:11px;gap:6px}
  .pcard .specs .s{font-size:12px}
  .pcard .cta .btn,.pcard .btn{padding:11px 12px;font-size:13px}
}

/* ===== ヒーロー2層レイヤー（背景=和風scenery / 前景=旅行者group） ===== */
.hero .art .hero-bg{position:absolute;left:50%;top:47%;transform:translate(-50%,-50%);width:124%;max-width:none;height:auto;z-index:0;opacity:.95;filter:none;pointer-events:none;-webkit-mask-image:linear-gradient(to bottom,#000 68%,transparent 97%);mask-image:linear-gradient(to bottom,#000 68%,transparent 97%)}
.hero .art .hero-fg{position:relative;z-index:1;width:100%;max-width:520px;filter:drop-shadow(0 20px 42px rgba(28,42,80,.12))}
@media(max-width:760px){
  .hero .art .hero-bg{display:none}
  .hero .art .hero-fg{max-width:560px}
}

/* ===== Instagram フィード セクション ===== */
.insta .ig-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.ig-tile{position:relative;aspect-ratio:1/1;border-radius:16px;overflow:hidden;display:block;background:var(--bg-soft)}
.ig-tile img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.ig-tile:hover img{transform:scale(1.07)}
.ig-tile .ig-ov{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;background:rgba(20,24,31,.30);opacity:0;transition:opacity .25s}
.ig-tile:hover .ig-ov{opacity:1}
@media(max-width:760px){.insta .ig-grid{grid-template-columns:repeat(3,1fr);gap:10px}}
/* Smash Balloon 実フィード（[instagram-feed]）をテーマの見た目に寄せる */
.insta .ig-feed #sb_instagram,.insta .ig-feed .sbi{padding:0!important;margin:0!important}
.insta .ig-feed .sbi_item,.insta .ig-feed .sbi_photo{border-radius:16px!important;overflow:hidden!important}
.insta .ig-feed .sbi_photo img{transition:transform .4s ease}
.insta .ig-feed .sbi_item:hover .sbi_photo img{transform:scale(1.07)}
/* SB 既定の青「Follow on Instagram」ボタン/ロードモアは非表示（テーマの @minpakuesim ボタンを使う） */
.insta .ig-feed #sbi_load,.insta .ig-feed .sbi_follow_btn,.insta .ig-feed .sb_instagram_header{display:none!important}

/* nav アクティブ＝オレンジpill（hoverと統一・一貫性） */
.nav nav a.on{color:var(--coral-d);background:var(--coral-50)}

/* SPフッター: ブランドを全幅・リンク列に余白（窮屈解消） */
@media(max-width:760px){
  .foot-main{grid-template-columns:1fr 1fr;gap:28px 22px;padding-top:46px}
  .foot-main .fbrand{grid-column:1/-1;margin-bottom:2px}
  .foot .fbrand .ftag{max-width:none}
  .socs{margin-top:16px}
  .foot-copy{flex-direction:column;gap:6px;text-align:left}
}

/* SPフッター: 長いリンク(特商法など)を折り返す */
@media(max-width:760px){
  .foot-main .fcol{min-width:0}
  .foot a{white-space:normal;overflow-wrap:break-word}
}

/* ===== page-hero subtitle / doc note / contact form ===== */
.page-hero .sub{color:var(--ink-3);font-size:16px;margin-top:10px;max-width:560px}
.note{border-radius:14px;padding:18px 22px;margin:6px 0 28px}
.note h3{font-family:var(--display);font-size:17px;font-weight:700;margin-bottom:8px;color:var(--ink)}
.note ul{margin:0;padding-left:20px}.note li{margin-bottom:6px;color:var(--ink-2)}
.note-warn{background:#fff4ea;border:1.5px solid #ffd9b8}
.cform{max-width:680px}
.cform label{display:block;font-size:13.5px;font-weight:700;color:var(--ink-2);margin-bottom:16px}
.cform .opt{font-weight:500;color:var(--ink-3)}
.cform input,.cform select,.cform textarea{display:block;width:100%;margin-top:7px;padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:15px;color:var(--ink);background:#fff}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--coral)}
.cform textarea{resize:vertical}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cf-note{font-size:13px;color:var(--ink-3);margin-top:14px}
@media(max-width:600px){.cf-row{grid-template-columns:1fr}}

/* ===== Checkout ===== */
.co-h{font-family:var(--display);font-size:18px;font-weight:700;margin:0 0 14px}
.co-main .co-h+form+.co-h,.co-main .co-h:nth-of-type(2){margin-top:28px}
.cf-hint{display:block;font-weight:500;color:var(--ink-3);font-size:12.5px;margin-top:6px}
.req{color:var(--coral)}
.pay-method{display:flex;align-items:center;gap:14px;border:1.5px solid var(--coral);background:var(--coral-50);border-radius:14px;padding:16px 18px}
.pay-method .pm-radio{flex:none;width:20px;height:20px;border-radius:50%;border:2px solid var(--coral);position:relative}
.pay-method.selected .pm-radio::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--coral)}
.pm-name{font-weight:700;font-size:15px}
.pm-sub{font-size:13px;color:var(--ink-3);margin-top:3px}
.pay-method svg{flex:none;margin-left:auto}
.summary .sum-line{display:flex;justify-content:space-between;gap:12px;font-size:14px;color:var(--ink-2);padding:7px 0}
.summary .sum-line b{font-weight:700;color:var(--ink);white-space:nowrap}
.summary .sum-line+.row{margin-top:8px;border-top:1.5px solid var(--line);padding-top:14px}
.co-pay{margin-top:18px}
.co-secure{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12.5px;color:var(--ink-3);margin-top:12px}

/* ===== Thanks ===== */
.thanks{max-width:680px;margin:0 auto;text-align:center;padding:10px 0 20px}
.thanks-badge{width:78px;height:78px;border-radius:50%;background:#e6f7ee;color:#17b06b;display:grid;place-items:center;margin:0 auto 22px}
.thanks h1{font-family:var(--display);font-size:32px;font-weight:800;letter-spacing:-.02em}
.thanks-sub{color:var(--ink-2);font-size:16px;margin:14px auto 0;max-width:520px}
.thanks-order{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin:28px 0}
.thanks-order>div{background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:14px 20px;min-width:150px}
.thanks-order span{display:block;font-size:12px;color:var(--ink-3)}
.thanks-order b{font-family:var(--display);font-size:17px;font-weight:700}
.thanks-steps{text-align:left;max-width:520px;margin:8px auto 28px;display:flex;flex-direction:column;gap:16px}
.ts{display:flex;gap:14px}
.ts-n{flex:none;width:30px;height:30px;border-radius:50%;background:var(--coral);color:#fff;font-weight:800;display:grid;place-items:center;font-size:14px}
.ts h4{font-family:var(--display);font-size:15px;font-weight:700}
.ts p{font-size:14px;color:var(--ink-3);margin-top:2px}
.thanks-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ===== Account ===== */
.acct{display:grid;grid-template-columns:230px 1fr;gap:30px;align-items:start;padding-bottom:30px}
.acct-nav{display:flex;flex-direction:column;gap:2px;border:1.5px solid var(--line);border-radius:16px;padding:10px;position:sticky;top:90px}
.acct-nav a{padding:12px 14px;border-radius:10px;font-weight:600;font-size:14.5px;color:var(--ink-2);cursor:pointer}
.acct-nav a:hover{background:var(--bg-soft)}
.acct-nav a.on{background:var(--coral-50);color:var(--coral-d)}
.acct-main{display:flex;flex-direction:column;gap:16px}
.ord{border:1.5px solid var(--line);border-radius:16px;overflow:hidden}
.ord-top{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;background:var(--bg-soft);border-bottom:1.5px solid var(--line)}
.ord-id{font-family:var(--display);font-weight:700;font-size:15.5px}
.ord-date{font-size:13px;color:var(--ink-3);margin-top:2px}
.ord-status{font-size:12px;font-weight:800;padding:5px 12px;border-radius:999px}
.ord-status.done{background:#e6f7ee;color:#0e8a4d}
.ord-items{display:flex;flex-direction:column}
.oi{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--line)}
.oi:last-child{border-bottom:none}
.oi-tag{flex:none;font-size:11px;font-weight:800;padding:5px 11px;border-radius:999px}
.oi-tag.unlim{background:#fff1e3;color:#d9660f}.oi-tag.capped{background:#e7f5f8;color:#2b8a9e}.oi-tag.fixed{background:#e6f7ee;color:#0e8a4d}
.oi-name{flex:1;font-size:14.5px;font-weight:600}
.oi-act{flex:none;font-size:13.5px;font-weight:700;color:var(--coral-d);cursor:pointer;background:var(--coral-50);padding:8px 14px;border-radius:999px}
.oi-act:hover{background:#ffe4cc}
@media(max-width:760px){
  .acct{grid-template-columns:1fr}
  .acct-nav{flex-direction:row;overflow-x:auto;position:static;top:auto}
  .acct-nav a{white-space:nowrap}
  .oi{flex-wrap:wrap}
}

/* ===== scroll reveal ===== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);will-change:opacity,transform}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ===== usage guide UI（ステップカード＋スマホモック） ===== */
.guide-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;margin:6px 0 28px}
.gsteps{display:flex;flex-direction:column;gap:14px}
.gstep{display:flex;gap:15px;align-items:flex-start;background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:18px 20px}
.gstep .gn{flex:none;width:34px;height:34px;border-radius:50%;background:var(--coral);color:#fff;font-weight:800;display:grid;place-items:center;font-family:var(--display);font-size:15px}
.gstep h4{font-family:var(--display);font-size:15.5px;font-weight:700}
.gstep p{font-size:13.5px;color:var(--ink-3);margin-top:3px;line-height:1.6}
.phone{width:228px;margin:0 auto;border:9px solid #14181f;border-radius:38px;background:#14181f;box-shadow:var(--shadow-lg);overflow:hidden;position:relative}
.phone .nub{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:84px;height:7px;border-radius:99px;background:#0b0d10;z-index:2}
.phone .scr{background:linear-gradient(180deg,#fff5ec,#ffffff);padding:42px 14px 20px}
.phone .pt{font-size:10.5px;color:var(--ink-3);font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin:0 4px 8px}
.phone .prow{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid var(--line);border-radius:13px;padding:12px 13px;margin-bottom:9px}
.phone .prow .pl{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:600;color:var(--ink)}
.phone .prow .pl .di{color:var(--coral);display:grid;place-items:center}
.phone .tog{flex:none;width:40px;height:23px;border-radius:99px;background:var(--coral);position:relative}
.phone .tog::after{content:"";position:absolute;top:2px;right:2px;width:19px;height:19px;border-radius:50%;background:#fff}
.phone .pconn{text-align:center;margin:16px 0 6px}
.phone .pconn .big{font-family:var(--display);font-size:17px;font-weight:800;color:var(--ink)}
.phone .pconn .sm{font-size:11.5px;color:var(--ink-3);margin-top:2px}
.phone .bars{display:flex;gap:3px;align-items:flex-end;justify-content:center;height:22px;margin-top:8px}
.phone .bars i{width:5px;border-radius:2px;background:var(--coral)}
.phone .bars i:nth-child(1){height:8px}.phone .bars i:nth-child(2){height:13px}.phone .bars i:nth-child(3){height:17px}.phone .bars i:nth-child(4){height:22px}
@media(max-width:760px){.guide-grid{grid-template-columns:1fr;gap:26px}}

/* ===== about feature cards ===== */
.afeat{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:14px 0 24px}
.afeat .ac{background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:22px}
.afeat .ac .aic{width:44px;height:44px;border-radius:13px;background:var(--coral-50);color:var(--coral);display:grid;place-items:center;margin-bottom:13px}
.afeat .ac h4{font-family:var(--display);font-size:15.5px;font-weight:700}
.afeat .ac p{font-size:13.5px;color:var(--ink-3);margin-top:5px;line-height:1.65}
@media(max-width:600px){.afeat{grid-template-columns:1fr}}

/* WooCommerce single-product description (real JP product content) */
.prod-desc{max-width:640px;color:var(--ink-2);font-size:15px;line-height:1.85}
.prod-desc h2,.prod-desc h3{color:var(--ink);font-weight:800;letter-spacing:-.01em;margin:26px 0 10px}
.prod-desc h2{font-size:20px}.prod-desc h3{font-size:17px}
.prod-desc ul{margin:8px 0 8px 2px;padding-left:18px}
.prod-desc li{margin:5px 0}
.prod-desc p{margin:10px 0}
.prod-desc strong{color:var(--ink)}

/* ============ WooCommerce pages (cart / checkout / account / content pages) ============ */
.woo-page{padding:48px 0 96px}
.woo-page-title{font-size:32px;font-weight:800;letter-spacing:-.025em;margin:0 0 28px;color:var(--ink)}
.woo-page-body{color:var(--ink-2);font-size:15px;line-height:1.85}
.woo-page-body h2{font-size:22px;font-weight:800;color:var(--ink);letter-spacing:-.01em;margin:30px 0 12px}
.woo-page-body h3{font-size:18px;font-weight:700;color:var(--ink);margin:24px 0 10px}
.woo-page-body p{margin:12px 0}
.woo-page-body a{color:var(--coral);font-weight:600}

/* Buttons → brand */
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,
.woocommerce a.button.alt,.woocommerce button.button.alt,.woocommerce #respond input#submit,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.woocommerce #payment #place_order,.woocommerce-checkout #place_order{
  background:var(--coral);color:#fff;border:none;border-radius:999px;
  font-family:var(--font);font-weight:700;font-size:15px;letter-spacing:.01em;
  padding:13px 26px;box-shadow:0 8px 22px -8px rgba(255,136,50,.6);transition:.18s;cursor:pointer;text-shadow:none}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,
.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover,
.woocommerce #payment #place_order:hover,.woocommerce-checkout #place_order:hover{
  background:#ff7a17;transform:translateY(-1px)}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,.woocommerce-checkout #place_order{display:block;width:100%;text-align:center;padding:16px;font-size:16px}

/* Cart table */
.woocommerce table.shop_table{border:1px solid var(--line);border-radius:18px;border-collapse:separate;overflow:hidden;background:#fff}
.woocommerce table.shop_table th{background:var(--bg-soft);font-family:var(--font);font-weight:700;color:var(--ink);padding:16px 18px;border:none}
.woocommerce table.shop_table td{padding:18px;border-top:1px solid var(--line);vertical-align:middle}
.woocommerce table.shop_table .product-thumbnail img{width:72px;border-radius:12px}
.woocommerce a.remove{color:var(--coral)!important;border-radius:50%}
.woocommerce a.remove:hover{background:var(--coral)!important;color:#fff!important}
.woocommerce .quantity .qty{border:1px solid var(--line);border-radius:10px;padding:8px;font-family:var(--font)}

/* Cart totals / order review cards */
.woocommerce .cart_totals,.woocommerce-checkout #order_review{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:8px 22px 22px;box-shadow:var(--shadow-sm,0 10px 30px -18px rgba(20,20,40,.18))}
.woocommerce .cart_totals h2,.woocommerce-checkout #order_review_heading{font-size:18px;font-weight:800;color:var(--ink);padding-top:16px}
.woocommerce .cart_totals table,.woocommerce-checkout #order_review table.shop_table{border:none;background:transparent}
.woocommerce .cart_totals table th,.woocommerce .cart_totals table td{background:transparent;border-top:1px solid var(--line);padding:12px 0}

/* Coupon + form fields */
.woocommerce .coupon .input-text,.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,.woocommerce-checkout .form-row .input-text,
.select2-container--default .select2-selection--single{
  border:1px solid var(--line);border-radius:12px;padding:12px 14px;font-family:var(--font);font-size:15px;background:#fff}
.woocommerce form .form-row label{font-family:var(--font);font-weight:600;color:var(--ink);font-size:14px}
.woocommerce-checkout .col2-set .col-1,.woocommerce-checkout .col2-set .col-2{float:none;width:100%}

/* Notices */
.woocommerce-message,.woocommerce-info,.woocommerce-error{
  border-radius:14px;border:none;font-family:var(--font);font-size:14px;border-top:3px solid var(--coral)!important;background:var(--bg-soft);color:var(--ink-2)}
.woocommerce-message{border-top-color:#149c63!important}

/* Checkout 2-col layout */
@media(min-width:900px){
  .woocommerce-checkout form.checkout{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:start}
  .woocommerce-checkout form.checkout #customer_details{grid-column:1}
  .woocommerce-checkout form.checkout #order_review,.woocommerce-checkout form.checkout #order_review_heading{grid-column:2}
  .woocommerce-checkout form.checkout #order_review_heading{margin-top:0}
}

/* Checkout 2-col refinement (override) */
.woocommerce-checkout #order_review table.shop_table{width:100%}
.woocommerce-checkout #order_review .product-name{word-break:normal}
@media(min-width:900px){
  .woocommerce-checkout form.checkout{display:grid;grid-template-columns:1.15fr .85fr;column-gap:40px;align-items:start}
  .woocommerce-checkout form.checkout #customer_details{grid-column:1;grid-row:1 / span 2}
  .woocommerce-checkout form.checkout #order_review_heading{grid-column:2;grid-row:1;margin-top:0}
  .woocommerce-checkout form.checkout #order_review{grid-column:2;grid-row:2;position:static!important;width:auto!important}
}

/* ============ Contact form (CF7 #135 — .contact__dl structure) ============ */
.cform .contact__dl-wrapper{margin:0}
.cform .contact__dl{margin:0 0 20px}
.cform .contact__dt{font-family:var(--font);font-weight:700;color:var(--ink);font-size:14px;margin:0 0 8px;display:flex;align-items:center;gap:8px}
.cform .contact__dt:not(.not-must)::after{content:"Required";font-size:11px;font-weight:600;color:var(--coral);background:#fff1ea;padding:2px 8px;border-radius:999px}
.cform .contact__dt.not-must::after{content:"Optional";font-size:11px;font-weight:600;color:var(--ink-3);background:var(--bg-soft);padding:2px 8px;border-radius:999px}
.cform .contact__dd{margin:0}
.cform input[type=text],.cform input[type=email],.cform input[type=tel],.cform textarea,
.wpcf7 input[type=text],.wpcf7 input[type=email],.wpcf7 input[type=tel],.wpcf7 textarea{
  width:100%;border:1px solid var(--line);border-radius:12px;padding:13px 15px;font-family:var(--font);font-size:15px;color:var(--ink);background:#fff;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}
.cform input:focus,.cform textarea:focus,.wpcf7 input:focus,.wpcf7 textarea:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px rgba(255,136,50,.14)}
.cform textarea,.wpcf7 textarea{min-height:170px;resize:vertical}
.cform .contact__btn{margin-top:28px;text-align:center}
.cform input[type=submit],.wpcf7 input[type=submit],.wpcf7-submit{
  background:var(--coral);color:#fff;border:none;border-radius:999px;font-family:var(--font);font-weight:700;font-size:16px;
  padding:15px 44px;cursor:pointer;box-shadow:0 10px 26px -10px rgba(255,136,50,.65);transition:.18s;-webkit-appearance:none}
.cform input[type=submit]:hover,.wpcf7 input[type=submit]:hover{background:#ff7a17;transform:translateY(-1px)}
.wpcf7-not-valid-tip{color:#e0413a;font-size:13px;margin-top:5px}
.wpcf7 .wpcf7-response-output{border-radius:12px;border:1px solid var(--line);border-left:3px solid var(--coral);font-family:var(--font);font-size:14px;padding:14px 16px;margin:18px 0 0}

/* ============ Legal / policy pages — make imported legal text feel designed ============ */
/* Constrain to a comfortable reading column */
.doc{max-width:780px}
/* 第X条 etc. are imported as <p><strong>…</strong></p> — promote to section headings */
.doc p:has(> strong:only-child){
  font-size:19px;font-weight:800;color:var(--ink);letter-spacing:-.012em;
  line-height:1.5;margin:44px 0 2px;padding-top:22px;border-top:1px solid var(--line)}
.doc p:has(> strong:only-child):first-child{margin-top:0;padding-top:0;border-top:none}
.doc p:has(> strong:only-child) strong{font-weight:800}
/* Imported body paragraphs: airy legal rhythm */
.doc p.wp-block-paragraph{margin:12px 0;line-height:1.95;color:var(--ink-2);font-size:15px}
.doc p.wp-block-paragraph:has(> strong:only-child){color:var(--ink);font-size:19px}

/* Legal headings v2: replace harsh full-width rules with a brand accent bar */
.doc p:has(> strong:only-child){
  border-top:none !important;padding-top:0;padding-left:16px;position:relative;
  font-size:18px;font-weight:800;color:var(--ink);letter-spacing:-.01em;margin:38px 0 10px}
.doc p:has(> strong:only-child)::before{
  content:"";position:absolute;left:0;top:.18em;bottom:.18em;width:4px;border-radius:3px;
  background:linear-gradient(var(--coral),#ff7a17)}
.doc p:has(> strong:only-child):first-child{margin-top:0}

/* Login form → centered card */
.woocommerce-account .woocommerce form.woocommerce-form-login{
  max-width:440px;margin:14px auto;background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:30px 30px 26px;box-shadow:0 16px 44px -26px rgba(20,20,40,.22)}
.woocommerce-account .woocommerce > h2,.woocommerce-account .woocommerce-form-login-toggle{text-align:center}
.woocommerce-account .woocommerce form.woocommerce-form-login .form-row{margin-bottom:14px}

/* ============ 特商法 / disclosure pages (label / value / <hr> triplets) ============ */
.doc:has(hr.wp-block-separator){max-width:700px}
.doc:has(hr.wp-block-separator) hr.wp-block-separator{
  border:0;height:1px;background:var(--line);opacity:1;margin:0;width:100%}
.doc:has(hr.wp-block-separator) > p.wp-block-paragraph{margin:0;line-height:1.65}
.doc:has(hr.wp-block-separator) > p:first-child,
.doc:has(hr.wp-block-separator) hr.wp-block-separator + p.wp-block-paragraph{
  font-size:12px;font-weight:800;color:var(--coral);letter-spacing:.06em;text-transform:uppercase;padding:22px 0 4px}
.doc:has(hr.wp-block-separator) p.wp-block-paragraph:has(+ hr.wp-block-separator){
  font-size:15.5px;color:var(--ink);font-weight:500;padding-bottom:22px}
.doc:has(hr.wp-block-separator) > p.wp-block-paragraph:last-child{font-size:15.5px;color:var(--ink);font-weight:500}

/* Scroll-reveal removed (felt slow / white flash). Force any .reveal element visible. */
.reveal{opacity:1 !important;transform:none !important;transition:none !important}

/* ============ Product detail (redesigned: desc above CTA + full-width detail) ============ */
.detail .dwrap{align-items:start}
.buybox .bb-title{font-size:13px;font-weight:700;color:var(--ink-3);letter-spacing:.02em}
.buybox .pr{margin:6px 0 16px}
.buybox .bb-desc{font-size:13.5px;line-height:1.72;color:var(--ink-2);margin:0 0 18px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.buybox .bb-cta{margin-top:22px}
.buybox .pay{margin-top:13px;font-size:12px;color:var(--ink-3)}
/* full-width detail below the top 2-col */
.pdp-detail{margin-top:52px;max-width:820px}
.pdp-block{margin:0 0 26px}
.pdp-h{font-size:18px;font-weight:800;color:var(--ink);letter-spacing:-.01em;margin:0 0 14px}
.pdp-acc{border:1px solid var(--line);border-radius:16px;background:#fff;padding:0 22px;margin:0 0 28px}
.pdp-acc > summary{cursor:pointer;list-style:none;font-size:17px;font-weight:800;color:var(--ink);padding:20px 0;display:flex;align-items:center;justify-content:space-between}
.pdp-acc > summary::-webkit-details-marker{display:none}
.pdp-acc > summary::after{content:"+";font-size:24px;font-weight:400;color:var(--coral);line-height:1}
.pdp-acc[open] > summary::after{content:"\2013"}
.pdp-acc[open] > summary{border-bottom:1px solid var(--line)}
.pdp-acc .prod-desc{padding:20px 0 24px;max-width:none}
@media(max-width:860px){
  .pdp-detail{margin-top:36px;max-width:100%}
  .detail .dcol-visual .pdp-block{margin-top:22px}
}

/* Product detail grid v2: PC = visual+included left / buybox spanning right; mobile = visual → buybox → included */
.detail .dwrap{display:grid;grid-template-columns:1.1fr .9fr;grid-template-areas:"visual buy" "incl buy";column-gap:48px;row-gap:0;align-items:start}
.detail .dcol-visual{grid-area:visual}
.detail .dcol-buy{grid-area:buy}
.detail .dcol-incl{grid-area:incl;margin-top:30px}
@media(max-width:860px){
  .detail .dwrap{grid-template-columns:1fr;grid-template-areas:"visual" "buy" "incl";column-gap:0}
  .detail .dcol-buy{margin-top:22px}
  .detail .dcol-incl{margin-top:26px}
}

/* Form selects (CF7 country, etc.) → match inputs */
.cform select,.wpcf7 select,.woocommerce form .form-row select{
  width:100%;border:1px solid var(--line);border-radius:12px;padding:13px 15px;font-family:var(--font);font-size:15px;color:var(--ink);
  background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239a9a9a' stroke-width='2.4' stroke-linecap='round'><path d='M6 9l6 6 6-6'/></svg>") no-repeat right 14px center;
  -webkit-appearance:none;appearance:none;box-sizing:border-box;cursor:pointer}
.cform select:focus,.wpcf7 select:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px rgba(255,136,50,.14)}

/* ============ Cart actions row (coupon + update) — fix cramped layout ============ */
.woocommerce table.cart td.actions{padding:22px 20px !important;vertical-align:middle;overflow:hidden;background:var(--bg-soft)}
.woocommerce table.cart td.actions .coupon{display:flex;align-items:center;gap:12px;float:left;margin:0}
.woocommerce table.cart td.actions .coupon label{display:none}
.woocommerce table.cart td.actions .coupon .input-text{margin:0;width:240px;padding:14px 16px}
.woocommerce table.cart td.actions .coupon .button{margin:0;white-space:nowrap;padding:14px 26px}
.woocommerce table.cart td.actions > button.button,
.woocommerce table.cart td.actions > input.button{float:right;margin:0;padding:14px 28px}
.woocommerce table.cart td.actions::after{content:"";display:table;clear:both}
/* spacing below the cart form + a bit of room around the table */
.woocommerce-cart .woocommerce-cart-form{margin-bottom:46px}
.woocommerce-cart table.cart{margin-bottom:0}
@media(max-width:600px){
  .woocommerce table.cart td.actions .coupon{float:none;flex-wrap:wrap}
  .woocommerce table.cart td.actions .coupon .input-text{width:100%}
  .woocommerce table.cart td.actions > button.button,
  .woocommerce table.cart td.actions > input.button{float:none;width:100%;margin-top:12px}
}

/* GTranslate: engine loads via the (hidden) float widget; language is driven by the nav switcher */
.gt_float_switcher,#gt_float_wrapper,.gt-float-switcher,.gtranslate_wrapper{display:none !important}
.goog-te-banner-frame,.skiptranslate iframe{display:none !important}
body{top:0 !important}
/* GTranslate wraps translated text in <font>; keep it inheriting our styles */
font{font:inherit !important;color:inherit !important;background:transparent !important;vertical-align:baseline !important}

/* ============ CLS: reserve space for JS-rendered chrome + grids (prevent layout shift) ============ */
#site-nav{min-height:76px}
@media(max-width:860px){#site-nav{min-height:64px}}
#popular-grid{min-height:430px}
#blog-grid{min-height:300px}
@media(max-width:980px){#popular-grid{min-height:0}#blog-grid{min-height:0}}
#site-foot{min-height:320px}
@media(max-width:760px){#site-foot{min-height:0}}

/* CLS: keep reserved aspect boxes for images with width/height attrs */
.hero .art img,.step .ill,.feat-media img{height:auto;max-width:100%}

/* === ヘッダー自動追従：下スクロールで隠す／上スクロールで出す（PC+SP） === */
#site-nav.nav{transition:transform .35s cubic-bezier(.4,0,.2,1);will-change:transform}
#site-nav.nav--hidden{transform:translateY(-115%)}
body.nav-open #site-nav.nav--hidden{transform:none}

/* sticky を壊す body の overflow-x:hidden（他CSS由来）を上書き。clipは横スクロール防止しつつ scroll container 化しない */
html,body{overflow-x:clip!important}

/* ===== app download badges (App Store / Google Play) ===== */
.store-badges{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.store-badge{display:inline-flex;align-items:center;text-decoration:none;border-radius:9px;transition:transform .15s ease,opacity .15s ease}
.store-badge:hover{opacity:.85;transform:translateY(-1px)}
.store-badge img{display:block;width:auto;height:44px}
.store-badge.sb-ios img{height:44px}
.store-badge.sb-and img{height:44px} /* 公式PNGは上下に余白があるため同じ高さで見た目が揃う */

/* app CTA block between the How-it-works cards and the buttons */
.app-cta{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap;
  max-width:720px;margin:36px auto 0;padding:20px 24px;
  background:#fff;border:1px solid #ffe2cb;border-radius:18px;text-align:left}
.app-cta-tx h3{margin:0 0 4px;font-size:18px;color:#1b1d21}
.app-cta-tx p{margin:0;font-size:13.5px;color:#6b7280;line-height:1.6}
.foot-badges{margin-top:14px}
.foot-badges .store-badge img{height:38px}
@media(max-width:560px){
  .app-cta{flex-direction:column;text-align:center;gap:14px;padding:18px 16px}
  .app-cta-tx{text-align:center}
  .app-cta .store-badges{justify-content:center}
}
