/* 禁煙コーチ — public site shared styles (kinen brand) */
:root{
  --bg:#F4F6F4;
  --bg-warm:#FBF6EC;
  --surface:#FFFFFF;
  --surface-alt:#F8FAF8;

  --ink:#1F2A26;
  --ink-dim:#5C6863;
  --ink-soft:#949D98;

  --primary:#3F8A6E;
  --primary-deep:#2A6651;
  --primary-soft:#E2EFE8;
  --primary-glow:#B9DCC9;

  --lime:#B6F24A;
  --lime-deep:#9BDB2E;
  --warm:#E8B26A;
  --warm-soft:#FAE9CB;
  --alert:#E55050;
  --cool:#6B7CE0;

  --dark:#071C15;
  --dark-2:#123F2E;

  --line:rgba(31,42,38,.09);
  --line-strong:rgba(31,42,38,.16);
  --line-green:#06C755;

  --jp:'Zen Kaku Gothic New',system-ui,sans-serif;
  --display:'Zen Maru Gothic','Hiragino Maru Gothic ProN',sans-serif;
  --num:'Manrope','Helvetica Neue',sans-serif;

  --radius:18px;
  --radius-lg:26px;
  --shadow:0 24px 60px -24px rgba(31,42,38,.22);
  --shadow-sm:0 10px 30px -16px rgba(31,42,38,.18);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  background:var(--bg);
  font-family:var(--jp);
  font-size:16px;
  line-height:1.85;
  letter-spacing:.012em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img,svg{display:block}
h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.01em}
p{margin:0}

.wrap{width:min(1160px,calc(100% - 48px));margin-inline:auto}
.wrap-narrow{width:min(820px,calc(100% - 48px));margin-inline:auto}

/* ---- eyebrow / labels ---- */
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--num);font-weight:700;font-size:12px;
  letter-spacing:.22em;text-transform:uppercase;color:var(--primary);
}
.eyebrow::before{content:"";width:22px;height:1.5px;background:var(--primary);opacity:.55}
.eyebrow.center::before{display:none}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--jp);font-weight:700;font-size:15px;
  padding:14px 22px;border-radius:999px;border:1.5px solid var(--line-strong);
  background:var(--surface);color:var(--ink);cursor:pointer;white-space:nowrap;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-ghost{background:transparent}
.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 14px 30px -12px rgba(63,138,110,.7)}
.btn-primary:hover{background:var(--primary-deep);border-color:var(--primary-deep)}
.btn-line{background:var(--line-green);border-color:var(--line-green);color:#fff;box-shadow:0 14px 30px -12px rgba(6,199,85,.6)}
.btn-line:hover{background:#05b14c;border-color:#05b14c}
.btn-line .bubble{width:18px;height:18px;border-radius:6px 6px 6px 2px;background:#fff;position:relative;flex:0 0 auto}
.btn-line .bubble::after{content:"";position:absolute;inset:5px;border-radius:2px;background:var(--line-green)}
.btn-lg{padding:16px 28px;font-size:16px}

/* ---- topbar ---- */
.topbar{position:sticky;top:0;z-index:60;background:rgba(244,246,244,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.nav{height:74px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mark{width:40px;height:40px;flex:0 0 auto}
.brand .wm{display:flex;flex-direction:column;line-height:1.05}
.brand .wm small{font-family:var(--num);font-weight:700;font-size:9px;letter-spacing:.26em;color:var(--ink-soft)}
.brand .wm b{font-family:var(--display);font-weight:700;font-size:19px;color:var(--primary-deep);letter-spacing:.02em}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto;margin-right:26px;font-size:14px;color:var(--ink-dim);font-weight:500}
.nav-links a{padding:9px 13px;border-radius:999px;transition:background .15s,color .15s}
.nav-links a:hover{background:var(--surface);color:var(--ink)}
.nav-links a.active{color:var(--primary-deep);font-weight:700}
.nav-right{display:flex;align-items:center;gap:10px}

/* nav dropdown (shared) */
.nav-links .dd{position:relative}
.nav-links .dd>a::after{content:"▾";font-size:10px;margin-left:5px;color:var(--ink-soft)}
.nav-links .dd-panel{position:absolute;top:calc(100% + 6px);left:0;min-width:250px;background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:8px;display:none;flex-direction:column;gap:2px}
.nav-links .dd:hover .dd-panel{display:flex}
.nav-links .dd-panel a{padding:10px 13px;border-radius:10px;font-size:13.5px;color:var(--ink-dim);font-weight:600}
.nav-links .dd-panel a small{display:block;font-family:var(--num);font-size:10px;color:var(--ink-soft);letter-spacing:.06em;font-weight:700;margin-top:2px}
.nav-links .dd-panel a:hover{background:var(--surface-alt);color:var(--primary-deep)}

/* ---- sections ---- */
section{position:relative}
.sec{padding:96px 0}
.sec-sm{padding:64px 0}
.bg-warm{background:var(--bg-warm)}
.bg-surface{background:var(--surface)}
.sec-head{max-width:720px;margin-bottom:48px}
.sec-head h2{font-family:var(--display);font-size:clamp(28px,3.4vw,40px);line-height:1.34;margin:18px 0 0}
.sec-head .lead{margin-top:18px;color:var(--ink-dim);font-size:17px;line-height:1.9}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}

/* ---- cards ---- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:30px;box-shadow:var(--shadow-sm)}
.card-flat{box-shadow:none}
.grid{display:grid;gap:22px}
.g2{grid-template-columns:repeat(2,minmax(0,1fr))}
.g3{grid-template-columns:repeat(3,minmax(0,1fr))}
.g4{grid-template-columns:repeat(4,minmax(0,1fr))}

.num-badge{font-family:var(--num);font-weight:800;font-size:13px;color:var(--primary);letter-spacing:.1em}
.idx{width:38px;height:38px;border-radius:13px;background:var(--primary-soft);color:var(--primary-deep);display:grid;place-items:center;font-family:var(--num);font-weight:800;font-size:16px;margin-bottom:18px}

.h3-card{font-family:var(--display);font-size:20px;line-height:1.5;margin-bottom:10px}
.card p{color:var(--ink-dim);font-size:15px;line-height:1.85}

/* check list */
.checks{display:grid;gap:11px;margin-top:18px}
.checks .it{display:flex;gap:11px;align-items:flex-start;color:var(--ink-dim);font-size:15px;line-height:1.7}
.checks .it::before{content:"";width:19px;height:19px;flex:0 0 auto;margin-top:3px;border-radius:50%;background:var(--primary-soft);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='19' height='19' viewBox='0 0 19 19'%3E%3Cpath d='M5 9.6l2.6 2.6L14 6' fill='none' stroke='%232A6651' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}

/* tags / chips */
.chip{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:999px;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink-dim);font-size:13px;font-weight:600}
.chip.solid{background:var(--primary-soft);color:var(--primary-deep);border-color:transparent}
.chip.cat{font-family:var(--num);letter-spacing:.08em;font-size:11px;text-transform:uppercase;font-weight:700}

/* placeholder media */
.ph{position:relative;border-radius:14px;overflow:hidden;background:var(--surface-alt);border:1px solid var(--line);
  background-image:repeating-linear-gradient(135deg,transparent 0 11px,rgba(63,138,110,.06) 11px 12px)}
.ph::after{content:attr(data-label);position:absolute;inset:0;display:grid;place-items:center;
  font-family:var(--num);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);padding:8px;text-align:center}

/* notice */
.notice{border:1px solid var(--warm);background:var(--warm-soft);border-radius:16px;padding:18px 20px;color:#6b5328;font-size:14px;line-height:1.8}
.notice b{color:#5a4520}
.fineprint{font-size:12.5px;color:var(--ink-soft);line-height:1.7}
.fineprint a{color:var(--ink-dim);text-decoration:underline;text-underline-offset:3px}

/* footer */
.footer{background:#142019;color:#cdd8d1;padding:72px 0 40px;margin-top:0}
.footer .brand .wm b{color:#fff}
.footer .brand .wm small{color:#7f8d85}
.footer-grid{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:36px}
.footer h4{font-family:var(--display);color:#fff;font-size:15px;margin-bottom:16px}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:11px;font-size:14px}
.footer ul a,.footer ul li{color:#a9b6ad}
.footer ul a:hover{color:#fff}
.footer p{color:#90a096;font-size:14px;line-height:1.85}
.footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12.5px;color:#7f8d85}

/* sticky cta */
.sticky-cta{position:fixed;left:50%;transform:translateX(-50%);bottom:20px;z-index:55;
  width:min(680px,calc(100% - 32px));background:rgba(255,255,255,.92);backdrop-filter:blur(14px);
  border:1px solid var(--line-strong);border-radius:999px;box-shadow:var(--shadow);
  display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 12px 10px 24px}
.sticky-cta b{font-size:14px}
.sticky-cta span{display:block;font-size:12.5px;color:var(--ink-dim)}

@media(max-width:880px){
  body{font-size:15px}
  .nav{flex-wrap:wrap;height:auto;padding:11px 0;gap:12px 16px}
  .nav-links{order:3;width:100%;gap:2px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;font-size:13.5px}
  .nav-links::-webkit-scrollbar{display:none}
  .nav-links a{white-space:nowrap;padding:8px 12px}
  .nav-links .dd-panel{display:none !important}
  .nav-links .dd>a::after{display:none}
  .sec{padding:64px 0}
  .g2,.g3,.g4{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .sticky-cta .stx{display:none}
  .sticky-cta{justify-content:center}
}
@media(max-width:560px){
  .footer-grid{grid-template-columns:1fr}
}

/* ===================================================================
   登録特典 MODULE (LINE登録特典) — calm, editorial, light
   Used on Home LP and inline inside articles.
   =================================================================== */
.spbanner{
  position:relative;overflow:hidden;color:var(--ink);
  border-radius:var(--radius-lg);
  background:
    radial-gradient(38% 30% at 4% 8%, rgba(63,138,110,.07), transparent 60%),
    radial-gradient(34% 26% at 97% 4%, rgba(63,138,110,.06), transparent 60%),
    radial-gradient(40% 34% at 100% 100%, rgba(63,138,110,.05), transparent 60%),
    var(--surface);
  border:1px solid var(--line-strong);
  box-shadow:var(--shadow-sm);
  padding:clamp(28px,3.6vw,48px);
}
/* botanical leaf motifs (default light variant only) */
.spbanner:not(.sp-inline):not(.sp-bold)::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-repeat:no-repeat;
  background-position:left 6px top 10px, right 10px top 6px;
  background-size:132px, 120px;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='150' viewBox='0 0 120 150'%3E%3Cg fill='none' stroke='%233F8A6E' stroke-width='1.4' stroke-linecap='round' opacity='.55'%3E%3Cpath d='M40 150 C40 90 55 40 96 12'/%3E%3Cpath d='M70 62 C58 54 44 58 36 74 C52 78 66 74 70 62Z' fill='%233F8A6E' fill-opacity='.14'/%3E%3Cpath d='M84 40 C72 32 58 36 50 52 C66 56 80 52 84 40Z' fill='%233F8A6E' fill-opacity='.14'/%3E%3Cpath d='M60 86 C48 80 34 85 27 101 C43 105 56 99 60 86Z' fill='%233F8A6E' fill-opacity='.1'/%3E%3C/g%3E%3C/svg%3E"),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='150' viewBox='0 0 120 150'%3E%3Cg fill='none' stroke='%233F8A6E' stroke-width='1.4' stroke-linecap='round'%3E%3Cpath d='M80 150 C80 90 66 42 24 14'/%3E%3Cpath d='M50 60 C62 52 76 56 84 72 C68 76 54 72 50 60Z' fill='%233F8A6E' fill-opacity='.14'/%3E%3Cpath d='M36 40 C48 32 62 36 70 52 C54 56 40 52 36 40Z' fill='%233F8A6E' fill-opacity='.14'/%3E%3C/g%3E%3C/svg%3E");
}
.spbanner::before{
  content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--primary-glow));
}
.spbanner > *{position:relative;z-index:1}
/* guard against article .prose heading rules leaking into the banner
   (.spbanner h2.sp-head specificity 0,2,1 beats page-local .prose h2) */
.spbanner h2.sp-head,.spbanner h3,.spbanner h4{border-left:0;padding-left:0}
.spbanner h2.sp-head{margin:16px 0 0}
.spbanner h3,.spbanner h4{margin:0}

.sp-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 15px 7px 11px;border-radius:999px;
  background:var(--primary-soft);color:var(--primary-deep);
  font-weight:700;font-size:13px;letter-spacing:.04em;
}
.sp-badge .bubble{width:16px;height:16px;border-radius:5px 5px 5px 2px;background:var(--line-green);position:relative;flex:0 0 auto}
.sp-badge .bubble::after{content:"";position:absolute;inset:4px;border-radius:2px;background:#fff}

.sp-head{
  font-family:var(--display);text-align:center;line-height:1.42;
  font-size:clamp(23px,3.2vw,33px);letter-spacing:-.005em;
  margin:16px 0 0;color:var(--ink);
}
.sp-head .big{color:var(--primary-deep)}
.sp-head .gold,.sp-head .free{color:var(--primary-deep);
  background:linear-gradient(transparent 66%, var(--warm-soft) 66%);padding:0 .06em}
.sp-sub{text-align:center;color:var(--ink-dim);font-size:15px;line-height:1.9;max-width:540px;margin:14px auto 0}

.sp-divider{width:44px;height:2px;margin:26px auto 28px;background:var(--line-strong);border-radius:2px}

.sp-perks{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
.perk{
  display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;
  background:var(--surface);border:1px solid var(--line);
  border-radius:18px;padding:24px clamp(20px,2.4vw,28px);box-shadow:var(--shadow-sm);
}
.perk-no{
  width:54px;flex:0 0 auto;text-align:center;line-height:1;
  font-family:var(--display);color:var(--primary-deep);font-weight:700;
  background:var(--primary-soft);
  border-radius:14px;padding:10px 0;
}
.perk-no small{display:block;font-size:10.5px;letter-spacing:.12em;font-weight:700;color:var(--primary);margin-bottom:4px}
.perk-no b{font-size:26px;font-family:var(--num)}
.perk-main{display:grid;grid-template-columns:1fr;gap:14px}
.perk-head{display:grid;grid-template-columns:1fr;gap:14px}
.perk-head h3{font-family:var(--display);color:var(--ink);font-size:clamp(17px,2vw,21px);line-height:1.46}
.perk-head h3 em{font-style:normal;color:var(--primary-deep)}
.perk p{color:var(--ink-dim);font-size:14px;line-height:1.85}
.perk p b{color:var(--ink);font-weight:700}
.perk p .em{color:var(--primary-deep);font-weight:700}

/* media placeholder — light, matches site .ph */
.sp-media{
  position:relative;border-radius:12px;overflow:hidden;min-height:134px;
  background:var(--surface);border:1px solid var(--line);
  background-image:repeating-linear-gradient(135deg,transparent 0 11px,rgba(63,138,110,.06) 11px 12px);
  display:grid;place-items:center;text-align:center;padding:14px;
}
.sp-media[data-label]::after{
  content:attr(data-label);position:absolute;left:0;right:0;bottom:8px;
  font-family:var(--num);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);
}
.sp-media .mock-title{font-family:var(--display);color:var(--ink-dim);font-size:14px;line-height:1.55}
.sp-media .mock-title b{color:var(--primary-deep);font-size:1.7em;font-family:var(--num)}
.sp-media.video::before{
  content:"";position:absolute;width:44px;height:44px;border-radius:50%;
  background:var(--primary);box-shadow:0 8px 20px -8px rgba(63,138,110,.6);
}
.sp-media.video::after{
  content:"";position:absolute;left:calc(50% - 5px);top:calc(50% - 9px);
  border-style:solid;border-width:9px 0 9px 14px;border-color:transparent transparent transparent #fff;
}

/* 具体例 / spec sub-box */
.sp-spec{background:var(--bg-warm);border:1px solid var(--line);border-radius:12px;padding:18px 20px}
.sp-spec h4{font-family:var(--display);color:var(--primary-deep);font-size:14px;margin-bottom:12px}
.sp-checks{display:grid;gap:9px;list-style:none;margin:0;padding:0}
.sp-checks li{display:flex;gap:10px;align-items:flex-start;color:var(--ink-dim);font-size:13.5px;line-height:1.6}
.sp-checks li::before{
  content:"";width:17px;height:17px;flex:0 0 auto;margin-top:2px;border-radius:50%;
  background:var(--primary-soft);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17' height='17' viewBox='0 0 19 19'%3E%3Cpath d='M5 9.6l2.6 2.6L14 6' fill='none' stroke='%232A6651' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;
}
.sp-checks li.more{color:var(--ink-soft);font-size:12.5px}
.sp-checks li.more::before{background:transparent;background-image:none}

.sp-cta-row{display:flex;justify-content:center;margin-top:30px}
.sp-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:16px 32px;border-radius:999px;border:1.5px solid var(--line-green);
  background:var(--line-green);color:#fff;
  font-family:var(--jp);font-weight:700;font-size:16px;letter-spacing:.01em;
  box-shadow:0 14px 30px -14px rgba(6,199,85,.5);
  transition:transform .18s ease, background .18s ease;
}
.sp-cta:hover{transform:translateY(-2px);background:#05b14c}
.sp-cta .bubble{width:20px;height:20px;border-radius:6px 6px 6px 2px;background:#fff;position:relative;flex:0 0 auto}
.sp-cta .bubble::after{content:"";position:absolute;inset:5px;border-radius:2px;background:var(--line-green)}
.sp-cta .arr{font-family:var(--num);font-weight:600;opacity:.85}
.sp-foot{text-align:center;margin-top:16px;font-size:12.5px;color:var(--ink-soft)}
/* gift footer bar (reference style) */
.sp-give{display:flex;align-items:center;gap:16px;justify-content:center;margin-top:26px;padding:16px 24px;border-radius:16px;background:var(--primary-soft);color:var(--primary-deep)}
.sp-give .gift{width:40px;height:40px;flex:0 0 auto;border-radius:50%;background:rgba(255,255,255,.6);display:grid;place-items:center;color:var(--primary-deep)}
.sp-give .gift svg{width:22px;height:22px}
.sp-give p{margin:0;font-family:var(--display);font-size:clamp(14px,1.6vw,16px);line-height:1.6;color:var(--primary-deep)}
.sp-give p b{color:var(--primary-deep)}

/* compact, restrained variant for inline-in-article */
.spbanner.sp-inline{padding:clamp(18px,2.2vw,24px);box-shadow:none;background:var(--surface-alt)}
.spbanner.sp-inline::before{height:0}
.spbanner.sp-inline .sp-sub,.spbanner.sp-inline .sp-divider,.spbanner.sp-inline .sp-spec,.spbanner.sp-inline .sp-foot{display:none}
.spbanner.sp-inline .sp-badge{font-size:11.5px;padding:5px 12px 5px 9px}
.spbanner.sp-inline > div:first-child{text-align:left}
.spbanner.sp-inline .sp-head{font-size:clamp(16px,2vw,19px);line-height:1.5;margin-top:10px;text-align:left}
.spbanner.sp-inline .sp-head .big,.spbanner.sp-inline .sp-head .free{font-size:1em}
.spbanner.sp-inline .sp-perks{gap:10px;margin-top:16px}
.spbanner.sp-inline .perk{background:var(--surface);padding:12px 14px;gap:12px;align-items:center;border-radius:14px}
.spbanner.sp-inline .perk-no{width:auto;display:inline-flex;align-items:baseline;gap:6px;padding:6px 11px;border-radius:10px}
.spbanner.sp-inline .perk-no small{display:inline;margin:0;font-size:10px}
.spbanner.sp-inline .perk-no b{font-size:17px}
.spbanner.sp-inline .perk-main{gap:0}
.spbanner.sp-inline .perk-head{grid-template-columns:1fr;gap:0}
.spbanner.sp-inline .perk-head h3{font-size:14.5px;line-height:1.45}
.spbanner.sp-inline .perk-head h3 br{display:none}
.spbanner.sp-inline .perk-head h3 em{display:inline}
.spbanner.sp-inline .sp-media{display:none}
.spbanner.sp-inline .perk p{display:none}
.spbanner.sp-inline .sp-cta{padding:12px 24px;font-size:14.5px}
.spbanner.sp-inline .sp-cta-row{margin-top:18px}

@media(max-width:720px){
  .sp-perks{grid-template-columns:1fr}
  .perk{grid-template-columns:1fr;gap:14px}
  .perk-no{width:auto;display:inline-flex;align-items:baseline;gap:8px;padding:8px 16px;justify-self:start}
  .perk-no small{display:inline;margin:0}
  .perk-head{grid-template-columns:1fr}
}

/* ===================================================================
   BOLD variant (風神雷神 LINE特典) — deep-green × gold, for MEDIA use
   =================================================================== */
.spbanner.sp-bold{
  color:#F4EFE2;border:1px solid rgba(232,178,106,.34);box-shadow:0 30px 70px -34px rgba(15,33,26,.6);
  background:
    radial-gradient(120% 90% at 50% -10%, rgba(232,178,106,.18), transparent 60%),
    linear-gradient(165deg,#1d3a2e 0%,#16302594 30%,#13291f 60%,#0f211a 100%);
}
.spbanner.sp-bold::before{height:0}
.spbanner.sp-bold > div:first-child{text-align:center}
.spbanner.sp-bold .sp-badge{background:var(--line-green);color:#fff;box-shadow:0 10px 24px -10px rgba(6,199,85,.55)}
.spbanner.sp-bold .sp-badge .bubble{background:#fff}
.spbanner.sp-bold .sp-badge .bubble::after{background:var(--line-green)}
.spbanner.sp-bold .sp-head{color:#fff;text-align:center;font-size:clamp(25px,3.6vw,38px);line-height:1.32;text-shadow:0 2px 18px rgba(0,0,0,.35)}
.spbanner.sp-bold .sp-head .big{font-size:1.3em;color:var(--warm);background:none;padding:0}
.spbanner.sp-bold .sp-head .free{font-size:1.3em;background:linear-gradient(180deg,#F7D89B,#E0A451);-webkit-background-clip:text;background-clip:text;color:transparent;padding:0}
.spbanner.sp-bold .sp-sub{color:#cfe0d4}
.spbanner.sp-bold .sp-divider{background:linear-gradient(90deg,transparent,rgba(232,178,106,.7),transparent)}
.spbanner.sp-bold .perk{background:rgba(244,239,226,.05);border-color:rgba(232,178,106,.16)}
.spbanner.sp-bold .perk-no{color:#0f211a;background:linear-gradient(165deg,#F7D89B,#D99A42);box-shadow:0 8px 18px -8px rgba(217,154,66,.6)}
.spbanner.sp-bold .perk-no small{color:#3a2a08}
.spbanner.sp-bold .perk-head h3{color:#fff}
.spbanner.sp-bold .perk-head h3 em{color:var(--warm)}
.spbanner.sp-bold .perk p{color:#bccabf}
.spbanner.sp-bold .perk p b{color:#F4EFE2}
.spbanner.sp-bold .perk p .em{color:var(--warm)}
.spbanner.sp-bold .sp-media{background:#0d1d16;border-color:rgba(232,178,106,.28);background-image:repeating-linear-gradient(135deg,transparent 0 11px,rgba(232,178,106,.05) 11px 12px)}
.spbanner.sp-bold .sp-media[data-label]::after{color:rgba(244,239,226,.45)}
.spbanner.sp-bold .sp-media .mock-title{color:#F4EFE2}
.spbanner.sp-bold .sp-media .mock-title b{color:var(--warm)}
.spbanner.sp-bold .sp-media.video::before{background:rgba(255,255,255,.92)}
.spbanner.sp-bold .sp-media.video::after{border-color:transparent transparent transparent #16302a}
.spbanner.sp-bold .sp-spec{background:rgba(13,29,22,.55);border-color:rgba(232,178,106,.18)}
.spbanner.sp-bold .sp-spec h4{color:var(--warm)}
.spbanner.sp-bold .sp-checks li{color:#d4e0d6}
.spbanner.sp-bold .sp-checks li::before{background:var(--line-green);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='17' height='17' viewBox='0 0 19 19'%3E%3Cpath d='M5 9.6l2.6 2.6L14 6' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}
.spbanner.sp-bold .sp-checks li.more{color:#9fb3a4}
.spbanner.sp-bold .sp-cta{
  background:linear-gradient(180deg,#10bd5a,#06A348);border-color:#1ec96a;border-radius:14px;padding:17px 30px;
  font-family:var(--display);font-size:clamp(16px,2.2vw,20px);box-shadow:0 18px 38px -14px rgba(6,199,85,.7);
}
.spbanner.sp-bold .sp-cta:hover{background:linear-gradient(180deg,#13c763,#06A348)}
.spbanner.sp-bold .sp-foot{color:#9fb3a4}
/* 風神雷神 art slots in the top corners */
.sp-fujin{position:absolute;top:0;width:clamp(78px,11vw,128px);height:clamp(108px,15vw,168px);z-index:0;opacity:.92}
.sp-fujin.left{left:0}
.sp-fujin.right{right:0}
.sp-fujin image-slot{width:100%;height:100%;display:block}
.sp-fujin .fl{position:absolute;top:8px;writing-mode:vertical-rl;font-family:var(--display);font-weight:700;font-size:12px;letter-spacing:.18em;color:var(--warm);background:rgba(15,33,26,.6);border:1px solid rgba(232,178,106,.4);border-radius:6px;padding:8px 4px;z-index:2}
.sp-fujin.left .fl{left:8px}
.sp-fujin.right .fl{right:8px}
@media(max-width:680px){.sp-fujin{display:none}}

/* ===================================================================
   PROGRAM intro CTA (禁煙プログラムとは → LP) — light, for MEDIA use
   =================================================================== */
.progcta{display:grid;grid-template-columns:auto 1fr auto;gap:22px;align-items:center;
  background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);padding:clamp(22px,2.6vw,30px) clamp(24px,3vw,34px);position:relative;overflow:hidden}
.progcta::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--primary),var(--primary-deep))}
.progcta .pg-mark{width:60px;height:60px;flex:0 0 auto;border-radius:18px;background:var(--primary-soft);display:grid;place-items:center}
.progcta .pg-mark svg{width:34px;height:34px}
.progcta .pg-body .eyebrow{margin-bottom:8px}
.progcta .pg-body h3{font-family:var(--display);font-size:clamp(18px,2.2vw,23px);line-height:1.45;color:var(--ink);margin-bottom:8px}
.progcta .pg-body p{font-size:14.5px;color:var(--ink-dim);line-height:1.8}
.progcta .pg-body .tag{display:inline-block;margin-top:10px;font-family:var(--num);font-size:11.5px;font-weight:700;letter-spacing:.04em;color:#7a5a1e;background:var(--warm-soft);padding:5px 11px;border-radius:999px}
.progcta .pg-act{flex:0 0 auto}
@media(max-width:680px){
  .progcta{grid-template-columns:1fr;gap:16px;text-align:left}
  .progcta .pg-act{width:100%}
  .progcta .pg-act .btn{width:100%}
}

/* ===================================================================
   AUTHOR / 筆者 profile box (articles)
   =================================================================== */
.author-box{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;background:var(--surface-alt);border:1px solid var(--line);border-radius:var(--radius);padding:26px clamp(20px,2.6vw,30px);margin:40px 0 8px}
.author-box .ab-face{width:72px;height:72px;flex:0 0 auto;border-radius:50%;background:linear-gradient(155deg,#5fb892,#2a6651);display:grid;place-items:center;color:#fff}
.author-box .ab-face svg{width:40px;height:40px}
.author-box .ab-role{font-family:var(--num);font-size:10.5px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--primary)}
.author-box .ab-name{font-family:var(--display);font-weight:900;font-size:19px;color:var(--ink);margin:4px 0 2px}
.author-box .ab-name span{font-family:var(--num);font-size:12px;font-weight:700;color:var(--ink-soft);margin-left:8px;letter-spacing:.04em}
.author-box .ab-bio{font-size:14px;color:var(--ink-dim);line-height:1.85;margin:10px 0 0}
.author-box .ab-bio b{color:var(--ink)}
@media(max-width:600px){.author-box{grid-template-columns:1fr;gap:14px}}

/* ===================================================================
   PRICING CARD (shared by Home LP + Service Site)
   =================================================================== */
.pricecard{position:relative;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}
.pricecard::before{content:"";position:absolute;left:0;right:0;top:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--warm))}
.pc-badge{display:inline-flex;align-items:center;gap:9px;margin:clamp(26px,3vw,34px) clamp(26px,3vw,40px) 0;padding:8px 16px;border-radius:999px;background:var(--warm-soft);color:#7a5a1e;font-weight:700;font-size:13px;letter-spacing:.02em}
.pc-badge .pulse{width:8px;height:8px;border-radius:50%;background:var(--warm);box-shadow:0 0 0 4px rgba(232,178,106,.25)}
.pc-grid{display:grid;grid-template-columns:1fr .9fr;gap:0}
.pc-incl{list-style:none;margin:0;padding:clamp(24px,3vw,34px) clamp(26px,3vw,40px);display:grid;gap:16px}
.pc-incl li{display:flex;gap:13px;align-items:flex-start}
.pc-incl li .ic{width:22px;height:22px;flex:0 0 auto;margin-top:2px;border-radius:50%;background:var(--primary-soft);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 19 19'%3E%3Cpath d='M5 9.6l2.6 2.6L14 6' fill='none' stroke='%232A6651' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.pc-incl li b{display:block;font-family:var(--display);font-size:16px;color:var(--ink)}
.pc-incl li span{font-size:13.5px;color:var(--ink-dim);line-height:1.7}
.pc-cta{background:var(--surface-alt);border-left:1px solid var(--line);padding:clamp(24px,3vw,34px) clamp(26px,3vw,36px);display:flex;flex-direction:column;justify-content:center;gap:14px}
.pc-cta .pc-note{font-size:14.5px;color:var(--ink-dim);line-height:1.85}
.pc-cta .btn{width:100%}
.pc-cta .fineprint{margin-top:2px}
@media(max-width:820px){.pc-grid{grid-template-columns:1fr}.pc-cta{border-left:0;border-top:1px solid var(--line)}}
