/* ===== ミエルーム 共通スタイル (site.css) ===== */
:root{
  --blue:#14a085;
  --blue-d:#0c7b66;
  --blue-l:#2bbfa3;
  --sky:#e4f5f0;
  --sky-2:#c9ebe2;
  --peach:#f0a08d;
  --peach-d:#e07a5f;
  --peach-soft:#fdeee7;
  --cream:#fbf7f0;
  --ink:#12302b;
  --ink-2:#3a544c;
  --ink-3:#6f847b;
  --line:#e6ece9;
  --bg:#ffffff;
  --bg-soft:#f6faf8;
  --red:#e8634a;
  --red-soft:#fdeee9;
  --amber:#e89b1c;
  --amber-soft:#fdf3e0;
  --green:#16a05a;
  --green-soft:#e7f6ee;
  --shadow-sm:0 2px 8px rgba(18,48,43,.06);
  --shadow:0 18px 50px -12px rgba(14,80,68,.2);
  --shadow-lg:0 40px 90px -24px rgba(14,80,68,.3);
  --maxw:1160px;
  --r:18px;
  --ease-bounce:cubic-bezier(.34,1.56,.64,1);
  --ease-soft:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

/* ===== animation utilities ===== */
@media(prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-soft), transform .8s var(--ease-soft)}
  .reveal.in{opacity:1;transform:none}
  .r-left{opacity:0;transform:translateX(-40px);transition:opacity .8s var(--ease-soft), transform .8s var(--ease-soft)}
  .r-left.in{opacity:1;transform:none}
  .r-right{opacity:0;transform:translateX(40px);transition:opacity .8s var(--ease-soft), transform .8s var(--ease-soft)}
  .r-right.in{opacity:1;transform:none}
  .r-pop{opacity:0;transform:scale(.85) translateY(20px);transition:opacity .7s var(--ease-bounce), transform .7s var(--ease-bounce)}
  .r-pop.in{opacity:1;transform:none}
  .stagger > *{opacity:0;transform:translateY(28px) scale(.97);transition:opacity .7s var(--ease-soft), transform .7s var(--ease-bounce)}
  .stagger.in > *{opacity:1;transform:none}
  .stagger.in > *:nth-child(1){transition-delay:.05s}
  .stagger.in > *:nth-child(2){transition-delay:.12s}
  .stagger.in > *:nth-child(3){transition-delay:.19s}
  .stagger.in > *:nth-child(4){transition-delay:.26s}
  .stagger.in > *:nth-child(5){transition-delay:.33s}
  .stagger.in > *:nth-child(6){transition-delay:.4s}
}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-14px) rotate(1deg)}}
@keyframes floaty2{0%,100%{transform:translateY(0) rotate(1deg)}50%{transform:translateY(-18px) rotate(-1.5deg)}}
@keyframes blobmove{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-24px) scale(1.08)}66%{transform:translate(-22px,18px) scale(.94)}}
@keyframes drift{0%,100%{transform:translate(0,0)}50%{transform:translate(0,-10px)}}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes pulseRing{0%{box-shadow:0 0 0 0 rgba(6,199,85,.45)}70%{box-shadow:0 0 0 14px rgba(6,199,85,0)}100%{box-shadow:0 0 0 0 rgba(6,199,85,0)}}
@keyframes bobIcon{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes sway{0%,100%{transform:translate(0,0)}50%{transform:translate(0,-16px)}}
@keyframes sway2{0%,100%{transform:translate(0,0)}50%{transform:translate(13px,-13px)}}
@keyframes swayRing{0%,100%{transform:translate(0,0) rotate(0deg)}50%{transform:translate(-11px,12px) rotate(10deg)}}
.deco{position:absolute;border-radius:50%;pointer-events:none;z-index:0}
.deco.ring{background:transparent;border-style:solid}
.blob{position:absolute;border-radius:50%;filter:blur(6px);opacity:.72;z-index:0;pointer-events:none}
@media(prefers-reduced-motion:reduce){.deco,.blob{animation:none!important}}

body{
  font-family:"Noto Sans JP",system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
  letter-spacing:.01em;
}
h1,h2,h3,h4,.disp{font-family:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;letter-spacing:.01em;line-height:1.32}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-weight:700;font-size:13px;letter-spacing:.14em;
  color:var(--blue);background:var(--sky);
  padding:7px 16px;border-radius:999px;
}
.eyebrow.on-dark{color:#a9e6d6;background:rgba(255,255,255,.08)}
.mark{color:var(--peach-d);font-weight:900;font-style:normal}
.u-blue{color:var(--blue)}
.u-peach{color:var(--peach-d)}
.hl{background:linear-gradient(transparent 62%, #ffe27a 62%);padding:0 .08em}

/* buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:"Zen Kaku Gothic New",sans-serif;font-weight:700;
  padding:17px 30px;border-radius:14px;font-size:16px;cursor:pointer;border:none;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space:nowrap;
}
.btn .sub{font-size:11px;font-weight:500;opacity:.85;display:block;margin-top:1px;letter-spacing:.04em}
.btn-line{background:#06c755;color:#fff;box-shadow:0 12px 26px -10px rgba(6,199,85,.7)}
.btn-line:hover{transform:translateY(-2px);box-shadow:0 18px 34px -10px rgba(6,199,85,.8)}
.btn-primary{background:linear-gradient(180deg,#2bbfa3,#14a085);color:#fff;box-shadow:0 14px 30px -10px rgba(20,160,133,.6)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 40px -10px rgba(20,160,133,.7)}
.btn-ghost{background:#fff;color:var(--blue);border:1.5px solid var(--sky-2)}
.btn-ghost:hover{background:var(--sky)}
.btn-lg{padding:21px 40px;font-size:18px;border-radius:16px}
.btn .ico{width:20px;height:20px;flex:none}
.btn.pulse{animation:pulseRing 2.4s ease-out infinite}
@media(prefers-reduced-motion:reduce){.btn.pulse{animation:none}}

/* header */
header.site{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:88px}
.brand{display:flex;align-items:center;gap:12px}
.brand img.logo{width:76px;height:76px;object-fit:contain;transition:transform .4s var(--ease-bounce)}
.brand:hover img.logo{transform:rotate(-6deg) scale(1.06)}
.brand .name{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:21px;letter-spacing:.02em}
.brand .name b{color:var(--blue);font-weight:900}
.brand .name i{color:var(--peach-d);font-style:normal;font-weight:900}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:14px;font-weight:500;color:var(--ink-2)}
.nav-links a:hover{color:var(--blue)}
.nav-links a.on{color:var(--blue);font-weight:700}
.nav-cta{display:flex;gap:10px;align-items:center}
.nav-cta .btn{padding:11px 20px;font-size:14px}
@media(max-width:920px){.nav-links{display:none}.nav-cta .btn-line{display:none}}

/* generic section */
section{padding:88px 0}
.sec-head{text-align:center;max-width:760px;margin:0 auto 52px}
.sec-head h2{font-size:36px;font-weight:900;margin-top:14px}
.sec-head p{color:var(--ink-2);margin-top:16px;font-size:16px;font-weight:500}
@media(max-width:920px){.sec-head h2{font-size:27px}section{padding:62px 0}}

/* section wave divider */
.sec-wave{position:absolute;left:0;width:100%;height:52px;line-height:0;z-index:2;pointer-events:none}
.sec-wave svg{width:100%;height:100%;display:block}
.sec-wave.top{top:-1px}
.sec-wave.bot{bottom:-1px}

/* marquee band */
.marquee-band{background:linear-gradient(180deg,#ffffff,#f6faf8);padding:26px 0 28px;overflow:hidden;text-align:center}
.marquee-lead{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:clamp(18px,3.4vw,26px);color:var(--ink);margin-bottom:18px;padding:0 20px}
.marquee{position:relative;width:100%;overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;align-items:center;gap:22px;width:max-content;animation:ticker 32s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.mq-chip{font-family:"Zen Kaku Gothic New";font-weight:700;font-size:16px;color:var(--blue-d);white-space:nowrap}
.mq-dot{width:7px;height:7px;border-radius:50%;background:var(--peach);flex:none}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none;flex-wrap:wrap;justify-content:center}}

/* app mock primitives */
.window{border-radius:16px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:#fff}
.app-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;background:#0e3a33;color:#fff}
.app-head .t{font-family:"Zen Kaku Gothic New";font-weight:700;font-size:13px;display:flex;align-items:center;gap:8px}
.app-head .pill{background:rgba(255,255,255,.14);padding:3px 9px;border-radius:6px;font-size:10px;font-weight:600}
.browserbar{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--line);background:#fafdfb}
.dot{width:10px;height:10px;border-radius:50%}
.dot.r{background:#ff5f57}.dot.y{background:#febc2e}.dot.g{background:#28c840}
.urlbar{margin-left:10px;flex:1;background:#eef4f1;border-radius:7px;height:22px;display:flex;align-items:center;padding:0 10px;font-size:11px;color:#7c918a;font-family:ui-monospace,monospace;overflow:hidden;white-space:nowrap}
.dash{padding:16px;background:#fff}
.tbl{width:100%;border-collapse:collapse;background:#fff;font-size:12px}
.tbl th{background:#f1f8f5;text-align:left;font-size:10.5px;color:var(--ink-3);font-weight:700;padding:9px 11px;border-bottom:1px solid var(--line);white-space:nowrap;letter-spacing:.02em}
.tbl td{padding:11px 11px;border-bottom:1px solid #eef4f1;font-size:11.5px;color:var(--ink-2);white-space:nowrap;vertical-align:middle}
.tbl tr:hover td{background:#f7fbf9}
.tbl .prop{font-weight:700;color:var(--ink)}
.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:10px;font-weight:700;white-space:nowrap}
.t-green{background:var(--green-soft);color:#0f7a43}
.t-amber{background:var(--amber-soft);color:#a9700a}
.t-red{background:var(--red-soft);color:#c2362a}
.t-blue{background:var(--sky);color:var(--blue)}
.t-gray{background:#eef1f6;color:#5b6a82}
.dotmark{width:7px;height:7px;border-radius:50%;display:inline-block}

/* final cta */
.final{background:linear-gradient(135deg,#14a085,#0c6f5c);color:#fff;text-align:center;position:relative;overflow:hidden}
.final h2{font-size:38px;font-weight:900;line-height:1.4}
.final p{margin-top:18px;color:#d2f1e9;font-size:16px;font-weight:500}
.final .cta-row{display:flex;gap:14px;justify-content:center;margin-top:34px;flex-wrap:wrap}
.final .btn-primary{background:#fff;color:var(--blue)}
.final .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.final .btn-ghost:hover{background:rgba(255,255,255,.12)}
@media(max-width:680px){.final h2{font-size:27px}}

/* footer */
footer.site{background:#0a201c;color:#eef5f2;padding:54px 0 30px;font-size:13px}
.foot-logo{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.foot-logo img{width:54px;height:54px;object-fit:contain}
.foot-logo .name{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:21px;color:#fff}
.foot-logo .name b{color:var(--blue-l)}
.foot-top{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-brand .name{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:20px;color:#fff}
.foot-brand .name b{color:var(--blue-l)}
.foot-brand p{margin-top:10px;max-width:340px;font-size:12.5px;color:#cfe0da}
.foot-cols{display:flex;gap:54px;flex-wrap:wrap}
.foot-cols h4{color:#fff;font-size:12px;margin-bottom:12px;letter-spacing:.05em}
.foot-cols a{display:block;margin-bottom:8px;font-size:12.5px;color:#eef5f2}
.foot-cols a:hover{color:#fff}
.foot-bottom{padding-top:24px;font-size:11.5px;color:#cfe0da}

/* sticky mobile cta */
.mobile-cta{position:fixed;bottom:0;left:0;right:0;z-index:60;display:none;gap:10px;padding:10px 14px;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-top:1px solid var(--line)}
.mobile-cta .btn{flex:1;padding:14px;font-size:14px}
@media(max-width:920px){.mobile-cta{display:flex}body{padding-bottom:74px}}

@media(prefers-reduced-motion:reduce){.reveal,.r-left,.r-right,.r-pop,.stagger>*{opacity:1;transform:none;transition:none}}

@media(max-width:560px){
  .wrap{padding:0 18px}
  .sec-head h2 br{display:none}
  .sec-wave{height:34px}
}

/* ===== feature detail page ===== */
.dt-hero{position:relative;overflow:hidden;background:
   radial-gradient(900px 480px at 84% -10%, #d8f2ea 0%, transparent 60%),
   radial-gradient(640px 460px at 4% 112%, #fdeee7 0%, transparent 58%),
   linear-gradient(180deg,#fbfdfc 0%, #f1faf6 100%);padding:54px 0 66px}
.dt-hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.04fr .96fr;gap:50px;align-items:center}
.crumb{display:flex;flex-wrap:wrap;gap:6px;font-size:12.5px;color:var(--ink-3);font-weight:600;margin-bottom:18px}
.crumb a:hover{color:var(--blue)}
.crumb .sep{opacity:.5}
.dt-eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:14px}
.dt-eyebrow .cno{font-family:"Zen Kaku Gothic New";font-weight:900;color:#fff;font-size:12px;letter-spacing:.1em;padding:5px 13px;border-radius:8px}
.dt-eyebrow .cat{font-family:"Zen Kaku Gothic New";font-weight:700;font-size:12.5px;color:var(--blue)}
.dt-hero h1{font-size:33px;font-weight:900;line-height:1.42}
.dt-hero .lead{font-size:16px;color:var(--ink-2);font-weight:500;margin-top:18px;max-width:540px}
.dt-hero .cta-row{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}
.dt-hero .cta-row .btn{padding:14px 24px;font-size:15px}
.dt-visual{position:relative}
.dt-visual .float-card{position:absolute;background:#fff;border-radius:13px;box-shadow:var(--shadow);border:1px solid var(--line);padding:12px 15px;z-index:3}
.dt-visual .float-card .k{font-size:10.5px;color:var(--ink-3);font-weight:600;letter-spacing:.03em}
.dt-visual .float-card .v{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:18px}
.dt-visual .ft-tl{top:-20px;left:-22px;animation:floaty 6s ease-in-out infinite}
.dt-visual .ft-br{bottom:-22px;right:-18px;animation:floaty2 7s ease-in-out infinite}
.dt-visual .window{animation:drift 8s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.dt-visual .float-card,.dt-visual .window{animation:none!important}}
@media(max-width:920px){.dt-hero .wrap{grid-template-columns:1fr;gap:40px}.dt-hero h1{font-size:27px}.dt-visual .ft-tl{left:-6px}.dt-visual .ft-br{right:-6px}}

/* problem strip */
.dt-problem{background:linear-gradient(180deg,#fff,#fbf3f2)}
.dt-problem .sec-head .eyebrow{background:var(--red-soft);color:var(--red)}
.prob-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.prob-card{background:#fff;border:1px solid #f3dad7;border-radius:var(--r);padding:24px 22px;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease-bounce),box-shadow .35s ease}
.prob-card:hover{transform:translateY(-6px) rotate(-.5deg);box-shadow:0 22px 42px -18px rgba(200,80,60,.26)}
.prob-card .x{width:30px;height:30px;border-radius:9px;background:var(--red-soft);color:var(--red);display:grid;place-items:center;font-weight:900;font-size:16px;margin-bottom:12px}
.prob-card p{font-size:14px;color:var(--ink-2);font-weight:500}
.prob-card p b{color:var(--ink);font-weight:700}
@media(max-width:820px){.prob-grid{grid-template-columns:1fr}}

/* solution detail block */
.dt-sol .fblock{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.dt-sol .fblock.rev .ftext{order:2}
.fnum{font-family:"Zen Kaku Gothic New";font-weight:900;color:var(--blue);font-size:13px;letter-spacing:.13em;display:flex;align-items:center;gap:10px}
.fnum::before{content:"";width:28px;height:2px;background:var(--blue)}
.ftext h2{font-size:28px;font-weight:900;margin:14px 0 16px;line-height:1.42}
.ftext p{color:var(--ink-2);font-size:15px;font-weight:500}
.ftext ul{list-style:none;margin-top:20px;display:flex;flex-direction:column;gap:12px}
.ftext li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;font-weight:500;color:var(--ink-2)}
.ftext li .ck{flex:none;width:22px;height:22px;border-radius:7px;background:var(--green-soft);color:var(--green);display:grid;place-items:center;font-weight:900;font-size:12px;margin-top:2px}
.ftext li b{color:var(--ink);font-weight:700}
@media(max-width:920px){.dt-sol .fblock{grid-template-columns:1fr;gap:32px}.dt-sol .fblock.rev .ftext{order:0}.ftext h2{font-size:23px}}

/* points */
.points{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.point{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px 24px;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease-bounce),box-shadow .35s ease}
.point:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.point .pi{width:44px;height:44px;border-radius:12px;background:linear-gradient(180deg,#2bbfa3,#14a085);display:grid;place-items:center;margin-bottom:15px}
.point .pi svg{width:23px;height:23px;stroke:#fff;fill:none;stroke-width:2}
.point h3{font-size:17px;font-weight:900;margin-bottom:9px}
.point p{font-size:13.5px;color:var(--ink-2);font-weight:500}
@media(max-width:820px){.points{grid-template-columns:1fr}}

/* related */
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px 22px;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease-bounce),box-shadow .3s ease}
.rcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.rcard .ri{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;margin-bottom:13px}
.rcard .ri svg{width:22px;height:22px;stroke:#fff;fill:none;stroke-width:2}
.rcard .rno{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:11px;letter-spacing:.1em;color:var(--blue);margin-bottom:6px}
.rcard h3{font-size:16px;font-weight:900;line-height:1.5;margin-bottom:8px}
.rcard p{font-size:12.5px;color:var(--ink-2);font-weight:500;flex:1}
.rcard .more{margin-top:14px;font-family:"Zen Kaku Gothic New";font-weight:700;font-size:13px;color:var(--blue);display:inline-flex;gap:6px;align-items:center}
.rcard:hover .more .arr{transform:translateX(4px);transition:transform .25s}
@media(max-width:820px){.related{grid-template-columns:1fr}}

/* ranking list mock */
.rank-list{display:flex;flex-direction:column;gap:8px}
.rank-row{display:grid;grid-template-columns:26px 1fr 52px;gap:11px;align-items:center;padding:9px 11px;border-radius:10px;background:#f7fbf9;border:1px solid var(--line)}
.rank-row .rk{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:14px;color:var(--ink-3);text-align:center}
.rank-row.top1{background:linear-gradient(90deg,#eef9f5,#fff);border-color:var(--sky-2)}
.rank-row.top1 .rk{color:var(--amber)}
.rank-row .nm{font-weight:700;font-size:12.5px}
.rank-row .nm small{display:block;color:var(--ink-3);font-weight:500;font-size:10px}
.rank-bar{height:7px;border-radius:5px;overflow:hidden;margin-top:5px;background:linear-gradient(90deg,#14a085 0 var(--w,0%),#e7eeeb var(--w,0%) 100%)}
.rank-row .pt{text-align:right;font-family:"Zen Kaku Gothic New";font-weight:900;font-size:13px;color:var(--blue)}

/* roi list mock */
.roi-list{display:flex;flex-direction:column}
.roi-row{display:grid;grid-template-columns:84px 1fr 56px;gap:11px;align-items:center;padding:10px 4px;border-bottom:1px solid #eef2f8}
.roi-row .nm{font-weight:700;font-size:12px}
.roi-bar{height:9px;border-radius:5px;overflow:hidden;background:linear-gradient(90deg,var(--c,#14a085) 0 var(--w,0%),#eef2f8 var(--w,0%) 100%)}
.roi-row .roi{text-align:right;font-family:"Zen Kaku Gothic New";font-weight:900;font-size:13px}

/* chat mock */
.chat{padding:14px;display:flex;flex-direction:column;gap:10px;background:#f4f8f6}
.chat .msg{max-width:78%;padding:9px 13px;border-radius:13px;font-size:12px;line-height:1.6;font-weight:500}
.chat .msg.in-m{background:#fff;border:1px solid var(--line);border-bottom-left-radius:4px;align-self:flex-start;color:var(--ink-2)}
.chat .msg.out-m{background:linear-gradient(180deg,#2bbfa3,#14a085);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}
.chat .meta{font-size:9.5px;color:var(--ink-3);font-weight:600;margin-top:3px}
.chat .alert{align-self:center;background:var(--red-soft);color:#c2362a;font-size:10.5px;font-weight:700;padding:5px 12px;border-radius:999px;display:inline-flex;gap:6px;align-items:center}

/* flow mock (form -> table) */
.flow{padding:16px;display:flex;align-items:center;gap:12px;background:#fff}
.flow .ff{flex:1;border:1px solid var(--line);border-radius:11px;padding:13px;background:var(--bg-soft)}
.flow .ff .fl{font-size:10px;color:var(--ink-3);font-weight:700;margin-bottom:8px;letter-spacing:.04em}
.flow .ff .frow{height:9px;border-radius:5px;background:#e3ece8;margin-bottom:7px}
.flow .ff .frow.s{width:60%}
.flow .arrowbox{flex:none;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--blue)}
.flow .arrowbox .ar{font-size:22px;font-weight:900;animation:bobIcon 1.6s ease-in-out infinite}
.flow .arrowbox small{font-size:9px;font-weight:700;color:var(--blue)}
@media(prefers-reduced-motion:reduce){.flow .arrowbox .ar{animation:none}}

/* floorplan mock */
.fp{padding:16px;background:#fff}
.fp .grid{position:relative;border:2.5px solid var(--ink);border-radius:6px;height:220px;display:grid;grid-template-columns:1.4fr 1fr;grid-template-rows:1fr 1fr;background:
  repeating-linear-gradient(0deg,transparent,transparent 19px,#eef4f1 19px,#eef4f1 20px),
  repeating-linear-gradient(90deg,transparent,transparent 19px,#eef4f1 19px,#eef4f1 20px)}
.fp .room{border:1.5px solid var(--ink-3);margin:-1px;display:flex;align-items:center;justify-content:center;font-family:"Zen Kaku Gothic New";font-weight:700;font-size:12px;color:var(--ink-2);position:relative}
.fp .room.lk{grid-column:1;grid-row:1 / span 2}
.fp .room small{position:absolute;bottom:6px;font-size:9px;color:var(--ink-3);font-weight:500}

/* doc / contract mock */
.docm{padding:16px;background:#eef2f0;display:flex;gap:12px;align-items:flex-start}
.docpage{flex:1;background:#fff;border:1px solid var(--line);border-radius:8px;padding:16px;box-shadow:0 6px 18px -10px rgba(0,0,0,.2)}
.docpage .dt-t{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:13px;text-align:center;padding-bottom:9px;border-bottom:1.5px solid var(--ink);margin-bottom:11px}
.docpage .drow{display:flex;gap:8px;font-size:11px;margin-bottom:8px;align-items:center}
.docpage .drow .lbl{color:var(--ink-3);font-weight:700;width:74px;flex:none}
.docpage .drow .fld{flex:1;border-bottom:1px dashed #c7d3ce;padding-bottom:2px;font-weight:700;color:var(--ink)}
.docpage .drow .fld.mg{background:var(--sky);color:var(--blue);border:none;border-radius:5px;padding:2px 8px;animation:pulseField 2.6s ease-in-out infinite}
@keyframes pulseField{0%,100%{background:var(--sky)}50%{background:#cdeee4}}
@media(prefers-reduced-motion:reduce){.docpage .drow .fld.mg{animation:none}}

/* generic kpi row reuse for detail */
.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px}
.kpi{background:#f1f8f5;border:1px solid var(--line);border-radius:11px;padding:12px}
.kpi .k{font-size:10px;color:var(--ink-3);font-weight:600}
.kpi .v{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:20px;margin-top:3px}
.kpi .v small{font-size:11px;font-weight:700}
.kpi .delta{font-size:10px;font-weight:700;margin-top:2px}
.kpi .up{color:var(--green)}.kpi .down{color:var(--red)}
.legend{display:flex;gap:14px;margin-top:10px;font-size:10px;color:var(--ink-3);font-weight:600;flex-wrap:wrap}
.legend span{display:inline-flex;align-items:center;gap:5px}
.ai-note{margin-top:14px;background:var(--sky);border-radius:11px;padding:12px 14px;font-size:11.5px;font-weight:600;color:var(--blue);display:flex;gap:9px;align-items:flex-start}
.ai-note .b{flex:none;font-family:"Zen Kaku Gothic New";font-weight:900;font-size:10px;letter-spacing:.04em;background:var(--blue);color:#fff;padding:3px 7px;border-radius:6px}
.ai-note b{font-weight:900}

/* tab bar mock */
.mocktabs{display:flex;gap:2px;padding:0 12px;background:#eef6f3;border-bottom:1px solid var(--line)}
.mocktabs .mt{padding:10px 14px;font-size:11.5px;font-weight:700;color:var(--ink-3);border-bottom:2px solid transparent;cursor:default}
.mocktabs .mt.on{color:var(--blue);border-color:var(--blue);background:#fff}

/* ===== blog post article ===== */
.post-hero{position:relative;overflow:hidden;padding:48px 0 8px;background:linear-gradient(180deg,#fbfdfc,#f1faf6)}
.post-hero .wrap{position:relative;z-index:1}
.post-narrow{max-width:760px;margin:0 auto}
.post-cat{display:inline-block;font-family:"Zen Kaku Gothic New";font-weight:700;font-size:12px;letter-spacing:.06em;color:#fff;padding:5px 14px;border-radius:8px}
.post-hero h1{font-size:33px;font-weight:900;line-height:1.5;margin:16px 0 0}
.post-meta{display:flex;gap:14px;margin-top:20px;color:var(--ink-3);font-size:13px;font-weight:600;align-items:center;flex-wrap:wrap}
.post-meta .av{width:36px;height:36px;border-radius:50%;background:var(--sky);display:grid;place-items:center;font-family:"Zen Kaku Gothic New";font-weight:900;color:var(--blue);font-size:14px}
.post-meta .sep{width:4px;height:4px;border-radius:50%;background:#cfdad5}
.post-cover{max-width:920px;margin:28px auto 0;padding:0 24px}
.post-cover .band{height:210px;border-radius:20px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);overflow:hidden;position:relative}
.post-cover .band svg{width:74px;height:74px;stroke:#fff;fill:none;stroke-width:1.6;opacity:.95;position:relative;z-index:1}
.post-cover .band .ring{position:absolute;border-radius:50%;border:2px solid rgba(255,255,255,.22)}
@media(max-width:680px){.post-hero h1{font-size:25px}.post-cover .band{height:160px}.post-cover .band svg{width:54px;height:54px}}

.post-body{max-width:760px;margin:0 auto;padding:46px 24px 4px;font-size:16px;line-height:2.05;color:var(--ink-2);font-weight:500}
.post-body > p:first-of-type{font-size:17.5px;color:var(--ink);font-weight:500;line-height:1.95}
.post-body h2{font-family:"Zen Kaku Gothic New";font-size:24px;font-weight:900;color:var(--ink);margin:46px 0 16px;padding-left:16px;border-left:5px solid var(--blue);line-height:1.45}
.post-body h3{font-family:"Zen Kaku Gothic New";font-size:18.5px;font-weight:900;color:var(--ink);margin:32px 0 10px}
.post-body p{margin-bottom:20px}
.post-body strong{color:var(--ink);font-weight:700;background:linear-gradient(transparent 64%,#ffe27a 64%);padding:0 .06em}
.post-body ul,.post-body ol{margin:6px 0 24px;padding:0;list-style:none;display:flex;flex-direction:column;gap:11px}
.post-body li{position:relative;padding-left:30px;font-size:15.5px}
.post-body ul li::before{content:"";position:absolute;left:0;top:.5em;width:16px;height:16px;border-radius:5px;background:var(--green-soft)}
.post-body ul li::after{content:"✓";position:absolute;left:3px;top:0;color:var(--green);font-weight:900;font-size:12px}
.post-body ol{counter-reset:n}
.post-body ol li{counter-increment:n}
.post-body ol li::before{content:counter(n);position:absolute;left:0;top:.15em;width:20px;height:20px;border-radius:6px;background:var(--blue);color:#fff;font-family:"Zen Kaku Gothic New";font-weight:900;font-size:11px;display:grid;place-items:center}
.callout{background:var(--sky);border:1px solid var(--sky-2);border-radius:16px;padding:22px 26px;margin:30px 0;font-size:15px}
.callout .ct{font-family:"Zen Kaku Gothic New";font-weight:900;color:var(--blue-d);font-size:14px;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.callout p{margin:0;color:var(--ink-2)}
.callout .ct .ci{width:22px;height:22px;border-radius:7px;background:var(--blue);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:900}
.pull{font-family:"Zen Kaku Gothic New";font-weight:900;font-size:21px;color:var(--ink);line-height:1.6;margin:34px 0;padding:6px 0 6px 22px;border-left:5px solid var(--peach-d)}
.post-divider{height:1px;background:var(--line);margin:42px 0}
.post-tags{display:flex;flex-wrap:wrap;gap:8px;margin:32px 0 0}
.post-tags .pt{font-size:12px;font-weight:600;color:var(--ink-3);background:var(--bg-soft);border:1px solid var(--line);padding:5px 13px;border-radius:999px}

.inline-cta{max-width:760px;margin:40px auto 0;padding:0 24px}
.inline-cta .box{background:linear-gradient(135deg,#10463d,#0b2c27);color:#fff;border-radius:20px;padding:32px 34px;display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap;position:relative;overflow:hidden}
.inline-cta .box::before{content:"";position:absolute;inset:0;background:radial-gradient(500px 240px at 88% 0,rgba(43,191,163,.34),transparent 62%)}
.inline-cta .box > *{position:relative;z-index:1}
.inline-cta h3{font-size:21px;font-weight:900}
.inline-cta p{color:#bcd5cd;font-size:13.5px;margin-top:6px;font-weight:500}
@media(max-width:600px){.inline-cta .box{flex-direction:column;align-items:flex-start}}

/* related posts */
.relposts{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:820px){.relposts{grid-template-columns:1fr}}
