/* ============================================================
   Ruska inc. — site stylesheet (reproduction)
   ============================================================ */
:root{
  --ink:#242422;          /* primary text / near-black */
  --ink-2:#3a3a38;
  --gray:#9f9f9f;         /* labels, secondary */
  --gray-2:#6b6b6b;
  --line:#e6e6e4;         /* hairlines */
  --line-2:#d9d9d7;
  --bg:#ffffff;
  --soft:#f5f5f4;         /* light gray sections */
  --soft-2:#fafafa;
  --dark:#26262420;       /* unused placeholder */
  --footer:#2a2a28;       /* footer / dark bands */
  --teal:#accacd;         /* "Creating Web Experiences" accent */
  --teal-deep:#7fa6a9;
  --maxw:1080px;
  --gutter:clamp(20px,4.5vw,80px);
  --font:"Inter","Noto Sans JP","Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic",sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font);
  font-size:15px;
  line-height:1.95;
  letter-spacing:.04em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"palt";
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
ul{list-style:none;margin:0;padding:0}

.wrap{max-width:calc(var(--maxw) + var(--gutter)*2);margin:0 auto;padding-inline:var(--gutter)}
.eyebrow{
  font-weight:400;font-size:14px;letter-spacing:.08em;color:var(--gray);
  margin:0 0 10px;
}
.sec-title{
  font-weight:700;font-size:clamp(22px,3.2vw,28px);letter-spacing:.06em;
  color:var(--ink);margin:0;line-height:1.5;
}
.more-link{
  display:inline-flex;align-items:center;gap:9px;
  font-weight:400;font-size:15px;letter-spacing:.06em;color:var(--ink);
  transition:gap .3s var(--ease),opacity .2s;
}
.more-link .ico{
  width:22px;height:22px;flex:none;color:var(--gray);
  transition:transform .35s var(--ease);
}
.more-link:hover{gap:13px}
.more-link:hover .ico{transform:translateX(3px)}

/* ============================ HEADER ============================ */
.masthead{
  position:sticky;top:0;z-index:200;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .35s,height .35s;
}
.masthead .bar{
  margin:0 auto;
  display:flex;align-items:center;
  padding:0 clamp(16px,3vw,90px);
  height:88px;transition:height .35s var(--ease);
}
.masthead.shrunk .bar{height:66px}
.masthead.shrunk{box-shadow:0 8px 30px rgba(0,0,0,.06)}
.brand{display:flex;align-items:center;flex:none}
.brand img{height:30px;width:auto;transition:height .35s var(--ease)}
.masthead.shrunk .brand img{height:26px}
.gnav{display:flex;align-items:center;gap:clamp(12px,1.7vw,38px);margin:0 auto;padding:0 clamp(10px,1.5vw,48px)}
.gnav>li{position:relative}
.gnav a,.gnav .navbtn{
  display:inline-flex;align-items:center;gap:6px;
  font-size:clamp(13.5px,1vw,15px);font-weight:400;letter-spacing:.05em;color:var(--ink);
  padding:6px 0;position:relative;white-space:nowrap;
}
.gnav a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1.5px;
  background:linear-gradient(90deg,#615fa8 0%,#e7bcc3 100%);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.gnav a:hover::after,.gnav a.current::after{transform:scaleX(1)}
.gnav .disabled{color:#c2c2c0;pointer-events:none}
.gnav .caret{width:9px;height:9px;transition:transform .3s}
.has-sub:hover .caret{transform:rotate(180deg)}
/* mega menu */
.gnav>li.has-mega{position:static}
.mega-wrap{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(6px);
  width:min(1140px,95vw);padding-top:14px;
  opacity:0;visibility:hidden;transition:opacity .28s var(--ease),transform .28s var(--ease);z-index:50;
}
/* transparent hover bridge so moving from the button down to the panel never drops :hover */
.mega-wrap::before{content:"";position:absolute;left:0;right:0;bottom:100%;height:48px}
.has-mega:hover .mega-wrap{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega{
  display:grid;grid-template-columns:268px 1fr;
  background:#fff;border:0;
  box-shadow:0 34px 80px rgba(20,20,18,.16);overflow:hidden;
}
.mega-intro{position:relative;padding:38px 32px;color:#fff;background:#242422;overflow:hidden}
.mega-intro::after{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:linear-gradient(90deg,#615fa8 0%,#accacd 50%,#e7bcc3 100%)}
.mega-intro .mi-label{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.7);margin:0 0 16px}
.mega-intro h3{font-size:21px;font-weight:700;line-height:1.55;letter-spacing:.04em;margin:0 0 16px}
.mega-intro .mi-text{font-size:12.5px;line-height:1.95;color:rgba(255,255,255,.82);margin:0 0 24px}
.mega-intro .mi-link{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:.04em;color:#fff;transition:gap .3s var(--ease)}
.mega-intro .mi-link .ico{width:18px;height:18px;color:#fff}
.mega-intro .mi-link:hover{gap:12px}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.mega-col{padding:26px 30px}
.mega-cat{display:flex;align-items:baseline;gap:9px;font-size:13px;font-weight:700;letter-spacing:.05em;color:var(--ink);margin:0 0 14px;padding-bottom:11px;border-bottom:1px solid var(--rule,#e6e6e4)}
.mega-cat span{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray)}
.mega-item{display:block;padding:9px 0;position:relative;transition:padding .25s var(--ease)}
.gnav .mega-item{display:block;gap:0;align-items:stretch}
.mega-item::after,.gnav .mega-item::after{display:none}
.mega-item .mi-ja{display:block;font-size:13.5px;font-weight:500;letter-spacing:.03em;color:var(--ink);transition:color .2s}
.mega-item .mi-en{display:block;font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);margin-top:2px}
.mega-item:hover{padding-left:8px}
.mega-item:hover .mi-ja{color:var(--teal-deep)}
.mega-item.active .mi-ja{color:var(--teal-deep);font-weight:700}

/* drawer service group */
.dr-group{border-bottom:1px solid var(--line);padding:8px 0 14px}
.dr-head{font-size:16px;font-weight:500;margin:0;padding:15px 0 4px}
.dr-head .en{font-size:10px;letter-spacing:.14em;color:var(--gray);margin-left:8px;text-transform:uppercase}
.dr-cat{font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--gray);margin:14px 0 4px}
.dr-sub{display:block;padding:9px 0 9px 12px;font-size:13.5px;font-weight:500;border-bottom:none !important}
.head-cta{display:flex;align-items:center;gap:16px;margin-left:0;flex:none}
.btn-line,.btn-fill{
  display:inline-flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:700;letter-spacing:.06em;line-height:1.2;
  padding:13px clamp(20px,1.9vw,32px);border-radius:0;white-space:nowrap;
  transition:color .35s var(--ease),border-color .35s var(--ease);
}
.btn-line{background:#fff;color:var(--ink);border:1px solid var(--ink);background-clip:padding-box}
.btn-fill{background:var(--ink);color:#fff;border:1px solid var(--ink);background-clip:padding-box}
/* CTA hover — gradient sweeps in from left to right */
.btn-line,.btn-fill,.btn-block,.cband-cols .actbtn,.loadmore button,.submit button,.doc-card .dl,.dl-done .dlbtn{position:relative;overflow:hidden;z-index:0}
.btn-line::before,.btn-fill::before,.btn-block::before,.cband-cols .actbtn::before,.loadmore button::before,.submit button::before,.doc-card .dl::before,.dl-done .dlbtn::before{
  content:"";position:absolute;inset:-1px;z-index:-1;border-radius:inherit;
  background:linear-gradient(90deg,#615fa8 0%,#e7bcc3 100%);
  transform:scaleX(0);transform-origin:left center;
  transition:transform .5s var(--ease);
}
.btn-line:hover::before,.btn-fill:hover::before,.btn-block:hover::before,.cband-cols .actbtn:hover::before,.loadmore button:hover::before,.submit button:hover::before,.doc-card .dl:hover::before,.dl-done .dlbtn:hover::before{transform:scaleX(1)}
.btn-line:hover{color:#fff}
.btn-line:hover,.btn-fill:hover{border-color:transparent}
.burger{display:none;width:30px;height:22px;position:relative;margin-left:auto;flex:none}
.burger span{position:absolute;left:0;height:2px;width:100%;background:var(--ink);transition:.3s var(--ease)}
.burger span:nth-child(1){top:2px}
.burger span:nth-child(2){top:10px}
.burger span:nth-child(3){top:18px}
body.menu-open .burger span:nth-child(1){top:10px;transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){top:10px;transform:rotate(-45deg)}

/* mobile drawer */
.drawer{
  position:fixed;inset:0 0 0 auto;width:min(86vw,360px);z-index:190;
  background:#fff;transform:translateX(100%);transition:transform .45s var(--ease);
  padding:96px 30px max(46px, env(safe-area-inset-bottom) + 30px);overflow-y:auto;box-shadow:-20px 0 60px rgba(0,0,0,.12);
}
body.menu-open .drawer{transform:translateX(0)}
.drawer-mask{position:fixed;inset:0;z-index:180;background:rgba(20,20,18,.4);opacity:0;visibility:hidden;transition:.4s}
body.menu-open .drawer-mask{opacity:1;visibility:visible}
.drawer nav > a{display:block;padding:15px 0;font-size:16px;font-weight:500;border-bottom:1px solid var(--line)}
.drawer nav > a .en{font-size:10px;letter-spacing:.14em;color:var(--gray);margin-left:8px;text-transform:uppercase}
.drawer .dr-cta{display:flex;flex-direction:column;gap:12px;margin-top:26px}
.drawer .dr-cta a{justify-content:center;padding:15px;font-size:14px;flex:none}

/* ============================ HERO (TOP) ============================ */
.hero{position:relative;background:#fff;overflow:hidden}
.hero-fx{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;display:block}
.hero-top,.hero-marquee{position:relative;z-index:1}
.hero-top{
  max-width:calc(var(--maxw) + var(--gutter)*2);margin:0 auto;
  padding:clamp(36px,5vw,56px) var(--gutter) 0;
  display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:clamp(24px,4vw,60px);align-items:start;
}
.hero-copy h1{margin:0 0 28px}
.hero-copy h1 span{
  display:table;background:var(--ink);color:#fff;font-weight:700;
  font-size:clamp(24px,2.7vw,34px);line-height:1.25;letter-spacing:.1em;padding:10px 18px;
}
.hero-copy h1 span+span{margin-top:6px}
.hero-copy .lead{
  margin:0;font-size:13px;line-height:2.2;letter-spacing:.05em;color:var(--ink-2);max-width:440px;
}
.hero-people{display:flex;flex-direction:column;gap:14px;align-items:flex-start;padding-top:6px}
.hero-people .row{display:flex;gap:clamp(16px,3vw,44px);align-items:flex-end}
.hero-people .row+.row{margin-left:clamp(10px,2vw,30px)}
.hero-people .fig{width:clamp(48px,5.4vw,78px);height:auto;flex:none}
.hero-people .fig img{width:100%;height:auto}
.hero-marquee{
  max-width:calc(var(--maxw) + var(--gutter)*2);
  margin:clamp(20px,2.6vw,36px) auto 0;
  padding:0 var(--gutter) clamp(14px,1.9vw,28px);
}
.hero-marquee .cwe{display:block;width:100%;height:auto;transition:opacity .25s var(--ease)}
html.cwe-measuring .hero-marquee .cwe{opacity:0}

/* ============================ SECTION SHELL ============================ */
.section{padding:clamp(64px,8vw,100px) 0}
.section.soft{background:var(--soft)}
.section.soft2{background:var(--soft-2)}
.section-head{margin-bottom:clamp(34px,4vw,52px)}

/* services grid (top) */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,2.4vw,40px)}
.svc-col .cat{
  display:block;font-size:12.5px;font-weight:700;letter-spacing:.06em;color:var(--ink);
  border-bottom:1px solid var(--ink);padding-bottom:9px;margin-bottom:16px;
}
.svc-col h3{margin:0 0 12px;font-size:16px;font-weight:700;letter-spacing:.05em}
.svc-col ul li{font-size:13px;line-height:2.25;color:var(--ink-2);letter-spacing:.03em}
.svc-col ul a.svc-l{display:inline-flex;align-items:center;gap:6px;color:var(--ink-2);transition:color .25s}
.svc-col ul a.svc-l .svc-ico{width:16px;height:16px;flex:none;color:var(--gray);transition:transform .35s var(--ease),color .25s}
.svc-col ul a.svc-l:hover{color:var(--ink)}
.svc-col ul a.svc-l:hover .svc-ico{transform:translateX(3px)}
.svc-note{margin-top:30px;font-size:13px}

/* features (3 reasons) */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,44px)}
.feat-card .num{font-weight:500;font-size:clamp(42px,4.6vw,58px);letter-spacing:.06em;color:#c8d9dc;line-height:1;text-align:center;margin-bottom:20px}
.feat-card .ph{aspect-ratio:16/10;background:var(--soft);overflow:hidden;margin-bottom:22px}
.feat-card .ph img{width:100%;height:100%;object-fit:cover}
.feat-card .cap{text-align:center}
.feat-card .cap .lbl{display:block;font-size:12px;font-weight:400;letter-spacing:.08em;color:var(--gray);margin-bottom:8px}
.feat-card .cap .txt{font-size:13px;font-weight:400;line-height:1.95;letter-spacing:.05em;color:var(--ink)}

/* partner logos */
.partner-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.partner-grid .cell{
  background:#fff;aspect-ratio:233/132;display:flex;align-items:center;justify-content:center;padding:12px 14px;
}
.partner-grid .cell img{max-height:56px;max-width:92%;width:auto;height:auto;object-fit:contain;transition:opacity .3s}
.partner-grid .cell img.tall{max-height:62px}
.partner-grid .cell img.sq{max-height:68px;max-width:58%}
.partner-grid .cell:hover img{opacity:.7}
.partner-grid .cell .wm{font-weight:800;letter-spacing:.02em;color:#2b2b29;font-size:clamp(13px,1.3vw,19px);transition:opacity .3s;text-align:center;line-height:1.1}
.partner-grid .cell:hover .wm{opacity:.7}
.partner-grid .cell .wm small{display:block;font-size:.6em;letter-spacing:.06em;color:var(--gray);margin-top:3px;font-weight:700}

/* seminar / event card — single narrow column, banner on top */
.semi-card{display:flex;flex-direction:column;max-width:348px}
.semi-card .ban{display:block;aspect-ratio:1200/628;background:var(--soft);overflow:hidden;transition:opacity .3s}
.semi-card .ban:hover{opacity:.75}
.semi-card .ban img{width:100%;height:100%;object-fit:cover}
.semi-card h3{margin:20px 0 0;font-size:16px;font-weight:700;line-height:1.75;letter-spacing:.04em;padding-bottom:16px;border-bottom:1px solid var(--line)}
.semi-card dl{display:grid;grid-template-columns:64px 1fr;gap:10px 22px;margin:18px 0 24px;font-size:13.5px}
.semi-card dt{color:#b3b3b0;font-weight:500;font-size:13px}
.semi-card dd{margin:0;color:var(--ink);font-weight:500;line-height:1.75}
.btn-block{display:inline-flex;align-items:center;justify-content:center;background:var(--ink);color:#fff;font-weight:700;font-size:14.5px;letter-spacing:.08em;padding:17px 30px;width:100%;transition:.3s var(--ease)}

/* cases grid */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,40px)}
.case-card{display:block}
.case-card:hover{opacity:1}
.case-card .ph{aspect-ratio:355/235;background:var(--soft);overflow:hidden;margin-bottom:16px}
.case-card .ph img{width:100%;height:100%;object-fit:cover}
.case-card .client{font-size:12px;color:var(--gray);margin:0 0 4px;letter-spacing:.04em}
.case-card h3{margin:0 0 12px;font-size:16px;font-weight:700;line-height:1.6;letter-spacing:.03em;color:var(--ink);transition:color .25s}
.case-card:hover h3{color:var(--teal-deep)}
.case-meta{display:grid;grid-template-columns:auto 1fr;gap:3px 12px;font-size:11px;color:var(--gray)}
.case-meta .chips{display:flex;gap:8px;flex-wrap:wrap;color:var(--ink-2)}

/* big section image band */
.band-img{height:clamp(220px,28vw,400px);background-size:cover;background-position:center}

/* info / news list */
.news-list{border-top:1px solid var(--line)}
.news-row{
  display:grid;grid-template-columns:108px 92px 1fr auto;align-items:center;gap:20px;
  padding:20px 6px;border-bottom:1px solid var(--line);transition:background .25s;
}
.news-row:hover{background:var(--soft-2)}
.news-row .date{font-size:13px;color:var(--ink-2);letter-spacing:.04em}
.news-row .cat{
  font-size:11px;font-weight:400;letter-spacing:.06em;color:var(--ink-2);
  border:1px solid var(--line-2);padding:5px 0;text-align:center;border-radius:2px;
}
.news-row .ttl{font-size:14px;line-height:1.7;color:var(--ink);letter-spacing:.03em}
.news-row .arr{width:18px;height:18px;color:var(--gray);transition:transform .3s}
.news-row:hover .arr{transform:translateX(3px)}

/* ============================ CONTACT BAND ============================ */
.cband{background:var(--soft);padding:clamp(56px,7vw,90px) 0}
.cband .lab{text-align:center;font-size:13px;color:var(--gray);letter-spacing:.1em;margin:0 0 14px}
.cband h2{text-align:center;font-weight:700;font-size:clamp(19px,2.6vw,28px);letter-spacing:.06em;margin:0 0 clamp(38px,4vw,56px);line-height:1.6}
.cband-cols{display:grid;grid-template-columns:1fr 1fr;gap:0;max-width:920px;margin:0 auto}
.cband-cols .col{padding:0 clamp(20px,3vw,48px);text-align:center}
.cband-cols .col+.col{border-left:1px solid var(--line-2)}
.cband-cols .en{font-size:12px;font-weight:400;letter-spacing:.14em;color:var(--gray);text-transform:uppercase;margin:0 0 8px}
.cband-cols h3{font-size:18px;font-weight:700;letter-spacing:.05em;margin:0 0 22px}
.cband-cols .actbtn{
  display:flex;align-items:center;justify-content:center;width:100%;max-width:360px;margin:0 auto;
  font-weight:700;font-size:15px;letter-spacing:.06em;padding:17px;transition:color .35s var(--ease),border-color .35s var(--ease);
}
.cband-cols .actbtn:hover{color:#fff;border-color:transparent}
.cband-cols .fill{background:var(--ink);color:#fff}
.cband-cols .ghost{border:1px solid var(--ink);color:var(--ink);background:#fff;transition:color .35s var(--ease),border-color .35s var(--ease)}
.cband-cols .tel{margin-top:20px;font-size:13px;color:var(--ink-2)}
.cband-cols .tel .num{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:18px;letter-spacing:.04em;color:var(--ink)}
.cband-cols .tel small{display:block;font-size:11px;color:var(--gray);margin-top:2px}
.cband-cols .faq{display:inline-block;margin-top:18px;font-size:12px;color:var(--gray);text-decoration:underline;text-underline-offset:3px;transition:color .25s var(--ease)}
.cband-cols .faq:hover{color:var(--teal-deep)}
.cband-cols .docnote{margin-top:18px;font-size:12.5px;color:var(--gray-2);line-height:1.8}

/* ============================ FOOTER ============================ */
.foot{background:var(--footer);color:#cdcdca;padding:clamp(48px,6vw,72px) 0 28px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:clamp(24px,3vw,40px)}
.foot .flogo img{height:30px;width:auto;margin-bottom:18px}
.foot .corp{font-weight:700;color:#fff;font-size:15px;letter-spacing:.06em;margin:0 0 16px}
.foot address{font-style:normal;font-size:12.5px;line-height:1.9;color:#a9a9a6;letter-spacing:.04em}
.foot h4{font-size:13px;font-weight:700;color:#fff;letter-spacing:.06em;margin:4px 0 16px}
.foot ul li{margin-bottom:11px}
.foot ul a{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:#bdbdba;transition:color .25s,gap .25s}
.foot ul a .pl{width:14px;height:14px;color:#7c7c79;flex:none;transition:.25s}
.foot ul a:hover{color:#fff;gap:9px}
.foot ul a:hover .pl{color:var(--teal)}
.foot .copy{margin-top:clamp(36px,5vw,60px);text-align:center;font-size:11px;letter-spacing:.14em;color:#85857f}

/* ============================ PAGE HERO (sub pages) ============================ */
.phero{position:relative;min-height:clamp(220px,26vw,360px);display:flex;align-items:center;overflow:hidden;background:#1c1c1a}
.phero .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.86;z-index:0}
.phero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(15,15,13,.5),rgba(15,15,13,.05))}
.phero .inner{position:relative;z-index:2;color:#fff;max-width:calc(var(--maxw) + var(--gutter)*2);margin:0 auto;width:100%;padding:0 var(--gutter)}
.phero .en{font-size:13px;font-weight:400;letter-spacing:.14em;margin:0 0 8px;color:rgba(255,255,255,.82)}
.phero h1{margin:0;font-size:clamp(26px,3.8vw,38px);font-weight:700;letter-spacing:.08em}
.phero .lead{margin:16px 0 0;font-size:13.5px;letter-spacing:.05em;color:rgba(255,255,255,.86);max-width:640px;line-height:1.9}

/* subpage hero background-pattern switcher */
.phero-switch{position:fixed;left:50%;bottom:20px;transform:translateX(-50%);z-index:120;display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:999px;padding:6px 8px 6px 16px;box-shadow:0 12px 34px rgba(0,0,0,.12);font-family:var(--font);max-width:calc(100vw - 28px);flex-wrap:wrap;justify-content:center}
.phero-switch .lbl{font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--gray);margin-right:4px}
.phero-switch button{font-size:12px;font-weight:500;letter-spacing:.03em;color:var(--ink-2);background:transparent;border:none;border-radius:999px;padding:7px 14px;cursor:pointer;transition:color .25s,background .3s var(--ease)}
.phero-switch button:hover{color:var(--ink)}
.phero-switch button.on{background:linear-gradient(90deg,#615fa8 0%,#e7bcc3 100%);color:#fff;font-weight:700}
@media (max-width:560px){.phero-switch .lbl{display:none}.phero-switch button{padding:7px 11px}}

/* simple inner page shell */
.page{padding:clamp(56px,7vw,90px) 0}
.page.tight{padding:clamp(40px,4.6vw,60px) 0}
.crumb-en{font-size:13px;font-weight:400;letter-spacing:.12em;color:var(--gray);margin:0 0 6px}
.page-title{font-size:clamp(26px,4vw,38px);font-weight:700;letter-spacing:.07em;margin:0 0 14px}

/* anchor nav (company) */
.anchnav{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(18px,3vw,44px);padding:clamp(28px,3.4vw,44px) 0;border-bottom:1px solid var(--line)}
.anchnav a{display:inline-flex;align-items:center;gap:9px;font-size:14px;font-weight:500;letter-spacing:.05em}
.anchnav a .ico,.anchnav a .ico-arrowdn{width:17px;height:17px;color:var(--gray);transition:color .3s var(--ease)}
.anchnav a:hover{color:var(--teal-deep)}

/* ============================ SERVICE DETAIL ============================ */
.svc-layout{display:grid;grid-template-columns:240px 1fr;gap:clamp(30px,4vw,64px);align-items:start}
.svc-side{position:sticky;top:100px;font-size:13px}
.svc-side .grp{margin-bottom:22px}
.svc-side .grp>.gt{font-weight:700;font-size:14px;letter-spacing:.04em;margin:0 0 12px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.svc-side ul li{margin-bottom:9px}
.svc-side ul a{display:inline-flex;align-items:center;gap:7px;color:var(--ink-2);font-size:12.5px;letter-spacing:.03em;transition:color .2s}
.svc-side ul a::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--line-2);flex:none}
.svc-side ul a:hover{color:var(--teal-deep)}
.svc-side ul a.on{color:var(--ink);font-weight:700}
.svc-side ul a.on::before{background:var(--teal)}
.svc-side .pill{display:inline-block;font-size:10px;font-weight:700;color:#fff;background:#95c11f;border-radius:2px;padding:2px 7px;margin-left:6px;letter-spacing:.04em}
.svc-side .pill.b{background:#3a489e}

.svc-main h2.lede{font-size:clamp(20px,2.6vw,26px);font-weight:700;letter-spacing:.05em;line-height:1.7;margin:0 0 22px}
.svc-main p.body{font-size:13.5px;line-height:2.1;color:var(--ink-2);margin:0 0 22px}
.anchor-pills{display:flex;flex-wrap:wrap;gap:14px 26px;margin:0 0 40px;padding-bottom:4px}
.anchor-pills a{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2);letter-spacing:.03em}
.anchor-pills a::before{display:none}
.anchor-pills .ico-arrowdn{flex:none;width:18px;height:18px;color:var(--gray);transition:color .3s var(--ease)}
.anchor-pills a:hover{color:var(--teal-deep)}

.rec-box{background:var(--soft);padding:clamp(28px,3.4vw,44px);margin:0 0 44px}
.rec-box .rtag{font-size:11px;font-weight:700;letter-spacing:.14em;color:var(--gray);text-transform:uppercase;margin:0 0 6px}
.rec-box h3{font-size:clamp(17px,2.2vw,21px);font-weight:700;letter-spacing:.04em;margin:0 0 22px}
.rec-box ul li{display:flex;align-items:flex-start;gap:11px;font-size:13.5px;line-height:1.9;color:var(--ink-2);margin-bottom:14px}
.rec-box ul li::before,.rec-box ul li::after{display:none}
.rec-box .ico-check{flex:none;width:18px;height:18px;margin-top:4px;color:var(--teal-deep)}

.svc-block{margin:0 0 50px}
.svc-fig{margin:6px auto 6px;max-width:440px}
.svc-fig img{width:100%;height:auto;display:block}
.svc-fig.wide{max-width:640px}
.svc-row{display:grid;grid-template-columns:210px 1fr;gap:34px;align-items:center;margin:6px 0}
.svc-row img{width:100%;height:auto;display:block}
.svc-row .body{margin:0}
.plan-fig{background:var(--soft);width:100%;margin:22px 0 26px;padding:clamp(28px,4vw,52px) clamp(20px,4vw,56px)}
.plan-fig img{display:block;width:100%;height:auto;margin:0 auto}
@media (max-width:680px){.svc-row{grid-template-columns:1fr;gap:16px;justify-items:center;text-align:center}.svc-row img{max-width:220px}}
.svc-block h3.bk{font-size:clamp(17px,2.2vw,21px);font-weight:700;letter-spacing:.04em;line-height:1.6;margin:0 0 20px}
.check-list li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;line-height:1.95;color:var(--ink-2);margin-bottom:12px}
.check-list li::before,.check-list li::after{display:none}
.check-list .ico-check{flex:none;width:17px;height:17px;margin-top:4px;color:var(--teal-deep)}
.point-badge{display:inline-block;background:var(--ink);color:#fff;font-size:12px;font-weight:700;letter-spacing:.08em;padding:6px 18px;border-radius:999px;margin-bottom:18px}
.row-img{display:grid;grid-template-columns:140px 1fr;gap:24px;align-items:start;margin:18px 0}
.row-img .ic{aspect-ratio:1;background:var(--soft);border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden}
.row-img .ic img{width:62%}
.row-img p{font-size:12.5px;line-height:2;color:var(--ink-2);margin:0}

.plan-circles{display:flex;gap:clamp(16px,3vw,40px);justify-content:center;margin:28px 0;flex-wrap:wrap}
.plan-circles .pc{
  width:clamp(128px,14vw,158px);aspect-ratio:1;border:1px solid var(--line-2);border-radius:50%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fff;gap:6px;
}
.plan-circles .pc .nm{font-size:12.5px;font-weight:700;letter-spacing:.06em;color:var(--ink)}
.plan-circles .pc .pr{font-size:27px;font-weight:800;letter-spacing:.02em;line-height:1}
.plan-circles .pc .pr small{font-size:10px;font-weight:500;color:var(--gray);margin-left:3px}
.lede-label{font-size:12.5px;font-weight:500;letter-spacing:.06em;color:var(--gray);margin:0 0 10px}
.shopify-logo{display:flex;justify-content:center;margin:8px 0 6px}
.shopify-logo img{height:34px;width:auto}

.flow{background:var(--soft);padding:clamp(30px,3.6vw,52px);margin-top:20px}
.flow .ft{font-size:11px;font-weight:700;letter-spacing:.14em;color:var(--gray);text-transform:uppercase;text-align:center;margin:0 0 6px}
.flow h3{text-align:center;font-size:clamp(18px,2.4vw,24px);font-weight:700;letter-spacing:.05em;margin:0 0 30px}
.flow .step{background:#fff;border:1px solid var(--line);padding:22px;text-align:center;position:relative;margin-bottom:34px}
.flow .step:last-child{margin-bottom:0}
.flow .step:not(:last-child)::after{content:"";position:absolute;left:50%;bottom:-22px;transform:translateX(-50%);border:9px solid transparent;border-top-color:var(--ink)}
.flow .step .sn{display:inline-block;background:var(--ink);color:#fff;font-size:11px;font-weight:700;letter-spacing:.1em;padding:5px 16px;border-radius:999px;margin-bottom:12px}
.flow .step h4{font-size:16px;font-weight:700;letter-spacing:.04em;margin:0 0 8px}
.flow .step p{font-size:12.5px;color:var(--ink-2);margin:0;line-height:1.85}

@media (max-width:860px){
  .svc-layout{grid-template-columns:1fr}
  .svc-side{position:static;border-bottom:1px solid var(--line);padding-bottom:20px;margin-bottom:8px}
  .plan-cards{grid-template-columns:1fr}
  .row-img{grid-template-columns:90px 1fr}
}

/* spec table */
.spec{width:100%;border-collapse:collapse}
.spec th,.spec td{text-align:left;vertical-align:top;padding:22px 8px;border-bottom:1px solid var(--line);font-weight:400;letter-spacing:.04em}
.spec th{width:180px;font-weight:700;font-size:14px;color:var(--ink)}
.spec td{font-size:14px;color:var(--ink-2);line-height:1.95}

.badge{display:inline-block;font-size:13px;font-weight:700;letter-spacing:.06em;color:#fff;background:var(--ink);padding:11px 26px;border-radius:24px 24px 24px 0}

/* mission blocks */
.mblock{margin-bottom:clamp(34px,4vw,52px)}
.mblock .badge{margin-bottom:22px}
.mblock h3{font-size:clamp(18px,2.4vw,22px);font-weight:700;letter-spacing:.05em;margin:0 0 14px}
.mblock p{font-size:13.5px;line-height:2.05;color:var(--ink-2);max-width:880px}
.mblock-wide p{max-width:100%}

/* exec / staff */
.exec{display:grid;grid-template-columns:1fr 170px;gap:40px;align-items:start;max-width:920px}
.exec .who h3{font-size:20px;font-weight:700;letter-spacing:.05em;margin:0 0 4px}
.exec .who .role{font-size:12px;color:var(--gray);margin:0 0 18px;letter-spacing:.06em}
.exec .who p{font-size:13.5px;line-height:2;color:var(--ink-2)}
.exec .pic{width:140px;height:140px;border-radius:50%;background:var(--soft);overflow:hidden;display:flex;align-items:flex-end;justify-content:center;margin-left:auto}
.exec .pic img{width:78%;height:auto}

/* category filter (cases) */
.filterbar{font-size:13px;color:var(--ink-2);margin-bottom:clamp(30px,3.4vw,46px);line-height:2.4}
.filterbar .frow{display:flex;flex-wrap:wrap;gap:10px 18px;align-items:baseline}
.filterbar .flabel{font-weight:700;color:var(--ink);min-width:64px}
.filterbar .chip{font-size:13px;color:var(--ink-2);cursor:pointer;letter-spacing:.04em;transition:color .2s;position:relative}
.filterbar .chip:hover{color:var(--teal-deep)}
.filterbar .chip.on{color:var(--ink);font-weight:700;border-bottom:2px solid transparent;border-image:linear-gradient(90deg,#615fa8 0%,#e7bcc3 100%) 1}

.loadmore{display:flex;justify-content:center;margin-top:clamp(36px,4vw,56px)}
.loadmore button{background:var(--ink);color:#fff;font-weight:700;font-size:14px;letter-spacing:.08em;padding:15px 60px;transition:.3s var(--ease)}

/* tabs (news) — pill segmented */
.tabs{display:inline-flex;gap:4px;padding:4px;background:var(--soft);border:1px solid var(--line);border-radius:999px;margin-bottom:clamp(24px,3vw,38px)}
.tabs button{font-size:13px;font-weight:500;letter-spacing:.05em;color:var(--gray-2);padding:8px 26px;border:none;background:transparent;border-radius:999px;transition:color .25s,background .3s var(--ease)}
.tabs button:hover{color:var(--ink)}
.tabs button.on{background:linear-gradient(90deg,#615fa8 0%,#e7bcc3 100%);color:#fff;font-weight:700}

/* news detail */
.article{max-width:840px;margin:0 auto}
.article .meta{display:flex;align-items:center;gap:16px;margin-bottom:18px}
.article .meta .date{font-size:13px;color:var(--ink-2)}
.article .meta .cat{font-size:11px;font-weight:700;border:1px solid var(--line-2);padding:5px 12px;border-radius:2px;color:var(--ink-2)}
.article h1{font-size:clamp(22px,3.2vw,30px);font-weight:700;letter-spacing:.05em;margin:0 0 26px;line-height:1.6;border-bottom:1px solid var(--ink);padding-bottom:26px}
.article p{font-size:14px;line-height:2.1;color:var(--ink-2);margin:0 0 18px}
.article strong{color:var(--ink);font-weight:700}
.backlink{display:flex;justify-content:center;margin-top:clamp(40px,5vw,64px)}
.backlink a{display:inline-flex;align-items:center;gap:10px;font-size:14px;color:var(--ink-2)}
.backlink a .ico{width:30px;height:30px;border:1px solid var(--line-2);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.3s var(--ease)}
.backlink a:hover .ico{background:var(--ink);color:#fff;transform:translateX(-3px)}

/* case detail */
.cdetail{max-width:720px;margin:0 auto}
.cdetail .tags{display:flex;gap:10px;margin:16px 0 28px}
.cdetail .tags span{font-size:12px;font-weight:700;border:1px solid var(--line-2);padding:5px 14px;border-radius:2px;color:var(--ink-2)}
.cdetail .shot{background:var(--soft);padding:clamp(24px,3vw,48px);margin-bottom:34px}
.cdetail .shot img{width:100%;display:block}
.cdetail p{font-size:13.5px;line-height:2.05;color:var(--ink-2);margin:0 0 18px}
.cdetail .url{color:var(--teal-deep);text-decoration:underline;text-underline-offset:3px;font-size:13.5px}
.cdetail h2{font-size:18px;font-weight:700;letter-spacing:.05em;margin:34px 0 8px}
.cdetail .small{font-size:13px;color:var(--ink-2);margin:0}
.member-grid{display:grid;grid-template-columns:repeat(5,auto);gap:8px 36px;margin-top:8px}
.member-grid .m .r{font-size:12px;font-weight:700;color:var(--ink);margin-bottom:5px}
.member-grid .m .n{font-size:13px;color:var(--ink-2)}

/* forms */
.form{max-width:720px;margin:0 auto}
.form .intro{text-align:center;font-size:14px;line-height:2;color:var(--ink-2);margin-bottom:18px}
.form .tel-c{text-align:center;margin-bottom:clamp(40px,5vw,60px)}
.form .tel-c .num{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:22px;letter-spacing:.04em}
.form .tel-c small{font-size:12px;color:var(--gray);margin-left:6px}
.field{margin-bottom:26px}
.field label{display:block;font-size:13px;font-weight:700;letter-spacing:.05em;margin-bottom:10px}
.field label .req{color:#c0392b;margin-left:4px}
.field input,.field select,.field textarea{
  width:100%;font:inherit;font-size:14px;letter-spacing:.03em;color:var(--ink);
  border:1px solid var(--line-2);background:#fff;padding:14px 16px;border-radius:2px;transition:border-color .25s,box-shadow .25s;
}
.field input::placeholder,.field textarea::placeholder{color:#bdbdba}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink);box-shadow:0 0 0 3px rgba(36,36,34,.06)}
.field textarea{min-height:150px;resize:vertical}
.agree{display:flex;align-items:center;justify-content:center;gap:10px;font-size:13px;margin:6px 0 30px}
.agree a{text-decoration:underline;text-underline-offset:3px;color:var(--teal-deep)}
.submit{display:flex;justify-content:center}
.submit button{background:var(--ink);color:#fff;font-weight:700;font-size:15px;letter-spacing:.08em;padding:17px 90px;transition:.3s var(--ease)}

/* empty state */
.empty-cols{display:grid;grid-template-columns:1fr 1fr;gap:40px;max-width:760px;margin:0 auto;text-align:center;color:var(--ink-2);font-size:14px;padding:clamp(30px,4vw,60px) 0}
.empty-cols h3{font-size:15px;font-weight:700;margin:0}

/* recruit values — text-first list */
.rvalues{max-width:100%;border-top:1px solid var(--line)}
.rvalue{display:grid;grid-template-columns:110px 1fr;gap:clamp(24px,5vw,72px);align-items:start;padding:clamp(28px,4vw,44px) 0;border-bottom:1px solid var(--line)}
.rv-num{font-size:clamp(38px,5vw,56px);font-weight:700;line-height:.82;color:#c8d9dc;letter-spacing:.04em}
.rv-en{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gray);margin:0 0 10px}
.rv-ja{font-size:clamp(16px,2.2vw,20px);font-weight:700;letter-spacing:.04em;line-height:1.6;margin:0 0 12px;color:var(--ink)}
.rv-text{font-size:13.5px;line-height:2;color:var(--ink-2);margin:0;max-width:760px}
@media (max-width:560px){
  .rvalue{grid-template-columns:1fr;gap:10px}
  .rv-num{font-size:34px}
}

/* recruit openings empty state */
.recruit-empty{border:1px solid var(--line);background:var(--soft-2);text-align:center;padding:clamp(40px,6vw,72px) clamp(20px,4vw,48px)}
.recruit-empty .re-lead{font-size:clamp(16px,2.2vw,20px);font-weight:700;letter-spacing:.05em;margin:0 0 16px;color:var(--ink)}
.recruit-empty .re-sub{font-size:13.5px;line-height:2;color:var(--ink-2);margin:0 0 30px}
.recruit-empty .re-btn{width:auto;display:inline-flex;padding-inline:clamp(40px,6vw,72px)}

/* ============================ DOCUMENTS ============================ */
.doc-filter{display:flex;flex-wrap:wrap;gap:10px 18px;align-items:baseline;margin:0 0 clamp(30px,3.4vw,44px)}
.doc-filter .flabel{font-size:13px;font-weight:700;color:var(--ink);letter-spacing:.04em}
.doc-filter .chip{font:inherit;font-size:13px;color:var(--ink-2);cursor:pointer;letter-spacing:.04em;background:none;border:0;padding:0 0 3px;border-bottom:2px solid transparent;transition:color .2s}
.doc-filter .chip:hover{color:var(--teal-deep)}
.doc-filter .chip.on{color:var(--ink);font-weight:700;border-bottom:2px solid transparent;border-image:linear-gradient(90deg,#615fa8 0%,#e7bcc3 100%) 1}
.doc-card.is-hidden{display:none}
.doc-intro{font-size:14px;line-height:2;color:var(--ink-2);margin:8px 0 clamp(34px,4vw,52px);max-width:680px}
.doc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,32px)}
.doc-card{display:flex;flex-direction:column;border:1px solid var(--line);background:#fff;transition:box-shadow .3s var(--ease)}
.doc-card:hover{box-shadow:0 18px 40px rgba(0,0,0,.07)}
.doc-card .ph{aspect-ratio:4/3;background:var(--soft);overflow:hidden;position:relative}
.doc-card .ph img{width:100%;height:100%;object-fit:cover}
.doc-card .ph .tag{position:absolute;z-index:2;top:12px;left:12px;font-size:11px;font-weight:700;letter-spacing:.06em;color:#fff;background:var(--ink);padding:5px 12px;border-radius:2px}
.doc-card .body{padding:22px 22px 26px;display:flex;flex-direction:column;flex:1}
.doc-card h3{margin:0 0 10px;font-size:15px;font-weight:700;line-height:1.7;letter-spacing:.03em}
.doc-card p{margin:0 0 20px;font-size:12.5px;line-height:1.9;color:var(--ink-2);flex:1}
.doc-card .dl{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:700;letter-spacing:.05em;color:#fff;background:var(--ink);padding:13px;transition:color .35s var(--ease)}
.doc-card .dl svg{width:16px;height:16px}

/* ============================ FAQ ============================ */
.faq-cats{display:flex;flex-wrap:wrap;gap:10px;margin:0 0 clamp(30px,3.4vw,44px)}
.faq-cats .fc{font-size:12.5px;font-weight:700;letter-spacing:.04em;color:var(--ink-2);border:1px solid var(--line-2);padding:8px 18px;border-radius:999px;transition:color .25s var(--ease),border-color .25s var(--ease)}
.faq-cats a.fc:hover{color:var(--teal-deep);border-color:var(--teal-deep)}
.faq-group{margin-bottom:clamp(34px,4vw,52px);scroll-margin-top:110px}
.faq-group h2{font-size:clamp(16px,2.2vw,20px);font-weight:700;letter-spacing:.05em;margin:0 0 18px;padding-left:14px;border-left:3px solid var(--teal)}
.faq-list{border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{display:flex;align-items:flex-start;gap:14px;width:100%;text-align:left;padding:20px 4px;cursor:pointer;font:inherit}
.faq-q .qm{flex:none;font-weight:700;font-size:16px;color:var(--teal-deep);line-height:1.6}
.faq-q .qt{flex:1;font-size:14px;font-weight:500;line-height:1.6;letter-spacing:.02em;color:var(--ink)}
.faq-q .ic{flex:none;width:20px;height:20px;margin-top:2px;position:relative;transition:transform .3s var(--ease)}
.faq-q .ic::before,.faq-q .ic::after{content:"";position:absolute;background:var(--ink-2);transition:opacity .3s}
.faq-q .ic::before{top:9px;left:2px;right:2px;height:1.6px}
.faq-q .ic::after{left:9px;top:2px;bottom:2px;width:1.6px}
.faq-item.open .faq-q .ic::after{opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a .inner{display:flex;gap:14px;padding:0 4px 22px}
.faq-a .am{flex:none;font-weight:700;font-size:16px;color:var(--gray);line-height:1.7}
.faq-a .at{flex:1;font-size:13.5px;line-height:2;color:var(--ink-2)}

/* ============================ LEGAL (privacy) ============================ */
.legal{max-width:860px;margin:0 auto}
.legal .updated{font-size:12px;color:var(--gray);margin:0 0 30px;letter-spacing:.04em}
.legal p{font-size:13.5px;line-height:2.05;color:var(--ink-2);margin:0 0 20px}
.legal h2{font-size:clamp(16px,2.2vw,19px);font-weight:700;letter-spacing:.04em;margin:36px 0 14px;color:var(--ink)}
.legal ul{margin:0 0 20px;padding:0}
.legal ul li{display:flex;gap:10px;font-size:13.5px;line-height:1.95;color:var(--ink-2);margin-bottom:8px}
.legal ul li::before{content:"";flex:none;width:6px;height:6px;border-radius:50%;background:var(--teal);margin-top:12px}
.legal .addr{border:1px solid var(--line);background:var(--soft-2);padding:24px 26px;font-size:13.5px;line-height:1.95;color:var(--ink-2)}

/* ============================ SITEMAP ============================ */
.sitemap-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(24px,3vw,44px)}
.sitemap-grid .span2{grid-column:span 2}
.sitemap-grid .span2 .cols2{column-count:2;column-gap:clamp(20px,2.4vw,40px)}
.sitemap-grid .span2 .cols2 li{break-inside:avoid}
.sitemap-grid h2{font-size:14px;font-weight:700;letter-spacing:.05em;margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid var(--ink)}
.sitemap-grid ul li{margin-bottom:11px}
.sitemap-grid ul a{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2);letter-spacing:.03em;transition:color .25s,gap .25s}
.sitemap-grid ul a:hover{color:var(--teal-deep);gap:11px}
.sitemap-grid ul a::before{content:"";flex:none;width:5px;height:5px;border-radius:50%;background:var(--line-2)}
.sitemap-grid .sub{margin:8px 0 0 14px}
.sitemap-grid .sub li{margin-bottom:8px}
.sitemap-grid .sub a{font-size:12px;color:var(--gray-2)}

@media (max-width:860px){
  .doc-grid{grid-template-columns:repeat(2,1fr)}
  .sitemap-grid{grid-template-columns:repeat(2,1fr)}
  .sitemap-grid .span2{grid-column:span 2}
}
@media (max-width:560px){
  .doc-grid{grid-template-columns:1fr;max-width:360px;margin:0 auto}
  .sitemap-grid{grid-template-columns:1fr}
  .sitemap-grid .span2{grid-column:span 1}
  .sitemap-grid .span2 .cols2{column-count:1}
}

/* ============================ DOC DOWNLOAD (lead form) ============================ */
.dlform{max-width:760px;margin:0 auto}
.dl-summary{display:flex;gap:20px;align-items:center;border:1px solid var(--line);background:var(--soft-2);padding:18px 20px;margin-bottom:clamp(30px,3.4vw,44px)}
.dl-summary .ph{flex:none;width:96px;aspect-ratio:4/3;background:var(--soft);overflow:hidden}
.dl-summary .ph img{width:100%;height:100%;object-fit:cover}
.dl-summary .meta .lab{font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--gray);text-transform:uppercase;margin:0 0 5px}
.dl-summary .meta h2{font-size:16px;font-weight:700;letter-spacing:.03em;margin:0 0 4px;line-height:1.6}
.dl-summary .meta p{font-size:12.5px;color:var(--ink-2);margin:0;line-height:1.7}
.dl-note{font-size:12.5px;color:var(--gray-2);line-height:1.9;margin:18px 0 0;text-align:center}
.field .row2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:560px){.field .row2{grid-template-columns:1fr}}

/* download success */
.dl-done{max-width:620px;margin:0 auto;text-align:center;border:1px solid var(--line);padding:clamp(40px,6vw,72px) clamp(24px,4vw,48px);background:#fff}
.dl-done .chk{width:64px;height:64px;border-radius:50%;background:var(--teal);display:flex;align-items:center;justify-content:center;margin:0 auto 24px}
.dl-done .chk svg{width:30px;height:30px;color:#fff}
.dl-done h2{font-size:clamp(18px,2.4vw,22px);font-weight:700;letter-spacing:.04em;margin:0 0 14px}
.dl-done p{font-size:13.5px;line-height:2;color:var(--ink-2);margin:0 0 28px}
.dl-done .dlbtn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:700;font-size:15px;letter-spacing:.06em;color:#fff;background:var(--ink);padding:16px 44px;transition:color .35s var(--ease),border-color .35s var(--ease)}
.dl-done .dlbtn svg{width:18px;height:18px}
.dl-done .back{display:block;margin-top:22px;font-size:13px;color:var(--gray-2);text-decoration:underline;text-underline-offset:3px}

/* ============================ LEADS (sales list admin) ============================ */
.leads-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.leads-bar .cnt{font-size:13px;color:var(--ink-2)}
.leads-bar .cnt b{font-size:20px;font-weight:800;color:var(--ink);margin-right:4px}
.leads-bar .acts{display:flex;gap:10px}
.leads-bar button{font-size:13px;font-weight:700;letter-spacing:.04em;padding:11px 22px;border-radius:0;transition:.25s var(--ease)}
.leads-bar .csv{background:var(--ink);color:#fff}
.leads-bar .csv:hover{opacity:.8}
.leads-bar .clr{background:#fff;color:var(--ink-2);border:1px solid var(--line-2)}
.leads-bar .clr:hover{border-color:#c0392b;color:#c0392b}
.leads-wrap{overflow-x:auto;border:1px solid var(--line)}
.leads-table{width:100%;border-collapse:collapse;min-width:840px;font-size:12.5px}
.leads-table th{background:var(--soft);text-align:left;font-weight:700;letter-spacing:.04em;color:var(--ink);padding:13px 14px;border-bottom:1px solid var(--line);white-space:nowrap}
.leads-table td{padding:13px 14px;border-bottom:1px solid var(--line);color:var(--ink-2);vertical-align:top;line-height:1.6}
.leads-table tr:last-child td{border-bottom:none}
.leads-table tr:hover td{background:var(--soft-2)}
.leads-table .lt-doc{font-weight:700;color:var(--ink)}
.leads-empty{text-align:center;padding:clamp(50px,7vw,90px) 20px;color:var(--gray-2);font-size:14px;border:1px dashed var(--line-2)}
.leads-empty p{margin:0 0 8px}

/* ============================ BLOG ============================ */
.blog-layout{display:grid;grid-template-columns:1fr 252px;gap:clamp(34px,4vw,64px);align-items:start}
.blog-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(26px,3vw,40px) clamp(20px,2.4vw,32px)}
.post-card{display:block}
.post-card .ph{aspect-ratio:16/10;background:var(--soft);overflow:hidden;margin-bottom:16px}
.post-card .ph img{width:100%;height:100%;object-fit:cover}
.post-card .meta{display:flex;align-items:center;gap:12px;margin-bottom:9px}
.post-card .date{font-size:12px;color:var(--gray);letter-spacing:.04em}
.post-card .cat{font-size:10.5px;font-weight:700;letter-spacing:.06em;color:var(--ink-2);border:1px solid var(--line-2);padding:3px 10px;border-radius:2px}
.post-card h3{margin:0;font-size:15px;font-weight:700;line-height:1.7;letter-spacing:.03em;color:var(--ink);transition:color .25s}
.post-card:hover h3{color:var(--teal-deep)}
.blog-side .sbox{border:1px solid var(--line);padding:24px 22px;margin-bottom:24px}
.blog-side .sbox h4{margin:0 0 16px;font-size:13px;font-weight:700;letter-spacing:.06em;padding-bottom:12px;border-bottom:1px solid var(--line)}
.blog-side .cat-list li+li{margin-top:4px}
.blog-side .cat-list a{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13px;color:var(--ink-2);padding:8px 0;letter-spacing:.03em;transition:color .25s}
.blog-side .cat-list a:hover{color:var(--teal-deep)}
.blog-side .cat-list a .n{font-size:11px;color:var(--gray)}
.tag-cloud{display:flex;flex-wrap:wrap;gap:8px}
.tag-cloud a{position:relative;overflow:hidden;z-index:0;font-size:12px;color:var(--ink-2);border:1px solid var(--line-2);padding:6px 12px;border-radius:999px;transition:color .4s var(--ease),border-color .4s var(--ease)}
.tag-cloud a::before{content:"";position:absolute;inset:-1px;z-index:-1;border-radius:inherit;background:linear-gradient(90deg,#615fa8 0%,#e7bcc3 100%);opacity:0;transition:opacity .4s var(--ease)}
.tag-cloud a:hover::before{opacity:1}
.tag-cloud a:hover{color:#fff;border-color:transparent}

/* blog article */
.article .hero-ph{aspect-ratio:16/8;background:var(--soft);overflow:hidden;margin:0 0 30px}
.article .hero-ph img{width:100%;height:100%;object-fit:cover;display:block}
.article h2{font-size:clamp(18px,2.4vw,22px);font-weight:700;letter-spacing:.04em;margin:38px 0 16px;padding-left:14px;border-left:3px solid var(--teal)}
.article h3{font-size:16px;font-weight:700;letter-spacing:.04em;margin:28px 0 12px}
.article ul.dot{margin:0 0 18px;padding:0}
.article ul.dot li{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:2;color:var(--ink-2);margin-bottom:6px}
.article ul.dot li::before{content:"";flex:none;width:6px;height:6px;border-radius:50%;background:var(--teal);margin-top:13px}
.article .lead-tags{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0 0}
.article .lead-tags span{font-size:11px;font-weight:700;color:var(--ink-2);border:1px solid var(--line-2);padding:5px 12px;border-radius:999px}

@media (max-width:860px){
  .blog-layout{grid-template-columns:1fr}
  .blog-side{display:grid;grid-template-columns:1fr 1fr;gap:0 24px}
}
@media (max-width:560px){
  .blog-grid{grid-template-columns:1fr;max-width:380px;margin:0 auto}
  .blog-side{grid-template-columns:1fr}
}

/* reveal animation — base state VISIBLE; hiding applied only when html.anim is set by JS */
.reveal{opacity:1}
html.anim .reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
html.anim .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  html.anim .reveal{opacity:1;transform:none;transition:none}
  .hero-marquee .run{animation:none}
}

/* ============================ RESPONSIVE ============================ */
@media (max-width:1240px){
  .gnav,.head-cta .btn-line{display:none}
  .burger{display:block}
  .head-cta{margin-left:auto}
  .head-cta .btn-fill{display:none}
}
@media (max-width:900px){
  .svc-grid{grid-template-columns:repeat(2,1fr);gap:32px}
  .partner-grid{grid-template-columns:repeat(3,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  .foot .fbrand{grid-column:1/-1}
}
@media (max-width:760px){
  .hero-top{grid-template-columns:1fr;gap:28px}
  .hero-people{padding-top:0}
  .hero-people .fig{width:clamp(44px,11vw,64px)}
  .feat-grid{grid-template-columns:1fr;gap:40px;max-width:420px;margin:0 auto}
  .case-grid{grid-template-columns:1fr;gap:36px;max-width:420px;margin:0 auto}
  .semi-card{max-width:none}
  .cband-cols{grid-template-columns:1fr;gap:40px}
  .cband-cols .col+.col{border-left:none;border-top:1px solid var(--line-2);padding-top:40px}
  .news-row{grid-template-columns:1fr auto;grid-template-areas:"date cat" "ttl ttl";gap:8px 14px;row-gap:8px}
  .news-row .date{grid-area:date}.news-row .cat{grid-area:cat;justify-self:end;padding:5px 12px}
  .news-row .ttl{grid-area:ttl}.news-row .arr{display:none}
  .exec{grid-template-columns:1fr}
  .exec .pic{margin:0 auto}
  .member-grid{grid-template-columns:repeat(2,1fr)}
  .spec th{width:110px;font-size:13px}
}
@media (max-width:560px){
  .svc-grid{grid-template-columns:1fr;max-width:340px;margin:0 auto}
  .partner-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr}
  .submit button{width:100%}
}

/* microCMS: 取得前の静的サンプルのチラつきを防ぐ。
   描画完了で .cms-ready が付くまで非表示（レイアウト高さは保持）。
   ※ microcms.js が必ず .cms-ready を付与する（未接続時は即時付与）。 */
[data-cms]{visibility:hidden}
[data-cms].cms-ready{visibility:visible}

/* 注入されるスティッキーヘッダーの高さを予約し、注入時のレイアウトシフト(CLS)を防ぐ。
   buildHeader() が同じ .masthead(88px) に置き換えるため、予約高さと一致して無シフト。 */
[data-include="header"]{display:block;height:88px}
