:root {
  --brp-green: #10b981;
  --brp-green-2: #059669;
  --brp-green-soft: #ecfdf5;
  --brp-green-pale: #d1fae5;
}

.accent { color: var(--brp-green-2); }
.blue { color: var(--blue-2); }
.nowrap { white-space: nowrap; }
.hero { position:relative; overflow:hidden; padding:78px 0 66px; background: radial-gradient(circle at 12% 18%, rgba(18,143,232,.12), transparent 26%), radial-gradient(circle at 90% 18%, rgba(16,185,129,.18), transparent 28%), linear-gradient(180deg,#f7fbff 0%, #ffffff 100%); }
.hero::after { content:""; position:absolute; right:-110px; bottom:-140px; width:470px; height:470px; border-radius:50%; background:rgba(16,185,129,.09); }
.hero-grid { position:relative; z-index:1; display:grid; grid-template-columns: 1.02fr .98fr; gap:42px; align-items:center; }
.eyebrow { display:inline-flex; align-items:center; gap:8px; color:var(--blue-2); font-size:.82rem; font-weight:700; letter-spacing:.04em; }
.eyebrow::before { content:""; width:28px; height:3px; border-radius:999px; background:var(--brp-green); }
h1 { margin:18px 0 18px; color:var(--navy); font-size:clamp(2.55rem, 4.45vw, 4.05rem); line-height:1.08; letter-spacing:-.055em; text-wrap:balance; }
.hero-title { max-width: 760px; }
.hero-title__line { display:block; white-space:nowrap; }
.hero-title .accent { color: var(--brp-green-2); }
.hero-copy { max-width:620px; color:var(--muted); font-size:1.07rem; }
.hero-actions { display:flex; flex-wrap:wrap; gap:14px; margin-top:30px; }
.hero-note { margin-top:16px; color:var(--muted); font-size:.88rem; }
.hero .product-provider { margin-top: 12px; }
.hero-learn { display:flex; flex-wrap:wrap; align-items:center; gap:8px 10px; margin:14px 0 0; font-size:.88rem; font-weight:800; }
.hero-learn a { color:var(--blue-2); text-decoration:none; }
.hero-learn a:hover { text-decoration:underline; }
.hero-learn span { color:var(--muted); font-weight:700; }
.occurrence-preview { padding:34px 0 10px; }
.occurrence-preview__inner { display:grid; grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr); gap:24px 28px; align-items:start; padding:24px 26px; border-radius:28px; border:1px solid var(--brp-green-pale); background:linear-gradient(135deg, rgba(236,253,245,.95), rgba(255,255,255,.98)); box-shadow:var(--shadow-soft); }
.occurrence-preview__eyebrow { display:inline-flex; margin-bottom:10px; padding:5px 11px; border-radius:999px; background:white; border:1px solid var(--brp-green-pale); color:var(--brp-green-2); font-size:.72rem; font-weight:950; letter-spacing:.04em; }
.occurrence-preview__copy h2 { margin:0 0 10px; color:var(--navy); font-size:clamp(1.35rem, 2.4vw, 1.75rem); line-height:1.25; letter-spacing:-.03em; }
.occurrence-preview__copy p { margin:0; color:var(--muted); font-size:.92rem; line-height:1.75; }
.occurrence-preview__list { margin:0; padding:0; list-style:none; display:grid; gap:10px; }
.occurrence-preview__list li { display:grid; gap:3px; padding:12px 14px; border-radius:16px; background:white; border:1px solid var(--line); box-shadow:0 6px 16px rgba(6,58,111,.04); }
.occurrence-preview__list strong { color:var(--navy); font-size:.92rem; }
.occurrence-preview__list span { color:var(--muted); font-size:.82rem; line-height:1.55; }
.occurrence-preview__actions { grid-column:1 / -1; display:flex; flex-wrap:wrap; gap:12px; margin-top:2px; }
.kangxi-jump { display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin:22px auto 0; }
.kangxi-jump a { display:inline-flex; align-items:center; min-height:38px; padding:0 14px; border-radius:999px; background:white; border:1px solid var(--line); color:var(--navy); font-size:.85rem; font-weight:900; box-shadow:0 8px 20px rgba(6,58,111,.04); text-decoration:none; }
.kangxi-jump a:hover { color:var(--blue-2); border-color:rgba(18,143,232,.32); transform:translateY(-1px); }
.kangxi-card__more { margin:12px 0 0; font-size:.88rem; font-weight:900; }
.kangxi-card__more a { color:var(--blue-2); text-decoration:none; }
.kangxi-card__more a:hover { text-decoration:underline; }
.hero-badges { display:flex; flex-wrap:wrap; gap:10px; margin-top:22px; }
.hero-badge { display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:999px; background:white; border:1px solid var(--line); color:var(--navy); font-weight:850; font-size:.82rem; box-shadow:0 8px 22px rgba(6,58,111,.05); }
.hero-badge span { color:var(--brp-green-2); }
.hero-visual { position:relative; min-height:470px; }
.floating-icon { position:absolute; left:-8px; top:-4px; width:92px; height:92px; border-radius:24px; padding:6px; background:white; box-shadow:0 18px 40px rgba(6,58,111,.18); z-index:4; transform: rotate(-3deg); }
.floating-icon img { width:100%; height:100%; border-radius:20px; display:block; }
.browser { position:absolute; inset:30px 138px 30px 24px; background:white; border:1px solid var(--line); border-radius:22px; overflow:hidden; box-shadow:var(--shadow); }
.browser-bar { height:46px; display:flex; align-items:center; gap:8px; padding:0 16px; background:#fbfdff; border-bottom:1px solid var(--line); }
.browser-dot { width:10px; height:10px; border-radius:50%; background:#d7e1eb; }
.app-head { height:50px; display:flex; align-items:center; justify-content:space-between; padding:0 18px; border-bottom:1px solid var(--line); }
.app-title { font-weight:950; color:var(--navy); }
.toolbar { display:flex; gap:8px; }
.tool { width:28px; height:28px; border-radius:8px; background:var(--blue-soft); }
.table { padding:16px 18px 18px; }
.row { display:grid; grid-template-columns:1.35fr 1fr .75fr .75fr; gap:8px; align-items:center; padding:11px 0; border-bottom:1px solid #eef3f8; font-size:.78rem; }
.row.head { color:var(--muted); font-weight:900; }
.link { color:var(--blue-2); font-weight:850; }
.status { display:inline-flex; align-items:center; justify-content:center; border-radius:999px; padding:2px 8px; font-weight:900; font-size:.68rem; }
.s1 { color:#a56000; background:#fff4d7; } .s2 { color:#0c6b42; background:#e6f7ee; } .s3 { color:#075ca8; background:#eaf6ff; }
.memo-panel { position:absolute; right:0; top:70px; width:276px; background:white; border:1px solid rgba(18,143,232,.24); border-radius:22px; box-shadow:0 22px 56px rgba(6,58,111,.22); overflow:hidden; z-index:3; }
.memo-head { display:flex; align-items:center; justify-content:space-between; padding:14px 15px; border-bottom:1px solid var(--line); }
.memo-logo { display:flex; align-items:center; gap:8px; font-weight:950; color:var(--navy); }
.mini-icon { width:24px; height:24px; border-radius:7px; }
.memo-tabs { display:flex; border-bottom:1px solid var(--line); }
.memo-tab { flex:1; text-align:center; padding:9px 0; font-size:.78rem; font-weight:950; }
.memo-tab.active { color:var(--brp-green-2); border-bottom:3px solid var(--brp-green); }
.memo-body { padding:14px; }
.memo-group-title { color:var(--navy); font-weight:950; font-size:.85rem; margin-bottom:8px; }
.task { display:flex; gap:9px; align-items:flex-start; padding:9px 0; font-size:.78rem; }
.box { width:16px; height:16px; border:2px solid var(--brp-green); border-radius:5px; flex:0 0 auto; margin-top:2px; }
.task.done { color:var(--muted); text-decoration: line-through; }
.task.done .box { border-color:var(--blue); background:linear-gradient(135deg,var(--blue),var(--blue-2)); position:relative; }
.memo-input { display:flex; align-items:center; gap:8px; padding:10px 12px; background:#f8fbff; border-top:1px solid var(--line); }
.input-dummy { flex:1; height:34px; border:1px solid var(--line); border-radius:10px; background:white; color:#a2afbb; font-size:.72rem; display:flex; align-items:center; padding:0 10px; }
.plus { width:32px; height:32px; border-radius:10px; background:var(--blue); color:white; display:grid; place-items:center; font-weight:900; }
.trustbar { padding:22px 0; border-block:1px solid var(--line); background:white; }
.trust-inner { display:flex; justify-content:center; gap:18px; flex-wrap:wrap; }
.trust-chip { padding:9px 15px; border-radius:999px; background:var(--soft); color:var(--navy); font-weight:900; font-size:.88rem; }
a.trust-chip-link:hover { background:var(--blue-soft); color:var(--blue-2); }
section { padding:94px 0; scroll-margin-top:76px; }
.section-soft { background:var(--soft); }
.section-head { max-width:790px; margin-bottom:38px; }
.section-head.center { margin-inline:auto; text-align:center; }
.section-head h2 { margin:10px 0 12px; color:var(--navy); font-size:clamp(1.9rem, 3.8vw, 3.05rem); line-height:1.23; letter-spacing:-.045em; text-wrap:balance; }
.section-head p { margin:0; color:var(--muted); font-size:1.02rem; }
.grid-3 { display:grid; grid-template-columns:repeat(3, 1fr); gap:20px; }
.grid-4 { display:grid; grid-template-columns:repeat(4, 1fr); gap:18px; }
.card { background:white; border:1px solid var(--line); border-radius:var(--radius-lg); padding:24px; box-shadow:var(--shadow-soft); }
.card-icon { width:50px; height:50px; border-radius:15px; display:grid; place-items:center; margin-bottom:14px; background:var(--blue-soft); font-size:1.35rem; }
.card h3 { margin:0 0 8px; color:var(--navy); font-size:1.05rem; }
.card p { margin:0; color:var(--muted); font-size:.93rem; }
.scene-card { padding:0; overflow:hidden; }
.scene-top { height:92px; padding:14px; background:linear-gradient(135deg,var(--blue-soft),white); border-bottom:1px solid var(--line); }
.scene-label { display:inline-flex; align-items:center; gap:6px; padding:5px 9px; border-radius:999px; color:var(--blue-2); background:white; border:1px solid var(--line); font-size:.72rem; font-weight:900; }
.mini-table { margin-top:10px; display:grid; gap:5px; }
.mini-line { height:8px; border-radius:99px; background:#d9e9f8; }
.mini-line.short { width:58%; }
.scene-card .copy { padding:18px; }
.feature-strip { display:grid; grid-template-columns:repeat(7,1fr); border:1px solid var(--line); border-radius:22px; background:white; box-shadow:var(--shadow-soft); overflow:hidden; }
.feature-item { min-height:116px; padding:18px 10px; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:8px; border-right:1px solid var(--line); font-weight:900; color:var(--navy); font-size:.84rem; }
.feature-item:last-child { border-right:0; }
.feature-icon { width:38px; height:38px; border-radius:12px; display:grid; place-items:center; background:var(--brp-green-soft); color:var(--brp-green-2); font-size:1.15rem; }
.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.step { background:white; border:1px solid var(--line); border-radius:22px; padding:18px; box-shadow:var(--shadow-soft); position:relative; }
.step-no { display:inline-flex; padding:4px 9px; border-radius:999px; background:linear-gradient(135deg,var(--brp-green),var(--brp-green-2)); color:white; font-size:.68rem; font-weight:950; margin-bottom:10px; }
.step h3 { margin:0 0 10px; color:var(--navy); }
.step-shot { height:112px; border:1px solid var(--line); border-radius:15px; background:#fbfdff; padding:12px; overflow:hidden; }
.step-shot .row { grid-template-columns:1fr .7fr; padding:6px 0; font-size:.68rem; }
.use-any { display:grid; grid-template-columns:.78fr 1.22fr; gap:36px; align-items:center; }
.any-list { display:grid; gap:12px; }
.any-point { display:flex; gap:12px; align-items:flex-start; padding:14px; border-radius:16px; background:white; border:1px solid var(--line); box-shadow:var(--shadow-soft); }
.checkmark { width:26px; height:26px; border-radius:9px; display:grid; place-items:center; background:var(--brp-green-soft); color:var(--brp-green-2); font-weight:950; flex:0 0 auto; }
.any-apps { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.any-app-card { min-height:150px; padding:18px; border-radius:22px; background:white; border:1px solid var(--line); box-shadow:var(--shadow-soft); }
.app-tag { display:inline-flex; gap:7px; align-items:center; padding:5px 9px; border-radius:999px; color:white; background:var(--blue); font-size:.72rem; font-weight:950; }
.any-app-card:nth-child(2) .app-tag { background:var(--brp-green); } .any-app-card:nth-child(3) .app-tag { background:var(--green); } .any-app-card:nth-child(4) .app-tag { background:var(--purple); }
.hub { display:grid; grid-template-columns:.75fr 1.25fr; gap:34px; align-items:center; }
.hub-visual { background:white; border:1px solid var(--line); border-radius:28px; padding:22px; box-shadow:var(--shadow); }
.hub-table { border:1px solid var(--line); border-radius:18px; overflow:hidden; }
.hub-row { display:grid; grid-template-columns:1fr 1.2fr .8fr .6fr; gap:8px; padding:12px 14px; border-bottom:1px solid var(--line); font-size:.82rem; }
.hub-row.head { background:#f8fbff; color:var(--muted); font-weight:950; }
.hub-row:last-child { border-bottom:0; }
.devices { display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.device-card { background:white; border:1px solid var(--line); border-radius:28px; overflow:hidden; box-shadow:var(--shadow-soft); }
.device-visual { min-height:310px; background:radial-gradient(circle at 80% 20%, rgba(16,185,129,.14), transparent 30%), linear-gradient(145deg,#fff,#f4fbff); position:relative; padding:24px; }
.desktop-screen { width:72%; min-height:210px; border:1px solid var(--line); border-radius:18px; background:white; box-shadow:0 12px 30px rgba(6,58,111,.08); overflow:hidden; }
.mini-panel { position:absolute; right:24px; bottom:24px; width:235px; border:1px solid rgba(18,143,232,.25); border-radius:18px; background:white; box-shadow:0 18px 38px rgba(6,58,111,.16); padding:15px; }
.phone { width:195px; margin:auto; border-radius:34px; background:#12395d; padding:10px; box-shadow:0 22px 45px rgba(6,58,111,.22); }
.phone--compact { width:100%; max-width:168px; padding:8px; border-radius:28px; }
.phone-screen { min-height:285px; border-radius:25px; background:#f7fbff; padding:16px 12px; position:relative; overflow:hidden; }
.phone--compact .phone-screen { min-height:250px; border-radius:22px; padding:12px 10px; }
.phone-screen--panel { background:#e8eef5; }
.mobile-tab-badge { position:absolute; right:8px; top:50%; transform:translateY(-50%); padding:4px 8px; border-radius:999px 0 0 999px; background:var(--blue); color:white; font-size:.62rem; font-weight:950; }
.mobile-sheet { position:absolute; left:9px; right:9px; bottom:9px; padding:13px; background:white; border-radius:17px; box-shadow:0 -10px 30px rgba(6,58,111,.13); }
.mobile-sheet--open { position:static; min-height:210px; margin-top:8px; box-shadow:0 8px 24px rgba(6,58,111,.12); }
.mobile-sheet--open .task { font-size:.7rem; }
.device-visual--mobile-pair { min-height:340px; padding:20px 14px; }
.mobile-pair { display:grid; grid-template-columns:1fr 1fr; gap:10px; align-items:end; max-width:420px; margin:0 auto; }
.mobile-shot { display:flex; flex-direction:column; align-items:center; gap:8px; min-width:0; }
.mobile-shot__label { margin:0; font-size:.72rem; font-weight:950; color:var(--muted); letter-spacing:.04em; }
.mobile-shot__frame { width:100%; display:flex; justify-content:center; }
.mobile-shot__img { display:block; width:auto; max-width:min(100%,180px); height:auto; max-height:340px; object-fit:contain; border-radius:16px; box-shadow:var(--shadow-soft); }
.mobile-shot.has-screenshot .mobile-shot__mock { display:none; }
.device-copy { padding:22px 24px 26px; }
.device-copy h3 { margin:0 0 8px; color:var(--navy); }
.device-copy p { margin:0; color:var(--muted); }
.workflow { display:grid; grid-template-columns:1fr 1fr; gap:22px; }
.workflow-card { min-height:310px; background:white; border:1px solid var(--line); border-radius:28px; padding:24px; box-shadow:var(--shadow-soft); }
.status-big { display:inline-flex; padding:7px 12px; border-radius:999px; background:#eaf6ff; color:var(--blue-2); font-weight:950; }
.guide-box { margin-top:18px; padding:18px; border-left:5px solid var(--brp-green); background:var(--brp-green-soft); border-radius:16px; }
.kangxi-grid { align-items: stretch; }
.kangxi-card { display:flex; flex-direction:column; gap:10px; height:100%; }
.kangxi-card p { margin:0; color:var(--muted); font-size:.92rem; line-height:1.7; }
.kangxi-list { margin:8px 0 0; padding-left:1.2em; color:var(--muted); font-size:.9rem; line-height:1.75; }
.kangxi-list li + li { margin-top:8px; }
.char-compare { margin-top:14px; padding:14px; border-radius:16px; background:var(--brp-green-soft); border:1px solid var(--brp-green-pale); }
.char-compare__pair { display:flex; align-items:center; flex-wrap:wrap; gap:8px 10px; }
.char-compare__pair + .char-compare__pair { margin-top:10px; padding-top:10px; border-top:1px dashed var(--brp-green-pale); }
.char-compare__label { font-size:.72rem; font-weight:900; color:var(--muted); letter-spacing:.04em; }
.char-compare__before,
.char-compare__after { font-size:1.45rem; font-weight:950; letter-spacing:.04em; }
.char-compare__before { color:#9a3412; }
.char-compare__after { color:var(--brp-green-2); }
.char-compare__arrow { color:var(--muted); font-weight:900; }
.char-compare__same { font-size:.72rem; font-weight:900; color:var(--brp-green-text); padding:3px 8px; border-radius:999px; background:white; border:1px dashed var(--brp-green-pale); }
.char-compare__note { margin:12px 0 0; font-size:.8rem; line-height:1.65; color:var(--brp-green-text); }
.kangxi-note { max-width:920px; margin:28px auto 0; }
.purpose-workflow { margin-top: 8px; }
.purpose-card h3 { margin: 12px 0 8px; color: var(--navy); font-size: 1.2rem; letter-spacing: -.02em; }
.purpose-card p { margin: 0; color: var(--muted); line-height: 1.7; font-size: .92rem; }
.purpose-tag { display: inline-flex; padding: 5px 11px; border-radius: 999px; background: var(--brp-green-2); color: white; font-size: .72rem; font-weight: 950; letter-spacing: .04em; }
.purpose-tag--secondary { background: var(--brp-green-soft); color: var(--brp-green-text); border: 1px solid var(--brp-green-pale); }
.purpose-card--primary { border-color: rgba(5, 150, 105, 0.28); background: linear-gradient(180deg, #fff, #f0fdf4); }
.purpose-flow-head { max-width: 760px; margin: 0 auto 18px; }
.purpose-flow-head--spaced { margin-top: 42px; }
.purpose-flow-head h3 { margin: 0 0 8px; color: var(--navy); font-size: 1.2rem; letter-spacing: -.02em; }
.purpose-flow-head p { margin: 0; color: var(--muted); font-size: .92rem; line-height: 1.65; }
.kangxi-note p { margin:10px 0 0; color:var(--brp-green-text); font-size:.92rem; line-height:1.75; }
.kangxi-note p:first-of-type { margin-top:8px; }
.calendar-mock { height:230px; border:1px solid var(--line); border-radius:18px; background:white; display:grid; grid-template-columns:repeat(5,1fr); overflow:hidden; }
.day { border-right:1px solid var(--line); padding:10px; font-size:.72rem; color:var(--muted); }
.event { margin-top:18px; padding:7px; border-radius:9px; background:#dff1ff; color:var(--blue-2); font-weight:900; }
.calendar-panel { position:absolute; right:30px; top:70px; width:230px; background:white; border:1px solid rgba(18,143,232,.25); border-radius:18px; box-shadow:0 18px 44px rgba(6,58,111,.18); padding:14px; }
.calendar-wrap { position:relative; }
.calendar-visual { position:relative; }
.hero-visual__shot,
.hub-visual__shot,
.workflow-visual__shot,
.calendar-visual__shot,
.device-visual__shot {
  display:block;
  width:100%;
  border-radius:18px;
  box-shadow:var(--shadow-soft);
}
.hero-visual.has-screenshot {
  min-height:auto;
}
.hero-visual.has-screenshot .hero-visual__mock,
.hero-visual.has-screenshot .floating-icon {
  display:none;
}
.hero-visual.has-screenshot .hero-visual__shot {
  border-radius:22px;
}
.hub-visual.has-screenshot {
  padding:0;
  background:transparent;
  border:0;
  box-shadow:none;
}
.hub-visual.has-screenshot .hub-visual__mock {
  display:none;
}
.workflow-visual {
  margin-top:18px;
}
.workflow-visual.has-screenshot .workflow-visual__mock {
  display:none;
}
.device-visual.has-screenshot,
.calendar-visual.has-screenshot {
  min-height:auto;
}
.device-visual.has-screenshot .device-visual__mock,
.calendar-visual.has-screenshot .calendar-visual__mock {
  display:none;
}
.pricing { display:grid; grid-template-columns:1fr 1fr 1.2fr; gap:20px; align-items:stretch; }
.pricing--single { grid-template-columns:minmax(0, 520px); justify-content:center; }
.price-card { background:white; border:1px solid var(--line); border-radius:24px; padding:24px; box-shadow:var(--shadow-soft); }
.price-card.highlight { border-color:rgba(16,185,129,.36); background:linear-gradient(180deg,#fff,#f0fdf4); }
.price-label { color:var(--blue-2); font-weight:950; font-size:.85rem; }
.price { margin:8px 0; color:var(--navy); font-size:2.35rem; line-height:1; font-weight:950; letter-spacing:-.04em; }
.price span { font-size:.9rem; }
.price-monthly { margin:8px 0 4px; color:var(--navy); font-size:2.8rem; line-height:1; font-weight:950; letter-spacing:-.05em; }
.price-monthly span { font-size:1rem; letter-spacing:0; }
.price-yearly-note { display:inline-flex; align-items:center; gap:6px; margin-top:6px; padding:7px 11px; border-radius:999px; background:var(--blue-pale); color:var(--blue-2); font-size:.82rem; font-weight:850; }
.price-list { margin:14px 0 0; padding:0; list-style:none; display:grid; gap:8px; color:var(--muted); font-size:.9rem; }
.price-list li::before { content:"✓"; color:var(--brp-green-2); font-weight:950; margin-right:7px; }
.campaign { background:linear-gradient(135deg,var(--brp-green),var(--brp-green-2)); color:white; border-radius:28px; padding:28px; box-shadow:0 20px 50px rgba(5,150,105,.24); }
.campaign h3 { margin:0 0 8px; font-size:1.4rem; }
.campaign .big { font-size:2.45rem; font-weight:950; line-height:1.08; letter-spacing:-.05em; margin:14px 0; }
.campaign-pill { display:inline-flex; padding:6px 12px; border-radius:999px; background:white; color:var(--brp-green-2); font-weight:950; }
.spot-consult { margin-top:16px; background:rgba(255,255,255,.78); border:1px dashed rgba(18,143,232,.32); border-radius:22px; padding:20px 22px; display:grid; grid-template-columns:1fr auto; gap:18px; align-items:center; }
.spot-consult h3 { margin:0 0 6px; color:var(--navy); font-size:1.08rem; }
.spot-consult p { margin:0; color:var(--muted); font-size:.92rem; }
.spot-consult .consult-price { color:var(--blue-2); font-weight:950; white-space:nowrap; }
.spot-consult .consult-pill { display:inline-flex; margin-bottom:8px; padding:4px 10px; border-radius:999px; background:#eaf6ff; color:var(--blue-2); font-size:.72rem; font-weight:950; }
.faq { display:grid; gap:34px; }
.faq-nav { display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin:30px auto 42px; }
.faq-nav a { display:inline-flex; align-items:center; min-height:38px; padding:0 14px; border-radius:999px; background:white; border:1px solid var(--line); color:var(--navy); font-size:.85rem; font-weight:900; box-shadow:0 8px 20px rgba(6,58,111,.04); }
.faq-nav a:hover { color:var(--blue-2); border-color:rgba(18,143,232,.32); transform:translateY(-1px); }
.faq-category { scroll-margin-top:96px; }
.faq-items details[id] { scroll-margin-top:96px; }
.faq-items details[id][open] { border-color:rgba(16,185,129,.35); box-shadow:0 10px 24px rgba(16,185,129,.08); }
.faq-category-head { display:flex; align-items:flex-end; justify-content:space-between; gap:18px; margin-bottom:14px; padding-bottom:10px; border-bottom:1px solid var(--line); }
.faq-category-head h3 { margin:0; color:var(--navy); font-size:1.28rem; letter-spacing:-.03em; }
.faq-category-head p { margin:0; color:var(--muted); font-size:.9rem; }
.faq-list { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
details { background:white; border:1px solid var(--line); border-radius:16px; padding:16px 18px; box-shadow:0 8px 20px rgba(6,58,111,.04); }
summary { cursor:pointer; color:var(--navy); font-weight:950; }
details p { margin:10px 0 0; color:var(--muted); }
details ul { margin:10px 0 0; padding-left:1.2em; color:var(--muted); }
details li { margin:.25em 0; }
.faq-note { margin-top:10px; padding:10px 12px; border-radius:12px; background:var(--blue-soft); color:var(--blue-dark); font-size:.9rem; font-weight:800; }
.faq-flow { margin:12px 0 0; padding:12px; border-radius:14px; background:#f8fbff; border:1px solid var(--line); color:var(--ink); font-size:.88rem; line-height:1.8; }
.faq-table { width:100%; margin-top:12px; border-collapse:separate; border-spacing:0; overflow:hidden; border:1px solid var(--line); border-radius:12px; font-size:.86rem; }
.faq-table th, .faq-table td { padding:9px 10px; border-bottom:1px solid var(--line); vertical-align:top; }
.faq-table th { background:#f8fbff; color:var(--navy); text-align:left; white-space:nowrap; }
.faq-table tr:last-child th, .faq-table tr:last-child td { border-bottom:0; }
.final-cta { padding:76px 0; background:linear-gradient(135deg,var(--blue-dark),#0c79cf); color:white; }
.final-box { display:grid; grid-template-columns:auto 1fr auto; gap:24px; align-items:center; }
.final-box img { width:86px; height:86px; border-radius:22px; background:white; padding:4px; }
.final-box h2 { margin:0; font-size:clamp(1.65rem,3vw,2.45rem); line-height:1.25; letter-spacing:-.04em; }
.final-box p { margin:8px 0 0; opacity:.88; }
@media (max-width: 1040px) {
  .hero-grid, .use-any, .hub, .workflow { grid-template-columns:1fr; }
  .occurrence-preview__inner { grid-template-columns:1fr; }
  .hero-visual { min-height:520px; }
  .browser { inset:35px 110px 30px 0; }
  .grid-4, .steps { grid-template-columns:repeat(2,1fr); }
  .feature-strip { grid-template-columns:repeat(4,1fr); }
  .feature-item { border-bottom:1px solid var(--line); }
  .pricing { grid-template-columns:1fr; }
  .support-note-grid { grid-template-columns:1fr; }
  .spot-consult { grid-template-columns:1fr; }
  .final-box { grid-template-columns:1fr; text-align:center; justify-items:center; }
}
@media (max-width: 760px) {
  :root { --content: min(100% - 28px, 1180px); }
  .hero { padding:54px 0 44px; }
  h1 { font-size:clamp(2.05rem, 9.5vw, 2.85rem); }
  .hero-title__line { white-space: normal; }
  section { padding:70px 0; }
  .hero-visual { min-height:610px; }
  .browser { inset:100px 0 110px 0; }
  .memo-panel { top:300px; right:8px; width:min(285px, calc(100% - 16px)); }
  .floating-icon { left:8px; top:8px; }
  .grid-3, .grid-4, .steps, .any-apps, .devices { grid-template-columns:1fr; }
  .faq-list { grid-template-columns:1fr; }
  .faq-category-head { display:block; }
  .faq-category-head p { margin-top:4px; }
  .feature-strip { grid-template-columns:1fr 1fr; }
  .feature-item:nth-child(even) { border-right:0; }
  .row { grid-template-columns:1.2fr .8fr; }
  .row span:nth-child(3), .row span:nth-child(4) { display:none; }
  .hub-row { grid-template-columns:1fr; gap:4px; }
  .desktop-screen { width:100%; }
  .mini-panel { position:static; width:100%; margin-top:16px; }
  .calendar-panel { position:static; width:100%; margin-top:14px; }
  .final-box img { width:76px; height:76px; }
}

/* ヒーロー：置換確認ダイアログモック */
.replace-panel {
  position: absolute;
  right: 0;
  top: 70px;
  width: 300px;
  background: white;
  border: 1px solid rgba(5, 150, 105, 0.28);
  border-radius: 22px;
  box-shadow: 0 22px 56px rgba(6, 58, 111, 0.22);
  overflow: hidden;
  z-index: 3;
}
.replace-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
  font-weight: 950;
  color: var(--navy);
  font-size: 0.88rem;
}
.replace-panel-head .mini-icon {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  margin-right: 8px;
  vertical-align: -5px;
}
.replace-diff {
  padding: 16px 16px 8px;
}
.replace-diff-row {
  margin-bottom: 12px;
}
.replace-diff-label {
  display: block;
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 850;
  letter-spacing: 0.04em;
}
.replace-diff-before,
.replace-diff-after {
  padding: 11px 12px;
  border-radius: 12px;
  font-size: 1.05rem;
  font-weight: 900;
  letter-spacing: 0.02em;
}
.replace-diff-before {
  background: #fff7ed;
  color: #9a3412;
  border: 1px solid #fed7aa;
}
.replace-diff-after {
  background: var(--brp-green-soft);
  color: var(--brp-green-2);
  border: 1px solid var(--brp-green-pale);
}
.replace-panel-actions {
  display: flex;
  gap: 8px;
  padding: 12px 16px 16px;
  border-top: 1px solid var(--line);
}
.btn-mock {
  flex: 1;
  text-align: center;
  padding: 10px 8px;
  border-radius: 10px;
  font-size: 0.76rem;
  font-weight: 900;
}
.btn-mock.primary {
  background: var(--brp-green-2);
  color: white;
}
.btn-mock.ghost {
  background: white;
  border: 1px solid var(--line);
  color: var(--navy);
}
@media (max-width: 760px) {
  .replace-panel {
    top: 300px;
    right: 8px;
    width: min(300px, calc(100% - 16px));
  }
}
