@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho+B1:wght@500;600;700;800&family=Zen+Kaku+Gothic+New:wght@400;500;700&display=swap');

:root{
  --bg:#FBF8F3;
  --warm:#F3ECE0;
  --panel:#FFFFFF;
  --ink:#3B362F;
  --ink-soft:#6F665B;
  --muted:#9C9387;
  --taupe:#9A7B50;
  --taupe-d:#6C5634;
  --taupe-soft:#EDE3D2;
  --line:#E6DCCC;
  --line-soft:#EFE7DA;
  --dark:#2B2824;
  --check:#BFA068;
  --rose:#D67E92;
  --rose-d:#C45F78;
  --rose-soft:#F7E8EB;
  --shadow:0 18px 50px -28px rgba(76,60,40,.35);
  /* ---- semantic accent / CTA colors (palette-swappable) ---- */
  --c-accent:#9A7B50; --c-accent-d:#6C5634;
  --c-cta-from:#a3855a; --c-cta-to:#8a6c43;
  --c-buy-from:#dd8497; --c-buy-to:#c75f79;
  --c-buy-ink:#C45F78; --c-buy-soft:#F7E8EB;
}

/* ===== PALETTE: TAUPE (unified premium) ===== */
:root[data-palette="taupe"]{
  --c-buy-from:#9a7c4f; --c-buy-to:#6f5733;
  --c-buy-ink:#6C5634; --c-buy-soft:#EDE3D2;
}
/* ===== PALETTE: BLUE (serra accent) ===== */
:root[data-palette="blue"]{
  --c-accent:#3F93B6; --c-accent-d:#2C7191;
  --c-cta-from:#5AA6C6; --c-cta-to:#3C8FB1;
  --c-buy-from:#4FA0C2; --c-buy-to:#327E9F;
  --c-buy-ink:#2C7191; --c-buy-soft:#E3EFF4;
}

*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  font-family:'Zen Kaku Gothic New',system-ui,sans-serif;
  background:
    radial-gradient(120% 90% at 50% 0%, #efeae2 0%, #e4ded4 55%, #d8d2c7 100%);
  color:var(--ink);
  display:grid;
  place-items:center;
  -webkit-font-smoothing:antialiased;
  overflow:hidden;
}

/* ===== device shell ===== */
.stage{
  display:grid;
  place-items:center;
  width:100vw;height:100vh;
  padding:14px;
}
.phone{
  position:relative;
  width:402px;
  height:min(872px,calc(100vh - 28px));
  background:#16130f;
  border-radius:56px;
  padding:13px;
  box-shadow:
    0 2px 2px rgba(255,255,255,.35) inset,
    0 50px 90px -40px rgba(40,32,22,.7),
    0 0 0 2px #2c261e;
}
.screen{
  position:relative;
  width:100%;height:100%;
  background:var(--bg);
  border-radius:44px;
  overflow:hidden;
  display:flex;flex-direction:column;
}
/* status bar */
.statusbar{
  position:absolute;top:0;left:0;right:0;height:54px;z-index:40;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 30px 0;
  font-size:14px;font-weight:700;color:var(--ink);
  pointer-events:none;
  background:linear-gradient(var(--bg) 58%,transparent);
}
.statusbar .si{display:flex;gap:6px;align-items:center}
.notch{
  position:absolute;top:14px;left:50%;transform:translateX(-50%);
  width:116px;height:32px;background:#0d0b08;border-radius:20px;z-index:41;
}
.notch::after{content:"";position:absolute;right:16px;top:50%;transform:translateY(-50%);
  width:11px;height:11px;border-radius:50%;background:#1c1813;box-shadow:0 0 0 2px #322a20}

/* scroll area */
.scroll{
  flex:1;overflow-y:auto;overflow-x:hidden;
  scroll-behavior:smooth;
  scrollbar-width:none;
}
.scroll::-webkit-scrollbar{display:none}

/* ===== reveal ===== */
.rv{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}.rv.d4{transition-delay:.32s}

/* ===== typography ===== */
.mincho{font-family:'Shippori Mincho B1',serif}
section{padding:54px 24px}
.eyebrow{font-size:13px;letter-spacing:.18em;color:var(--c-accent);font-weight:700;text-align:center}
.s-title{font-family:'Shippori Mincho B1',serif;font-weight:700;font-size:25px;line-height:1.5;text-align:center;letter-spacing:.01em;text-wrap:balance;word-break:auto-phrase}
.kicker{display:flex;align-items:center;justify-content:center;gap:11px;font-size:11px;letter-spacing:.24em;color:var(--c-accent);font-weight:700;margin-bottom:14px}
.kicker::before,.kicker::after{content:"";width:26px;height:1px;background:currentColor;opacity:.55}
.s-title .accent{color:var(--c-accent)}
.lead{font-size:14.5px;line-height:2;color:var(--ink-soft)}

/* ===== HERO ===== */
.hero{padding:0;position:relative;background:var(--bg)}
.statusgap{height:50px}
.anno{display:flex;align-items:center;justify-content:center;gap:9px;flex-wrap:wrap;
  background:linear-gradient(95deg,var(--c-buy-from),var(--c-buy-to));color:#fff;
  padding:9px 14px;text-align:center;font-size:11.5px;font-weight:700;letter-spacing:.02em;line-height:1.45}
.anno span{white-space:nowrap}
.anno .dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.7)}
.anno b{font-size:13px}
.anno .yen{font-family:'Shippori Mincho B1',serif;font-size:15px;font-weight:800;letter-spacing:0}
.hero-head{display:flex;align-items:center;justify-content:space-between;padding:14px 24px 2px}
.hero-logo{font-family:'Shippori Mincho B1',serif;font-size:26px;letter-spacing:.14em;color:var(--ink);font-weight:600}
.hero-logo img{height:30px;width:auto;display:block}
.hero-badge{width:64px;height:64px;border-radius:50%;background:var(--dark);color:#fff;
  display:grid;place-content:center;text-align:center;gap:1px;border:1px solid rgba(255,255,255,.22)}
.hero-badge small{font-size:8px;letter-spacing:.08em;opacity:.82}
.hero-badge b{font-family:'Shippori Mincho B1',serif;font-size:13px;font-weight:600;letter-spacing:.06em}
.hero-h1{font-family:'Shippori Mincho B1',serif;font-weight:700;font-size:27px;line-height:1.62;color:var(--ink);letter-spacing:.005em;padding:10px 24px 16px}
.hero-h1 .mk{background:linear-gradient(transparent 56%,var(--c-buy-soft) 56%,var(--c-buy-soft) 92%,transparent 92%);padding:0 3px;font-weight:800}
.hero-photo{position:relative;width:100%;height:352px}
.hero-photo image-slot{width:100%;height:100%;display:block}
.hero-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(251,248,243,.18) 0%,transparent 14%,transparent 74%,rgba(251,248,243,.75) 100%);pointer-events:none}
.hero-body{margin-top:22px;padding:0 26px 4px}
.hero-small{font-size:13px;line-height:2;color:var(--ink-soft)}
.hero-h2{font-family:'Shippori Mincho B1',serif;font-weight:700;font-size:23px;line-height:1.55;margin-top:20px}
.hero-tag{display:inline-flex;align-items:center;gap:7px;margin-top:14px;font-size:13px;font-weight:700;white-space:nowrap;
  color:var(--c-buy-ink);background:var(--c-buy-soft);padding:8px 15px;border-radius:999px;letter-spacing:.02em}
.hero-tag .pdot{width:7px;height:7px;border-radius:50%;background:var(--c-buy-ink)}
.hero-points{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.hero-points span{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;color:var(--c-accent);
  border:1px solid var(--c-accent);border-radius:999px;padding:7px 13px;background:rgba(255,255,255,.5)}
.hero-points span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--c-accent)}
.hero-cta-wrap{padding:18px 26px 40px}

/* buttons */
.btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  font-weight:700;font-size:15px;border:none;cursor:pointer;text-decoration:none;border-radius:999px;letter-spacing:.02em}
.btn-taupe{background:linear-gradient(180deg,var(--c-cta-from),var(--c-cta-to));color:#fff;padding:18px 20px;
  box-shadow:0 14px 26px -12px rgba(120,92,52,.7)}
.btn-taupe .ar{transition:transform .3s}
.btn-taupe:active .ar{transform:translateX(4px)}
.btn-rose{background:linear-gradient(110deg,var(--c-buy-from),var(--c-buy-to));color:#fff;padding:19px 20px;
  box-shadow:0 16px 30px -12px rgba(196,95,120,.7)}
.btn-sub{font-size:11px;font-weight:500;opacity:.92;margin-top:2px}

/* ===== WORRIES ===== */
.sec-warm{background:var(--warm)}
.worry-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:26px}
.worry{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px 13px;display:flex;gap:9px;align-items:flex-start}
.worry .ck{flex:none;width:18px;height:18px;border-radius:5px;border:1.5px solid var(--check);display:grid;place-items:center;margin-top:1px}
.worry .ck svg{width:11px;height:11px;stroke:var(--check)}
.worry p{font-size:12.5px;line-height:1.55;color:var(--ink);font-weight:500}
.clutter{position:relative;margin-top:22px;border-radius:18px;overflow:hidden;height:230px}
.clutter image-slot{width:100%;height:100%;display:block}
.clutter-bubble{position:absolute;right:14px;top:18px;width:140px;height:140px;border-radius:50%;
  background:rgba(38,35,31,.9);color:#fff;display:grid;place-content:center;text-align:center;padding:14px;
  font-family:'Shippori Mincho B1',serif;font-size:13px;line-height:1.7;backdrop-filter:blur(2px)}
.clutter-bubble b{color:#f0d9b6}
.cause{margin-top:24px;text-align:center;font-family:'Shippori Mincho B1',serif;font-size:16px;line-height:1.9;color:var(--ink)}
.cause .hl{color:var(--c-accent);font-weight:700;border-bottom:2px solid var(--taupe-soft)}

/* ===== STEPS ===== */
.steps{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.step{display:flex;gap:14px;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:15px 16px;position:relative}
.step .num{flex:none;width:52px;text-align:center}
.step .num .ic{width:34px;height:34px;margin:0 auto 4px;color:var(--c-accent)}
.step .num small{font-size:9px;letter-spacing:.14em;color:var(--c-accent);font-weight:700}
.step .tx h4{font-family:'Shippori Mincho B1',serif;font-size:15px;margin-bottom:3px}
.step .tx p{font-size:12px;color:var(--ink-soft);line-height:1.6}
.step:not(:last-child)::after{content:"";position:absolute;left:42px;bottom:-12px;width:1px;height:12px;background:var(--line)}
.gift{margin-top:14px;background:linear-gradient(180deg,var(--c-accent),var(--c-accent-d));color:#fff;border-radius:16px;padding:20px;display:flex;gap:14px;align-items:center}
.gift .gic{flex:none;width:42px;height:42px;color:#f3e2c6}
.gift p{font-family:'Shippori Mincho B1',serif;font-size:14px;line-height:1.7}

/* ===== RESULT ===== */
.result-phone{margin:26px auto 0;width:206px;background:#fff;border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);padding:14px 14px 18px;position:relative}
.result-phone .rp-bar{width:46px;height:5px;border-radius:5px;background:#e9e0d2;margin:2px auto 12px}
.result-phone h5{text-align:center;font-size:11px;letter-spacing:.16em;color:var(--muted);font-weight:700;margin-bottom:10px}
.result-faces{display:flex;justify-content:center;gap:10px;margin-bottom:12px}
.result-faces .face{width:62px;height:62px;border-radius:50%;display:grid;place-items:center;
  background:var(--c-buy-soft);color:var(--c-buy-ink);border:1px solid var(--line);
  font-family:'Shippori Mincho B1',serif;font-size:18px;font-weight:600}
.result-type{text-align:center;background:var(--taupe-soft);border-radius:12px;padding:11px}
.result-type small{font-size:10px;color:var(--ink-soft)}
.result-type b{display:block;font-family:'Shippori Mincho B1',serif;font-size:15px;color:var(--c-accent-d);margin-top:3px}
.result-lead{margin-top:26px;text-align:center}
.result-lead .big{font-family:'Shippori Mincho B1',serif;font-size:21px;line-height:1.6;margin-top:6px}
.result-lead .big .hl{color:var(--c-accent)}
.result-lead p{margin-top:16px}
.products{display:flex;justify-content:center;gap:24px;margin-top:28px}
.product{text-align:center}
.product image-slot{width:104px;height:156px;display:block;margin-bottom:8px;background:#fff;border:1px solid var(--line);border-radius:14px}
.product span{font-size:12px;color:var(--ink-soft);font-weight:500;letter-spacing:.08em}
.merits{margin-top:30px;display:flex;flex-direction:column;gap:14px}
.merit{display:flex;gap:13px;align-items:flex-start;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:15px 16px}
.merit .mi{flex:none;width:30px;height:30px;color:var(--c-accent)}
.merit p{font-size:13px;line-height:1.65}
.merit p b{color:var(--c-accent-d)}

/* ===== diagnosis result card ===== */
.dx-card{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);padding:24px 20px 22px;max-width:332px;margin:24px auto 0}
.dx-head{display:flex;justify-content:space-between;align-items:center}
.dx-head .lbl{font-size:10px;letter-spacing:.16em;color:var(--muted);font-weight:700}
.dx-head .pill{font-size:10px;font-weight:700;color:var(--c-buy-ink);background:var(--c-buy-soft);padding:4px 11px;border-radius:999px}
.dx-ring{position:relative;width:132px;height:132px;margin:14px auto 6px}
.dx-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.dx-ring .track{fill:none;stroke:var(--line);stroke-width:9}
.dx-ring .prog{fill:none;stroke:var(--c-accent);stroke-width:9;stroke-linecap:round;
  stroke-dasharray:327;stroke-dashoffset:327;transition:stroke-dashoffset 1.3s cubic-bezier(.2,.8,.2,1) .25s}
.dx-card.in .dx-ring .prog{stroke-dashoffset:26}
.dx-ring .ctr{position:absolute;inset:0;display:grid;place-content:center;text-align:center;line-height:1}
.dx-ring .ctr b{font-family:'Shippori Mincho B1',serif;font-size:36px;color:var(--c-accent-d);font-weight:700}
.dx-ring .ctr small{display:block;font-size:11px;color:var(--ink-soft);margin-top:4px;letter-spacing:.12em}
.dx-type{text-align:center;margin-top:4px}
.dx-type small{font-size:11px;color:var(--ink-soft)}
.dx-type b{display:block;font-family:'Shippori Mincho B1',serif;font-size:21px;color:var(--ink);margin-top:3px}
.dx-people{display:flex;gap:10px;margin-top:18px}
.dx-person{flex:1;background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:12px 8px;text-align:center}
.dx-person .who{font-family:'Shippori Mincho B1',serif;font-size:14px;display:block}
.dx-person .tag{display:inline-block;margin-top:7px;font-size:10.5px;font-weight:700;color:var(--c-accent);border:1px solid var(--c-accent);border-radius:999px;padding:3px 10px}
.dx-cause{margin-top:14px;background:var(--taupe-soft);border-radius:12px;padding:12px;text-align:center;font-size:12.5px;color:var(--ink)}
.dx-cause b{color:var(--c-accent-d);font-weight:700}
.routine{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:24px}
.routine .rstep{text-align:center}
.routine .rstep .sno{display:block;font-size:10px;font-weight:700;letter-spacing:.12em;color:var(--c-accent);margin-bottom:7px}
.routine .rstep image-slot{width:98px;height:146px;display:block;background:#fff;border:1px solid var(--line);border-radius:14px}
.routine .rstep .rname{display:block;margin-top:8px;font-size:12px;color:var(--ink-soft);font-weight:500;letter-spacing:.08em}
.routine .rarrow{color:var(--c-accent);font-size:22px;padding-bottom:34px}

/* ===== USE SCENES ===== */
.scenes{display:flex;flex-direction:column;gap:16px;margin-top:28px}
.scene{display:flex;gap:16px;align-items:center}
.scene image-slot{flex:none;width:110px;height:96px;display:block}
.scene p{flex:1;font-size:13px;line-height:1.8;text-wrap:pretty;word-break:auto-phrase}
.scene .n{font-family:'Shippori Mincho B1',serif;color:var(--c-accent);font-size:13px;display:block;margin-bottom:3px}

/* ===== BEFORE / AFTER ===== */
.ba{display:flex;flex-direction:column;gap:16px;margin-top:26px}
.ba-card{border-radius:18px;overflow:hidden;border:1px solid var(--line);background:var(--panel)}
.ba-img{position:relative;height:150px}
.ba-img image-slot{width:100%;height:100%;display:block}
.ba-img .lbl{position:absolute;left:12px;top:12px;font-family:'Shippori Mincho B1',serif;font-size:14px;color:#fff;letter-spacing:.12em;padding:4px 12px;background:rgba(43,40,36,.82);border-radius:999px}
.ba-list{padding:16px}
.ba-list li{list-style:none;display:flex;gap:9px;align-items:flex-start;font-size:13px;line-height:1.55;padding:7px 0;color:var(--ink)}
.ba-list li:not(:last-child){border-bottom:1px dashed var(--line)}
.ba-list .ck{flex:none;width:17px;height:17px;border-radius:5px;display:grid;place-items:center;margin-top:1px}
.ba-before .ck{background:#ded5c8}.ba-before .ck svg{stroke:#8c8275}
.ba-after .ck{background:var(--c-accent)}.ba-after .ck svg{stroke:#fff}
.ba-arrow{text-align:center;color:var(--c-accent);font-size:22px}

/* ===== REASONS ===== */
.reasons{display:flex;flex-direction:column;gap:16px;margin-top:28px}
.reason{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:22px;text-align:center}
.reason .rno{font-family:'Shippori Mincho B1',serif;font-size:13px;color:var(--c-accent);letter-spacing:.1em}
.reason h4{font-family:'Shippori Mincho B1',serif;font-size:18px;margin:6px 0 12px;line-height:1.5}
.reason p{font-size:13px;color:var(--ink-soft);line-height:1.8}
.reason-badges{display:flex;justify-content:center;gap:10px;margin:8px 0 12px}
.rb{width:78px;text-align:center}
.rb .ic{width:46px;height:46px;margin:0 auto 6px;color:var(--c-accent)}
.rb small{font-size:11px;font-weight:700;color:var(--ink)}
.reason .note{font-size:10px;color:var(--muted);margin-top:8px}
.reason .drop{width:56px;height:56px;margin:0 auto 10px;color:var(--c-accent)}

/* ===== COMPARE TABLE ===== */
.cmp{margin-top:26px;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--panel)}
.cmp table{width:100%;border-collapse:collapse;font-size:11.5px}
.cmp th,.cmp td{padding:13px 6px;text-align:center;border-bottom:1px solid var(--line-soft)}
.cmp thead th{background:var(--warm);font-weight:700;font-size:10.5px;line-height:1.3;color:var(--ink)}
.cmp thead th.serra{background:var(--c-accent);color:#fff}
.cmp tbody th{text-align:left;padding-left:12px;font-weight:500;font-size:11px;color:var(--ink)}
.cmp td.serra{background:#faf4ea;font-weight:700}
.cmp .o2{color:var(--c-accent);font-size:16px;font-weight:700}
.cmp .o1{color:#b9a98f;font-size:15px}
.cmp .tri{color:#cdbfa6;font-size:13px}
.cmp .x{color:#cbb0b0;font-size:14px}
.cmp tr:last-child td,.cmp tr:last-child th{border-bottom:none}

/* ===== FAQ ===== */
.faq{margin-top:26px;display:flex;flex-direction:column;gap:10px}
.qa{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.qa-q{width:100%;display:flex;gap:12px;align-items:center;padding:16px 16px;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit}
.qa-q .qm{flex:none;width:24px;height:24px;border-radius:50%;background:var(--taupe-soft);color:var(--c-accent-d);display:grid;place-items:center;font-family:'Shippori Mincho B1',serif;font-weight:700;font-size:13px}
.qa-q .qt{flex:1;font-size:13.5px;font-weight:500;line-height:1.5}
.qa-q .qx{flex:none;color:var(--c-accent);transition:transform .35s;width:14px;height:14px}
.qa.open .qx{transform:rotate(180deg)}
.qa-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.qa-a p{padding:0 16px 16px 52px;font-size:12.5px;line-height:1.8;color:var(--ink-soft)}
.faq-note{font-size:10px;color:var(--muted);text-align:right;margin-top:10px}

/* ===== CLOSING / PRICE ===== */
.closing{background:linear-gradient(180deg,#fff 0%,#fffafa 42%,#fdeff3 74%,#fff 100%);color:var(--ink);padding:50px 20px 56px;border-radius:0}
.closing .s-title{color:var(--ink)}
.closing .c-lead{text-align:center;font-size:14px;line-height:1.9;color:var(--ink-soft);margin-top:12px}
.closing .kicker{width:max-content;max-width:100%;margin-left:auto;margin-right:auto;background:var(--c-buy-soft);color:var(--c-buy-ink);border-radius:999px;padding:8px 26px;font-size:13px;letter-spacing:.08em}
.closing .kicker::before,.closing .kicker::after{display:none}
.set-title{font-size:32px;line-height:1.25;margin-top:14px;letter-spacing:0}
.set-title span{font-family:'Shippori Mincho B1',serif;font-size:56px;color:var(--c-buy-ink);font-weight:800;line-height:.8;padding:0 4px}
.price-card{margin-top:30px;background:var(--bg);color:var(--ink);border-radius:22px;padding:24px 20px;box-shadow:0 30px 60px -30px rgba(0,0,0,.6)}
.price-tag{display:inline-block;background:var(--c-buy-soft);color:var(--c-buy-ink);font-size:11px;font-weight:700;padding:5px 12px;border-radius:999px;letter-spacing:.05em}
.price-name{font-family:'Shippori Mincho B1',serif;font-size:20px;text-align:center;margin:14px 0 2px}
.price-name small{display:block;font-size:12px;color:var(--ink-soft);font-weight:400;margin-top:4px;font-family:'Zen Kaku Gothic New'}
.price-em{font-family:'Shippori Mincho B1',serif;font-size:16px;font-weight:800;color:var(--c-buy-ink);line-height:1}
.price-delta,.price-per{font-family:'Shippori Mincho B1',serif;color:var(--c-buy-ink);font-weight:800}
.price-was{text-align:center;font-size:12px;color:var(--muted);margin-top:14px}
.price-was s{}
.price-main{text-align:center;margin-top:2px;display:flex;align-items:baseline;justify-content:center;gap:6px}
.price-main .lab{font-size:13px;color:var(--c-buy-ink);font-weight:700}
.price-main .yen{font-family:'Shippori Mincho B1',serif;font-size:52px;font-weight:800;color:var(--c-buy-ink);line-height:1}
.price-main .u{font-size:14px;color:var(--c-buy-ink);font-weight:700}
.price-main .tax{font-size:11px;color:var(--muted)}
.price-strip{margin-top:14px;background:linear-gradient(110deg,var(--c-buy-from),var(--c-buy-to));color:#fff;border-radius:10px;padding:9px 12px;text-align:center;font-size:12px;font-weight:700}
.price-meta{display:flex;justify-content:center;gap:18px;margin-top:14px;text-align:center}
.price-meta div b{font-family:'Shippori Mincho B1',serif;font-size:20px;color:var(--c-accent-d);white-space:nowrap}
.price-meta div small{display:block;font-size:10px;color:var(--ink-soft);margin-top:3px;line-height:1.5}
.perks{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:18px}
.perk{background:var(--warm);border-radius:12px;padding:12px 6px;text-align:center}
.perk .pi{width:26px;height:26px;margin:0 auto 6px;color:var(--c-accent)}
.perk small{font-size:10px;font-weight:700;line-height:1.4;display:block;color:var(--ink)}
.price-card .btn-rose{margin-top:20px}
.guarantee{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:12px;font-size:11px;color:var(--ink-soft)}
.bottles{display:flex;justify-content:center;gap:18px;margin-top:6px}
.bottle{text-align:center}
.bottle span{display:block;margin-top:8px;font-size:12px;color:#cdbfa6;font-weight:500;letter-spacing:.1em}
.bottles image-slot{width:88px;height:132px;display:block;background:#fff;border:1px solid rgba(255,255,255,.5);border-radius:14px}

.set-chooser{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.08fr);gap:10px;margin-top:28px}
.set-card{position:relative;background:rgba(255,255,255,.98);border:1px solid rgba(229,222,216,.95);border-radius:18px;padding:18px 10px 14px;text-align:center;box-shadow:0 18px 34px -24px rgba(64,48,40,.42);overflow:hidden;min-width:0}
.set-card-couple{border:2px solid rgba(216,74,113,.9);box-shadow:0 22px 44px -24px rgba(216,74,113,.42);padding-top:48px}
.set-badge{position:absolute;top:4px;right:3px;width:54px;height:54px;border-radius:50%;background:radial-gradient(circle at 34% 28%,#fff7d9 0%,#efd184 48%,#d8a848 100%);color:#4e3724;border:2px solid #d9ae58;display:grid;place-content:center;text-align:center;font-family:'Shippori Mincho B1',serif;font-size:10px;font-weight:800;line-height:1.12;box-shadow:0 9px 18px -10px rgba(90,58,20,.72);z-index:2}
.set-badge::before,.set-badge::after{content:"";position:absolute;bottom:-14px;width:16px;height:24px;background:linear-gradient(180deg,#e95383,#c73867);z-index:-1}
.set-badge::before{left:10px;transform:rotate(14deg);clip-path:polygon(0 0,100% 0,72% 100%,48% 72%,20% 100%)}
.set-badge::after{right:10px;transform:rotate(-14deg);clip-path:polygon(0 0,100% 0,80% 100%,52% 72%,28% 100%)}
.set-badge::first-line{font-size:10px}
.set-ribbon{position:absolute;left:0;right:0;top:0;background:linear-gradient(110deg,var(--c-buy-from),var(--c-buy-to));color:#fff;padding:10px 56px 10px 12px;font-size:12px;font-weight:700;line-height:1.3;text-align:left}
.set-for{display:inline-block;background:#faf8f6;border-radius:999px;font-size:12px;line-height:1.45;color:var(--ink);font-weight:700;margin:0 0 12px;padding:7px 10px;max-width:100%}
.set-card h3{font-family:'Shippori Mincho B1',serif;font-size:21px;line-height:1.35;margin:0;color:var(--ink)}
.set-price{display:flex;align-items:baseline;justify-content:center;gap:4px;margin-top:8px;color:var(--c-buy-ink)}
.set-price span{font-family:'Shippori Mincho B1',serif;font-size:38px;font-weight:800;line-height:1;letter-spacing:0}
.set-price small{font-size:14px;font-weight:700;color:var(--c-buy-ink)}
.set-tax{font-size:12px;font-weight:700;color:var(--ink);line-height:1.2;margin-top:2px}
.set-content{font-size:13px;font-weight:700;color:var(--ink);margin-top:10px;line-height:1.45}
.set-products{display:flex;align-items:flex-end;justify-content:center;gap:7px;margin:16px auto 15px;max-width:100%}
.set-product-img{display:block;width:auto;height:116px;max-width:100%;object-fit:contain}
.set-products-couple{gap:5px}
.set-products-couple .set-product-img{height:86px}
.set-product-pair{display:flex;gap:1px;align-items:flex-end}
.set-plus{font-family:'Shippori Mincho B1',serif;font-size:24px;color:var(--ink);line-height:1}
.set-deal{background:var(--c-buy-soft);color:var(--ink);border:1px solid rgba(200,90,120,.14);border-radius:10px;padding:8px 8px;font-size:12px;font-weight:700;line-height:1.38;margin:10px 0 0}
.set-deal strong,.set-deal b{color:var(--c-buy-ink)}
.set-split{color:#3f3933;background:#fff;border:1px solid rgba(200,90,120,.32);border-radius:12px;padding:11px 18px;margin:9px 2px 0;font-size:14px;font-weight:700;line-height:1.55}
.set-perks{display:grid;grid-template-columns:1fr;gap:5px;margin-top:13px}
.set-perks div{display:flex;align-items:center;gap:8px;background:#faf8f6;border:1px solid var(--line-soft);border-radius:8px;padding:8px 8px;text-align:left;color:var(--ink);min-width:0}
.set-perks b{font-size:12px;font-weight:700;line-height:1.25;color:var(--ink)}
.set-perks small{display:block;font-size:9px;line-height:1.3;color:#5f5750;font-weight:500}
.perk-icon{flex:0 0 auto;width:23px;height:23px;color:var(--ink);display:grid;place-items:center}
.perk-icon svg{width:23px;height:23px}
.set-btn{display:flex;align-items:center;justify-content:center;min-height:54px;border-radius:7px;text-decoration:none;font-size:13px;font-weight:700;line-height:1.45;padding:12px 8px;margin-top:15px}
.set-btn-normal{background:#fff;color:var(--ink);border:1.5px solid #bfb5aa}
.set-btn-couple{background:linear-gradient(110deg,var(--c-buy-from),var(--c-buy-to));color:#fff;border:1.5px solid transparent;box-shadow:0 16px 30px -16px rgba(196,95,120,.8)}
.set-bottom{margin:36px -20px 0;background:linear-gradient(100deg,#fff6f8 0%,#fde8ef 100%);padding:25px 24px 24px;text-align:left;color:var(--ink)}
.set-bottom p{font-family:'Shippori Mincho B1',serif;font-size:17px;font-weight:700;line-height:1.5;margin:0;color:var(--ink)}
.set-bottom p span{font-size:14px;color:var(--ink);margin-right:4px}
.set-bottom p b{font-family:'Shippori Mincho B1',serif;font-size:48px;color:var(--c-buy-ink);line-height:1}
.set-bottom p small{font-size:18px;color:var(--c-buy-ink);font-weight:800;margin:0 4px}
.set-bottom-copy{font-size:14px;line-height:1.9;color:#4f4841;margin-top:10px}
.set-benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:28px;text-align:center}
.set-benefits div{min-width:0}
.set-benefit-ic{width:58px;height:58px;border-radius:50%;background:var(--c-buy-soft);color:var(--c-buy-ink);display:grid;place-items:center;margin:0 auto 9px}
.set-benefit-ic svg{width:28px;height:28px}
.set-benefits b{display:block;font-size:13px;line-height:1.45;color:var(--ink)}
.set-benefits small{display:block;font-size:11px;line-height:1.4;color:#5f5750;margin-top:2px}
.set-note{font-size:12px;line-height:1.85;color:#5f5750;margin-top:22px;text-align:left}
@media (min-width:760px){
  .set-chooser{grid-template-columns:1fr 1.28fr;align-items:stretch;gap:22px}
  .set-card{padding:24px 20px 20px}
  .set-card-couple{padding-top:64px}
  .set-ribbon{font-size:15px;padding:14px 80px 14px 22px}
  .set-badge{width:76px;height:76px;right:12px;top:10px;font-size:13px}
  .set-card h3{font-size:28px}
  .set-price span{font-size:58px}
  .set-content{font-size:16px}
  .set-product-img{height:176px}
  .set-products-couple .set-product-img{height:140px}
  .set-deal{font-size:16px;padding:12px}
  .set-perks b{font-size:14px}
  .set-btn{font-size:16px;min-height:62px}
  .set-card{display:flex;flex-direction:column}
  .set-card .set-btn{margin-top:auto}
  .set-bottom{text-align:center}
}

/* ===== FLOATING CTA ===== */
.float-cta{position:absolute;left:13px;right:13px;bottom:14px;z-index:50;
  transform:translateY(140%);transition:transform .45s cubic-bezier(.2,.8,.2,1);opacity:0}
.float-cta.show{transform:none;opacity:1}
.float-cta .btn-rose{box-shadow:0 18px 36px -10px rgba(150,60,80,.6),0 0 0 6px rgba(251,248,243,.55)}
.home-ind{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);width:120px;height:5px;border-radius:5px;background:rgba(40,32,22,.32);z-index:45;pointer-events:none}

/* footer */
.foot{background:var(--dark);color:#9a9085;text-align:center;font-size:10px;padding:22px;letter-spacing:.08em}
.foot .fl{font-family:'Shippori Mincho B1',serif;color:#e7ddcc;font-size:18px;letter-spacing:.18em;margin-bottom:8px}
.foot .fl img{height:44px;width:auto;display:block;margin:0 auto 10px}
