@charset "UTF-8";
/* =========================================================
   Makutane Inc. — Design System v1 (Phase 1)
   和モダン × 高級感 / モチーフ:種と芽(蒔く種)
   ========================================================= */
:root{
  --green:#0E3B33;        /* コーポレートカラー */
  --green-2:#16554A;
  --deep:#08251F;         /* 暗部・フッター */
  --washi:#F4F0E6;        /* 和紙 */
  --paper:#FBF9F2;        /* 白紙 */
  --ink:#26231C;
  --ink-2:#5B5446;
  --gold:#AE9355;         /* 金 */
  --gold-2:#D3C295;
  --line:rgba(38,35,28,.16);
  --line-d:rgba(244,240,230,.18);
  --serif:"Shippori Mincho","Hiragino Mincho ProN","Yu Mincho","BIZ UDPMincho",serif;
  --sans:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN","Yu Gothic Medium","Yu Gothic","Noto Sans JP",sans-serif;
  --latin:"EB Garamond",Georgia,"Times New Roman",serif;
  --w:1160px;
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.18 0 0 0 0 0.16 0 0 0 0 0.10 0 0 0 0.05 0'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  font-size:16px;
  line-height:2;
  letter-spacing:.05em;
  color:var(--ink);
  background-color:var(--washi);
  background-image:var(--grain);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"palt";
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
::selection{background:var(--green);color:var(--washi)}

.inner{max-width:var(--w);margin-inline:auto;padding-inline:clamp(22px,5vw,48px)}
.serif{font-family:var(--serif)}
.latin{font-family:var(--latin)}

/* ---------- header ---------- */
.site-header{position:fixed;inset:0 0 auto 0;z-index:60;transition:background .4s,box-shadow .4s,border-color .4s;border-bottom:1px solid transparent}
.site-header.scrolled{background:rgba(251,249,242,.88);backdrop-filter:blur(12px);border-bottom-color:var(--line)}
.header-inner{max-width:1280px;margin-inline:auto;padding:18px clamp(20px,4vw,40px);display:flex;align-items:center;gap:34px}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:30px;height:30px;object-fit:contain}
.brand-name{font-family:var(--latin);font-weight:600;font-size:19px;letter-spacing:.3em;color:var(--green);transform:translateY(1px)}
.gnav{margin-left:auto}
.gnav ul{display:flex;gap:30px}
.gnav a{font-size:12.5px;letter-spacing:.18em;color:var(--ink);position:relative;padding:6px 0}
.gnav a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .35s}
.gnav a:hover::after{transform:scaleX(1);transform-origin:left}
.header-cta{font-size:12px;letter-spacing:.18em;color:var(--washi);background:var(--green);padding:13px 22px;transition:background .3s;white-space:nowrap}
.header-cta:hover{background:var(--green-2)}
.menu-btn{display:none;margin-left:auto;width:46px;height:46px;background:none;border:1px solid var(--line);cursor:pointer;position:relative;z-index:80}
.menu-btn span{position:absolute;left:13px;right:13px;height:1px;background:var(--ink);transition:.35s}
.menu-btn span:nth-child(1){top:17px}
.menu-btn span:nth-child(2){top:23px}
.menu-btn span:nth-child(3){top:29px}
body.menu-open .menu-btn{border-color:var(--line-d)}
body.menu-open .menu-btn span{background:var(--washi)}
body.menu-open .menu-btn span:nth-child(1){top:23px;transform:rotate(35deg)}
body.menu-open .menu-btn span:nth-child(2){opacity:0}
body.menu-open .menu-btn span:nth-child(3){top:23px;transform:rotate(-35deg)}

.mobile-menu{position:fixed;inset:0;z-index:70;background:var(--deep);display:grid;place-items:center;opacity:0;visibility:hidden;transition:opacity .45s,visibility .45s}
body.menu-open .mobile-menu{opacity:1;visibility:visible}
.mobile-menu ul{text-align:center;display:grid;gap:26px}
.mobile-menu a{font-family:var(--serif);font-size:21px;letter-spacing:.22em;color:var(--washi)}
.mobile-menu .mm-cta{display:inline-block;margin-top:10px;border:1px solid var(--gold-2);color:var(--gold-2);font-family:var(--sans);font-size:13px;letter-spacing:.2em;padding:16px 30px}
body.menu-open{overflow:hidden}

/* ---------- buttons / links ---------- */
.btn{display:inline-flex;align-items:center;gap:16px;font-size:13px;letter-spacing:.24em;padding:20px 34px;border:1px solid var(--green);color:var(--green);transition:.35s;line-height:1}
.btn .ar{font-family:var(--latin);transition:transform .35s}
.btn:hover .ar{transform:translateX(7px)}
.btn-fill{background:var(--green);color:var(--washi)}
.btn-fill:hover{background:var(--green-2)}
.btn-gold{border-color:var(--gold-2);color:var(--gold-2)}
.btn-gold:hover{background:var(--gold-2);color:var(--deep)}
.link-arrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--serif);font-size:14px;letter-spacing:.14em;color:var(--green);position:relative;padding-bottom:6px}
.link-arrow::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--gold);transform:scaleX(.35);transform-origin:left;transition:transform .4s}
.link-arrow:hover::after{transform:scaleX(1)}
.link-arrow .ar{font-family:var(--latin);transition:transform .35s}
.link-arrow:hover .ar{transform:translateX(6px)}

/* ---------- section head / 落款 ---------- */
section{position:relative}
.sec{padding-block:clamp(96px,12vw,158px)}
.sec-head{display:flex;align-items:center;gap:22px;margin-bottom:clamp(44px,6vw,72px)}
.seal{flex:none;width:48px;height:48px;border:1px solid var(--gold);color:var(--gold);display:grid;place-items:center;font-family:var(--serif);font-size:21px;font-weight:600;position:relative}
.seal::after{content:"";position:absolute;inset:3px;border:1px solid rgba(174,147,85,.35)}
.sec-en{display:block;font-family:var(--latin);font-size:12px;letter-spacing:.46em;color:var(--gold);margin-bottom:8px}
.sec-head h2{font-family:var(--serif);font-weight:600;font-size:clamp(25px,3.4vw,38px);letter-spacing:.1em;line-height:1.5;color:var(--green)}
.dark .seal{border-color:var(--gold-2);color:var(--gold-2)}
.dark .sec-en{color:var(--gold-2)}
.dark .sec-head h2{color:var(--washi)}
.lead{font-family:var(--serif);font-size:clamp(15.5px,1.6vw,17.5px);line-height:2.3;letter-spacing:.08em;max-width:42em}

/* ---------- hero ---------- */
.hero{min-height:100svh;display:flex;flex-direction:column;position:relative;overflow:hidden}
.hero-ghost{position:absolute;left:-.04em;bottom:-.16em;font-family:var(--latin);font-weight:500;font-size:clamp(110px,19vw,272px);letter-spacing:.02em;line-height:1;color:transparent;-webkit-text-stroke:1px rgba(14,59,51,.13);user-select:none;pointer-events:none;white-space:nowrap}
.hero-rings{position:absolute;right:-12%;top:-18%;width:min(58vw,760px);opacity:.5;pointer-events:none}
.hero-rings circle{fill:none;stroke:var(--gold);stroke-width:.6;opacity:.45}
.hero-inner{flex:1;display:flex;align-items:stretch;gap:clamp(28px,5vw,72px);padding-top:110px;padding-bottom:56px;position:relative}
.hero-art{align-self:flex-end;flex:none;width:clamp(120px,16vw,205px);margin-bottom:-12px}
.hero-spacer{flex:1}
.hero-side{align-self:flex-end;max-width:470px;display:grid;gap:30px;padding-bottom:6vh}
.hero-sub{font-size:14.5px;line-height:2.35;letter-spacing:.07em;color:var(--ink)}
.hero-actions{display:flex;flex-wrap:wrap;gap:18px;align-items:center}
.hero-tate{align-self:center;font-family:var(--serif);font-weight:600;writing-mode:vertical-rl;font-size:clamp(35px,5.1vw,62px);letter-spacing:.24em;line-height:2;color:var(--green);white-space:nowrap}
.hero-tate .accent{color:var(--gold)}
.scroll-cue{position:absolute;left:clamp(22px,5vw,48px);bottom:0;display:flex;flex-direction:column;align-items:center;gap:12px}
.scroll-cue span{font-family:var(--latin);font-size:10.5px;letter-spacing:.42em;writing-mode:vertical-rl;color:var(--ink-2)}
.scroll-cue i{display:block;width:1px;height:74px;background:var(--line);position:relative;overflow:hidden}
.scroll-cue i::after{content:"";position:absolute;left:0;top:-100%;width:100%;height:100%;background:var(--gold);animation:cue 2.4s ease-in-out infinite}
@keyframes cue{0%{top:-100%}55%{top:0}100%{top:100%}}

/* 芽のドローイング */
.sprout .draw{fill:none;stroke-linecap:round}
.sprout .stem{stroke:var(--green);stroke-width:2.4}
.sprout .leaf-l{stroke:var(--green);stroke-width:2}
.sprout .leaf-r{stroke:var(--gold);stroke-width:2}
.sprout .seed{fill:var(--gold)}
html.js .sprout .draw{stroke-dasharray:1;stroke-dashoffset:1}
html.js .sprout .seed{opacity:0;transform:scale(0);transform-box:fill-box;transform-origin:center}
html.js .hero.ready .sprout .seed{animation:seedin .7s .15s cubic-bezier(.34,1.56,.64,1) forwards}
html.js .hero.ready .sprout .stem{animation:draw 1.5s .5s cubic-bezier(.65,0,.2,1) forwards}
html.js .hero.ready .sprout .leaf-l{animation:draw 1s 1.7s cubic-bezier(.65,0,.3,1) forwards}
html.js .hero.ready .sprout .leaf-r{animation:draw 1s 1.95s cubic-bezier(.65,0,.3,1) forwards}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes seedin{to{opacity:1;transform:scale(1)}}

/* ---------- 01 変 / shift ---------- */
.shift{background:var(--paper);background-image:var(--grain);border-top:1px solid var(--line)}
.shift-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:clamp(40px,5vw,64px)}
.shift-card{background:var(--paper);padding:clamp(30px,3.4vw,46px) clamp(26px,3vw,40px)}
.shift-card .no{font-family:var(--latin);font-size:13px;letter-spacing:.3em;color:var(--gold);display:block;margin-bottom:18px}
.shift-card h3{font-family:var(--serif);font-weight:600;font-size:18.5px;letter-spacing:.1em;line-height:1.8;color:var(--green);margin-bottom:16px}
.shift-card p{font-size:13.5px;line-height:2.15;color:var(--ink-2)}
.note{margin-top:30px;font-size:12.5px;letter-spacing:.06em;color:var(--ink-2)}

/* ---------- 02 種 / origin ---------- */
.origin{text-align:center;overflow:hidden}
.origin .sec-head{justify-content:center}
.origin-rings{position:absolute;left:50%;top:54%;transform:translate(-50%,-50%);width:min(86vw,860px);opacity:.4;pointer-events:none}
.origin-rings circle{fill:none;stroke:var(--gold);stroke-width:.5;opacity:.5}
.origin-state{font-family:var(--serif);font-weight:600;font-size:clamp(26px,4.7vw,46px);letter-spacing:.16em;line-height:1.9;color:var(--green);margin-bottom:clamp(36px,5vw,56px);position:relative}
.origin-state .dot{color:var(--gold)}
.origin-body{max-width:37em;margin-inline:auto;text-align:left;display:grid;gap:1.6em;position:relative}
.origin-body p{font-family:var(--serif);font-size:15px;line-height:2.5;letter-spacing:.09em;text-align:justify}
.origin-name{margin-top:clamp(36px,5vw,52px);font-family:var(--latin);font-size:12px;letter-spacing:.5em;color:var(--gold)}

/* ---------- 03 業 / service ---------- */
.service{background:var(--paper);background-image:var(--grain);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.svc-feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.6vw,34px)}
.svc-card{background:var(--washi);border:1px solid var(--line);padding:clamp(32px,4vw,52px);display:flex;flex-direction:column;gap:18px;transition:transform .45s,box-shadow .45s,border-color .45s;position:relative;overflow:hidden}
.svc-card::before{content:"";position:absolute;top:0;left:0;width:54px;height:1px;background:var(--gold);transition:width .5s}
.svc-card:hover{transform:translateY(-5px);border-color:rgba(174,147,85,.55);box-shadow:0 30px 50px -34px rgba(8,37,31,.4)}
.svc-card:hover::before{width:100%}
.svc-tag{font-family:var(--latin);font-size:11.5px;letter-spacing:.34em;color:var(--gold)}
.svc-card h3{font-family:var(--serif);font-weight:600;font-size:clamp(19px,2vw,23px);letter-spacing:.1em;line-height:1.7;color:var(--green)}
.svc-card p{font-size:13.5px;line-height:2.15;color:var(--ink-2);flex:1}
.svc-sub{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,34px);margin-top:clamp(20px,2.6vw,34px)}
.svc-sub .svc-card{padding:clamp(26px,3vw,36px)}
.svc-sub h3{font-size:17.5px}
.svc-note{margin-top:34px;font-size:12.5px;color:var(--ink-2)}

/* ---------- 04 理 / reason ---------- */
.reason-list{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(34px,4vw,56px);counter-reset:r}
.reason-list li{border-top:1px solid var(--line);padding-top:30px;position:relative}
.reason-list li::before{content:"";position:absolute;top:-1px;left:0;width:46px;height:1px;background:var(--gold)}
.r-no{font-family:var(--latin);font-size:34px;font-weight:500;color:var(--gold);line-height:1;display:block;margin-bottom:20px}
.reason-list h3{font-family:var(--serif);font-weight:600;font-size:18.5px;letter-spacing:.1em;line-height:1.8;color:var(--green);margin-bottom:14px}
.reason-list p{font-size:13.5px;line-height:2.15;color:var(--ink-2)}

/* ---------- 05 績 / works ---------- */
.works{background:var(--paper);background-image:var(--grain);border-top:1px solid var(--line)}
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,34px)}
.work-card{background:var(--washi);border:1px solid var(--line);padding:clamp(30px,3.4vw,42px);display:flex;flex-direction:column;gap:16px;transition:transform .45s,border-color .45s,box-shadow .45s}
.work-card:hover{transform:translateY(-5px);border-color:rgba(174,147,85,.55);box-shadow:0 30px 50px -34px rgba(8,37,31,.4)}
.w-tag{font-size:11px;letter-spacing:.26em;color:var(--gold);border:1px solid rgba(174,147,85,.5);align-self:flex-start;padding:6px 12px}
.work-card h3{font-family:var(--serif);font-weight:600;font-size:18px;letter-spacing:.08em;line-height:1.8;color:var(--green)}
.w-chips{display:flex;flex-wrap:wrap;gap:8px}
.w-chips li{font-size:10.5px;letter-spacing:.12em;color:var(--ink-2);border:1px solid var(--line);padding:5px 10px}
.work-card p{font-size:13px;line-height:2.1;color:var(--ink-2);flex:1}
.works-foot{margin-top:clamp(40px,5vw,60px);text-align:center}

/* ---------- 診断 CTA ---------- */
.cta-band{background:var(--deep);color:var(--washi);clip-path:polygon(0 84px,100% 0,100% 100%,0 100%);margin-top:-84px;padding-top:clamp(150px,16vw,210px);padding-bottom:clamp(96px,11vw,150px);position:relative;overflow:hidden}
.cta-rings{position:absolute;right:-10%;bottom:-32%;width:min(60vw,720px);opacity:.5;pointer-events:none}
.cta-rings circle{fill:none;stroke:var(--gold-2);stroke-width:.5;opacity:.4}
.cta-inner{position:relative;max-width:860px}
.cta-en{font-family:var(--latin);font-size:12px;letter-spacing:.46em;color:var(--gold-2);display:block;margin-bottom:22px}
.cta-band h2{font-family:var(--serif);font-weight:600;font-size:clamp(25px,4vw,40px);letter-spacing:.12em;line-height:1.9;margin-bottom:26px}
.cta-band .cta-lead{font-size:14px;line-height:2.3;color:rgba(244,240,230,.82);max-width:40em;margin-bottom:42px}
.cta-points{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line-d);border:1px solid var(--line-d);margin-bottom:42px}
.cta-points li{background:rgba(244,240,230,.04);padding:24px 22px}
.cta-points .no{font-family:var(--latin);font-size:12px;letter-spacing:.3em;color:var(--gold-2);display:block;margin-bottom:10px}
.cta-points h3{font-family:var(--serif);font-size:15.5px;font-weight:600;letter-spacing:.08em;line-height:1.9}
.cta-flow{font-size:12.5px;letter-spacing:.1em;color:rgba(244,240,230,.66);margin-bottom:40px}
.cta-flow b{color:var(--gold-2);font-weight:500}

/* ---------- 信 / message ---------- */
.president-grid{display:grid;grid-template-columns:minmax(250px,340px) 1fr;gap:clamp(44px,7vw,96px);align-items:start}
.photo-ph{aspect-ratio:3/4;border:1px solid var(--gold);position:relative;background:linear-gradient(165deg,rgba(14,59,51,.08),rgba(14,59,51,0) 55%),var(--paper);background-image:var(--grain);display:grid;place-items:center}
.photo-ph::before,.photo-ph::after{content:"";position:absolute;width:16px;height:16px;border-color:var(--green);border-style:solid}
.photo-ph::before{top:-5px;left:-5px;border-width:1px 0 0 1px}
.photo-ph::after{bottom:-5px;right:-5px;border-width:0 1px 1px 0}
.photo-ph span{writing-mode:vertical-rl;font-family:var(--serif);font-size:17px;letter-spacing:.4em;color:var(--green)}
.photo-real{aspect-ratio:3/4;object-fit:cover;border:1px solid var(--gold)}
.p-msg{display:grid;gap:1.6em;max-width:36em}
.p-msg p{font-family:var(--serif);font-size:15px;line-height:2.5;letter-spacing:.08em;text-align:justify}
.p-prof{margin-top:38px;border-top:1px solid var(--line);padding-top:26px}
.p-prof .role{font-size:11.5px;letter-spacing:.3em;color:var(--gold);display:block;margin-bottom:10px}
.p-prof .name{font-family:var(--serif);font-size:23px;font-weight:600;letter-spacing:.22em;color:var(--green)}
.p-prof .name small{font-family:var(--latin);font-size:11px;letter-spacing:.3em;color:var(--ink-2);margin-left:16px}
.p-prof .bio{margin-top:14px;font-size:12.5px;line-height:2.1;color:var(--ink-2)}

/* ---------- 問 / faq ---------- */
.faq{background:var(--paper);background-image:var(--grain);border-top:1px solid var(--line)}
.faq-list{border-top:1px solid var(--line)}
.qa{border-bottom:1px solid var(--line)}
.qa summary{list-style:none;cursor:pointer;display:flex;align-items:baseline;gap:20px;padding:26px 54px 26px 6px;position:relative;transition:color .3s}
.qa summary::-webkit-details-marker{display:none}
.qa summary:hover{color:var(--green)}
.qa .q-ico{font-family:var(--latin);font-size:17px;color:var(--gold);flex:none}
.qa summary h3{font-family:var(--serif);font-weight:600;font-size:15.5px;letter-spacing:.08em;line-height:1.9}
.qa summary::after{content:"＋";position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:15px;color:var(--gold);transition:transform .35s}
.qa[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.qa-a{padding:0 6px 30px 37px;display:flex;gap:20px}
.qa-a .a-ico{font-family:var(--latin);font-size:17px;color:var(--green);flex:none;line-height:2.1}
.qa-a p{font-size:13.5px;line-height:2.2;color:var(--ink-2);max-width:44em}
.faq-foot{margin-top:46px;text-align:center}

/* ---------- footer ---------- */
.site-footer{background:var(--deep);color:var(--washi);padding:clamp(80px,10vw,130px) 0 40px;position:relative;overflow:hidden}
.f-state{font-family:var(--serif);font-weight:600;font-size:clamp(21px,3.2vw,32px);letter-spacing:.18em;line-height:2;margin-bottom:clamp(56px,7vw,84px)}
.f-state .dot{color:var(--gold-2)}
.f-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:clamp(36px,5vw,64px);padding-top:46px;border-top:1px solid var(--line-d)}
.f-brand{display:grid;gap:18px;align-content:start}
.f-brand img{width:34px}
.f-brand .fb-name{font-family:var(--latin);font-size:17px;letter-spacing:.3em}
.f-brand address{font-style:normal;font-size:12px;line-height:2.1;color:rgba(244,240,230,.66)}
.f-col h4{font-family:var(--latin);font-size:11px;letter-spacing:.4em;color:var(--gold-2);margin-bottom:20px}
.f-col ul{display:grid;gap:13px}
.f-col a{font-size:12.5px;letter-spacing:.12em;color:rgba(244,240,230,.8);transition:color .3s}
.f-col a:hover{color:var(--gold-2)}
.f-bottom{margin-top:64px;display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:center;font-family:var(--latin);font-size:10.5px;letter-spacing:.22em;color:rgba(244,240,230,.45)}
.f-bottom a{color:inherit}
.f-bottom a:hover{color:var(--gold-2)}

/* ---------- reveal ---------- */
html.js .rv{opacity:0;transform:translateY(26px)}
html.js .rv.on{opacity:1;transform:none;transition:opacity 1s cubic-bezier(.21,.8,.27,1),transform 1s cubic-bezier(.21,.8,.27,1);transition-delay:var(--d,0s)}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
  html.js .rv{opacity:1;transform:none}
  html.js .sprout .draw{stroke-dashoffset:0}
  html.js .sprout .seed{opacity:1;transform:scale(1)}
}

/* ---------- responsive ---------- */
@media (max-width:1020px){
  .gnav{display:none}
  .header-cta{display:none}
  .menu-btn{display:block}
}
@media (max-width:920px){
  .svc-feature{grid-template-columns:1fr}
  .svc-sub{grid-template-columns:1fr}
  .works-grid{grid-template-columns:1fr}
  .reason-list{grid-template-columns:1fr;gap:40px}
  .shift-grid{grid-template-columns:1fr}
  .cta-points{grid-template-columns:1fr}
  .president-grid{grid-template-columns:1fr;gap:48px}
  .photo-ph,.photo-real{max-width:330px}
  .f-grid{grid-template-columns:1fr;gap:40px}
  .cta-band{clip-path:polygon(0 46px,100% 0,100% 100%,0 100%);margin-top:-46px;padding-top:120px}
}
@media (max-width:760px){
  .hero-inner{flex-wrap:wrap;align-content:flex-end;gap:0 30px;padding-top:96px}
  .hero-spacer{display:none}
  .hero-art{order:1;width:108px;margin-bottom:0;align-self:flex-end}
  .hero-tate{order:2;font-size:clamp(33px,9.6vw,44px);align-self:flex-end;margin-left:auto}
  .hero-side{order:3;width:100%;padding-bottom:0;margin-top:40px}
  .hero-ghost{font-size:30vw;bottom:-.1em}
  .scroll-cue{display:none}
  .qa summary{padding-right:38px}
}

/* =========================================================
   v1.1 — 可読性調整・図解・写真フレーム
   ========================================================= */
h1,h2,h3,.lead,.origin-state,.origin-body p,.p-msg p{word-break:auto-phrase}
.gnav a{font-size:13.5px}
.lead{font-size:clamp(16.5px,1.7vw,19px)}
.hero-sub{font-size:16px;line-height:2.3}
.shift-card h3{font-size:20px}
.shift-card p{font-size:14.5px;line-height:2.1}
.note{font-size:13.5px}
.svc-card p{font-size:14.5px}
.svc-sub h3{font-size:18px}
.reason-list h3{font-size:19.5px}
.reason-list p{font-size:14.5px}
.work-card p{font-size:14px}
.w-chips li{font-size:11px}
.cta-band .cta-lead{font-size:15px}
.cta-points h3{font-size:16.5px}
.qa summary h3{font-size:16.5px}
.qa-a p{font-size:14.5px}
.origin-body p,.p-msg p{font-size:16px}
.p-prof .bio{font-size:13.5px}
.f-col a{font-size:13.5px}
.f-brand address{font-size:13px}

/* 図解(SHIFTセクション) */
.dg{margin-bottom:26px;border-bottom:1px solid var(--line);padding-bottom:24px}
.dg svg{width:100%;height:auto;display:block}
.dg .st{stroke:var(--green);stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}
.dg .st-soft{stroke:rgba(38,35,28,.32);stroke-width:1.4;fill:none}
.dg .gd{stroke:var(--gold);stroke-width:1.6;fill:none}
.dg .soft{fill:rgba(38,35,28,.2)}
.dg .ln{fill:rgba(14,59,51,.5)}
.dg .glow{fill:rgba(174,147,85,.1)}
.dg .fill-gd{fill:var(--gold)}
.dg .fill-gn{fill:var(--green)}
.dg .ck{stroke:var(--washi);stroke-width:2.2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.dg .ck-g{stroke:var(--gold);stroke-width:2;fill:none;stroke-linecap:round;stroke-linejoin:round}
.dg text{font-family:var(--sans);letter-spacing:.1em}
.dg .lbl{font-size:10.5px;fill:var(--ink-2)}
.dg .lbl-g{font-size:10.5px;fill:var(--gold)}
.dg .ai{font-family:var(--latin);font-size:14px;fill:var(--washi);letter-spacing:.08em}

/* 代表写真フレーム */
.photo-frame{position:relative}
.photo-frame::before,.photo-frame::after{content:"";position:absolute;width:16px;height:16px;border-color:var(--green);border-style:solid;z-index:1}
.photo-frame::before{top:-5px;left:-5px;border-width:1px 0 0 1px}
.photo-frame::after{bottom:-5px;right:-5px;border-width:0 1px 1px 0}
.photo-real{width:100%;object-position:50% 18%}

/* =========================================================
   v1.2 — 成長する盆栽・改行制御・写真・アイコン
   ========================================================= */
/* 改行:文節折返し(対応ブラウザ)+主要文はフレーズ固定 */
body{word-break:auto-phrase;line-break:strict}
.ph{display:inline-block}
.origin-body p,.p-msg p{text-align:left}

/* 写真:自然な比率で表示 */
.photo-real{aspect-ratio:auto;object-fit:contain;object-position:center;height:auto}

/* ヒーロー:旧スプラウト撤去後のレイアウトと漂う種 */
.hero-inner{justify-content:flex-end}
.scroll-cue{left:auto;right:clamp(22px,5vw,48px)}
.drift{position:absolute;inset:0;pointer-events:none}
.drift i{position:absolute;width:5px;height:5px;border-radius:50%;background:var(--gold);opacity:0;animation:drift 13s linear infinite}
.drift i:nth-child(1){left:30%;top:72%}
.drift i:nth-child(2){left:52%;top:80%;animation-delay:4.5s;transform:scale(.8)}
.drift i:nth-child(3){left:66%;top:64%;animation-delay:9s;transform:scale(.7)}
@keyframes drift{0%{opacity:0;translate:0 0}12%{opacity:.55}55%{opacity:.4}100%{opacity:0;translate:-46px -190px}}

/* 成長する盆栽レイヤー */
.grow-rail{position:fixed;left:16px;bottom:18px;z-index:5;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:12px;width:clamp(104px,calc((100vw - 1230px)/2),270px)}
.grow-rail::before{content:"";position:absolute;inset:-14% -18%;background:radial-gradient(closest-side,rgba(244,240,230,.92),rgba(244,240,230,0));z-index:-1}
.grow-rail svg{width:100%;height:auto;display:block;transform-origin:50% 96%}
.grow-rail.done svg{animation:sway 6s ease-in-out infinite}
@keyframes sway{0%,100%{rotate:0deg}50%{rotate:1.2deg}}
.stage-seal{width:34px;height:34px;border:1px solid var(--gold);color:var(--gold);background:rgba(244,240,230,.85);display:grid;place-items:center;font-family:var(--serif);font-weight:600;font-size:15px}
.stage-seal.pop{animation:sealpop .4s cubic-bezier(.34,1.56,.64,1)}
@keyframes sealpop{0%{scale:.5;opacity:.2}100%{scale:1;opacity:1}}
.grow [data-kind="draw"]{fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:1;stroke-dashoffset:1}
.grow [data-kind="fade"]{opacity:0}
.grow [data-kind="pop"]{opacity:0;transform:scale(.4);transform-box:fill-box;transform-origin:center}
.grow .g-stem{stroke:var(--green);stroke-width:2}
.grow .g-leaf{stroke:var(--green);stroke-width:1.8}
.grow .g-trunk{stroke:var(--green);stroke-width:2.7}
.grow .g-trunk2{stroke:var(--green);stroke-width:2.2}
.grow .g-br{stroke:var(--green);stroke-width:2}
.grow .g-pad{stroke:var(--green);stroke-width:1.9}
.grow .g-padfill path{fill:rgba(14,59,51,.1);stroke:none}
.grow .g-gold{fill:var(--gold)}
.grow .g-moss{fill:var(--green)}
.grow .g-pot{stroke:var(--gold);stroke-width:2}
.grow .g-ground{stroke:var(--gold);stroke-width:1}
.grow-rail.static [data-kind="draw"]{stroke-dashoffset:0!important}
.grow-rail.static [data-kind="fade"],.grow-rail.static [data-kind="pop"]{opacity:1!important;transform:none!important}
@media (max-width:1240px){.grow-rail{opacity:.4;width:100px}.grow-rail::before{display:none}.stage-seal{display:none}}
@media (max-width:760px){.grow-rail{opacity:.35;width:84px;left:8px;bottom:10px}}

/* サービスアイコン */
.svc-top{display:flex;align-items:center;justify-content:space-between;gap:14px}
.svc-ico{width:36px;height:36px;flex:none}
.svc-ico svg{width:100%;height:100%}
.i-st{stroke:var(--green);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.i-gd{stroke:var(--gold);stroke-width:1.6;fill:none;stroke-linecap:round}
.i-gd-f{fill:var(--gold)}

/* =========================================================
   v1.3 — 模様木の大型化・完成演出・開幕演出・モバイルFV
   ========================================================= */
/* 開幕:深緑の幕から金の種が落ち、幕が上がる */
.intro{position:fixed;inset:0;z-index:100;background:var(--deep);display:grid;place-items:center;pointer-events:none;animation:introup .85s 1.05s cubic-bezier(.76,0,.24,1) forwards}
.intro::before{content:"";position:absolute;top:0;left:50%;width:1px;height:0;background:var(--gold-2);animation:introline .7s .1s ease-out forwards}
.intro-seed{width:13px;height:13px;border-radius:50%;background:var(--gold-2);scale:0;animation:iseed .5s .6s cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes introline{to{height:calc(50% - 10px)}}
@keyframes iseed{to{scale:1}}
@keyframes introup{to{translate:0 -101%}}

/* 見出し:一字ずつ立ち上がる */
html.js .hero-tate .ch{display:inline-block;opacity:0;translate:0 18px;animation:chin .7s cubic-bezier(.21,.8,.27,1) forwards;animation-delay:calc(1.25s + var(--i)*.07s)}
html.js .hero-side{opacity:0;translate:0 18px;animation:chin .9s 2.3s cubic-bezier(.21,.8,.27,1) forwards}
@keyframes chin{to{opacity:1;translate:0 0}}
.hero-rings{animation:breathe 11s ease-in-out infinite}
@keyframes breathe{0%,100%{scale:1}50%{scale:1.05}}

/* 盆栽:画面の縦いっぱいに */
.grow-rail{left:20px;bottom:12px;width:auto}
.grow-rail svg.grow{width:auto;height:min(86vh,880px)}
.grow-rail::before{inset:-6% -30%;background:radial-gradient(closest-side,rgba(244,240,230,.95) 30%,rgba(244,240,230,0))}
.stage-seal{width:40px;height:40px;font-size:17px;transition:background .5s,color .5s}
.grow-rail.done .stage-seal{background:var(--gold);color:var(--deep)}
.grow .g-stem{stroke-width:2.6}
.grow .g-leaf{stroke-width:2.2}
.grow .g-trunk{stroke-width:4.4}
.grow .g-trunkfill{fill:rgba(14,59,51,.14);stroke:none}
.grow .g-br{stroke-width:3}
.grow .g-pad{stroke-width:2.4}
.grow .g-padfill path{fill:rgba(14,59,51,.12)}
.grow .g-root{stroke:var(--green);stroke-width:3}
.grow .g-pot{stroke-width:3}
.grow .g-fruit circle{fill:var(--gold)}
.grow .g-fruit .hl{fill:#F8F3E4;opacity:.9}
.grow .g-fruit line{stroke:var(--green);stroke-width:2.2;stroke-linecap:round}
.grow .g-glow{opacity:0;transition:opacity 1.6s ease}
.grow-rail.done .g-glow{opacity:.55}
/* 完成:金の粒子が舞う */
.spk{position:absolute;width:9px;height:9px;background:var(--gold);clip-path:polygon(50% 0,62% 38%,100% 50%,62% 62%,50% 100%,38% 62%,0 50%,38% 38%);opacity:0}
.grow-rail.done .spk{animation:spk 1.5s ease-out forwards}
.spk:nth-child(3){left:14%;top:66%;animation-delay:.05s}
.spk:nth-child(4){left:78%;top:58%;animation-delay:.15s}
.spk:nth-child(5){left:8%;top:46%;animation-delay:.25s}
.spk:nth-child(6){left:84%;top:38%;animation-delay:.35s}
.spk:nth-child(7){left:22%;top:26%;animation-delay:.45s}
.spk:nth-child(8){left:70%;top:18%;animation-delay:.55s}
.spk:nth-child(9){left:46%;top:10%;animation-delay:.65s}
.spk:nth-child(10){left:52%;top:78%;animation-delay:.3s}
@keyframes spk{0%{transform:translateY(8px) scale(0);opacity:0}25%{opacity:1}100%{transform:translateY(-30px) scale(1.1);opacity:0}}

@media (max-width:1240px){
  .grow-rail{opacity:.95;width:auto}
  .grow-rail::before{display:block}
  .stage-seal{display:grid;width:34px;height:34px;font-size:15px}
  .grow-rail svg.grow{height:66vh}
}
@media (max-width:760px){
  .grow-rail{opacity:.9;left:8px;bottom:6px;width:auto}
  .grow-rail svg.grow{height:54vh}
  .stage-seal{width:30px;height:30px;font-size:13px}
  /* モバイルFV:中央に大きく */
  .hero-inner{align-content:center;justify-content:center;min-height:100svh;padding-top:84px}
  .hero-tate{order:1;margin-inline:auto;align-self:center;font-size:clamp(44px,13vw,58px);letter-spacing:.26em}
  .hero-side{order:2;width:100%;margin-top:48px}
  .hero-rings{right:auto;left:50%;top:32%;width:150vw;margin-left:-75vw;margin-top:-75vw;opacity:.55}
  .hero-ghost{font-size:34vw;bottom:-2vw}
  .scroll-cue{display:flex;left:50%;right:auto;margin-left:-8px}
  .drift i{width:6px;height:6px}
}
@media (prefers-reduced-motion:reduce){
  .intro{display:none}
  html.js .hero-tate .ch,html.js .hero-side{opacity:1!important;translate:0 0!important;animation:none!important}
}

/* =========================================================
   v2.0 — 床の間レイアウト・リアル盆栽・完成の間
   ========================================================= */
:root{--rail-w:clamp(216px,21vw,304px)}

/* PC(1100px以上):左20%を床の間、右にコンテンツ */
@media (min-width:1100px){
  .page-top .site-header{left:0}
  .page-top main,.page-top .site-footer{margin-left:var(--rail-w)}
  .grow-rail{position:fixed;left:0;top:0;bottom:0;width:var(--rail-w);z-index:40;display:flex;flex-direction:column;align-items:center;padding:34px 0 22px;opacity:1;background-color:var(--washi);background-image:var(--grain);border-right:1px solid rgba(174,147,85,.45);transition:border-color 1.2s}
  .grow-rail::before{display:none}
  .grow-rail::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:0;transition:opacity 1.8s ease;background:radial-gradient(120% 56% at 50% 60%,rgba(8,37,31,0) 30%,rgba(8,37,31,.95) 82%)}
  .grow-rail.done::after{opacity:1}
  .grow-rail.done{border-right-color:rgba(8,37,31,.85)}
  .grow-rail .stage-seal{position:relative;z-index:3;width:42px;height:42px;font-size:18px}
  .rail-line{flex:1;width:1px;min-height:30px;background:linear-gradient(to bottom,rgba(174,147,85,.6),rgba(174,147,85,.1));margin:16px 0 10px;position:relative;z-index:2}
  .grow-rail svg.grow{position:relative;z-index:1;width:88%;height:auto;margin:0 0 4px}
}
@media (max-width:1099px){
  .grow-rail{display:none}
}

/* 段階落款ミニ(狭幅画面) */
.stage-seal-m{display:none}
@media (max-width:1099px){
  .stage-seal-m{display:grid;position:fixed;right:14px;bottom:14px;z-index:45;width:36px;height:36px;font-size:15px;box-shadow:0 10px 24px -12px rgba(8,37,31,.45)}
  body.grown .stage-seal-m{background:var(--gold);color:var(--deep);border-color:var(--gold)}
}

/* 盆栽v3:配色 */
.grow .tr{stroke:#4A3829;fill:none}
.grow .bark{stroke:#33261A;stroke-width:1.8;fill:none}
.grow .pad .p1{fill:#0B2F29}
.grow .pad .p2{fill:#0E3B33}
.grow .pad .p3{fill:#1C5547}
.grow .ndl{stroke-width:1.1;stroke-linecap:round;fill:none;opacity:.92}
.grow .fruit circle{fill:var(--gold)}
.grow .fruit .hl{fill:#F8F3E4;opacity:.92}
.grow .fruit line{stroke:#4A3829;stroke-width:2.4;stroke-linecap:round}
.grow .pbody{fill:#4A372A}
.grow .plip{fill:#5C4636}
.grow .prim{stroke:var(--gold);stroke-width:2;fill:none}
.grow .pfoot{fill:#3A2A1E}
.grow .pshadow{fill:rgba(8,37,31,.18)}
.grow .searth{fill:#2E2218}
.grow .g-ground{stroke-width:1.4}
.grow [data-kind="rise"]{opacity:0}
.grow-rail.static [data-kind="rise"]{opacity:1!important;transform:none!important}

/* 粒子の再配置(子要素:落款1・罫2・svg3・粒子4〜11) */
.spk:nth-child(4){left:16%;top:60%;animation-delay:.05s}
.spk:nth-child(5){left:80%;top:54%;animation-delay:.15s}
.spk:nth-child(6){left:10%;top:42%;animation-delay:.25s}
.spk:nth-child(7){left:86%;top:36%;animation-delay:.35s}
.spk:nth-child(8){left:24%;top:22%;animation-delay:.45s}
.spk:nth-child(9){left:72%;top:16%;animation-delay:.55s}
.spk:nth-child(10){left:46%;top:8%;animation-delay:.65s}
.spk:nth-child(11){left:54%;top:70%;animation-delay:.3s}

/* 完成の間(狭幅画面のみ表示) */
.finale{display:none}
@media (max-width:1099px){
  .finale{display:block;background:var(--paper);background-image:var(--grain);border-top:1px solid var(--line);padding:clamp(84px,15vw,128px) 0;text-align:center;overflow:hidden}
}
.finale-tree{position:relative;width:min(74vw,340px);margin:0 auto clamp(36px,8vw,56px)}
.finale-tree svg{width:100%;height:auto;display:block;opacity:0;translate:0 36px;transition:opacity 1.3s ease,translate 1.3s cubic-bezier(.21,.8,.27,1)}
.finale.bloom .finale-tree svg{opacity:1;translate:0 0}
.finale.bloom .g-glow{opacity:.6}
.grow.final [data-kind]{stroke-dashoffset:0;opacity:1;transform:none}
.finale.bloom .fruit{animation:fruitpulse 3s ease-in-out infinite alternate}
@keyframes fruitpulse{from{opacity:1}to{opacity:.72}}
.finale-tree .spk:nth-child(2){left:14%;top:58%;animation-delay:.2s}
.finale-tree .spk:nth-child(3){left:82%;top:50%;animation-delay:.45s}
.finale-tree .spk:nth-child(4){left:8%;top:34%;animation-delay:.7s}
.finale-tree .spk:nth-child(5){left:88%;top:26%;animation-delay:.95s}
.finale-tree .spk:nth-child(6){left:30%;top:12%;animation-delay:1.2s}
.finale-tree .spk:nth-child(7){left:64%;top:6%;animation-delay:1.45s}
.finale.bloom .spk{animation-name:spk;animation-duration:1.6s;animation-timing-function:ease-out;animation-fill-mode:forwards}
.f-en{display:block;font-family:var(--latin);font-size:12px;letter-spacing:.46em;color:var(--gold);margin-bottom:16px}
.f-title{font-family:var(--serif);font-weight:600;font-size:clamp(24px,6.6vw,34px);letter-spacing:.14em;line-height:1.9;color:var(--green);margin-bottom:14px}
.f-title .dot{color:var(--gold)}
.f-lead{max-width:30em;margin:0 auto 34px;font-size:14.5px;line-height:2.2;color:var(--ink-2)}

@media (prefers-reduced-motion:reduce){
  .finale-tree svg{opacity:1!important;translate:0 0!important}
}

/* =========================================================
   v2.1 — 受賞サイト技法パッケージ
   ========================================================= */
/* A1 行マスク・テキストリベール */
.lm{display:block;overflow:hidden}
span.ph.lm{display:inline-block;vertical-align:bottom}
.lm-i{display:block;translate:0 112%;transition:translate .9s cubic-bezier(.22,1,.36,1);transition-delay:var(--d,0s)}
.on .lm-i,.bloom .lm-i{translate:0 0}

/* A2 章漢字ウォーターマーク */
.wm{position:absolute;z-index:0;right:-.06em;top:50%;transform:translateY(-50%);font-family:var(--serif);font-weight:600;font-size:clamp(260px,34vw,540px);line-height:1;color:transparent;-webkit-text-stroke:1px rgba(14,59,51,.1);pointer-events:none;user-select:none}
.cta-band .wm{-webkit-text-stroke-color:rgba(211,194,149,.12)}
.finale .wm{font-size:clamp(220px,60vw,400px)}
.has-wm{overflow:hidden}
.has-wm>.inner{position:relative;z-index:1}

/* A3 マグネティックボタン */
.mag{will-change:translate}

/* A4 カスタムカーソル(PCのみ) */
.cur{position:fixed;inset:0;z-index:200;pointer-events:none;opacity:0;transition:opacity .3s}
.cur.on{opacity:1}
.cur-dot{position:fixed;top:-4px;left:-4px;width:8px;height:8px;border-radius:50%;background:var(--gold);transition:scale .3s}
.cur-ring{position:fixed;top:-19px;left:-19px;width:38px;height:38px;border-radius:50%;border:1px solid rgba(174,147,85,.65);transition:scale .35s,border-color .35s}
.cur.lk .cur-ring{scale:1.7;border-color:var(--gold)}
.cur.lk .cur-dot{scale:.5}
html.cur-on *{cursor:none!important}

/* A5 マーキー帯 */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:20px 0;background:var(--washi);background-image:var(--grain)}
.mq-track{display:flex;width:max-content;animation:mq 38s linear infinite}
.mq-track span{white-space:nowrap;font-family:var(--latin);font-size:15px;letter-spacing:.3em;color:var(--ink-2)}
.mq-track i{font-style:normal;color:var(--gold);padding:0 1.1em}
@keyframes mq{to{translate:-50% 0}}

/* B7 漂う金の塵 */
.dust{position:fixed;inset:0;z-index:55;pointer-events:none}

/* B8 開幕演出の強化(全体約2.9秒) */
.intro{animation:introup .85s 2s cubic-bezier(.76,0,.24,1) forwards}
.intro-txt{position:absolute;left:50%;top:calc(50% + 36px);transform:translateX(-50%);margin:0;white-space:nowrap;font-family:var(--serif);font-size:clamp(15px,2.2vw,21px);letter-spacing:.32em;color:var(--washi);opacity:0;animation:itxt .8s 1.05s ease forwards}
.intro-txt .dot{color:var(--gold-2)}
@keyframes itxt{to{opacity:1}}
html.js .hero-tate .ch{animation-delay:calc(2.15s + var(--i)*.07s)}
html.js .hero-side{animation-delay:3.1s}

@media (max-width:1099px){.cur{display:none}}
@media (prefers-reduced-motion:reduce){
  .lm-i{translate:0 0!important}
  .mq-track{animation:none!important}
  .cur,.dust{display:none!important}
  .wm{display:none}
  .intro{display:none}
}

/* =========================================================
   v2.2 — 文節組版(全ブラウザ)・見出しの1行収め
   ========================================================= */
.jw{display:inline-block}
@media (max-width:760px){
  .cta-band h2{font-size:clamp(23px,6vw,30px)}
  .origin-state{font-size:clamp(22px,5.6vw,46px)}
  .f-title{font-size:clamp(21px,5.6vw,34px)}
  .f-state{font-size:clamp(19px,5vw,32px)}
}

/* =========================================================
   v3.0 — 下層ページ共通(Phase 2: 不動産LP・無料AEO診断)
   ========================================================= */
.pg-en{display:block;font-family:var(--latin);font-size:12px;letter-spacing:.46em;color:var(--gold);margin-bottom:18px}
.page-hero{padding:clamp(140px,18vh,190px) 0 clamp(56px,8vw,90px);position:relative;overflow:hidden}
.page-hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(26px,4.6vw,46px);letter-spacing:.1em;line-height:1.9;color:var(--green);margin-bottom:20px}
.page-hero .lead{margin-bottom:32px}
.pg-rings{position:absolute;right:-12%;top:-30%;width:min(54vw,640px);opacity:.45;pointer-events:none}
.pg-rings circle{fill:none;stroke:var(--gold);stroke-width:.6;opacity:.45}

/* LPヒーロー2カラム+チャット図解 */
.lp-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,70px);align-items:center}
.lp-chat-wrap{border-bottom:none;padding-bottom:0;margin-bottom:0}
.lp-chat{width:100%;height:auto;display:block}
.dg .tx{font-size:13px;fill:var(--ink);letter-spacing:.06em}
.dg .tx-g{font-size:13px;fill:var(--gold);letter-spacing:.06em}
@media (max-width:920px){.lp-hero-grid{grid-template-columns:1fr}.lp-chat{max-width:420px;margin:0 auto}}

/* LP用スリムヘッダー・フッター */
.lp-header .gnav,.lp-header .menu-btn{display:none}
.lp-header .header-cta{display:inline-block;margin-left:auto}
.lp-footer{background:var(--deep);color:rgba(244,240,230,.72);padding:44px 0;font-size:12.5px;letter-spacing:.08em;line-height:2}
.lp-footer .inner{display:flex;flex-wrap:wrap;gap:10px 32px;justify-content:space-between;align-items:center}
.lp-footer a{color:rgba(244,240,230,.78);transition:color .3s}
.lp-footer a:hover{color:var(--gold-2)}

/* スリム問いかけバンド */
.band-slim{clip-path:polygon(0 44px,100% 0,100% 100%,0 100%);margin-top:-44px;padding-top:clamp(110px,12vw,150px);padding-bottom:clamp(80px,9vw,110px)}

/* 導入の流れ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,3vw,40px)}
.steps li{position:relative;border-top:1px solid var(--line);padding-top:24px}
.steps li::before{content:"";position:absolute;top:-1px;left:0;width:40px;height:1px;background:var(--gold)}
.st-no{font-family:var(--latin);font-size:13px;letter-spacing:.3em;color:var(--gold);display:block;margin-bottom:12px}
.steps h3{font-family:var(--serif);font-size:17.5px;font-weight:600;letter-spacing:.08em;line-height:1.8;color:var(--green);margin-bottom:10px}
.steps p{font-size:13.5px;line-height:2;color:var(--ink-2)}
@media (max-width:860px){.steps{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.steps{grid-template-columns:1fr}}

/* 6つの整え */
.grid6{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.g-item{background:var(--paper);padding:clamp(26px,3vw,34px) clamp(24px,2.6vw,30px)}
.gi-no{font-family:var(--latin);font-size:12px;letter-spacing:.3em;color:var(--gold);display:block;margin-bottom:12px}
.g-item h3{font-family:var(--serif);font-size:16.5px;font-weight:600;letter-spacing:.08em;line-height:1.8;color:var(--green);margin-bottom:8px}
.g-item p{font-size:13px;line-height:2;color:var(--ink-2)}
@media (max-width:880px){.grid6{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.grid6{grid-template-columns:1fr}}

/* 信頼の三点 */
.trust{display:flex;flex-wrap:wrap;gap:10px 26px;margin-top:26px}
.trust li{font-size:12.5px;letter-spacing:.06em;color:var(--ink-2);display:flex;gap:8px;align-items:baseline}
.trust li::before{content:"✓";color:var(--gold);font-family:var(--latin)}
.form-wrap .trust{justify-content:center}

/* 申込みフォーム枠 */
.form-wrap{max-width:620px;margin:0 auto}
.form-shell{background:var(--washi);background-image:var(--grain);border:1px solid var(--gold);padding:clamp(28px,5vw,46px);position:relative;text-align:center}
.form-shell::before,.form-shell::after{content:"";position:absolute;width:16px;height:16px;border-color:var(--green);border-style:solid}
.form-shell::before{top:-5px;left:-5px;border-width:1px 0 0 1px}
.form-shell::after{bottom:-5px;right:-5px;border-width:0 1px 1px 0}
.fs-note{font-size:13px;line-height:2.1;color:var(--ink-2);text-align:left;margin-bottom:24px}
.form-shell .btn{width:100%;justify-content:center}
.fs-mail{margin-top:14px;font-size:11.5px;letter-spacing:.06em;color:var(--ink-2)}

/* レポートサンプル枠 */
.report-ph{max-width:560px;margin:0 auto 26px;aspect-ratio:4/3;border:1px solid var(--gold);background-color:var(--paper);background-image:var(--grain);display:grid;place-items:center;text-align:center;position:relative}
.report-ph::before,.report-ph::after{content:"";position:absolute;width:16px;height:16px;border-color:var(--green);border-style:solid}
.report-ph::before{top:-5px;left:-5px;border-width:1px 0 0 1px}
.report-ph::after{bottom:-5px;right:-5px;border-width:0 1px 1px 0}
.rp-en{display:block;font-family:var(--latin);font-size:11px;letter-spacing:.42em;color:var(--gold);margin-bottom:14px}
.rp-t{font-family:var(--serif);font-size:19px;font-weight:600;letter-spacing:.18em;color:var(--green);margin-bottom:8px}
.rp-s{font-size:12px;letter-spacing:.08em;color:var(--ink-2)}

/* =========================================================
   v3.1 — Phase 3(サービス・実績・会社概要)
   ========================================================= */
/* サービス */
.svc-jump{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}
.svc-jump a{font-size:12.5px;letter-spacing:.12em;color:var(--ink-2);border:1px solid var(--line);padding:10px 16px;transition:border-color .3s,color .3s}
.svc-jump a:hover{border-color:var(--gold);color:var(--green)}
.svc-detail{scroll-margin-top:90px}
.svc-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);margin-top:clamp(28px,4vw,44px)}
.svc-col h3{font-family:var(--serif);font-size:16.5px;font-weight:600;letter-spacing:.14em;color:var(--green);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--line);position:relative}
.svc-col h3::after{content:"";position:absolute;left:0;bottom:-1px;width:34px;height:1px;background:var(--gold)}
.svc-col h3+p,.svc-col ul+h3{margin-top:26px}
.svc-col p{font-size:14px;line-height:2.15;color:var(--ink-2)}
.dot-list li{font-size:13.5px;line-height:1.9;color:var(--ink-2);padding:7px 0 7px 18px;position:relative}
.dot-list li::before{content:"";position:absolute;left:2px;top:1.05em;width:5px;height:5px;border-radius:50%;background:var(--gold)}
.tx-link{color:var(--green);border-bottom:1px solid var(--gold);transition:color .3s}
.tx-link:hover{color:var(--gold)}
@media (max-width:820px){.svc-cols{grid-template-columns:1fr}}

/* 実績 */
.case-list{display:grid;gap:clamp(26px,3.4vw,40px)}
.case-card{background:var(--washi);background-image:var(--grain);border:1px solid var(--line);padding:clamp(30px,4.4vw,54px);transition:border-color .4s}
.case-card:hover{border-color:rgba(174,147,85,.55)}
.case-head{display:grid;gap:10px;margin-bottom:18px}
.case-head .w-tag{justify-self:start}
.case-head h3{font-family:var(--serif);font-size:clamp(20px,2.4vw,26px);font-weight:600;letter-spacing:.1em;line-height:1.7;color:var(--green)}
.case-sub{font-size:12.5px;letter-spacing:.12em;color:var(--ink-2)}
.case-card .w-chips{margin-bottom:10px}
.case-dl{margin-top:16px}
.case-dl>div{display:grid;grid-template-columns:clamp(86px,12vw,130px) 1fr;gap:16px;border-top:1px solid var(--line);padding:18px 0}
.case-dl dt{font-family:var(--serif);font-size:14px;font-weight:600;letter-spacing:.18em;color:var(--gold);padding-top:2px}
.case-dl dd{font-size:14px;line-height:2.15;color:var(--ink)}
@media (max-width:560px){.case-dl>div{grid-template-columns:1fr;gap:6px;padding:16px 0}}

/* 会社概要 */
.spec{border-top:1px solid var(--line);max-width:860px}
.spec>div{display:grid;grid-template-columns:clamp(110px,16vw,190px) 1fr;gap:18px;border-bottom:1px solid var(--line);padding:22px 4px}
.spec dt{font-family:var(--serif);font-size:14.5px;font-weight:600;letter-spacing:.14em;color:var(--green)}
.spec dd{font-size:14.5px;line-height:2.1;color:var(--ink)}
@media (max-width:560px){.spec>div{grid-template-columns:1fr;gap:4px;padding:18px 4px}}
.hist{border-top:1px solid var(--line);max-width:860px}
.hist li{display:grid;grid-template-columns:clamp(96px,14vw,140px) 1fr;gap:18px;border-bottom:1px solid var(--line);padding:20px 4px;align-items:baseline}
.hist .yr{font-family:var(--latin);font-size:17px;letter-spacing:.14em;color:var(--gold)}
.hist p{font-size:14.5px;line-height:2;color:var(--ink)}

/* =========================================================
   v3.2 — 図解・メディア枠・コード抜粋
   ========================================================= */
.svc-visual{margin-top:clamp(26px,3.5vw,40px);border:1px solid var(--line);background-color:var(--paper);background-image:var(--grain);padding:clamp(16px,2.4vw,28px)}
.svc-visual svg{width:100%;height:auto;display:block}
.case-media{margin:16px 0 4px;aspect-ratio:16/6;border:1px dashed rgba(174,147,85,.65);background-color:var(--paper);background-image:var(--grain);display:grid;place-items:center;text-align:center;padding:18px}
.cm-en{display:block;font-family:var(--latin);font-size:10.5px;letter-spacing:.42em;color:var(--gold);margin-bottom:8px}
.case-media p{font-size:12px;letter-spacing:.08em;color:var(--ink-2)}
.code-peek{margin:16px 0 4px;background:var(--deep);color:rgba(244,240,230,.92);border:1px solid rgba(174,147,85,.45);padding:22px 26px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12.5px;line-height:1.95;letter-spacing:.02em;overflow-x:auto}

/* v3.3 — コード額装・矢の描画 */
.code-win{margin:16px 0 4px;border:1px solid rgba(174,147,85,.45);background:var(--deep)}
.code-bar{display:flex;align-items:center;gap:7px;padding:11px 16px;border-bottom:1px solid rgba(244,240,230,.14)}
.cdot{width:9px;height:9px;border-radius:50%;background:rgba(244,240,230,.28)}
.code-file{margin-left:8px;font-family:var(--latin);font-size:11px;letter-spacing:.14em;color:var(--gold-2)}
.code-win .code-peek{margin:0;border:none}
.code-win figcaption{padding:11px 16px;background:var(--paper);border-top:1px solid var(--line);font-size:11.5px;line-height:1.9;letter-spacing:.06em;color:var(--ink-2)}
.dg .dart{stroke:var(--gold);stroke-width:3;fill:none;stroke-linecap:round}
.dg .dart-h{fill:var(--gold)}

/* =========================================================
   v3.4 — FV演出(掛け軸・デュオトーン写真・金砂子)
   ========================================================= */
/* 金砂子テクスチャ(全ヒーロー下地) */
.hero::after,.page-hero::after{content:"";position:absolute;inset:0;background:url('/assets/img/kinsunago.png') repeat;background-size:480px auto;opacity:.5;pointer-events:none;z-index:1}
.hero-inner,.page-hero .inner{position:relative;z-index:2}
.scroll-cue{z-index:2}

/* FV写真(デュオトーン・フェード焼き込み済み) */
.hero-photo{position:absolute;top:0;right:0;bottom:0;z-index:0;pointer-events:none;display:flex;justify-content:flex-end}
.hero-photo img{height:100%;width:auto;display:block}
@media (max-width:919px){.hero-photo{display:none}}
@media (min-width:920px){.has-photo .inner{padding-right:clamp(300px,36vw,540px)}}

/* 掛け軸(トップFV・床の間の構図) */
.kakejiku{flex:none;align-self:center;width:clamp(185px,16.5vw,290px);margin-right:auto;position:relative;display:none}
@media (min-width:1280px){.kakejiku{display:block}}
.kakejiku::before{content:"";position:absolute;left:50%;top:-32px;width:1px;height:32px;background:linear-gradient(var(--gold),rgba(174,147,85,.2))}
.kj-rod{display:block;height:11px;border-radius:6px;background:linear-gradient(180deg,#4a3f33,#241b13);position:relative;width:calc(100% + 28px);margin-left:-14px;box-shadow:0 2px 6px rgba(8,37,31,.25)}
.kj-rod::before,.kj-rod::after{content:"";position:absolute;top:50%;transform:translateY(-50%);width:9px;height:9px;border-radius:50%;background:radial-gradient(circle at 35% 35%,var(--gold-2),var(--gold))}
.kj-rod::before{left:-5px}
.kj-rod::after{right:-5px}
.kj-top{margin-bottom:12px}
.kj-bot{margin-top:12px}
.kj-img{border:1px solid var(--gold);background:var(--washi);padding:9px;box-shadow:0 22px 54px rgba(8,37,31,.16)}
.kj-img img{display:block;width:100%;height:auto}

/* =========================================================
   v3.5 — トップFV改訂(全幅ヘッダー・暗景・AEO主役)
   ========================================================= */
.page-top .site-header{background:rgba(251,249,242,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom-color:var(--line)}
@media (min-width:1100px){.page-top .grow-rail{padding-top:100px}}

/* 暗景ヒーロー: 画像が届くまでは深緑グラデで成立 */
.hero-dark{background-color:#0A2D26;background-image:radial-gradient(110% 85% at 82% 12%,rgba(36,88,73,.9) 0%,rgba(14,59,51,.35) 46%,rgba(8,37,31,0) 72%),radial-gradient(95% 75% at 8% 92%,rgba(22,72,59,.75) 0%,rgba(8,37,31,0) 62%),linear-gradient(180deg,#0E3B33,#08251F);border-bottom:1px solid rgba(174,147,85,.4)}
.hero-dark::after{opacity:.62}
.hero-dark .hero-ghost{-webkit-text-stroke:1px rgba(244,240,230,.13);font-size:clamp(170px,27vw,420px);letter-spacing:.05em}
.hero-dark .hero-tate{color:var(--washi)}
.hero-dark .hero-sub{color:rgba(244,240,230,.9)}
.hero-dark .link-arrow{color:var(--gold-2)}
.hero-dark .scroll-cue span{color:rgba(244,240,230,.62)}
.hero-dark .scroll-cue i{background:rgba(244,240,230,.22)}
.hero-kicker{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 16px;font-family:var(--latin);font-size:11px;letter-spacing:.44em;color:var(--gold-2)}
.hero-kicker em{font-style:normal;font-family:var(--sans);font-size:11px;letter-spacing:.3em;color:rgba(244,240,230,.66)}
@media (max-width:760px){.hero-dark .hero-ghost{font-size:46vw}}

/* =========================================================
   v3.6 — トップLP化(盆栽レール撤去・FVフォーム・CTA強化)
   ========================================================= */
/* 盆栽レール撤去 */
.page-top .grow-rail,.stage-seal-m{display:none!important}
.page-top main,.page-top .site-footer{margin-left:0}

/* LP型FVレイアウト */
.hero-lp .hero-inner{display:grid;grid-template-columns:1.06fr .94fr;gap:clamp(34px,5vw,84px);align-items:center;padding-top:128px;padding-bottom:64px}
.hero-lp .scroll-cue{display:none}
.hero-copy{display:grid;gap:24px;justify-items:start;align-content:center}
.hero-title{writing-mode:horizontal-tb;white-space:normal;order:0;align-self:auto;margin:2px 0 0;font-size:clamp(31px,4.4vw,55px);letter-spacing:.12em;line-height:1.78}
.hero-lp .hero-sub{max-width:560px}
.hero-lp .link-arrow{color:var(--gold-2)}

/* FVフォームパネル */
.hero-form{background:var(--washi);background-image:var(--grain);border:1px solid var(--gold);padding:clamp(26px,3vw,38px);position:relative;box-shadow:0 32px 80px rgba(0,0,0,.4)}
.hero-form::before,.hero-form::after{content:"";position:absolute;width:16px;height:16px;border-color:var(--green);border-style:solid}
.hero-form::before{top:-5px;left:-5px;border-width:1px 0 0 1px}
.hero-form::after{bottom:-5px;right:-5px;border-width:0 1px 1px 0}
.hf-en{display:block;font-family:var(--latin);font-size:10.5px;letter-spacing:.42em;color:var(--gold);margin-bottom:10px}
.hf-title{font-family:var(--serif);font-weight:600;font-size:clamp(21px,1.9vw,25px);letter-spacing:.12em;line-height:1.6;color:var(--green);margin-bottom:8px}
.hf-sub{font-size:12.5px;line-height:1.95;letter-spacing:.04em;color:var(--ink-2);margin-bottom:20px}
.hf-form{display:grid;gap:14px}
.hf-form label{display:grid;gap:7px;font-size:12px;font-weight:700;letter-spacing:.14em;color:var(--green)}
.req{display:inline-block;justify-self:start;margin-left:8px;font-size:9.5px;letter-spacing:.18em;color:#fff;background:var(--green);padding:2px 7px 1px;border-radius:3px;vertical-align:2px}
.hf-form label{grid-template-columns:1fr auto;align-items:center}
.hf-form label input{grid-column:1/-1}
.hf-form input{width:100%;padding:13px 14px;border:1px solid var(--line);background:#fff;font-family:var(--sans);font-size:16px;color:var(--ink);transition:border-color .3s;border-radius:4px}
.hf-form input:focus{outline:none;border-color:var(--gold)}
.hf-form input::placeholder{color:rgba(91,84,70,.45)}
.hf-trust{margin-top:16px;gap:6px 18px}
.hf-trust li{font-size:11px}

/* 強化CTA(金・大型・シャイン) */
.btn-cta{display:inline-flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:19px 30px;background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--deep);font-family:var(--serif);font-weight:700;font-size:16.5px;letter-spacing:.14em;border:none;border-radius:7px;cursor:pointer;box-shadow:0 10px 28px rgba(174,147,85,.45);position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s;line-height:1.4}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 15px 34px rgba(174,147,85,.55)}
.btn-cta .ar{font-family:var(--latin);transition:transform .3s}
.btn-cta:hover .ar{transform:translateX(6px)}
.btn-cta::after{content:"";position:absolute;top:0;left:-70%;width:42%;height:100%;background:linear-gradient(105deg,transparent,rgba(255,255,255,.55),transparent);animation:ctashine 3.4s ease-in-out infinite}
@keyframes ctashine{0%{left:-70%}55%{left:130%}100%{left:130%}}

/* 既存CTAボタンの底上げ(全ページ) */
.btn-gold{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--deep);border-color:transparent;font-weight:700;font-size:14px;border-radius:7px;box-shadow:0 10px 26px rgba(0,0,0,.28)}
.btn-gold:hover{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--deep);transform:translateY(-2px)}
.header-cta{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--deep);font-weight:700;border-radius:6px;box-shadow:0 4px 14px rgba(174,147,85,.35)}
.header-cta:hover{background:linear-gradient(135deg,var(--gold-2),var(--gold));filter:brightness(1.06)}

@media (max-width:980px){
  .hero-lp .hero-inner{grid-template-columns:1fr;gap:42px;padding-top:108px;min-height:0}
  .hero-form{max-width:540px;width:100%;justify-self:center}
  .hero-copy{justify-items:start}
}

/* =========================================================
   v3.7 — 生きた背景(オーロラ)+常駐AIチャット演出
   ========================================================= */
.hero-dark::before{content:"";position:absolute;width:56vw;height:56vw;left:6%;top:-20%;background:radial-gradient(closest-side,rgba(211,194,149,.15),rgba(211,194,149,0) 70%);filter:blur(50px);animation:aura 16s ease-in-out infinite alternate;pointer-events:none}
@keyframes aura{0%{transform:translate(0,0) scale(1)}100%{transform:translate(15vw,9vh) scale(1.16)}}

.ai-widget{position:fixed;left:20px;bottom:20px;z-index:55;width:min(330px,calc(100vw - 32px));font-family:var(--sans);filter:drop-shadow(0 18px 40px rgba(8,37,31,.38))}
.ai-head{display:flex;align-items:center;gap:10px;width:100%;background:var(--deep);color:var(--washi);padding:13px 16px;border:1px solid rgba(174,147,85,.55);cursor:pointer;text-align:left}
.ai-head .spark{width:17px;height:17px;flex:none}
.ai-head .spark path{fill:var(--gold-2)}
.ai-label{font-size:12.5px;letter-spacing:.14em;font-weight:700}
.ai-dot{width:7px;height:7px;border-radius:50%;background:var(--gold-2);margin-left:auto;animation:aidot 2s ease-in-out infinite}
@keyframes aidot{0%,100%{opacity:.3}50%{opacity:1}}
.ai-body{background:rgba(8,37,31,.95);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(174,147,85,.55);border-top:none;padding:13px 13px 10px;max-height:min(330px,44vh);overflow-y:auto;display:flex;flex-direction:column;gap:10px}
.ai-widget.min .ai-body{display:none}
.ai-msg{max-width:90%;padding:10px 13px;font-size:12.5px;line-height:1.9;letter-spacing:.03em}
.ai-q{align-self:flex-end;background:rgba(244,240,230,.14);color:#F4F0E6;border-radius:10px 10px 2px 10px}
.ai-a{align-self:flex-start;color:#F4F0E6;border:1px solid rgba(174,147,85,.45);background:rgba(174,147,85,.08);border-radius:10px 10px 10px 2px}
.ai-a .hl{color:var(--gold-2);font-weight:700}
.ai-caret{display:inline-block;width:7px;height:13px;background:var(--gold-2);margin-left:2px;vertical-align:-2px;animation:aidot 1s steps(1) infinite}
.ai-cta{align-self:flex-start;display:inline-flex;gap:8px;align-items:center;background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--deep);font-weight:700;font-size:12px;letter-spacing:.1em;padding:9px 14px;border-radius:6px}
.ai-note{font-size:9.5px;letter-spacing:.08em;color:rgba(244,240,230,.4);text-align:right}
@media (max-width:760px){.ai-widget{left:12px;bottom:12px}}

/* =========================================================
   v4.0 — Phase 4a(FAQ・コラム・記事)
   ========================================================= */
/* コラム一覧 */
.col-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-bottom:30px}
.col-card{border:1px solid var(--line);background-color:var(--washi);background-image:var(--grain);padding:30px 28px;display:grid;gap:14px;align-content:start;transition:border-color .4s,transform .35s}
.col-card:hover{border-color:rgba(174,147,85,.6);transform:translateY(-4px)}
.col-meta{display:flex;align-items:center;gap:12px;font-family:var(--latin);font-size:11.5px;letter-spacing:.18em;color:var(--gold)}
.col-tag{border:1px solid var(--line);padding:4px 10px;font-family:var(--sans);font-size:10.5px;letter-spacing:.16em;color:var(--ink-2)}
.col-card h2{font-family:var(--serif);font-weight:600;font-size:17.5px;letter-spacing:.08em;line-height:1.9;color:var(--green)}
.col-card p{font-size:13px;line-height:2;color:var(--ink-2)}
.col-card .link-arrow{font-size:12px}
@media (max-width:980px){.col-grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.col-grid{grid-template-columns:1fr}}

/* 記事 */
.art-sec{padding-top:clamp(150px,18vh,200px)}
.article{max-width:780px;margin:0 auto}
.art-meta{display:flex;align-items:center;gap:14px;font-family:var(--latin);font-size:11.5px;letter-spacing:.2em;color:var(--gold);margin-bottom:18px}
.art-back{color:var(--gold);border-bottom:1px solid rgba(174,147,85,.5)}
.article h1{font-family:var(--serif);font-weight:600;font-size:clamp(24px,3.4vw,34px);letter-spacing:.1em;line-height:1.95;color:var(--green);margin-bottom:26px}
.art-lead{font-size:15px;line-height:2.3;color:var(--ink);padding-bottom:30px;margin-bottom:38px;border-bottom:1px solid var(--line)}
.toc{border:1px solid var(--line);background-color:var(--paper);background-image:var(--grain);padding:24px 28px;margin-bottom:46px}
.toc-t{display:block;font-family:var(--latin);font-size:11px;letter-spacing:.42em;color:var(--gold);margin-bottom:14px}
.toc ol{display:grid;gap:9px;counter-reset:toc}
.toc li{counter-increment:toc;display:flex;gap:12px;align-items:baseline}
.toc li::before{content:counter(toc,decimal-leading-zero);font-family:var(--latin);font-size:12px;letter-spacing:.1em;color:var(--gold)}
.toc a{font-size:13.5px;letter-spacing:.06em;color:var(--green);border-bottom:1px solid transparent;transition:border-color .3s}
.toc a:hover{border-bottom-color:var(--gold)}
.article h2{font-family:var(--serif);font-weight:600;font-size:clamp(19px,2.2vw,22px);letter-spacing:.12em;line-height:1.8;color:var(--green);margin:52px 0 20px;padding-bottom:13px;border-bottom:1px solid var(--line);position:relative;scroll-margin-top:90px}
.article h2::after{content:"";position:absolute;left:0;bottom:-1px;width:38px;height:1px;background:var(--gold)}
.article h3{font-family:var(--serif);font-weight:600;font-size:17px;letter-spacing:.1em;line-height:1.8;color:var(--green);margin:34px 0 12px}
.article p{font-size:14.5px;line-height:2.3;letter-spacing:.04em;color:var(--ink);margin-bottom:22px}
.art-cta{border:1px solid var(--gold);background-color:var(--washi);background-image:var(--grain);padding:clamp(28px,4vw,40px);margin-top:52px;text-align:center;position:relative}
.art-cta::before,.art-cta::after{content:"";position:absolute;width:16px;height:16px;border-color:var(--green);border-style:solid}
.art-cta::before{top:-5px;left:-5px;border-width:1px 0 0 1px}
.art-cta::after{bottom:-5px;right:-5px;border-width:0 1px 1px 0}
.ac-t{font-family:var(--serif);font-weight:600;font-size:clamp(18px,2.2vw,22px);letter-spacing:.12em;line-height:1.9;color:var(--green);margin:6px 0 10px}
.ac-s{font-size:13px;line-height:2;color:var(--ink-2);margin-bottom:20px}
.ac-btn{max-width:420px;margin:0 auto}
.art-author{display:flex;gap:20px;align-items:flex-start;margin-top:52px;padding-top:30px;border-top:1px solid var(--line)}
.art-author img{width:64px;height:80px;object-fit:cover;object-position:center 20%;border:1px solid var(--line);flex:none}
.aa-role{display:block;font-size:11px;letter-spacing:.16em;color:var(--gold);margin-bottom:6px}
.aa-name{font-family:var(--serif);font-weight:600;font-size:16px;letter-spacing:.14em;color:var(--green);margin-bottom:8px}
.aa-bio{font-size:12.5px;line-height:2;color:var(--ink-2)}
.art-foot{margin-top:40px;text-align:right}

/* =========================================================
   v4.1 — 可読性向上(高齢読者対応・全ページ文字サイズ底上げ)+アイキャッチ
   ========================================================= */
.lead{font-size:16.5px;line-height:2.25}
.hero-sub{font-size:16px;line-height:2.2}
.note{font-size:13.5px}
.cta-lead{font-size:15.5px;line-height:2.2}
.shift-card p,.svc-card p{font-size:15px;line-height:2.15}
.shift-card h3,.svc-card h3{font-size:19px}
.qa summary h3{font-size:16.5px;line-height:1.9}
.qa-a p{font-size:15.5px;line-height:2.25}
.dot-list li{font-size:15px;line-height:2}
.svc-col p{font-size:15px;line-height:2.2}
.g-item h3{font-size:17.5px}
.g-item p{font-size:14.5px;line-height:2.05}
.steps h3{font-size:18.5px}
.steps p{font-size:14.5px;line-height:2.05}
.case-dl dd{font-size:15px;line-height:2.2}
.case-sub{font-size:13.5px}
.spec dt{font-size:15.5px}
.spec dd{font-size:15.5px;line-height:2.15}
.hist p{font-size:15.5px}
.p-msg p{font-size:16px;line-height:2.3}
.p-prof .bio{font-size:14px;line-height:2.1}
.col-card h2{font-size:18.5px}
.col-card p{font-size:14.5px;line-height:2.05}
.article p{font-size:16.5px;line-height:2.25}
.art-lead{font-size:16.5px;line-height:2.3}
.article h2{font-size:clamp(21px,2.4vw,24px)}
.article h3{font-size:18.5px}
.toc a{font-size:15px}
.aa-bio{font-size:13.5px;line-height:2.05}
.hf-sub{font-size:13.5px}
.fs-note{font-size:14px;line-height:2.1}
.hf-form label{font-size:13px}
.trust li{font-size:13.5px}
.hf-trust li{font-size:12px}
.f-brand address{font-size:13px;line-height:2.1}
.f-col a{font-size:13.5px}
.ai-msg{font-size:13.5px}
.case-media p{font-size:13px}
.gnav a{font-size:14px}

/* アイキャッチ */
.col-thumb{margin:-30px -28px 8px;border-bottom:1px solid var(--line);aspect-ratio:1200/630;overflow:hidden}
.col-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s}
.col-card:hover .col-thumb img{transform:scale(1.03)}
.art-eyecatch{margin:4px 0 34px;border:1px solid var(--line)}
.art-eyecatch img{width:100%;height:auto;display:block}

/* v4.2 — モバイルメニュー閉鎖バグ修正 */
body.menu-open{overflow:hidden}
body.menu-open .site-header{z-index:90;background:transparent;border-color:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}
body.menu-open .brand,body.menu-open .gnav,body.menu-open .header-cta{opacity:0;pointer-events:none;transition:opacity .25s}

/* =========================================================
   v4.3 — Phase 4b(お問い合わせ・404)
   ========================================================= */
.contact-wrap{max-width:660px;margin:0 auto}
.form-shell--left{text-align:left}
.hf-form select,.hf-form textarea{width:100%;padding:13px 14px;border:1px solid var(--line);background:#fff;font-family:var(--sans);font-size:16px;color:var(--ink);transition:border-color .3s;border-radius:4px}
.hf-form select:focus,.hf-form textarea:focus{outline:none;border-color:var(--gold)}
.hf-form textarea{resize:vertical;min-height:150px;line-height:1.9}
.contact-wrap .trust{margin-top:22px}

.nf{min-height:68vh;display:grid;align-items:center;padding-top:clamp(130px,16vh,170px)}
.nf-inner{text-align:center}
.nf-num{font-family:var(--latin);font-size:clamp(96px,17vw,190px);letter-spacing:.12em;line-height:1;color:transparent;-webkit-text-stroke:1.5px var(--gold);margin-bottom:14px}
.nf h1{font-family:var(--serif);font-weight:600;font-size:clamp(20px,3vw,28px);letter-spacing:.12em;line-height:1.9;color:var(--green);margin-bottom:18px}
.nf .lead{margin-bottom:30px}
.nf-actions{justify-content:center}

/* v4.4 — AIウィジェットのモバイル縮小(サイト本文を読める幅に) */
@media (max-width:760px){
  .ai-widget{left:10px;bottom:10px;width:min(252px,calc(100vw - 96px))}
  .ai-head{padding:9px 12px;gap:8px}
  .ai-label{font-size:11px}
  .ai-head .spark{width:14px;height:14px}
  .ai-body{padding:10px 10px 8px;gap:8px;max-height:46vh}
  .ai-msg{font-size:11.5px;line-height:1.75;padding:8px 10px;max-width:94%}
  .ai-cta{font-size:11px;padding:8px 12px}
  .ai-note{font-size:8.5px}
}

/* =========================================================
   v4.5 — FVフォームをファーストビュー内に収める+モバイル盆栽撤去
   ========================================================= */
.hf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:560px){.hf-row{grid-template-columns:1fr}}
.hero-form{padding:clamp(20px,2.2vw,28px)}
.hero-form h2{font-size:clamp(18px,1.7vw,21px);margin-bottom:6px}
.hf-en{margin-bottom:8px}
.hf-sub{font-size:12px;line-height:1.8;margin-bottom:14px}
.hf-form{gap:11px}
.hf-form label{gap:5px;font-size:12px}
.hf-form input{padding:11px 13px}
.hero-form .btn-cta{padding:14px 18px;font-size:15px;margin-top:2px}
.hf-trust{margin-top:12px;gap:5px 14px}
.hf-trust li{font-size:11px}
@media (min-width:921px) and (max-height:780px){
  .hero-form{padding:18px 22px}
  .hf-sub{display:none}
  .hf-form{gap:9px}
  .hf-form input{padding:10px 12px}
}

/* モバイル「完成の間」(盆栽)を撤去 */
#finale{display:none!important}
.stage-seal-m{display:none!important}

/* =========================================================
   v4.6 — S:対話チップ / C:質感パック
   ========================================================= */
.ai-log{display:flex;flex-direction:column;gap:10px}
.ai-log:empty{display:none}
.ai-chips{display:flex;flex-wrap:wrap;gap:6px;padding-top:10px;border-top:1px dashed rgba(174,147,85,.35)}
.ai-log:empty+.ai-chips{border-top:none;padding-top:0}
.ai-chips button{font-family:var(--sans);font-size:10.5px;letter-spacing:.06em;color:#F4F0E6;background:rgba(244,240,230,.07);border:1px solid rgba(174,147,85,.5);border-radius:999px;padding:6px 11px;cursor:pointer;transition:background .3s,border-color .3s}
.ai-chips button:hover{background:rgba(174,147,85,.25);border-color:var(--gold-2)}
@media (max-width:760px){.ai-chips button{font-size:10px;padding:5px 9px}}

/* C-1: ページ間クロスフェード */
@view-transition{navigation:auto}
::view-transition-old(root){animation:vtFadeOut .28s ease both}
::view-transition-new(root){animation:vtFadeIn .4s ease both}
@keyframes vtFadeOut{to{opacity:0}}
@keyframes vtFadeIn{from{opacity:0}}
@media (prefers-reduced-motion: reduce){::view-transition-old(root),::view-transition-new(root){animation:none}}

/* C-2: FVポインタ・パララックス */
.hero-dark .hero-ghost{transform:translate3d(calc(var(--px,0)*26px),calc(var(--py,0)*16px),0);transition:transform .7s cubic-bezier(.2,.8,.2,1)}

/* C-3: カードホバーの金角飾り */
.shift-card,.col-card{position:relative}
.shift-card::before,.shift-card::after,.col-card::before,.col-card::after{content:"";position:absolute;width:0;height:0;opacity:0;transition:width .35s ease,height .35s ease,opacity .25s;pointer-events:none}
.shift-card::before,.col-card::before{top:-1px;left:-1px;border-top:1px solid var(--gold);border-left:1px solid var(--gold)}
.shift-card::after,.col-card::after{bottom:-1px;right:-1px;border-bottom:1px solid var(--gold);border-right:1px solid var(--gold)}
.shift-card:hover::before,.shift-card:hover::after,.col-card:hover::before,.col-card:hover::after{width:20px;height:20px;opacity:1}

/* =========================================================
   v4.7 — A:「AIの目で見る」透視モード
   ========================================================= */
.xray-btn{position:fixed;right:16px;bottom:16px;z-index:56;display:flex;align-items:center;gap:7px;background:var(--deep);color:var(--washi);border:1px solid rgba(174,147,85,.55);padding:10px 14px;border-radius:999px;font-family:var(--sans);font-size:11.5px;letter-spacing:.12em;font-weight:700;cursor:pointer;filter:drop-shadow(0 10px 26px rgba(8,37,31,.35));transition:background .3s,color .3s}
.xray-btn svg{width:15px;height:15px}
.xray-btn svg path{fill:var(--gold-2)}
body.xray .xray-btn{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--deep);border-color:transparent}
body.xray .xray-btn svg path{fill:var(--deep)}

.xray-panel{position:fixed;top:0;right:0;bottom:0;z-index:75;width:min(380px,94vw);background:rgba(8,37,31,.97);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-left:1px solid rgba(174,147,85,.55);color:#F4F0E6;transform:translateX(102%);transition:transform .45s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column;font-family:var(--sans)}
body.xray .xray-panel{transform:none}
.xrp-head{display:flex;align-items:center;gap:10px;padding:18px 20px;border-bottom:1px solid rgba(174,147,85,.3);flex:none}
.xrp-head svg{width:17px;height:17px}
.xrp-head svg path{fill:var(--gold-2)}
.xrp-head .t{font-family:var(--serif);font-weight:600;font-size:16px;letter-spacing:.16em}
.xrp-close{margin-left:auto;background:none;border:1px solid rgba(174,147,85,.45);color:#F4F0E6;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:15px;line-height:1;transition:background .3s}
.xrp-close:hover{background:rgba(174,147,85,.2)}
.xrp-body{padding:18px 20px 24px;overflow-y:auto;display:grid;gap:18px;align-content:start}
.xrp-lead{font-size:12.5px;line-height:2;color:rgba(244,240,230,.88)}
.xrp-sec h4{font-family:var(--latin);font-size:10px;letter-spacing:.42em;color:var(--gold-2);margin-bottom:8px}
.xrp-cap{font-size:10.5px;letter-spacing:.05em;color:rgba(244,240,230,.55);margin-bottom:9px}
.xrp-chips{display:flex;flex-wrap:wrap;gap:6px}
.xrp-chips span{border:1px solid rgba(174,147,85,.5);border-radius:4px;padding:4px 9px;font-size:10.5px;letter-spacing:.05em;font-family:var(--latin)}
.xrp-chips b{color:var(--gold-2);font-weight:600}
.xrp-list{display:grid;gap:8px}
.xrp-list li{font-size:12.5px;line-height:1.9;letter-spacing:.04em;padding-left:17px;position:relative}
.xrp-list li::before{content:"";position:absolute;left:1px;top:.62em;width:7px;height:7px;border:1px solid var(--gold-2);transform:rotate(45deg)}
.xrp-json-btn{border:1px solid var(--gold-2);color:var(--gold-2);background:transparent;padding:10px 12px;font-size:11.5px;letter-spacing:.12em;cursor:pointer;border-radius:4px;font-family:var(--sans);font-weight:700;transition:background .3s}
.xrp-json-btn:hover{background:rgba(174,147,85,.16)}
.xrp-pre{display:none;background:rgba(0,0,0,.32);border:1px solid rgba(174,147,85,.3);padding:12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10px;line-height:1.6;color:var(--gold-2);max-height:250px;overflow:auto;white-space:pre;border-radius:4px}
.xrp-pre.show{display:block}
.xrp-note{font-size:11px;line-height:1.95;color:rgba(244,240,230,.6);border-top:1px dashed rgba(174,147,85,.3);padding-top:12px}

.xr-tag{position:absolute;z-index:5;display:inline-flex;align-items:center;gap:6px;background:rgba(8,37,31,.93);color:#F4F0E6;border:1px solid var(--gold-2);padding:6px 11px;font-family:var(--sans);font-size:10.5px;letter-spacing:.08em;font-weight:500;opacity:0;translate:0 8px;transition:opacity .45s ease,translate .45s ease;pointer-events:none;border-radius:3px;box-shadow:0 8px 22px rgba(8,37,31,.3);white-space:nowrap}
.xr-tag::before{content:"◆";color:var(--gold-2);font-size:8px}
body.xray .xr-tag{opacity:1;translate:0 0}
[data-xrs]{position:relative}
body.xray [data-xrs]{outline:1px dashed rgba(174,147,85,.55);outline-offset:-10px}
@media (max-width:760px){
  .xr-tag{display:none}
  .xray-btn{right:12px;bottom:12px;padding:9px 12px;font-size:11px}
}

/* =========================================================
   v4.8 — 「AIの目」シアター版(暗転→読み歩き→結果カード)
   ========================================================= */
body.xray main>*,body.xray .site-footer{filter:grayscale(.55) brightness(.5);transition:filter .8s ease}
body.xray .site-header{filter:grayscale(.4) brightness(.55);transition:filter .8s ease}
body.xray main>.xr-live,body.xray .site-footer.xr-live{filter:none}
body.xray .xr-live{outline:1px solid rgba(211,194,149,.85);outline-offset:-6px;box-shadow:0 0 0 6px rgba(174,147,85,.12),0 0 70px rgba(174,147,85,.22)}
body.xray .ai-widget,body.xray .scroll-cue{opacity:0;pointer-events:none;transition:opacity .4s}
body.xray [data-xrs]{outline-style:solid}

/* 確認スタンプ(平易な日本語) */
.xr-tag{position:absolute;z-index:6;display:inline-flex;align-items:center;gap:8px;background:var(--washi);color:var(--green);border:1px solid var(--gold);padding:8px 13px;font-family:var(--sans);font-size:12.5px;letter-spacing:.06em;font-weight:700;opacity:0;translate:0 10px;scale:.92;transition:opacity .5s ease,translate .5s ease,scale .5s ease;pointer-events:none;border-radius:4px;box-shadow:0 10px 28px rgba(8,37,31,.35);white-space:nowrap}
.xr-tag::before{content:"✓";display:grid;place-items:center;width:17px;height:17px;border-radius:50%;background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--deep);font-size:11px;font-weight:900;flex:none}
body.xray .xr-tag{opacity:0;translate:0 10px}
body.xray .xr-live .xr-tag{opacity:1;translate:0 0;scale:1}

/* 字幕 */
.xr-cap{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);z-index:78;display:flex;align-items:center;gap:10px;max-width:min(660px,88vw);background:rgba(8,37,31,.96);border:1px solid rgba(174,147,85,.6);border-radius:14px;padding:11px 20px;color:#F4F0E6;font-family:var(--sans);font-size:13.5px;letter-spacing:.05em;line-height:1.7;opacity:0;pointer-events:none;transition:opacity .4s}
.xr-cap.show{opacity:1}
.xr-cap-eye svg{width:16px;height:16px;display:block}
.xr-cap-eye svg path{fill:var(--gold-2)}
.xr-cap-t{min-height:1.4em}

/* 結果カード */
.xr-card{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:20px;background:rgba(8,37,31,.55);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity .5s}
.xr-card.show{opacity:1;pointer-events:auto}
.xr-card-in{width:min(560px,94vw);max-height:92vh;overflow-y:auto;background-color:var(--washi);background-image:var(--grain);border:1px solid var(--gold);padding:clamp(26px,4vw,40px);position:relative;box-shadow:0 40px 100px rgba(0,0,0,.45);text-align:center;translate:0 14px;transition:translate .5s cubic-bezier(.2,.8,.2,1)}
.xr-card.show .xr-card-in{translate:0 0}
.xr-card-in::before,.xr-card-in::after{content:"";position:absolute;width:16px;height:16px;border-color:var(--green);border-style:solid}
.xr-card-in::before{top:-5px;left:-5px;border-width:1px 0 0 1px}
.xr-card-in::after{bottom:-5px;right:-5px;border-width:0 1px 1px 0}
.xrc-en{display:block;font-family:var(--latin);font-size:10px;letter-spacing:.42em;color:var(--gold);margin-bottom:10px}
.xr-card-in h3{font-family:var(--serif);font-weight:600;font-size:clamp(20px,3vw,25px);letter-spacing:.14em;color:var(--green);margin-bottom:10px}
.xrc-lead{font-size:14px;line-height:2;color:var(--ink);margin-bottom:16px}
.xrc-list{display:grid;gap:9px;text-align:left;max-width:430px;margin:0 auto 18px}
.xrc-list li{font-size:13.5px;line-height:1.95;color:var(--ink);padding-left:27px;position:relative}
.xrc-list li::before{content:"✓";position:absolute;left:0;top:.12em;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--deep);font-size:11px;font-weight:900;display:grid;place-items:center}
.xrc-list b{color:var(--green)}
.xrc-q{font-family:var(--serif);font-weight:600;font-size:15px;letter-spacing:.1em;color:var(--green);margin-bottom:16px}
.xrc-btn{max-width:380px;margin:0 auto}
.xrc-foot{display:flex;justify-content:center;gap:20px;margin-top:14px}
.xrc-foot button{background:none;border:none;font-family:var(--sans);font-size:11.5px;letter-spacing:.1em;color:var(--ink-2);border-bottom:1px solid var(--line);cursor:pointer;padding:2px 0;transition:color .3s,border-color .3s}
.xrc-foot button:hover{color:var(--green);border-color:var(--gold)}
.xrc-note{font-size:10px;color:var(--ink-2);margin-top:12px;letter-spacing:.05em}

.xray-panel{z-index:82}
body.xray .xray-panel{transform:translateX(102%)}
body .xray-panel.open{transform:none}

@media (max-width:760px){
  .xr-tag{display:inline-flex;font-size:11.5px;padding:7px 11px;white-space:normal;max-width:74vw}
  .xr-cap{font-size:12.5px;padding:10px 14px;bottom:14px}
}

/* v4.9 — 検査成績書(28項目チェックの連射) */
.xrc-num{font-family:var(--latin);font-size:1.18em;color:var(--gold);font-weight:600;letter-spacing:.02em}
.xrc-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px 16px;text-align:left;margin:16px auto 18px;max-width:474px}
.xrc-grid li{font-size:11px;line-height:1.7;letter-spacing:.03em;color:var(--ink);padding-left:21px;position:relative;opacity:.22;transition:opacity .3s}
.xrc-grid li::before{content:"✓";position:absolute;left:0;top:.16em;width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--deep);font-size:9px;font-weight:900;display:grid;place-items:center;scale:.4;opacity:0;transition:scale .25s cubic-bezier(.34,1.56,.64,1),opacity .2s}
.xrc-grid li.on{opacity:1}
.xrc-grid li.on::before{scale:1;opacity:1}
@media (max-width:560px){
  .xrc-grid{gap:5px 10px}
  .xrc-grid li{font-size:10.5px;padding-left:19px}
}

/* v5.0 — 検査成績書を1画面に収める(モバイル/背の低い画面) */
.xr-card-in .ph{display:inline-block}
@media (max-width:560px){
  .xr-card{padding:12px}
  .xr-card-in{padding:18px 16px 16px;max-height:96vh}
  .xrc-en{font-size:9px;margin-bottom:6px;letter-spacing:.34em}
  .xr-card-in h3{font-size:17.5px;margin-bottom:6px}
  .xrc-lead{display:none}
  .xrc-grid{gap:3px 10px;margin:10px auto 12px}
  .xrc-grid li{font-size:10px;line-height:1.55;padding-left:17px}
  .xrc-grid li::before{width:12px;height:12px;font-size:8px;top:.14em}
  .xrc-q{font-size:12.5px;line-height:1.85;margin-bottom:12px}
  .xrc-btn{padding:12px 14px;font-size:13.5px}
  .xrc-foot{margin-top:8px;gap:14px}
  .xrc-note{font-size:9px;margin-top:8px;line-height:1.7}
}
@media (min-width:561px) and (max-height:780px){
  .xr-card-in{padding:22px 28px}
  .xrc-lead{display:none}
  .xrc-grid{gap:4px 16px;margin:12px auto 14px}
  .xrc-grid li{font-size:10.5px;line-height:1.6}
  .xrc-q{margin-bottom:12px}
  .xrc-note{margin-top:8px}
}

/* v5.1 — 成績書(モバイル): 見出しとCTAを拡大し、上下余白を活用 */
@media (max-width:560px){
  .xr-card-in{padding:24px 18px 18px}
  .xrc-en{font-size:9.5px;margin-bottom:8px}
  .xr-card-in h3{font-size:24px;line-height:1.5;margin-bottom:12px}
  .xrc-grid{margin:12px auto 14px}
  .xrc-q{font-size:13.5px;line-height:1.9;margin-bottom:14px}
  .xrc-btn{padding:16px 18px;font-size:16px}
  .xrc-foot{margin-top:10px}
}
