/* ============================================================
   UFB AGRI ／ Kajitsudo-style rebuild
   palette: white + green + ink
============================================================ */
:root{
  --green:#7cc242;
  --green-deep:#5fa826;
  --green-soft:#e8f5db;
  --green-bg:#f4faec;
  --ink:#1a1f24;
  --ink-2:#4b5560;
  --ink-3:#8a929b;
  --line:#e6e9ee;
  --line-soft:#eef0f3;
  --bg:#ffffff;
  --bg-soft:#f7f8f9;
  --accent-red:#e35d4a;
  --shadow:0 14px 40px rgba(20,30,40,.08);
  --shadow-soft:0 6px 18px rgba(20,30,40,.05);
  --radius:6px;
  --radius-l:14px;
  --sans:"Noto Sans JP","Inter",-apple-system,BlinkMacSystemFont,"Hiragino Sans",sans-serif;
  --display:"Inter","Noto Sans JP",sans-serif;
  --rail:100px;
  --header-h:84px;
  --hamburger-h:130px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  line-height:1.85;
  font-feature-settings:"palt";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  padding-right:var(--rail);
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color .25s ease}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--green);color:#fff}

/* ============================================================
   LEFT RAIL (sidebar) ─ kajitsu-style: white body + green top-block
============================================================ */
.rail{
  position:fixed;right:0;top:0;bottom:0;width:var(--rail);
  background:#fff;z-index:50;
  display:flex;flex-direction:column;align-items:stretch;
  border-left:1px solid var(--line-soft);
}
/* Top: green gradient hamburger block */
.rail__top{
  height:var(--hamburger-h);
  background:linear-gradient(135deg,var(--green) 0%,var(--green-deep) 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:10px;cursor:pointer;color:#fff;
  transition:filter .3s;
}
.rail__top:hover{filter:brightness(1.06)}
.rail__menu{
  width:36px;height:24px;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;background:none;border:none;padding:0;
}
.rail__menu span{display:block;height:2px;background:#fff;border-radius:2px;width:100%;transition:.3s}
.rail__menu-label{font-size:11px;letter-spacing:.16em;color:#fff;font-weight:700;font-family:var(--display);margin-top:4px}

/* Middle: vertical copyright */
.rail__name{
  flex:1;display:flex;align-items:center;justify-content:center;
  writing-mode:vertical-rl;font-size:11px;letter-spacing:.34em;
  color:var(--ink-3);font-weight:500;font-family:var(--display);
}

/* Bottom: BACK TO TOP with ring */
.rail__bottom{
  padding:0 0 24px;display:flex;flex-direction:column;align-items:center;gap:14px;
}
.rail__back{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  font-size:11px;letter-spacing:.28em;color:var(--ink);font-weight:800;
  font-family:var(--display);writing-mode:vertical-rl;
  text-decoration:none;transition:color .3s;
}
.rail__back:hover{color:var(--green-deep)}
.rail__back-ring{
  width:42px;height:42px;border:0;border-radius:50%;
  background:var(--green);color:#fff;
  display:grid;place-items:center;
  position:relative;writing-mode:horizontal-tb;
  box-shadow:0 6px 18px rgba(95,168,38,.32);
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.rail__back-ring::before{content:"↑";font-size:16px;font-weight:800}
.rail__back:hover .rail__back-ring{background:var(--green-deep);transform:translateY(-3px);box-shadow:0 10px 24px rgba(95,168,38,.42)}

/* hamburger drawer (full-screen) */
.drawer{position:fixed;inset:0;z-index:200;background:#1a2024;color:#fff;visibility:hidden;opacity:0;transition:opacity .35s,visibility .35s;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.drawer.is-open{visibility:visible;opacity:1}
.drawer__close{position:fixed;top:24px;right:32px;font-size:14px;letter-spacing:.2em;color:#fff;background:#1a2024;border:1px solid rgba(255,255,255,.3);padding:10px 18px;border-radius:999px;cursor:pointer;z-index:201}
.drawer__close:hover{background:rgba(255,255,255,.08)}
.drawer__inner{max-width:920px;margin:0 auto;padding:140px 40px 80px;min-height:100%}
.drawer__list{list-style:none;display:flex;flex-direction:column;gap:24px}
.drawer__list a{font-size:34px;font-weight:700;color:#fff;display:flex;align-items:center;gap:18px;letter-spacing:.04em}
.drawer__list a small{font-size:11px;letter-spacing:.24em;color:var(--green);font-weight:600;font-family:var(--display)}

/* ============================================================
   HEADER
============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:var(--rail);z-index:40;
  height:var(--header-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 32px;
  background:rgba(255,255,255,.96);backdrop-filter:blur(14px);
  transition:box-shadow .3s,background .3s;
}
.site-header.scrolled{box-shadow:0 1px 0 var(--line)}
.site-header.is-hero-top{background:transparent;box-shadow:none}
.site-header.is-hero-top .nav a,
.site-header.is-hero-top .brand{color:#fff}
.site-header.is-hero-top .nav a::after{background:#fff}
.site-header.is-hero-top .brand-leaf{box-shadow:0 0 0 2px rgba(255,255,255,.6)}

.brand{display:flex;align-items:center;gap:10px;color:var(--ink);font-weight:700;font-size:18px;letter-spacing:.04em;transition:color .3s}
.brand-leaf{width:38px;height:38px;flex-shrink:0;object-fit:contain;display:block;border-radius:8px}
.brand__txt{display:flex;flex-direction:column;line-height:1.2}
.brand__txt small{font-size:10px;letter-spacing:.2em;color:var(--ink-3);font-weight:500;margin-top:3px}
.site-header.is-hero-top .brand__txt small{color:rgba(255,255,255,.7)}

.nav{display:flex;align-items:center;gap:22px}
.nav a{font-size:15px;color:var(--ink);font-weight:500;letter-spacing:.02em;display:flex;align-items:center;gap:8px;position:relative;transition:color .3s;white-space:nowrap}
.nav a::after{content:"";width:7px;height:7px;border-radius:50%;border:1.5px solid currentColor;display:inline-block;transition:all .3s;flex-shrink:0}
.nav a:hover{color:var(--green-deep)}
.nav a:hover::after{background:var(--green);border-color:var(--green)}
.site-header.is-hero-top .nav a{color:#fff}
.site-header.is-hero-top .nav a:hover{color:var(--green-soft)}

.header-tail{display:flex;align-items:center;gap:14px;height:100%}
.header-mob-toggle{display:none}

/* lang switch */
.lang-switch{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border:1px solid var(--line);border-radius:999px;color:var(--ink-2);font-family:var(--display);font-size:12px;letter-spacing:.12em;cursor:pointer;background:#fff;transition:all .3s}
.lang-switch:hover{border-color:var(--green);color:var(--green-deep)}
.site-header.is-hero-top .lang-switch{border-color:rgba(255,255,255,.5);color:#fff;background:transparent}
.site-header.is-hero-top .lang-switch:hover{background:#fff;color:var(--green-deep);border-color:#fff}
.lang-switch__opt{padding:0 4px;opacity:.55;transition:opacity .25s}
.lang-switch__opt.is-on{opacity:1;color:var(--green-deep);font-weight:700}
.site-header.is-hero-top .lang-switch__opt.is-on{color:#fff}
.lang-switch__sep{opacity:.4}

/* contact button */
.btn-contact{display:inline-flex;align-items:center;gap:10px;padding:11px 22px 11px 18px;border:1.5px solid var(--ink);border-radius:999px;color:var(--ink);font-weight:700;font-size:13px;letter-spacing:.05em;background:transparent;transition:all .3s}
.btn-contact::before{content:"✎";font-size:14px;color:var(--green-deep)}
.btn-contact:hover{background:var(--ink);color:#fff}
.btn-contact:hover::before{color:#fff}
.site-header.is-hero-top .btn-contact{border-color:#fff;color:#fff;background:rgba(255,255,255,.1)}
.site-header.is-hero-top .btn-contact:hover{background:#fff;color:var(--ink)}

/* ============================================================
   GENERAL
============================================================ */
.section{padding:120px 32px;position:relative}
.section__inner{max-width:1280px;margin:0 auto}

/* section heading: 大見出し + 緑リーフ + 英字キャプション */
.section-heading{margin-bottom:60px;display:flex;align-items:flex-start;gap:48px;flex-wrap:wrap}
.section-heading__title{display:flex;flex-direction:column;gap:6px}
.section-heading__title h2{font-size:clamp(28px,3.6vw,42px);font-weight:900;color:var(--ink);letter-spacing:.04em;line-height:1.4;display:flex;align-items:center;gap:12px}
.section-heading__title h2::after{content:"";width:14px;height:18px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 32' fill='%237cc242'><path d='M12 2c-5 4-7 9-7 14 0 7 5 14 7 14 2 0 7-7 7-14 0-5-2-10-7-14z'/></svg>") center/contain no-repeat;display:inline-block}
.section-heading__caption{font-family:var(--display);font-size:13px;letter-spacing:.24em;color:var(--accent-red);font-weight:700;margin-top:2px}
.section-heading__lead{flex:1;min-width:300px;max-width:680px;font-size:14.5px;line-height:2.1;color:var(--ink-2);padding-top:20px}
.section-heading__more{flex-shrink:0;align-self:flex-start;margin-top:30px}

/* link with circle arrow */
.link-arrow{display:inline-flex;align-items:center;gap:14px;font-size:13px;font-weight:700;letter-spacing:.08em;color:var(--ink);transition:color .3s}
.link-arrow::after{content:"→";display:inline-grid;place-items:center;width:32px;height:32px;border:1.5px solid currentColor;border-radius:50%;font-size:14px;transition:all .3s}
.link-arrow:hover{color:var(--green-deep)}
.link-arrow:hover::after{background:var(--green);border-color:var(--green);color:#fff;transform:rotate(-45deg)}

/* button: primary green pill */
.btn-pill{display:inline-flex;align-items:center;gap:14px;padding:18px 30px 18px 36px;border-radius:999px;background:var(--green);color:#fff;font-weight:700;font-size:14px;letter-spacing:.06em;transition:all .3s;box-shadow:0 10px 24px rgba(124,194,66,.3)}
.btn-pill::after{content:"→";display:grid;place-items:center;width:32px;height:32px;border:1.5px solid #fff;border-radius:50%;font-size:14px;transition:transform .3s}
.btn-pill:hover{background:var(--green-deep);transform:translateY(-2px);box-shadow:0 16px 36px rgba(95,168,38,.4)}
.btn-pill:hover::after{transform:rotate(-45deg)}
.btn-pill--outline{background:transparent;color:var(--ink);box-shadow:none;border:1.5px solid var(--ink)}
.btn-pill--outline::after{border-color:currentColor}
.btn-pill--outline:hover{background:var(--ink);color:#fff;box-shadow:none}
.btn-pill--white{background:#fff;color:var(--ink);box-shadow:var(--shadow-soft)}
.btn-pill--white::after{border-color:var(--ink);color:var(--ink)}
.btn-pill--white:hover{background:var(--green);color:#fff}
.btn-pill--white:hover::after{border-color:#fff;color:#fff}

/* ============================================================
   HERO
============================================================ */
.hero{
  position:relative;height:100vh;min-height:680px;
  display:flex;align-items:center;
  padding:0 32px;
  margin-top:0;
  overflow:hidden;
  color:#fff;
}
.hero__bg{position:absolute;inset:0;background:#000;z-index:0}
.hero__bg::before{content:"";position:absolute;inset:0;background-size:cover;background-position:center;background-image:
  linear-gradient(120deg,rgba(20,40,30,.55) 0%,rgba(20,40,30,.15) 60%),
  url("https://images.unsplash.com/photo-1530836369250-ef72a3f5cda8?w=2400&q=85");
  z-index:0;
}
.hero__inner{position:relative;z-index:2;max-width:1280px;margin:0 auto;width:100%;padding-top:var(--header-h)}
.hero__eyebrow{display:inline-block;font-size:14px;font-weight:700;color:#fff;background:rgba(0,0,0,.35);backdrop-filter:blur(6px);padding:8px 18px;border-radius:4px;margin-bottom:24px;letter-spacing:.05em}
.hero__title{display:flex;flex-direction:column;gap:10px;align-items:flex-start;margin-bottom:28px}
.hero__line{display:inline-block;background:#fff;color:var(--ink);padding:8px 22px 12px;font-size:clamp(34px,5.6vw,76px);font-weight:900;line-height:1.18;letter-spacing:.04em}
.hero__line em{font-style:normal;color:var(--green-deep)}
.hero__sub{font-size:14px;color:rgba(255,255,255,.92);font-family:var(--display);font-weight:400;letter-spacing:.04em;margin-bottom:42px;max-width:560px;line-height:1.85;font-style:italic}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}

.hero__scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;color:#fff;font-size:10px;letter-spacing:.32em;display:flex;flex-direction:column;align-items:center;gap:14px;font-weight:600}
.hero__scroll::after{content:"";width:1px;height:48px;background:linear-gradient(to bottom,#fff,transparent);animation:scrollHint 2s ease-in-out infinite}
@keyframes scrollHint{0%,100%{transform:scaleY(.3);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}

/* ============================================================
   NEWS
============================================================ */
.news{padding:90px 32px}
.news__inner{max-width:1280px;margin:0 auto}
.news__row{display:flex;justify-content:space-between;align-items:flex-start;gap:48px;margin-bottom:36px;flex-wrap:wrap}
.news__list{list-style:none;border-top:1px solid var(--line)}
.news__list li{display:grid;grid-template-columns:140px 130px 1fr 60px;gap:24px;align-items:center;padding:22px 0;border-bottom:1px solid var(--line);font-size:14px;transition:background .3s}
.news__list li:hover{background:var(--bg-soft)}
.news__list time{font-family:var(--display);font-weight:600;color:var(--ink-2);letter-spacing:.04em;font-size:13px}
.news__tag{justify-self:start;background:var(--green);color:#fff;font-size:11px;font-weight:700;padding:5px 12px;border-radius:3px;letter-spacing:.06em}
.news__tag--alt{background:#5aa3d4}
.news__tag--info{background:#e0a83c}
.news__title{font-weight:600;color:var(--ink);text-decoration:underline;text-decoration-color:rgba(124,194,66,.4);text-underline-offset:5px;text-decoration-thickness:1px}
.news__list a:hover .news__title{color:var(--green-deep)}
.news__arrow{justify-self:end;width:28px;height:28px;display:grid;place-items:center;border:1px solid var(--line);border-radius:50%;color:var(--ink-2);font-size:12px;transition:all .3s}
.news__list a{display:contents}
.news__list a:hover .news__arrow{background:var(--green);border-color:var(--green);color:#fff}

/* ============================================================
   ABOUT (intro)
============================================================ */
.about{padding:120px 32px;background:linear-gradient(180deg,var(--bg) 0%,var(--green-bg) 100%);position:relative;overflow:hidden}
.about::before{content:"ABOUT";position:absolute;right:-30px;bottom:-40px;font-family:var(--display);font-weight:900;font-size:clamp(120px,18vw,240px);color:rgba(124,194,66,.08);letter-spacing:-.02em;line-height:1;pointer-events:none}
.about__inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:center;position:relative}
.about__copy h3{font-size:clamp(20px,2.2vw,28px);font-weight:900;line-height:1.7;color:var(--ink);margin-bottom:30px;letter-spacing:.04em}
.about__copy h3 em{font-style:normal;color:var(--green-deep);background:linear-gradient(transparent 60%,rgba(124,194,66,.25) 60%);padding:0 4px}
.about__copy p{font-size:14.5px;line-height:2.05;color:var(--ink-2);margin-bottom:24px}

/* ============================================================
   UFB DUAL とは？ ─ infographic
============================================================ */
.ufb-dual-sec{padding:120px 32px;background:linear-gradient(180deg,#fff,#f4faec 100%);position:relative;overflow:hidden}
.ufb-dual-sec::before{content:"UFB DUAL";position:absolute;left:-30px;top:60px;font-family:var(--display);font-weight:900;font-size:clamp(110px,15vw,200px);color:rgba(124,194,66,.06);letter-spacing:-.02em;line-height:1;pointer-events:none;writing-mode:horizontal-tb}
.ufb-dual-sec strong{font-weight:700;color:var(--ink)}

/* AI infographic */
.ufb-info{
  margin:24px 0 56px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:32px 32px 28px;
  box-shadow:var(--shadow-soft);
}
.ufb-info__scroll{
  width:100%;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;
  scrollbar-color:var(--green) var(--line-soft);
  border-radius:14px;
}
.ufb-info__scroll::-webkit-scrollbar{height:8px}
.ufb-info__scroll::-webkit-scrollbar-track{background:var(--line-soft);border-radius:8px}
.ufb-info__scroll::-webkit-scrollbar-thumb{background:var(--green);border-radius:8px}
.ufb-info__scroll img{
  width:100%;
  height:auto;
  display:block;
  border-radius:10px;
}
.ufb-info__cap{
  font-size:13px;color:var(--ink-2);font-weight:500;line-height:1.85;
  margin-top:18px;text-align:left;padding:0 4px;
}
.ufb-info__hint{display:none}
@media(max-width:880px){
  .ufb-info{padding:14px 10px}
  .ufb-info__scroll img{
    width:auto;
    height:600px;
    max-width:none;
  }
  .ufb-info__cap{font-size:12px;line-height:1.7;margin-top:14px;padding:0 6px}
  .ufb-info__hint{display:block;font-size:11px;color:var(--green-deep);font-weight:600;margin-top:6px;text-align:center}
}
@media(max-width:480px){
  .ufb-info{padding:10px 6px}
  .ufb-info__scroll img{height:560px}
}

.ufb-diagram{
  margin-top:24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:64px 56px 56px;
  box-shadow:var(--shadow-soft);
  position:relative;
  display:none; /* superseded by .ufb-info */
}
.ufb-diagram__head{text-align:center;max-width:880px;margin:0 auto 56px}
.ufb-diagram__eyebrow{display:inline-block;color:var(--green-deep);font-size:13px;font-weight:700;letter-spacing:.08em;margin-bottom:14px;font-family:var(--display);font-style:italic}
.ufb-diagram__title{font-size:clamp(22px,2.6vw,32px);font-weight:900;color:var(--ink);line-height:1.5;letter-spacing:.04em}
.ufb-diagram__title em{font-style:normal;color:var(--green-deep);background:linear-gradient(transparent 60%,rgba(124,194,66,.25) 60%);padding:0 4px}

.ufb-diagram__board{
  position:relative;
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  grid-template-rows:auto auto auto;
  gap:24px;
  align-items:start;
  max-width:1120px;
  margin:0 auto;
}

/* Center placement (row2-col2) */
.ufb-diagram__center{
  grid-row:2;grid-column:2;
  display:flex;flex-direction:column;align-items:center;gap:16px;
  position:relative;
  padding:24px 12px;
}
.ufb-diagram__device{
  width:200px;height:200px;
  border-radius:50%;
  background:radial-gradient(circle at center,#fff 30%,#e8f5db 70%,transparent 90%);
  display:grid;place-items:center;
  position:relative;
  box-shadow:0 30px 60px rgba(124,194,66,.16);
}
.ufb-diagram__device::before{
  content:"";position:absolute;inset:-12px;
  border-radius:50%;
  background:radial-gradient(circle at center,transparent 60%,rgba(124,194,66,.16) 70%,transparent 80%);
  animation:dualPulse 3s ease-in-out infinite;
  z-index:0;
}
@keyframes dualPulse{
  0%,100%{transform:scale(1);opacity:.6}
  50%{transform:scale(1.08);opacity:.9}
}
.ufb-diagram__device img{
  position:relative;z-index:1;
  width:80%;height:auto;
  filter:drop-shadow(0 10px 24px rgba(0,0,0,.18));
}
.ufb-diagram__center-label{text-align:center}
.ufb-diagram__core-tag{
  display:inline-block;background:var(--green);color:#fff;
  font-family:var(--display);font-weight:800;font-size:13px;
  padding:6px 14px;border-radius:999px;letter-spacing:.08em;
  margin-bottom:10px;
}
.ufb-diagram__center-label small{display:block;font-size:12px;color:var(--ink-2);font-weight:600;line-height:1.6}

/* Application callouts ─ 3x3 minus center */
.ufb-app{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:22px 22px 24px;
  position:relative;
  transition:all .35s;
  box-shadow:var(--shadow-soft);
}
.ufb-app:hover{
  border-color:var(--green);
  transform:translateY(-3px);
  box-shadow:0 16px 32px rgba(124,194,66,.12);
}
.ufb-app__icon{
  width:42px;height:42px;border-radius:50%;
  background:var(--green-bg);
  display:grid;place-items:center;
  font-size:20px;margin-bottom:12px;
}
.ufb-app h4{
  font-size:15px;font-weight:800;color:var(--ink);
  margin-bottom:8px;letter-spacing:.04em;
}
.ufb-app p{
  font-size:12.5px;line-height:1.85;color:var(--ink-2);
}

/* Position the 8 callouts around the center */
.ufb-app--1{grid-row:1;grid-column:1}
.ufb-app--2{grid-row:1;grid-column:2}
.ufb-app--3{grid-row:1;grid-column:3}
.ufb-app--4{grid-row:2;grid-column:1}
.ufb-app--5{grid-row:2;grid-column:3}
.ufb-app--6{grid-row:3;grid-column:1}
.ufb-app--7{grid-row:3;grid-column:2}
.ufb-app--8{grid-row:3;grid-column:3}

/* Connection lines from center to each app card (decorative pseudo) */
.ufb-diagram__center::after{
  content:"";position:absolute;inset:-10%;
  border-radius:50%;
  border:1.5px dashed rgba(124,194,66,.35);
  pointer-events:none;
  z-index:-1;
}

.ufb-diagram__footnote{
  margin-top:40px;text-align:center;
  font-size:12px;color:var(--ink-3);font-weight:500;line-height:1.85;
}

/* 4 BENEFITS */
.ufb-benefits{
  margin-top:48px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.ufb-benefit{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:30px 26px 28px;transition:all .35s;
}
.ufb-benefit:hover{border-color:var(--green);box-shadow:0 16px 32px rgba(124,194,66,.1);transform:translateY(-3px)}
.ufb-benefit__num{
  font-family:var(--display);font-weight:900;font-size:34px;
  color:var(--green);line-height:1;margin-bottom:14px;letter-spacing:-.02em;
}
.ufb-benefit h4{font-size:16px;font-weight:800;color:var(--ink);margin-bottom:12px;letter-spacing:.04em}
.ufb-benefit p{font-size:13px;line-height:1.95;color:var(--ink-2)}

/* Tablet */
@media(max-width:1100px){
  .ufb-diagram{padding:48px 28px 40px}
  .ufb-diagram__board{grid-template-columns:1fr 1fr;grid-template-rows:none;gap:18px}
  .ufb-diagram__center{
    grid-row:auto;grid-column:1 / -1;
    order:-1;
    padding:18px 12px 24px;
  }
  .ufb-diagram__device{width:160px;height:160px}
  .ufb-app--1,.ufb-app--2,.ufb-app--3,.ufb-app--4,
  .ufb-app--5,.ufb-app--6,.ufb-app--7,.ufb-app--8{grid-row:auto;grid-column:auto}
  .ufb-benefits{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .ufb-dual-sec{padding:80px 22px}
  .ufb-diagram{padding:36px 20px 32px}
  .ufb-diagram__board{grid-template-columns:1fr}
  .ufb-diagram__center{padding:8px 0 24px}
  .ufb-diagram__device{width:140px;height:140px}
  .ufb-benefits{grid-template-columns:1fr;gap:14px}
}

/* ============================================================
   BUSINESS / SERVICES
============================================================ */
.business{padding:140px 32px 120px;position:relative;overflow:hidden}
.business::before{content:"BUSINESS";position:absolute;right:-40px;top:80px;font-family:var(--display);font-weight:900;font-size:clamp(110px,15vw,220px);color:rgba(124,194,66,.06);letter-spacing:-.02em;line-height:1;pointer-events:none;writing-mode:horizontal-tb}
.services{display:grid;grid-template-columns:1fr 1fr;gap:32px;margin-top:48px}
.svc{background:#fff;border-radius:var(--radius-l);overflow:hidden;box-shadow:var(--shadow-soft);transition:all .4s;border:1px solid var(--line)}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--green-soft)}
.svc__img{aspect-ratio:16/9;background-size:cover;background-position:center;position:relative}
.svc__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.4))}
.svc__img-label{position:absolute;left:24px;bottom:18px;color:#fff;font-weight:800;font-size:18px;letter-spacing:.04em;z-index:1;display:flex;align-items:center;gap:10px}
.svc__img-label::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--green)}
.svc__body{padding:32px 32px 36px}
.svc__tag{font-family:var(--display);font-size:11px;letter-spacing:.18em;color:var(--green-deep);font-weight:700;margin-bottom:8px}
.svc__title{font-size:22px;font-weight:900;color:var(--ink);line-height:1.5;margin-bottom:18px;letter-spacing:.04em}
.svc__body p{font-size:14px;line-height:1.95;color:var(--ink-2);margin-bottom:24px}
.svc__metrics{display:flex;gap:18px;padding-top:18px;border-top:1px dashed var(--line);flex-wrap:wrap}
.svc__metric{display:flex;flex-direction:column}
.svc__metric strong{font-family:var(--display);font-size:24px;font-weight:800;color:var(--green-deep);line-height:1}
.svc__metric small{font-size:11px;color:var(--ink-3);margin-top:4px;letter-spacing:.04em}

/* ============================================================
   PRODUCT (Lineup)
============================================================ */
.product{padding:120px 32px;background:#fafbfc}
.product__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:48px}
.bore{background:#fff;border:1px solid var(--line);border-radius:var(--radius-l);padding:28px 22px 30px;text-align:center;transition:all .4s;position:relative}
.bore:hover{border-color:var(--green);transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.bore--feat{border-color:var(--green);background:linear-gradient(180deg,#fff,var(--green-bg))}
.bore__feat-tag{position:absolute;top:14px;right:14px;background:var(--green);color:#fff;font-size:10px;font-weight:700;padding:4px 10px;border-radius:3px;letter-spacing:.08em}
.bore__device{height:160px;display:grid;place-items:center;margin-bottom:14px}
.bore__device img{max-height:140px;width:auto;filter:drop-shadow(0 8px 20px rgba(0,0,0,.18))}
.bore__no{font-family:var(--display);font-size:38px;font-weight:800;color:var(--ink);letter-spacing:-.02em;line-height:1;margin-bottom:6px}
.bore__no small{font-size:.6em;color:var(--green-deep);font-weight:700;margin-left:2px}
.bore__title{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:10px;letter-spacing:.04em}
.bore__body{font-size:12.5px;line-height:1.85;color:var(--ink-2)}

/* ============================================================
   CASE STUDY (実例)
============================================================ */
.cases{padding:120px 32px;background:linear-gradient(180deg,#fff,var(--green-bg) 70%)}
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:40px}
.case{background:#fff;border-radius:var(--radius-l);overflow:hidden;box-shadow:var(--shadow-soft);transition:all .4s}
.case:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.case__img{aspect-ratio:4/3;background-size:cover;background-position:center}
.case__body{padding:24px 24px 28px}
.case__loc{font-size:11px;font-weight:700;color:var(--ink-3);letter-spacing:.1em;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.case__loc::before{content:"●";color:var(--green);font-size:8px}
.case__title{font-size:16px;font-weight:800;color:var(--ink);line-height:1.6;margin-bottom:14px}
.case__partner{font-size:12px;color:var(--ink-2);padding-top:14px;border-top:1px solid var(--line-soft);font-weight:600}
.case__metric{display:inline-block;background:var(--green);color:#fff;font-family:var(--display);font-weight:800;font-size:13px;padding:4px 12px;border-radius:3px;margin-bottom:10px;letter-spacing:.04em}

/* ============================================================
   TRUST BANNER
============================================================ */
.trust-bar{padding:64px 32px;background:#1a2024;color:#fff;position:relative;overflow:hidden}
.trust-bar__inner{max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap}
.trust-bar__head h3{font-size:22px;font-weight:900;letter-spacing:.06em;margin-bottom:8px}
.trust-bar__head p{font-size:13px;color:rgba(255,255,255,.7);line-height:1.85;max-width:480px}
.trust-badges{display:flex;gap:18px;flex-wrap:wrap}
.tbadge{padding:14px 18px;border:1px solid rgba(255,255,255,.18);border-radius:8px;text-align:center;min-width:110px}
.tbadge strong{display:block;font-family:var(--display);font-weight:800;font-size:14px;letter-spacing:.06em;color:#fff;line-height:1.3}
.tbadge small{display:block;font-size:10px;color:var(--green);margin-top:6px;letter-spacing:.1em;font-weight:600}

/* ============================================================
   RECRUIT-style CTA banner (parallax photo)
============================================================ */
.cta-banner{position:relative;padding:160px 32px;color:#fff;text-align:center;overflow:hidden;background:#163d22}
.cta-banner::before{content:"";position:absolute;inset:0;background-size:cover;background-position:center;background-image:linear-gradient(rgba(15,40,20,.55),rgba(15,40,20,.55)),url("https://images.unsplash.com/photo-1500382017468-9049fed747ef?w=2400&q=85")}
.cta-banner__inner{position:relative;z-index:1;max-width:880px;margin:0 auto}
.cta-banner__caption{font-family:var(--display);font-size:13px;letter-spacing:.24em;color:var(--green);font-weight:700;margin-bottom:18px}
.cta-banner__title{font-size:clamp(28px,4.4vw,52px);font-weight:900;line-height:1.4;letter-spacing:.04em;margin-bottom:36px;text-decoration:underline;text-decoration-color:#fff;text-underline-offset:14px;text-decoration-thickness:2px}

/* ============================================================
   CONTACT
============================================================ */
.contact{padding:120px 32px;background:#fff}
.contact__inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start}
.contact__lead h3{font-size:14.5px;line-height:2;color:var(--ink-2);font-weight:500}
.contact__lead h3 strong{color:var(--ink);font-weight:700}
.contact__row{display:flex;flex-direction:column;gap:22px}
.contact__block{padding:24px 28px;border:1px solid var(--line);border-radius:var(--radius-l);background:var(--bg-soft)}
.contact__block-tag{font-size:12px;font-weight:700;color:var(--ink);letter-spacing:.04em;margin-bottom:14px}
.contact__form-link{display:flex;justify-content:space-between;align-items:center;padding:16px 22px;background:#fff;border:1px solid var(--line);border-radius:999px;font-weight:700;color:var(--ink)}
.contact__form-link:hover{border-color:var(--green);color:var(--green-deep)}
.contact__form-link::after{content:"→";display:grid;place-items:center;width:28px;height:28px;border:1.5px solid currentColor;border-radius:50%;font-size:12px}
.contact__phone{display:flex;align-items:center;justify-content:flex-start;gap:12px;font-family:var(--display);font-weight:800;font-size:28px;color:var(--accent-red);margin:8px 0 4px;letter-spacing:.02em}
.contact__phone::before{content:"📞";font-size:22px;-webkit-text-fill-color:var(--accent-red)}
.contact__hours{font-size:12px;color:var(--ink-3);font-weight:500}
.contact__phone-block{margin-top:32px;padding:22px 26px;border:1px solid var(--line);border-radius:var(--radius-l);background:var(--bg-soft)}

/* ============================================================
   CONTACT FORM (cform)
============================================================ */
.cform{background:#fff;border:1px solid var(--line);border-radius:var(--radius-l);padding:36px 36px 32px;box-shadow:var(--shadow-soft)}
.cform__row{margin-bottom:20px}
.cform__row--split{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cform__label{display:block;font-size:13px;font-weight:700;color:var(--ink);margin-bottom:8px;letter-spacing:.04em}
.cform__req{display:inline-block;background:var(--accent-red);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:3px;margin-left:6px;letter-spacing:.06em;vertical-align:1px}
.cform__input,.cform__select,.cform__textarea{
  width:100%;padding:13px 16px;font-size:14px;font-family:inherit;
  background:#fff;color:var(--ink);
  border:1px solid var(--line);border-radius:8px;
  transition:border-color .25s,box-shadow .25s;
  -webkit-appearance:none;appearance:none;
}
.cform__input::placeholder,.cform__textarea::placeholder{color:var(--ink-3);font-size:13px}
.cform__input:focus,.cform__select:focus,.cform__textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(124,194,66,.16)}
.cform__textarea{resize:vertical;min-height:120px;line-height:1.7;font-family:inherit}
.cform__select-wrap{position:relative}
.cform__select-wrap::after{
  content:"";position:absolute;right:18px;top:50%;
  width:8px;height:8px;
  border-right:2px solid var(--ink-2);border-bottom:2px solid var(--ink-2);
  transform:translateY(-70%) rotate(45deg);
  pointer-events:none;
}
.cform__select{padding-right:42px;cursor:pointer}
.cform__policy{margin:24px 0 22px;padding:14px 16px;background:var(--bg-soft);border:1px solid var(--line-soft);border-radius:8px}
.cform__check{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:13px;color:var(--ink-2);font-weight:500}
.cform__check input[type=checkbox]{
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;border:2px solid var(--ink-3);border-radius:4px;
  cursor:pointer;flex-shrink:0;position:relative;transition:.2s;background:#fff;
}
.cform__check input[type=checkbox]:checked{background:var(--green);border-color:var(--green)}
.cform__check input[type=checkbox]:checked::after{
  content:"";position:absolute;left:4px;top:0px;width:6px;height:11px;
  border-right:2px solid #fff;border-bottom:2px solid #fff;
  transform:rotate(45deg);
}
.cform__check a{color:var(--green-deep);text-decoration:underline;font-weight:600}
.cform__submit-wrap{text-align:center;margin-top:8px}
.cform__submit{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 36px 18px 42px;
  background:var(--green);color:#fff;font-weight:800;font-size:15px;letter-spacing:.06em;
  border:none;border-radius:999px;cursor:pointer;
  transition:all .3s;box-shadow:0 12px 26px rgba(124,194,66,.3);
  font-family:inherit;
}
.cform__submit:hover{background:var(--green-deep);transform:translateY(-2px);box-shadow:0 18px 36px rgba(95,168,38,.4)}
.cform__submit-arrow{display:grid;place-items:center;width:28px;height:28px;border:1.5px solid #fff;border-radius:50%;font-size:13px;transition:transform .3s}
.cform__submit:hover .cform__submit-arrow{transform:rotate(-45deg)}

/* ============================================================
   FOOTER  ─ light, clean
============================================================ */
.footer{background:#fafbfc;color:var(--ink-2);padding:72px 32px 28px;border-top:1px solid var(--line)}
.footer__inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr;gap:56px;align-items:start}
.footer__brand{display:flex;align-items:center;gap:14px;margin-bottom:18px;color:var(--ink)}
.footer__brand strong{font-size:18px;font-weight:800;letter-spacing:.04em}
.footer__addr{font-size:13px;line-height:1.95;color:var(--ink-2)}
.footer__addr a{color:var(--green-deep);text-decoration:underline;font-weight:600}
.footer__nav{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.footer__nav h5{font-size:11px;font-weight:700;color:var(--ink);margin-bottom:16px;letter-spacing:.18em;font-family:var(--display)}
.footer__nav ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:13.5px}
.footer__nav a{color:var(--ink-2);display:inline-flex;align-items:center;gap:8px;font-weight:500}
.footer__nav a::before{content:"";width:6px;height:6px;border-radius:50%;border:1px solid var(--ink-3);transition:all .25s;flex-shrink:0}
.footer__nav a:hover{color:var(--green-deep)}
.footer__nav a:hover::before{background:var(--green);border-color:var(--green)}

/* Powered-by block */
.footer__powered{margin-top:48px;padding-top:32px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.footer__powered-label{font-size:11px;letter-spacing:.18em;color:var(--ink-3);font-weight:600;font-family:var(--display);text-transform:uppercase}
.footer__powered-link{display:flex;align-items:center;gap:14px;transition:opacity .25s}
.footer__powered-link:hover{opacity:.7}
.footer__powered-logo{height:32px;width:auto;display:block}
.footer__powered-text{font-size:12px;color:var(--ink-3);font-weight:500;letter-spacing:.04em;text-decoration:none}

.footer__bottom{margin-top:24px;padding-top:18px;font-size:11px;letter-spacing:.04em;color:var(--ink-3);text-align:center;font-family:var(--display)}

/* ============================================================
   PAGE HEADER (subpages)
============================================================ */
.page-hero{padding:calc(var(--header-h) + 60px) 32px 80px;background:var(--green-bg);position:relative;overflow:hidden}
.page-hero::before{content:attr(data-en);position:absolute;right:-30px;bottom:-40px;font-family:var(--display);font-weight:900;font-size:clamp(110px,15vw,200px);color:rgba(124,194,66,.13);letter-spacing:-.02em;line-height:1;pointer-events:none}
.page-hero__inner{position:relative;max-width:1280px;margin:0 auto}
.page-hero h1{font-size:clamp(32px,4.4vw,52px);font-weight:900;color:var(--ink);letter-spacing:.04em;display:flex;align-items:center;gap:14px}
.page-hero h1::after{content:"";width:18px;height:22px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 32' fill='%237cc242'><path d='M12 2c-5 4-7 9-7 14 0 7 5 14 7 14 2 0 7-7 7-14 0-5-2-10-7-14z'/></svg>") center/contain no-repeat}
.page-hero__caption{font-family:var(--display);font-size:13px;letter-spacing:.24em;color:var(--accent-red);font-weight:700;margin-top:6px}
.page-hero p{font-size:15px;line-height:2;color:var(--ink-2);max-width:680px;margin-top:24px}

/* ============================================================
   ABOUT subpage tables
============================================================ */
.company-info{margin-top:48px;background:#fff;border-radius:var(--radius-l);overflow:hidden;box-shadow:var(--shadow-soft);border:1px solid var(--line)}
.company-info dl{margin:0}
.company-info dl > div{display:grid;grid-template-columns:200px 1fr;gap:32px;padding:22px 32px;border-bottom:1px solid var(--line-soft)}
.company-info dl > div:last-child{border-bottom:0}
.company-info dt{font-weight:700;color:var(--ink);font-size:14px;letter-spacing:.04em}
.company-info dd{font-size:14px;line-height:1.85;color:var(--ink-2)}

.timeline{display:flex;flex-direction:column;margin-top:40px;position:relative}
.timeline::before{content:"";position:absolute;left:80px;top:14px;bottom:14px;width:2px;background:var(--green-soft)}
.t-item{display:grid;grid-template-columns:80px 24px 1fr;gap:0;padding:16px 0;align-items:flex-start}
.t-item__year{font-family:var(--display);font-weight:800;font-size:18px;color:var(--green-deep);letter-spacing:.04em}
.t-item__dot{position:relative;display:grid;place-items:center}
.t-item__dot::before{content:"";width:12px;height:12px;border-radius:50%;background:#fff;border:2px solid var(--green);box-shadow:0 0 0 4px #fff}
.t-item__body{padding-left:24px}
.t-item__body h4{font-size:15px;font-weight:800;color:var(--ink);margin-bottom:6px}
.t-item__body p{font-size:13px;line-height:1.85;color:var(--ink-2)}

/* ============================================================
   COLUMN PAGE
============================================================ */
.cols{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}
.col-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-l);overflow:hidden;transition:all .4s;display:flex;flex-direction:column}
.col-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft);border-color:var(--green-soft)}
.col-card__img{aspect-ratio:16/10;background-size:cover;background-position:center;transition:transform 1s}
.col-card:hover .col-card__img{transform:scale(1.05)}
.col-card__body{padding:24px 26px 28px;display:flex;flex-direction:column;flex:1}
.col-card__meta{display:flex;gap:14px;align-items:center;font-size:11px;letter-spacing:.1em;color:var(--green-deep);font-weight:700;margin-bottom:12px}
.col-card__meta time{color:var(--ink-3);font-weight:500;font-family:var(--display)}
.col-card__title{font-size:16px;font-weight:800;color:var(--ink);line-height:1.65;margin-bottom:12px;flex:1}
.col-card__excerpt{font-size:13px;line-height:1.85;color:var(--ink-2);margin-bottom:18px}
.col-card__more{font-size:11px;letter-spacing:.12em;color:var(--ink);font-weight:700;display:inline-flex;align-items:center;gap:8px;margin-top:auto}
.col-card__more::after{content:"→";transition:transform .3s}
.col-card:hover .col-card__more::after{transform:translateX(4px)}

/* ============================================================
   ARTICLE PAGE
============================================================ */
.article{padding:calc(var(--header-h) + 40px) 32px 80px;max-width:880px;margin:0 auto}
.article__meta{display:flex;gap:14px;align-items:center;font-size:11px;letter-spacing:.12em;color:var(--green-deep);font-weight:700;margin-bottom:18px}
.article__meta time{color:var(--ink-3);font-weight:500;font-family:var(--display)}
.article h1{font-size:clamp(24px,3vw,36px);font-weight:900;color:var(--ink);line-height:1.55;margin-bottom:24px;letter-spacing:.02em}
.article__hero{aspect-ratio:16/9;background-size:cover;background-position:center;border-radius:var(--radius-l);margin-bottom:40px}
.article__body{font-size:15px;line-height:2.05;color:var(--ink)}
.article__body h2{font-size:22px;font-weight:900;color:var(--ink);margin:42px 0 16px;padding-left:16px;border-left:4px solid var(--green);letter-spacing:.04em}
.article__body h3{font-size:17px;font-weight:800;color:var(--ink);margin:30px 0 10px}
.article__body p{margin-bottom:22px;color:var(--ink-2)}
.article__body ul,.article__body ol{margin:0 0 24px 22px;color:var(--ink-2)}
.article__body li{margin-bottom:8px;line-height:1.95}
.article__body blockquote{margin:30px 0;padding:24px 28px;background:var(--green-bg);border-left:3px solid var(--green);border-radius:0 var(--radius) var(--radius) 0;font-size:15px;line-height:1.85;color:var(--ink)}
.article__body strong{color:var(--ink);font-weight:700}
.article__body a{color:var(--green-deep);text-decoration:underline}
.article__back{margin-top:60px;padding-top:32px;border-top:1px solid var(--line)}

/* ============================================================
   ANIMATIONS  ─ Awwwards-tier
============================================================ */
:root{
  --ease-out-quart:cubic-bezier(.25,1,.5,1);
  --ease-out-expo:cubic-bezier(.16,1,.3,1);
  --ease-out-back:cubic-bezier(.34,1.56,.64,1);
}

/* Generic fade up (default) */
.reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity 1s var(--ease-out-quart),transform 1s var(--ease-out-quart);
  will-change:opacity,transform;
}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal--delay-1{transition-delay:.08s}
.reveal--delay-2{transition-delay:.18s}
.reveal--delay-3{transition-delay:.28s}
.reveal--delay-4{transition-delay:.38s}

/* Wipe up reveal — clip-path bottom→top mask */
.reveal-wipe{
  opacity:0;
  clip-path:inset(0 0 100% 0);
  transition:opacity 1.1s var(--ease-out-expo),clip-path 1.1s var(--ease-out-expo);
}
.reveal-wipe.visible{opacity:1;clip-path:inset(0 0 0 0)}

/* Wipe left → right (for headlines) */
.reveal-wipe-x{
  opacity:0;
  clip-path:inset(0 100% 0 0);
  transition:opacity 1.2s var(--ease-out-expo),clip-path 1.2s var(--ease-out-expo);
}
.reveal-wipe-x.visible{opacity:1;clip-path:inset(0 0 0 0)}

/* Image scale-in with mask */
.reveal-img{
  position:relative;overflow:hidden;
  clip-path:inset(0 0 100% 0);
  transition:clip-path 1.2s var(--ease-out-expo);
}
.reveal-img.visible{clip-path:inset(0 0 0 0)}
.reveal-img img,.reveal-img > [class*="__img"]{
  transform:scale(1.15);
  transition:transform 1.4s var(--ease-out-quart);
}
.reveal-img.visible img,.reveal-img.visible > [class*="__img"]{transform:scale(1)}

/* Stagger children — relies on --i custom prop set by JS */
.stagger > *{
  opacity:0;transform:translateY(24px);
  transition:opacity .9s var(--ease-out-quart),transform .9s var(--ease-out-quart);
  transition-delay:calc(var(--i,0) * 80ms);
}
.stagger.visible > *{opacity:1;transform:translateY(0)}

/* Count-up wrapper — pulses subtly when finishing */
.count-up{display:inline-block;font-variant-numeric:tabular-nums}
.count-up.is-done{animation:countDone .6s var(--ease-out-back)}
@keyframes countDone{0%{transform:scale(1)}40%{transform:scale(1.06)}100%{transform:scale(1)}}

/* Hero entrance — runs once on body.is-loaded */
.hero__eyebrow,.hero__title .hero__line,.hero__sub,.hero__cta>*{
  opacity:0;transform:translateY(28px);
  transition:opacity 1s var(--ease-out-expo),transform 1s var(--ease-out-expo);
}
body.is-loaded .hero__eyebrow{opacity:1;transform:translateY(0);transition-delay:.1s}
body.is-loaded .hero__title .hero__line:nth-child(1){opacity:1;transform:translateY(0);transition-delay:.25s}
body.is-loaded .hero__title .hero__line:nth-child(2){opacity:1;transform:translateY(0);transition-delay:.4s}
body.is-loaded .hero__sub{opacity:1;transform:translateY(0);transition-delay:.55s}
body.is-loaded .hero__cta>*:nth-child(1){opacity:1;transform:translateY(0);transition-delay:.7s}
body.is-loaded .hero__cta>*:nth-child(2){opacity:1;transform:translateY(0);transition-delay:.85s}

/* Hero photo slow zoom */
.hero__bg::before{transform:scale(1.06);transition:transform 4s var(--ease-out-quart)}
body.is-loaded .hero__bg::before{transform:scale(1)}

/* Header slide-down */
.site-header{transform:translateY(-100%);transition:transform 1s var(--ease-out-expo) .6s,background .3s,box-shadow .3s,padding .3s}
body.is-loaded .site-header{transform:translateY(0)}

/* Trust strip slide-up */
.trust-strip{opacity:0;transform:translateY(20px);transition:opacity .9s var(--ease-out-quart) 1.4s,transform .9s var(--ease-out-quart) 1.4s}
body.is-loaded .trust-strip{opacity:1;transform:translateY(0)}

/* Section heading bullet — animated leaf */
.section-heading__title h2::after{
  transform-origin:bottom center;
  transform:scale(0);
  transition:transform .7s var(--ease-out-back) .35s;
}
.section-heading__title.visible h2::after,
.reveal.visible h2::after{transform:scale(1)}

/* Buttons — micro arrow shift */
.link-arrow::after,.btn-pill::after,.contact__form-link::after{transition:transform .4s var(--ease-out-quart),background .3s,border-color .3s,color .3s}
.link-arrow:hover::after{transform:rotate(-45deg) scale(1.04)}
.btn-pill:hover::after{transform:rotate(-45deg)}

/* News list row hover — slide in arrow */
.news__list a{transition:background .3s}
.news__list a:hover .news__title{color:var(--green-deep);transition:color .3s}
.news__list .news__arrow{transition:all .35s var(--ease-out-quart)}
.news__list a:hover .news__arrow{transform:rotate(-45deg)}

/* Card hover lift refinement */
.svc,.case,.bore,.col-card,.ufb-benefit{transition:transform .55s var(--ease-out-quart),box-shadow .55s var(--ease-out-quart),border-color .35s}

/* Marquee speed (already exists) — no change */

/* MV device gentle float */
.mv__device,.largebore__device img{
  animation:floatY 6s ease-in-out infinite;
}
@keyframes floatY{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}

/* Reduced motion — respect user pref */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    transition-delay:0ms !important;
  }
  .loader{transition:opacity .2s}
}

/* ============================================================
   i18n (JP / EN toggle)
============================================================ */
[data-lang="ja"] [data-i18n="en"]{display:none !important}
[data-lang="en"] [data-i18n="ja"]{display:none !important}

/* ============================================================
   LOADER  ─ cinematic
============================================================ */
.loader{
  position:fixed;inset:0;background:#fff;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  transition:clip-path 1s cubic-bezier(.76,0,.24,1) .25s,opacity .5s;
  clip-path:inset(0 0 0 0);
}
.loader.is-out{clip-path:inset(50% 0 50% 0)}
.loader.hidden{visibility:hidden;pointer-events:none;opacity:0}
.loader::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(124,194,66,.06),transparent 60%);
  pointer-events:none;
}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:30px;position:relative}
.loader__bubble-stack{
  position:relative;width:84px;height:84px;
}
.loader__bubble-stack span{
  position:absolute;inset:0;border-radius:50%;
  background:radial-gradient(circle at 35% 32%,rgba(255,255,255,.95),var(--green) 55%,var(--green-deep));
  box-shadow:0 12px 32px rgba(95,168,38,.32);
  opacity:0;
  animation:loaderBubble 2.2s cubic-bezier(.25,.46,.45,.94) infinite;
}
.loader__bubble-stack span:nth-child(1){animation-delay:0s}
.loader__bubble-stack span:nth-child(2){animation-delay:.55s}
.loader__bubble-stack span:nth-child(3){animation-delay:1.1s}
.loader__bubble-stack span:nth-child(4){animation-delay:1.65s}
@keyframes loaderBubble{
  0%{transform:scale(.2);opacity:0}
  20%{opacity:.95}
  100%{transform:scale(1.6);opacity:0}
}
.loader__name{
  display:flex;gap:1px;font-size:18px;font-weight:800;
  color:var(--ink);letter-spacing:.16em;
}
.loader__name span{
  display:inline-block;opacity:0;transform:translateY(8px);
  animation:loaderChar .6s cubic-bezier(.25,.46,.45,.94) forwards;
}
.loader__name span:nth-child(1){animation-delay:.05s}
.loader__name span:nth-child(2){animation-delay:.12s}
.loader__name span:nth-child(3){animation-delay:.19s}
.loader__name span:nth-child(4){animation-delay:.26s}
.loader__name span:nth-child(5){animation-delay:.33s}
.loader__name span:nth-child(6){animation-delay:.40s}
.loader__name span:nth-child(7){animation-delay:.47s}
.loader__name span:nth-child(8){animation-delay:.54s}
.loader__name span:nth-child(9){animation-delay:.61s}
.loader__name span:nth-child(10){animation-delay:.68s}
.loader__name span:nth-child(11){animation-delay:.75s}
.loader__name span:nth-child(12){animation-delay:.82s}
@keyframes loaderChar{
  to{opacity:1;transform:translateY(0)}
}
.loader__bar{
  width:160px;height:2px;background:var(--line);border-radius:2px;overflow:hidden;
}
.loader__bar i{
  display:block;height:100%;width:0;
  background:linear-gradient(90deg,var(--green),var(--green-deep));
  animation:loaderBar 1.4s cubic-bezier(.6,0,.4,1) forwards;
}
@keyframes loaderBar{0%{width:0}100%{width:100%}}

/* ============================================================
   RESPONSIVE  ─ tablet (≤1320px): hide nav, keep rail with hamburger
============================================================ */
@media(max-width:1080px){
  .nav{display:none}
  :root{--rail:90px}
  /* show a small hamburger in header tail too on tablet */
  .header-mob-toggle{
    display:grid;place-items:center;
    width:48px;height:48px;
    background:linear-gradient(135deg,var(--green) 0%,var(--green-deep) 100%);
    border:none;cursor:pointer;color:#fff;flex-shrink:0;border-radius:6px;
  }
  .header-mob-toggle__lines{display:flex;flex-direction:column;gap:5px;width:20px}
  .header-mob-toggle__lines span{height:2px;background:#fff;border-radius:2px;display:block}
}

/* ============================================================
   RESPONSIVE  ─ mobile (≤780px): rail hidden, top-right hamburger
============================================================ */
@media(max-width:780px){
  :root{--header-h:64px;--rail:0px}
  body{padding-left:0}

  /* hide left rail entirely */
  .rail{display:none}

  /* full-width header: small logo left + small lang + green hamburger right */
  .site-header{padding:0 0 0 14px;height:var(--header-h)}
  .site-header.is-hero-top{background:rgba(255,255,255,.96);backdrop-filter:blur(14px)}
  .site-header.is-hero-top .brand,
  .site-header.is-hero-top .nav a{color:var(--ink)}
  .site-header.is-hero-top .brand-leaf{filter:none}
  .site-header.is-hero-top .lang-switch{border-color:var(--line);color:var(--ink-2);background:#fff}
  .site-header.is-hero-top .btn-contact{display:none}
  .site-header.is-hero-top .lang-switch__opt.is-on{color:var(--green-deep)}
  .site-header.is-hero-top .nav a::after{background:transparent}

  .brand{font-size:14px;gap:8px}
  .brand-leaf{width:30px;height:30px}
  .brand__txt small{font-size:9px}

  .nav{display:none}

  .header-tail{gap:8px;height:100%}
  .lang-switch{font-size:10px;padding:5px 9px}
  .btn-contact{display:none}

  /* Mobile hamburger: large green square at top-right */
  .header-mob-toggle{
    display:grid;place-items:center;
    width:var(--header-h);height:var(--header-h);
    background:linear-gradient(135deg,var(--green) 0%,var(--green-deep) 100%);
    border:none;cursor:pointer;color:#fff;flex-shrink:0;
  }
  .header-mob-toggle__lines{display:flex;flex-direction:column;gap:6px;width:24px}
  .header-mob-toggle__lines span{height:2px;background:#fff;border-radius:2px;display:block}

  /* sections */
  .section{padding:64px 22px}
  .news{padding:52px 22px 24px}
  .business,.cases,.contact,.product{padding:64px 22px}
  .about{padding:64px 22px}
  .about__inner{grid-template-columns:1fr;gap:30px}
  .about__copy h3{font-size:18px}
  .services{grid-template-columns:1fr;gap:22px}
  .product__grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .case-grid,.cols{grid-template-columns:1fr;gap:18px}
  .contact__inner{grid-template-columns:1fr;gap:32px}
  .cform{padding:24px 22px}
  .cform__row--split{grid-template-columns:1fr;gap:18px}
  .footer__inner{grid-template-columns:1fr;gap:30px}
  .footer__nav{grid-template-columns:1fr 1fr}
  .cta-banner{padding:80px 22px}
  .trust-bar{padding:42px 22px}
  .trust-bar__inner{flex-direction:column;align-items:flex-start;gap:24px}
  .trust-badges{gap:10px}
  .tbadge{padding:10px 12px;min-width:80px}
  .tbadge strong{font-size:12px}
  .tbadge small{font-size:9px}

  /* News list — stack on mobile */
  .news__list li{grid-template-columns:1fr;gap:6px;padding:18px 0;align-items:start}
  .news__list time{font-size:12px}
  .news__tag{justify-self:start;font-size:10px;padding:3px 9px}
  .news__title{font-size:13px;line-height:1.7}
  .news__arrow{display:none}

  /* Hero */
  .hero{height:auto;min-height:100svh;padding:calc(var(--header-h) + 40px) 22px 80px;align-items:center}
  .hero__inner{padding-top:0}
  .hero__eyebrow{font-size:11px;padding:6px 12px;margin-bottom:16px}
  .hero__title{gap:6px;margin-bottom:20px}
  .hero__line{font-size:30px;padding:5px 14px 7px;line-height:1.2}
  .hero__sub{font-size:12px;line-height:1.7;margin-bottom:28px}
  .hero__scroll{display:none}

  /* Section headings */
  .section-heading{flex-direction:column;gap:16px;margin-bottom:36px}
  .section-heading__title h2{font-size:24px}
  .section-heading__lead{font-size:13.5px;padding-top:0}
  .section-heading__more{margin-top:0}

  /* SVC card */
  .svc__body{padding:22px}
  .svc__title{font-size:18px}
  .svc__metrics{gap:14px}
  .svc__metric strong{font-size:20px}

  /* BORE card */
  .bore{padding:22px 16px 24px}
  .bore__device{height:120px;margin-bottom:10px}
  .bore__device img{max-height:108px}
  .bore__no{font-size:30px}
  .bore__title{font-size:13px}
  .bore__body{font-size:12px;line-height:1.7}
  .bore__feat-tag{font-size:9px;padding:3px 7px;top:10px;right:10px}

  /* CASE card */
  .case__body{padding:18px}
  .case__title{font-size:15px}

  /* CTA banner */
  .cta-banner__caption{font-size:11px}
  .cta-banner__title{font-size:24px;text-underline-offset:8px}

  /* Contact */
  .contact__lead h3{font-size:13px;line-height:1.95;margin-top:18px !important}
  .contact__block{padding:18px 20px}
  .contact__phone{font-size:24px}

  /* Page hero */
  .page-hero{padding:calc(var(--header-h) + 32px) 22px 56px}
  .page-hero h1{font-size:28px;gap:10px}
  .page-hero h1::after{width:14px;height:18px}
  .page-hero p{font-size:13.5px;margin-top:18px}

  /* Article */
  .article{padding:calc(var(--header-h) + 24px) 22px 60px}
  .article h1{font-size:22px}
  .article__hero{aspect-ratio:16/10;margin-bottom:28px}
  .article__body{font-size:14px}
  .article__body h2{font-size:18px;margin:32px 0 12px}

  /* Company info */
  .company-info dl > div{grid-template-columns:1fr;gap:6px;padding:16px 20px}
  .timeline::before{left:24px;top:16px;bottom:16px}
  .t-item{grid-template-columns:48px 20px 1fr}
  .t-item__year{font-size:14px}

  /* Drawer */
  .drawer__inner{padding:120px 28px 60px}
  .drawer__list a{font-size:24px;gap:14px}
  .drawer__list a small{font-size:9px}
  .drawer__close{top:18px;right:22px;font-size:11px;padding:8px 14px}

  /* btn-pill */
  .btn-pill{padding:14px 22px 14px 26px;font-size:12.5px}
  .btn-pill::after{width:26px;height:26px;font-size:12px}
}

/* tiny phones */
@media(max-width:380px){
  .product__grid{grid-template-columns:1fr}
  .footer__nav{grid-template-columns:1fr}
  .hero__line{font-size:26px}
}

/* ============================================================
   ─ Final polish utilities
============================================================ */

/* Registered trademark mark for UFB DUAL */
sup.r-mark{
  font-size:.55em;
  font-weight:500;
  vertical-align:baseline;
  line-height:1;
  letter-spacing:0;
  color:inherit;
  margin:0 0 0 -.06em;
  padding:0;
  opacity:.75;
  font-family:inherit;
  font-style:normal;
  display:inline-block;
  position:relative;
  top:-.55em;
}

/* Trust strip under hero */
.trust-strip{
  background:#fff;
  border-bottom:1px solid var(--line);
  padding:18px 32px;
}
.trust-strip__inner{
  max-width:1280px;margin:0 auto;
  display:flex;justify-content:center;align-items:center;gap:36px;flex-wrap:wrap;
}
.trust-strip__item{
  display:inline-flex;align-items:center;gap:10px;
  font-size:13px;font-weight:600;color:var(--ink-2);
  letter-spacing:.02em;
}
.trust-strip__item::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--green);flex-shrink:0;
}
.trust-strip__item strong{color:var(--ink);font-weight:800}
@media(max-width:780px){
  .trust-strip{padding:12px 0}
  .trust-strip__inner{gap:18px;justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0 18px}
  .trust-strip__item{font-size:11.5px;white-space:nowrap;flex-shrink:0}
}

/* Floating CTA — appears after hero scroll */
.floating-cta{
  position:fixed;
  right:calc(var(--rail) + 24px);
  bottom:28px;
  z-index:90;
  display:flex;flex-direction:column;align-items:flex-end;gap:10px;
  opacity:0;visibility:hidden;transform:translateY(12px);
  transition:opacity .35s ease,transform .35s ease,visibility .35s;
  pointer-events:none;
}
.floating-cta.is-visible{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}
.floating-cta__main{
  display:inline-flex;align-items:center;gap:12px;
  padding:14px 22px 14px 26px;border-radius:999px;
  background:var(--green);color:#fff;font-weight:800;font-size:14px;letter-spacing:.04em;
  box-shadow:0 18px 36px rgba(95,168,38,.36);
  transition:all .25s;
}
.floating-cta__main:hover{background:var(--green-deep);transform:translateY(-2px)}
.floating-cta__main::after{content:"→";display:grid;place-items:center;width:26px;height:26px;border:1.5px solid #fff;border-radius:50%;font-size:13px}
.floating-cta__phone{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 16px;border-radius:999px;
  background:#fff;color:var(--accent-red);font-weight:800;font-size:13px;
  border:1px solid var(--line);box-shadow:var(--shadow-soft);
}
.floating-cta__phone::before{content:"📞";font-size:14px}

/* SP-only sticky bottom bar */
.mob-cta-bar{
  display:none;
  position:fixed;left:0;right:0;bottom:0;z-index:80;
  background:rgba(255,255,255,.96);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);
  padding:10px 12px calc(10px + env(safe-area-inset-bottom,0px));
  gap:8px;
}
.mob-cta-bar a{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 12px;border-radius:999px;font-weight:800;font-size:13px;letter-spacing:.02em;
  white-space:nowrap;
}
.mob-cta-bar__phone{background:#fff;color:var(--accent-red);border:1.5px solid var(--accent-red)}
.mob-cta-bar__phone::before{content:"📞"}
.mob-cta-bar__form{background:var(--green);color:#fff;box-shadow:0 8px 18px rgba(124,194,66,.3)}
.mob-cta-bar__form::after{content:"→";display:grid;place-items:center;width:22px;height:22px;border:1.5px solid #fff;border-radius:50%;font-size:11px}
@media(max-width:780px){
  .mob-cta-bar{display:flex}
  body{padding-bottom:74px}
  .floating-cta{display:none}
}

/* ============================================================
   UFB DUAL page — figures & diagrams
============================================================ */
.ud-hero-fig{margin:0 0 40px;text-align:center}
.ud-hero-fig__img{max-width:520px;width:100%;height:auto;display:inline-block}
.ud-hero-fig figcaption{margin-top:14px;color:var(--ink-2);font-size:13px;letter-spacing:.02em}

/* Bubble scale */
.ud-bubble-scale{margin:32px 0 48px;padding:32px 24px;background:var(--bg-soft);border-radius:18px}
.ud-bubble-scale__title{font-size:13px;font-weight:800;letter-spacing:.12em;color:var(--ink-2);text-transform:uppercase;text-align:center;margin-bottom:28px}
.ud-bubble-scale__row{display:flex;align-items:flex-end;justify-content:space-around;gap:16px;flex-wrap:wrap}
.ud-bub{flex:1 1 180px;min-width:160px;text-align:center;padding:8px 4px}
.ud-bub__circle{margin:0 auto 14px;border-radius:50%;background:radial-gradient(circle at 32% 32%, #cfe6f7 0%, #7cb6e0 60%, #5a9bcf 100%);box-shadow:inset -3px -4px 8px rgba(0,0,0,.12),0 6px 20px rgba(60,120,180,.18)}
.ud-bub__circle--lg{width:120px;height:120px}
.ud-bub__circle--md{width:80px;height:80px}
.ud-bub__circle--sm{width:36px;height:36px;background:radial-gradient(circle at 32% 32%, #d8efbf 0%, #7cc242 60%, #5fa826 100%);box-shadow:inset -2px -3px 5px rgba(0,0,0,.14),0 6px 16px rgba(124,194,66,.35)}
.ud-bub__name{font-weight:800;font-size:14px;color:var(--ink);margin-bottom:4px}
.ud-bub__size{font-family:Inter,sans-serif;font-size:13px;color:var(--green-deep);font-weight:700;letter-spacing:.02em;margin-bottom:6px}
.ud-bub__note{font-size:12px;color:var(--ink-2);line-height:1.5}
.ud-bub--feature .ud-bub__name{color:var(--green-deep)}

/* Mechanism cards */
.ud-mech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:32px 0 40px}
.ud-mech{background:#fff;border:1px solid var(--line-soft);border-radius:16px;padding:28px 24px;position:relative;transition:transform .25s ease, box-shadow .25s ease}
.ud-mech:hover{transform:translateY(-3px);box-shadow:0 18px 38px rgba(20,40,16,.08)}
.ud-mech__num{font-family:Inter,sans-serif;font-size:11px;font-weight:800;letter-spacing:.18em;color:var(--green-deep);background:var(--green-soft);display:inline-block;padding:5px 10px;border-radius:4px;margin-bottom:14px}
.ud-mech__icon{width:64px;height:64px;display:block;margin-bottom:14px}
.ud-mech h3{font-size:18px;line-height:1.45;margin:0 0 12px;color:var(--ink)}
.ud-mech p{font-size:14px;line-height:1.8;color:var(--ink-2);margin:0}
.ud-mech p strong{color:var(--ink)}

/* Pipe diagram */
.ud-pipe-diagram{margin:32px 0 48px;padding:28px 20px;background:linear-gradient(180deg,#f4faec 0%, #fff 100%);border-radius:18px;border:1px solid var(--line-soft)}
.ud-pipe-diagram__title{font-size:13px;font-weight:800;letter-spacing:.1em;color:var(--ink-2);text-transform:uppercase;text-align:center;margin-bottom:18px}
.ud-pipe-diagram__svg-wrap{max-width:760px;margin:0 auto;overflow-x:auto}
.ud-pipe-diagram svg{width:100%;height:auto;min-width:600px;display:block}

/* Certification badges */
.ud-certs{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0 32px}
.ud-cert{background:#fff;border:1px solid var(--line-soft);border-radius:14px;padding:20px 14px;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:130px}
.ud-cert__mark{font-family:Inter,sans-serif;font-size:22px;font-weight:900;letter-spacing:.04em;color:var(--green-deep);background:var(--green-soft);width:78px;height:78px;border-radius:50%;display:grid;place-items:center;margin-bottom:12px;border:2px solid var(--green)}
.ud-cert__mark--small{font-size:14px;letter-spacing:.02em}
.ud-cert__label{font-size:12px;color:var(--ink-2);font-weight:700;line-height:1.5}

/* Stat cards */
.ud-stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:24px 0 32px}
.ud-stat{background:#fff;border:1px solid var(--line-soft);border-radius:16px;padding:28px 24px;display:flex;flex-direction:column;gap:8px;border-left:4px solid var(--green)}
.ud-stat__num{font-family:Inter,sans-serif;font-size:42px;font-weight:900;line-height:1;color:var(--green-deep);letter-spacing:-.01em}
.ud-stat__crop{font-size:13px;font-weight:800;color:var(--ink);letter-spacing:.04em;text-transform:uppercase;margin-top:4px}
.ud-stat__desc{font-size:14px;line-height:1.7;color:var(--ink-2);margin:0}

/* Lineup */
.ud-lineup{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0 32px}
.ud-lineup__card{background:#fff;border:1px solid var(--line-soft);border-radius:14px;padding:24px 16px 20px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}
.ud-lineup__card img{width:100%;max-width:140px;height:120px;object-fit:contain;margin-bottom:8px}
.ud-lineup__bore{font-family:Inter,sans-serif;font-size:24px;font-weight:900;color:var(--ink);letter-spacing:.02em;line-height:1}
.ud-lineup__use{font-size:13px;font-weight:700;color:var(--green-deep);margin-top:2px}
.ud-lineup__desc{font-size:12px;color:var(--ink-2);line-height:1.5;margin-top:4px}
.ud-lineup__badge{position:absolute;top:10px;right:10px;background:var(--green);color:#fff;font-size:10px;font-weight:800;letter-spacing:.06em;padding:4px 9px;border-radius:999px;text-transform:uppercase}
.ud-lineup__card--standard{border-color:var(--green);box-shadow:0 12px 30px rgba(124,194,66,.12)}
.ud-lineup__card--flagship{border:2px solid var(--green-deep);box-shadow:0 14px 36px rgba(95,168,38,.18)}
.ud-lineup__card--flagship .ud-lineup__badge{background:var(--green-deep)}

/* Install flow */
.ud-flow{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0 32px;padding:0;list-style:none;counter-reset:none}
.ud-flow li{background:var(--bg-soft);border-radius:14px;padding:24px 20px;position:relative;border-top:3px solid var(--green)}
.ud-flow__step{font-family:Inter,sans-serif;font-size:11px;font-weight:800;letter-spacing:.18em;color:var(--green-deep);margin-bottom:10px}
.ud-flow li h4{font-size:15px;margin:0 0 8px;color:var(--ink)}
.ud-flow li p{font-size:13px;line-height:1.65;color:var(--ink-2);margin:0}

/* Mobile */
@media(max-width:880px){
  .ud-mech-grid{grid-template-columns:1fr;gap:14px}
  .ud-certs{grid-template-columns:repeat(2,1fr)}
  .ud-stat-grid{grid-template-columns:1fr}
  .ud-lineup{grid-template-columns:repeat(2,1fr)}
  .ud-flow{grid-template-columns:1fr 1fr;gap:12px}
}
@media(max-width:520px){
  .ud-bub__circle--lg{width:96px;height:96px}
  .ud-bub__circle--md{width:64px;height:64px}
  .ud-flow{grid-template-columns:1fr}
  .ud-stat__num{font-size:36px}
}

/* ============================================================
   Subsidies / Compare / Patent pages — components
============================================================ */

/* Callout note (subsidy disclaimer) */
.callout-note{background:#fef9e7;border-left:4px solid #d4a017;border-radius:8px;padding:18px 22px;margin:0 0 36px;font-size:13px;line-height:1.8;color:var(--ink-2)}
.callout-note p{margin:0}

/* Subsidy grid */
.subsidy-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:24px 0 40px}
.subsidy-card{background:#fff;border:1px solid var(--line-soft);border-radius:14px;padding:24px 22px;display:flex;flex-direction:column;gap:8px;border-top:3px solid var(--green)}
.subsidy-card__tag{font-family:Inter,sans-serif;font-size:10px;font-weight:800;letter-spacing:.18em;color:var(--green-deep);background:var(--green-soft);display:inline-block;padding:5px 10px;border-radius:4px;margin-bottom:6px;text-transform:uppercase;align-self:flex-start}
.subsidy-card h3{font-size:17px;line-height:1.4;margin:0 0 8px;color:var(--ink)}
.subsidy-card p{font-size:13px;line-height:1.8;color:var(--ink-2);margin:0 0 10px}
.subsidy-card__bullets{list-style:none;padding:0;margin:6px 0 0;font-size:12px;line-height:1.7}
.subsidy-card__bullets li{padding:4px 0 4px 16px;position:relative;color:var(--ink-2)}
.subsidy-card__bullets li::before{content:"▸";position:absolute;left:0;color:var(--green-deep)}

/* Pattern list (subsidy patterns A/B/C) */
.pattern-list{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0 40px}
.pattern{background:var(--bg-soft);border-radius:14px;padding:24px 20px;border-top:3px solid var(--green)}
.pattern__num{font-family:Inter,sans-serif;font-size:32px;font-weight:900;color:var(--green-deep);line-height:1;margin-bottom:10px}
.pattern h3{font-size:15px;margin:0 0 8px;color:var(--ink)}
.pattern p{font-size:13px;line-height:1.7;color:var(--ink-2);margin:0}

/* Step list (JA route 3 steps) */
.step-list{list-style:none;padding:0;margin:20px 0 40px;counter-reset:step}
.step-list li{padding:18px 22px 18px 22px;background:#fff;border-left:4px solid var(--green);border-radius:8px;margin-bottom:12px;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.step-list li strong{display:block;font-size:15px;color:var(--ink);margin-bottom:6px}
.step-list li p{font-size:13px;line-height:1.7;color:var(--ink-2);margin:0}

/* Compare table */
.cmp-table-wrap{overflow-x:auto;margin:20px 0 32px;border-radius:12px;border:1px solid var(--line)}
.cmp-table{width:100%;border-collapse:collapse;font-size:12px;background:#fff;min-width:900px}
.cmp-table th,.cmp-table td{padding:12px 10px;text-align:left;border-bottom:1px solid var(--line-soft);vertical-align:top;line-height:1.55}
.cmp-table thead th{background:var(--bg-soft);font-size:11px;font-weight:800;letter-spacing:.04em;color:var(--ink);position:sticky;top:0}
.cmp-table tbody td:first-child{background:var(--bg-soft);font-weight:700;color:var(--ink);width:120px}
.cmp-table th.is-feature,.cmp-table td.is-feature{background:var(--green-soft);color:var(--green-deep)}
.cmp-table td.is-feature strong{color:var(--green-deep)}
.cmp-note{font-size:12px;color:var(--ink-3);margin-top:10px;line-height:1.6}

/* Compare cards */
.cmp-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:24px 0 40px}
.cmp-card{background:#fff;border:1px solid var(--line-soft);border-radius:14px;padding:22px 22px;position:relative;display:flex;flex-direction:column;gap:8px}
.cmp-card__tag{position:absolute;top:18px;right:20px;font-family:Inter,sans-serif;font-size:24px;font-weight:900;color:var(--ink-3);line-height:1}
.cmp-card__tag--feature{color:var(--green-deep);font-size:28px}
.cmp-card h3{font-size:16px;margin:0 0 4px;color:var(--ink);padding-right:36px}
.cmp-card p{font-size:13px;line-height:1.75;color:var(--ink-2);margin:0}
.cmp-card--feature{background:linear-gradient(135deg, var(--green-bg) 0%, #fff 100%);border:2px solid var(--green);box-shadow:0 14px 36px rgba(95,168,38,.12)}

/* Check list */
.check-list{list-style:none;padding:0;margin:20px 0 40px;counter-reset:chk}
.check-list li{position:relative;padding:18px 22px 18px 60px;background:#fff;border:1px solid var(--line-soft);border-radius:10px;margin-bottom:12px;counter-increment:chk}
.check-list li::before{content:counter(chk);position:absolute;left:18px;top:18px;width:28px;height:28px;background:var(--green);color:#fff;border-radius:50%;display:grid;place-items:center;font-family:Inter,sans-serif;font-size:13px;font-weight:800}
.check-list li strong{display:block;font-size:15px;color:var(--ink);margin-bottom:6px}
.check-list li p{font-size:13px;line-height:1.7;color:var(--ink-2);margin:0}

/* Mobile */
@media(max-width:880px){
  .subsidy-grid{grid-template-columns:1fr;gap:14px}
  .pattern-list{grid-template-columns:1fr;gap:12px}
  .cmp-cards{grid-template-columns:1fr}
  .cmp-table{font-size:11px;min-width:760px}
  .cmp-table th,.cmp-table td{padding:8px 6px}
}

/* ============================================================
   CTA Hub — 3-card entry funnel before the contact form
============================================================ */
.cta-hub{padding:96px 32px 80px;background:linear-gradient(180deg,#fff 0%,var(--green-bg) 100%)}
.cta-hub__inner{max-width:1200px;margin:0 auto}
.cta-hub__lead{text-align:center;font-size:15px;line-height:1.9;color:var(--ink-2);max-width:760px;margin:24px auto 48px}
.cta-hub__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:0 auto 32px;max-width:1140px}
.cta-hub__card{background:#fff;border:1px solid var(--line-soft);border-radius:18px;padding:36px 28px 28px;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:8px;position:relative;transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.cta-hub__card:hover{transform:translateY(-6px);border-color:var(--green);box-shadow:0 24px 48px rgba(95,168,38,.16)}
.cta-hub__card--feature{border:2px solid var(--green);box-shadow:0 18px 42px rgba(95,168,38,.18);background:linear-gradient(180deg,#fff 0%,#f4faec 100%)}
.cta-hub__card--feature:hover{border-color:var(--green-deep);box-shadow:0 28px 56px rgba(95,168,38,.26)}
.cta-hub__badge{position:absolute;top:14px;right:14px;background:var(--green-deep);color:#fff;font-family:Inter,sans-serif;font-size:11px;font-weight:800;letter-spacing:.08em;padding:5px 11px;border-radius:999px;text-transform:uppercase}
.cta-hub__icon{width:64px;height:64px;margin-bottom:10px}
.cta-hub__icon svg{width:100%;height:100%}
.cta-hub__tag{font-family:Inter,sans-serif;font-size:11px;font-weight:800;letter-spacing:.18em;color:var(--green-deep);text-transform:uppercase;background:var(--green-soft);display:inline-block;padding:4px 10px;border-radius:4px;align-self:flex-start;margin-bottom:6px}
.cta-hub__card h3{font-size:20px;line-height:1.45;margin:0 0 10px;color:var(--ink)}
.cta-hub__card p{font-size:14px;line-height:1.85;color:var(--ink-2);margin:0 0 18px;flex:1}
.cta-hub__arrow{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:800;color:var(--green-deep);letter-spacing:.04em;margin-top:auto}
.cta-hub__card:hover .cta-hub__arrow{color:var(--green-deep);text-decoration:underline}
.cta-hub__sub{text-align:center;font-size:13px;line-height:1.85;color:var(--ink-2);max-width:760px;margin:0 auto;padding:24px;background:#fff;border-radius:12px;border:1px dashed var(--line)}
.cta-hub__sub a{color:var(--green-deep);text-decoration:underline;font-weight:700}

/* Pre-filled visual feedback on the contact form */
.cform.is-prefilled #cf_type{box-shadow:0 0 0 4px rgba(124,194,66,.28);border-color:var(--green);transition:box-shadow .35s ease, border-color .35s ease}

@media(max-width:880px){
  .cta-hub{padding:64px 16px 56px}
  .cta-hub__grid{grid-template-columns:1fr;gap:16px}
  .cta-hub__card{padding:28px 22px 22px}
  .cta-hub__lead{font-size:13.5px;margin:18px auto 32px}
}
