/* SS Support - Common Styles (extracted from production pages) */

/* Variables */
:root{
  --navy:#2B4C3F;
  --navy-light:#3A6354;
  --navy-dark:#1E3A30;
  --accent:#00A076;
  --accent-light:#1AB88A;
  --accent-pale:rgba(0,160,118,.1);
  --blue:#17643D;
  --blue-light:#1E7A4B;
  --bg:#fff;
  --bg-light:#F5F8F7;
  --bg-pale:#EAF0EE;
  --text:#222;
  --text-body:#3a3a3a;
  --text-sub:#666;
  --text-muted:#999;
  --border:#d8ddd9;
  --border-light:#e8ece9;
  --shadow-sm:0 2px 8px rgba(0,0,0,.05);
  --shadow-md:0 8px 32px rgba(0,0,0,.08);
  --shadow-lg:0 16px 48px rgba(0,0,0,.1);
  --max-w:1200px;
  --radius:4px;
}
html{scroll-behavior:smooth}
body{
  font-family:'Noto Sans JP',sans-serif;
  color:var(--text-body);line-height:1.85;font-size:17px;font-weight:400;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;background:var(--bg);
}
a{color:inherit;text-decoration:none;transition:.3s}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--max-w);margin:0 auto;padding:0 48px}

/* ============================================
   Header -- CellChain-inspired ultra-clean
   ============================================ */
.header{
  position:sticky;top:0;width:100%;z-index:1000;
  background:#fff;
  height:110px;display:flex;align-items:center;
  transition:height .4s ease, box-shadow .4s ease;
}
.header.scrolled{
  height:80px;
  box-shadow:0 1px 0 var(--border-light), 0 4px 20px rgba(43,76,63,.06);
}
.header-inner{
  width:100%;max-width:1320px;margin:0 auto;
  display:flex;align-items:center;padding:0 56px;
}

/* Logo */
.logo-group{flex-shrink:0;margin-right:72px}
.logo-group a{display:flex;align-items:center;gap:14px;padding:4px 0}
.logo-icon{
  width:50px;height:50px;flex-shrink:0;
  transition:width .4s ease, height .4s ease;
}
.header.scrolled .logo-icon{width:40px;height:40px}
.logo-text{display:flex;flex-direction:column;gap:6px}
.logo-main{
  font-size:2rem;font-weight:900;color:var(--navy);
  letter-spacing:.02em;line-height:1.15;
  transition:font-size .4s ease;
}
.header.scrolled .logo-main{font-size:1.6rem}
.logo-sub{
  font-size:.7rem;font-weight:500;color:var(--text-muted);
  letter-spacing:.12em;line-height:1;
}

/* Nav -- 2-tier (EN label + JP) with border separators */
.gnav{display:flex;align-items:stretch;height:100%;flex:1}
.gnav-item{position:relative;display:flex;align-items:center}
.gnav-link{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:0 28px;height:100%;justify-content:center;
  position:relative;cursor:pointer;
  transition:all .25s;
  border-right:1px solid var(--border-light);
}
.gnav-item:first-child .gnav-link{border-left:1px solid var(--border-light)}
.gnav-en{
  font-size:.8rem;font-weight:700;color:var(--navy);
  letter-spacing:.1em;text-transform:uppercase;line-height:1;
  opacity:.55;
}
.gnav-jp{
  display:flex;align-items:center;gap:4px;
  font-size:1.18rem;font-weight:800;color:var(--navy);
  letter-spacing:.02em;line-height:1.2;
}
.gnav-item:hover .gnav-en,
.gnav-item:hover .gnav-jp{color:var(--accent)}
.gnav-link.current .gnav-en{color:var(--accent)}
.gnav-link.current .gnav-jp{color:var(--accent)}
.gnav-chevron{
  width:10px;height:10px;fill:none;stroke:currentColor;stroke-width:2.5;
  stroke-linecap:round;stroke-linejoin:round;
  transition:transform .3s;margin-top:1px;
}
.gnav-item:hover .gnav-chevron{transform:rotate(180deg)}

/* Dropdown */
.gnav-dropdown{
  position:absolute;top:100%;left:0;
  min-width:260px;
  background:#fff;
  border-radius:0 0 8px 8px;
  box-shadow:0 12px 40px rgba(43,76,63,.1), 0 1px 0 var(--border-light) inset;
  padding:20px 8px;
  opacity:0;visibility:hidden;
  transform:translateY(8px);
  transition:all .3s cubic-bezier(.22,1,.36,1);
  pointer-events:none;
}
.gnav-item:hover .gnav-dropdown{
  opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;
}
.gnav-dropdown a{
  display:flex;align-items:center;gap:14px;
  padding:13px 20px;border-radius:6px;
  font-size:.95rem;font-weight:700;color:var(--navy);
  transition:all .2s;letter-spacing:.02em;
}
.gnav-dropdown a:hover{background:var(--bg-light);color:var(--accent)}
.gnav-dropdown a::before{
  content:"";width:4px;height:4px;border-radius:50%;
  background:var(--accent);flex-shrink:0;opacity:.6;
  transition:opacity .2s;
}
.gnav-dropdown a:hover::before{opacity:1}
.gnav-dd-desc{
  font-size:.78rem;color:var(--text-sub);font-weight:500;
  margin-top:2px;letter-spacing:0;
}

/* Header right -- dual CTA, 2-tier text */
.header-right{
  display:flex;align-items:center;gap:12px;
  margin-left:auto;flex-shrink:0;
}
.hdr-btn{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:14px 36px;border-radius:5px;
  transition:all .3s;cursor:pointer;white-space:nowrap;line-height:1.15;
}
.hdr-btn-en{
  font-size:.72rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;opacity:.75;
}
.hdr-btn-jp{
  font-size:1.15rem;font-weight:800;letter-spacing:.03em;
}
.hdr-btn-ghost{
  color:var(--navy);background:transparent;
  border:1.5px solid var(--border);
}
.hdr-btn-ghost:hover{border-color:var(--navy);background:var(--bg-light)}
.hdr-btn-solid{
  color:#fff;background:var(--accent);border:1.5px solid var(--accent);
  box-shadow:0 2px 8px rgba(0,160,118,.18);
}
.hdr-btn-solid:hover{
  background:var(--accent-light);border-color:var(--accent-light);
  transform:translateY(-1px);
  box-shadow:0 4px 16px rgba(0,160,118,.25);
}

/* Hamburger */
.hamburger{
  display:none;width:44px;height:44px;flex-direction:column;
  align-items:center;justify-content:center;gap:6px;cursor:pointer;
  border-radius:6px;transition:background .2s;order:-1;
}
.hamburger:hover{background:var(--bg-light)}
.hamburger span{width:20px;height:1.5px;background:var(--navy);transition:.3s;border-radius:1px}
.hamburger.active span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* Mobile nav -- full overlay, right slide panel */
.mobile-nav{
  display:none;position:fixed;top:0;left:0;width:100%;height:100dvh;
  background:rgba(43,76,63,.35);backdrop-filter:blur(3px);
  z-index:1100;
}
.mobile-nav.open{display:block}
.mobile-nav-panel{
  position:absolute;top:0;right:0;
  width:min(380px,88vw);height:100%;
  background:#fff;overflow-y:auto;
  box-shadow:-12px 0 40px rgba(0,0,0,.1);
  animation:mnavSlide .3s ease;
}
@keyframes mnavSlide{from{transform:translateX(100%)}to{transform:translateX(0)}}
.mnav-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--border-light);
}
.mnav-close{
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;border-radius:6px;font-size:1.3rem;color:var(--text-muted);
  transition:background .2s;
}
.mnav-close:hover{background:var(--bg-light)}
.mnav-body{padding:12px 0}
/* Accordion group */
.mnav-group{border-bottom:1px solid var(--border-light)}
.mnav-group-toggle{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:16px 24px;
  font-size:.95rem;font-weight:600;color:var(--text);
  background:none;border:none;cursor:pointer;
  letter-spacing:.02em;
}
.mnav-group-toggle svg{
  width:12px;height:12px;fill:none;stroke:var(--text-muted);
  stroke-width:2.5;transition:transform .3s;
}
.mnav-group.open .mnav-group-toggle svg{transform:rotate(180deg)}
.mnav-group-items{
  max-height:0;overflow:hidden;transition:max-height .35s ease;
}
.mnav-group.open .mnav-group-items{max-height:400px}
.mnav-group-items a{
  display:block;padding:12px 24px 12px 40px;
  font-size:.88rem;font-weight:500;color:var(--text-sub);
  transition:all .2s;position:relative;
}
.mnav-group-items a::before{
  content:"";position:absolute;left:26px;top:50%;transform:translateY(-50%);
  width:4px;height:4px;border-radius:50%;background:var(--border);
  transition:background .2s;
}
.mnav-group-items a:hover{background:var(--bg-light);color:var(--navy)}
.mnav-group-items a:hover::before{background:var(--accent)}
/* Direct link (no accordion) */
.mnav-direct{
  display:block;padding:16px 24px;
  font-size:.95rem;font-weight:600;color:var(--text);
  border-bottom:1px solid var(--border-light);
  transition:all .2s;letter-spacing:.02em;
}
.mnav-direct:hover{background:var(--bg-light);color:var(--navy)}
.mnav-direct.current{color:var(--accent);font-weight:700}
/* Mobile CTA area */
.mnav-ctas{
  padding:24px;display:flex;flex-direction:column;gap:10px;
}
.mnav-cta-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:16px;border-radius:6px;font-weight:700;font-size:.95rem;
  letter-spacing:.03em;transition:all .25s;
}
.mnav-cta-btn svg{width:16px;height:16px}
.mnav-cta-primary{background:var(--accent);color:#fff}
.mnav-cta-primary svg{fill:#fff}
.mnav-cta-primary:hover{background:var(--accent-light)}
.mnav-cta-outline{background:#fff;color:var(--navy);border:1.5px solid var(--border)}
.mnav-cta-outline svg{fill:var(--accent)}
.mnav-cta-outline:hover{border-color:var(--navy);background:var(--bg-light)}
.mnav-tel{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:14px;font-weight:800;font-size:1.15rem;color:var(--navy);
  letter-spacing:.02em;
}
.mnav-tel svg{width:18px;height:18px;fill:var(--accent)}
.mnav-hours{text-align:center;font-size:.72rem;color:var(--text-muted);margin-top:-4px}

/* Mobile bottom sticky bar */
.mobile-sticky{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:997;
  background:#fff;border-top:1px solid var(--border-light);
  box-shadow:0 -2px 12px rgba(0,0,0,.06);
  padding:6px 12px env(safe-area-inset-bottom,6px);
}
.mobile-sticky-inner{
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px;
  max-width:480px;margin:0 auto;
}
.mobile-sticky-btn{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  padding:8px 4px;border-radius:6px;transition:background .2s;
  font-size:.65rem;font-weight:600;letter-spacing:.02em;color:var(--text-sub);
}
.mobile-sticky-btn svg{width:20px;height:20px;fill:currentColor}
.mobile-sticky-btn:hover{background:var(--bg-light)}
.mobile-sticky-btn--accent{color:var(--accent)}
.mobile-sticky-btn--navy{color:var(--navy)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:700;border-radius:var(--radius);transition:.3s;cursor:pointer;border:none;
  font-size:1.02rem;letter-spacing:.04em;
}
.btn-accent{
  background:var(--accent);color:var(--navy);padding:20px 56px;
  border-bottom:3px solid rgba(0,0,0,.15);font-size:1.08rem;
}
.btn-accent:hover{background:var(--accent-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.hero-btns .btn-accent{color:#fff}
.hero-btns .btn-accent:hover{color:#fff}
.btn-navy{
  background:var(--navy);color:#fff;padding:20px 56px;
  border-bottom:3px solid rgba(0,0,0,.2);font-size:1.08rem;
}
.btn-navy:hover{background:var(--navy-light);transform:translateY(-2px)}
.btn-outline{
  background:transparent;color:var(--navy);padding:18px 48px;
  border:2px solid var(--navy);font-size:1.02rem;
}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-outline-white{
  background:transparent;color:#fff;padding:16px 40px;
  border:1px solid rgba(255,255,255,.35);font-size:.9rem;
}
.btn-outline-white:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7)}
.btn-text{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.9rem;font-weight:700;color:var(--navy);
  letter-spacing:.06em;transition:gap .2s;cursor:pointer;
  background:none;border:none;padding:0;
}
.btn-text:hover{gap:10px;color:var(--accent)}
.btn-text::after{content:"\203A";font-size:1.2rem}

/* ============================================
   Hero -- diagonal bottom, route decorations
   ============================================ */
.hero{
  min-height:90vh;max-height:920px;
  display:flex;align-items:center;
  color:#fff;position:relative;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;overflow:hidden}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:62% 50%}
.hero-overlay{
  position:absolute;inset:0;
  background: none;
}
/* Route line decorations */
.hero::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(168deg, transparent 30%, rgba(0,160,118,.06) 31%, rgba(0,160,118,.06) 31.3%, transparent 31.6%),
    linear-gradient(168deg, transparent 55%, rgba(0,160,118,.04) 55.3%, rgba(0,160,118,.04) 55.6%, transparent 55.9%),
    linear-gradient(168deg, transparent 72%, rgba(255,255,255,.03) 72.3%, rgba(255,255,255,.03) 72.5%, transparent 72.8%);
}
/* Diagonal bottom clip */
.hero-clip{
  position:absolute;bottom:-1px;left:0;right:0;z-index:3;
  height:80px;overflow:hidden;
}
.hero-clip svg{display:block;width:100%;height:100%}

.hero-content{
  position:relative;z-index:2;
  width:100%;max-width:var(--max-w);margin:0 auto;padding:0 48px;
}
.hero-inner{max-width:680px}
.hero-label{
  display:inline-flex;align-items:center;gap:12px;
  font-size:.72rem;font-weight:700;letter-spacing:.2em;
  color:var(--accent-light);text-transform:uppercase;margin-bottom:24px;
}
.hero-label::before{
  content:"";display:block;width:40px;height:2px;background:var(--accent);
}
.hero-content h2{
  font-size:clamp(2.6rem,5.5vw,3.8rem);
  font-weight:900;line-height:1.25;margin-bottom:24px;
  letter-spacing:.04em;
  text-shadow:0 2px 24px rgba(0,0,0,.4);
}
.hero-sub{
  font-size:clamp(1.05rem,1.6vw,1.25rem);font-weight:500;
  margin-bottom:44px;letter-spacing:.05em;
  opacity:.85;max-width:560px;line-height:1.9;
}
.hero-btns{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.hero-side-label{
  position:absolute;right:48px;top:50%;transform:translateY(-50%) rotate(90deg);
  transform-origin:center;
  font-size:.68rem;font-weight:700;letter-spacing:.25em;
  color:rgba(255,255,255,.2);text-transform:uppercase;white-space:nowrap;
}

/* Banner Cards -- overlapping hero bottom */
.banner-cards{
  display:grid;grid-template-columns:1fr 1fr;
  max-width:var(--max-w);margin:-48px auto 0;
  padding:0 48px;position:relative;z-index:10;gap:24px;
}
.banner-card{
  position:relative;overflow:hidden;border-radius:6px;
  height:190px;display:flex;align-items:flex-end;
  box-shadow:var(--shadow-lg);transition:transform .3s;
}
.banner-card:hover{transform:translateY(-4px)}
.banner-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.banner-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(43,76,63,.85) 0%,rgba(43,76,63,.12) 100%);
}
.banner-card-body{position:relative;z-index:2;padding:28px 32px;color:#fff;width:100%}
.banner-card-label{
  font-size:.7rem;font-weight:700;letter-spacing:.18em;
  color:var(--accent);text-transform:uppercase;margin-bottom:8px;
}
.banner-card-body h3{font-size:1.3rem;font-weight:900;letter-spacing:.03em;line-height:1.4}

/* ============================================
   News -- decorative accent, first item highlight
   ============================================ */
.news{padding:100px 0 72px;position:relative;overflow:hidden}
.news::before{
  content:"";position:absolute;top:40px;right:-60px;
  width:200px;height:200px;border-radius:50%;
  border:1px solid var(--border-light);pointer-events:none;
}
.news::after{
  content:"";position:absolute;top:100px;right:20px;
  width:80px;height:80px;border-radius:50%;
  border:1px solid rgba(0,160,118,.1);pointer-events:none;
}
.news-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:40px;position:relative;
}
.news-header-left{position:relative;padding-left:20px}
.news-header-left::before{
  content:"";position:absolute;left:0;top:4px;bottom:4px;
  width:4px;background:var(--accent);border-radius:2px;
}
.news-list{display:flex;flex-direction:column;gap:0}
.news-item{
  display:flex;align-items:center;gap:24px;
  padding:22px 24px;border-bottom:1px solid var(--border);
  transition:background .2s;
}
.news-item:hover{background:var(--bg-light)}
.news-item:first-child{
  background:var(--bg-light);border-radius:6px 6px 0 0;
  border-left:3px solid var(--accent);
  padding-left:21px;
}
.news-date{
  font-size:.92rem;font-weight:700;color:var(--accent);
  letter-spacing:.04em;white-space:nowrap;
  min-width:96px;
}
.news-badge{
  display:inline-block;background:var(--accent-pale);color:var(--accent);
  font-size:.7rem;font-weight:700;padding:3px 12px;border-radius:2px;
  letter-spacing:.06em;margin-right:8px;
}
.news-text{font-size:1.05rem;color:var(--text-body);line-height:1.7}
a.news-item,a.news-item:hover,a.news-item:focus,a.news-item:visited{text-decoration:none!important;color:inherit;cursor:pointer;border-bottom:none}

/* ============================================
   Business -- asymmetric, layered, varied
   ============================================ */
.business{padding:100px 0 80px;position:relative;overflow:hidden}
/* Route-line bg decoration */
.business::before{
  content:"";position:absolute;top:0;left:0;right:0;bottom:0;
  pointer-events:none;
  background:
    linear-gradient(172deg, transparent 48%, var(--bg-light) 48.5%, var(--bg-light) 52%, transparent 52.5%);
  opacity:.5;
}
.business-head{text-align:center;margin-bottom:80px;position:relative;z-index:1}

/* Shared business item base */
.biz{
  position:relative;z-index:1;
  display:grid;align-items:center;
  margin-bottom:100px;
}
.biz:last-child{margin-bottom:0}

/* Item 01 -- image left larger, text right */
.biz-01{
  grid-template-columns:55% 1fr;gap:48px;
  padding-right:48px;
}
.biz-01 .biz-img{
  height:420px;border-radius:0 8px 8px 0;overflow:hidden;position:relative;
}
.biz-01 .biz-img img{width:100%;height:100%;object-fit:cover}
.biz-01 .biz-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to right, rgba(43,76,63,.08), transparent 40%);
}

/* Item 02 -- text left, image right with offset */
.biz-02{
  grid-template-columns:1fr 52%;gap:48px;
  padding-left:48px;
}
.biz-02 .biz-img{
  height:380px;border-radius:8px 0 0 8px;overflow:hidden;
  transform:translateY(24px);
}
.biz-02 .biz-img img{width:100%;height:100%;object-fit:cover}

/* Item 03 -- centered wider, image left smaller */
.biz-03{
  grid-template-columns:45% 1fr;gap:56px;
  max-width:var(--max-w);margin-left:auto;margin-right:auto;
  padding:0 48px;margin-bottom:0;
}
.biz-03 .biz-img{
  height:340px;border-radius:8px;overflow:hidden;
  box-shadow:var(--shadow-md);
}
.biz-03 .biz-img img{width:100%;height:100%;object-fit:cover}

/* Business body text */
.biz-body{position:relative;padding:28px 0}
.biz-num{
  position:absolute;right:-10px;top:-30px;
  font-size:clamp(7rem,12vw,10rem);font-weight:900;
  line-height:1;letter-spacing:-.04em;z-index:0;
  color:transparent;
  -webkit-text-stroke:1.5px var(--border-light);
  opacity:.5;
}
.biz-02 .biz-num{left:-10px;right:auto}
.biz-body .biz-label{
  display:flex;align-items:center;gap:12px;
  margin-bottom:14px;position:relative;z-index:1;
}
.biz-body .biz-label::before{
  content:"";width:28px;height:2px;background:var(--accent);
}
.biz-body .biz-label span{
  font-size:.72rem;font-weight:700;letter-spacing:.2em;
  color:var(--text-muted);text-transform:uppercase;
}
.biz-body h3{
  font-size:clamp(1.7rem,3vw,2.3rem);font-weight:900;
  color:var(--text);line-height:1.4;margin-bottom:24px;
  position:relative;z-index:1;letter-spacing:.03em;
}
.biz-body h3 strong{
  background:linear-gradient(transparent 60%,var(--accent-pale) 60%);
}
.biz-body p{
  font-size:1.05rem;color:var(--text-body);line-height:1.95;
  margin-bottom:32px;position:relative;z-index:1;max-width:520px;
}
/* Diagonal separator before business */
.biz-separator{
  height:60px;position:relative;overflow:hidden;margin-bottom:-1px;
}
.biz-separator svg{display:block;width:100%;height:100%}

/* ============================================
   Numbers -- diagonal edges, arc decorations
   ============================================ */
.numbers-wrap{position:relative}
.numbers-clip-top{
  height:60px;overflow:hidden;position:relative;z-index:2;
  margin-bottom:-1px;
}
.numbers-clip-top svg{display:block;width:100%;height:100%}
.numbers{
  padding:100px 0 110px;position:relative;overflow:hidden;
  background:#fff;
}
.numbers::before{
  content:"";position:absolute;inset:0;
  background:url('https://www.ss-support.com/wp-content/uploads/2026/03/156944156.jpg') center/cover no-repeat;
  opacity:.35;
}
.numbers::after{
  content:"";position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  width:600px;height:600px;border-radius:50%;
  border:1px solid rgba(0,160,118,.06);
  pointer-events:none;
}
.numbers .container{position:relative;z-index:1}
.numbers-head{text-align:center;margin-bottom:64px;color:var(--navy)}
.numbers-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:32px;
  max-width:1000px;margin:0 auto;text-align:center;color:var(--text);
}
.num-card{
  position:relative;padding:36px 20px;
  border-radius:8px;
  background:var(--bg-light);
  border:1px solid var(--border-light);
  transition:transform .3s;
}
.num-card:hover{transform:translateY(-4px)}
.num-card:nth-child(2){transform:translateY(-12px)}
.num-card:nth-child(2):hover{transform:translateY(-16px)}
.numbers-val{
  font-size:clamp(3rem,5.5vw,4.2rem);font-weight:900;
  line-height:1;letter-spacing:-.02em;margin-bottom:16px;
  color:var(--accent);
}
.numbers-val span{font-size:1rem;font-weight:500;margin-left:2px;color:var(--text-muted)}
.numbers-label{font-size:.95rem;color:var(--text-sub);font-weight:500;letter-spacing:.04em}
.numbers-clip-btm{
  height:60px;overflow:hidden;position:relative;z-index:2;
  margin-top:-1px;
}
.numbers-clip-btm svg{display:block;width:100%;height:100%}

/* ============================================
   About -- overlapping photos, layered panel
   ============================================ */
.about{padding:120px 0 140px;position:relative;overflow:hidden}
.about::before{
  content:"";position:absolute;top:0;left:0;right:0;bottom:0;
  background:var(--bg-light);
  clip-path:polygon(0 8%, 100% 0, 100% 92%, 0 100%);
}
.about-grid{
  display:grid;grid-template-columns:1.15fr 1fr;
  gap:52px;align-items:center;position:relative;z-index:1;
}
/* Photo stack with overlap */
.about-photos{position:relative;min-height:500px}
.about-img-main{
  position:relative;width:90%;height:380px;
  border-radius:8px;overflow:hidden;
  box-shadow:var(--shadow-lg);z-index:2;
}
.about-img-main img{width:100%;height:100%;object-fit:cover}
.about-img-sub{
  position:absolute;bottom:-16px;right:-10px;
  width:55%;height:210px;
  border-radius:8px;overflow:hidden;
  box-shadow:var(--shadow-md);z-index:3;
  border:4px solid #fff;
}
.about-img-sub img{width:100%;height:100%;object-fit:cover}
/* Decorative frame behind photos */
.about-photos::before{
  content:"";position:absolute;top:20px;left:20px;
  width:90%;height:380px;border:2px solid var(--accent);
  border-radius:8px;opacity:.15;z-index:1;
}
.about-text{position:relative}
.about-text h3{
  font-size:clamp(1.7rem,3vw,2.3rem);font-weight:900;line-height:1.4;
  margin-bottom:24px;color:var(--text);letter-spacing:.03em;
}
.about-text p{font-size:1.02rem;color:var(--text-body);line-height:1.9;margin-bottom:16px}
.about-quote{
  font-size:.95rem;color:var(--text-muted);
  border-left:3px solid var(--accent);padding-left:16px;
  margin-top:12px;line-height:1.8;
}
.about-info{
  font-size:.95rem;color:var(--text-sub);
  padding:20px 0;border-top:1px solid var(--border);margin-top:12px;line-height:2;
}
.about-info strong{color:var(--text);font-weight:700}

/* ============================================
   CTA Banner
   ============================================ */
.cta-banner{
  padding:72px 0;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 50%,var(--navy-dark) 100%);
}
.cta-watermark{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-size:clamp(5rem,14vw,12rem);font-weight:900;
  letter-spacing:.08em;color:rgba(255,255,255,.03);
  white-space:nowrap;text-transform:uppercase;pointer-events:none;
}
.cta-banner .container{position:relative;z-index:1;text-align:center;color:#fff}
.cta-tagline{
  font-size:.9rem;font-weight:700;letter-spacing:.16em;
  color:var(--accent);margin-bottom:8px;
}
.cta-banner h2{
  font-size:clamp(1.6rem,3vw,2.2rem);font-weight:900;
  margin-bottom:12px;letter-spacing:.06em;
}
.cta-bar{width:48px;height:2px;background:var(--accent);margin:24px auto}

/* ============================================
   Recruit -- floating panel, layered CTA
   ============================================ */
.recruit-wrap{position:relative}
.recruit-clip{
  height:50px;overflow:hidden;position:relative;z-index:2;margin-bottom:-1px;
}
.recruit-clip svg{display:block;width:100%;height:100%}
.recruit{position:relative;overflow:hidden;background:#fff}
.recruit-bg{display:none}
.recruit-overlay{display:none}
.recruit-content{
  position:relative;z-index:2;
  max-width:var(--max-w);margin:0 auto;padding:72px 48px;color:var(--text);
  display:flex;align-items:center;justify-content:space-between;gap:48px;
}
.recruit-inner{
  max-width:520px;flex-shrink:0;
}
.recruit-img{
  flex:1;min-width:0;max-width:480px;
  border-radius:8px;overflow:hidden;
}
.recruit-img img{width:100%;height:100%;object-fit:cover;display:block}
.recruit-content h3{
  font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:900;
  line-height:1.35;margin-bottom:20px;letter-spacing:.04em;
  color:var(--navy);
}
.recruit-inner>p{font-size:1.02rem;color:var(--text-body);max-width:460px;margin-bottom:18px;line-height:1.9}
.recruit-merits{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:32px}
.recruit-merit-tag{
  background:var(--accent-pale);border:1px solid rgba(0,160,118,.3);
  padding:9px 20px;border-radius:2px;font-size:.92rem;font-weight:700;
  color:var(--accent);letter-spacing:.03em;
}
.recruit-btns{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.recruit-btns .btn-accent{background:#fff;color:var(--navy);border:2px solid var(--border);border-bottom:3px solid var(--border)}
.recruit-btns .btn-accent:hover{background:var(--bg-light);transform:translateY(-2px)}
/* Phone card -- aligned right */
.recruit-float-card{
  position:relative;right:auto;bottom:auto;z-index:3;
  background:rgba(255,255,255,.96);backdrop-filter:blur(8px);
  border-radius:8px;padding:32px 36px;
  box-shadow:var(--shadow-lg);color:var(--text);
  min-width:260px;border-left:4px solid var(--accent);
  flex-shrink:0;text-align:center;
}
.recruit-float-card .rfc-label{
  font-size:.7rem;font-weight:700;color:var(--accent);
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px;
}
.recruit-float-card .rfc-tel{
  font-size:1.7rem;font-weight:900;color:var(--navy);
  letter-spacing:.02em;margin-bottom:6px;display:block;
}
.recruit-float-card .rfc-note{font-size:.8rem;color:var(--text-muted)}

/* ============================================
   Contact
   ============================================ */
.contact{padding:0;position:relative}
.contact-methods{
  display:grid;grid-template-columns:1fr 1fr;
  max-width:920px;margin:0 auto;border-radius:6px;overflow:hidden;
  box-shadow:0 20px 40px rgba(0,0,0,.12);
}
.contact-phone{
  background:linear-gradient(160deg,var(--navy-dark) 0%,var(--navy) 100%);
  color:#fff;padding:56px 48px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
}
.contact-phone-icon{
  width:48px;height:48px;fill:#fff;opacity:.3;margin-bottom:16px;
}
.contact-phone h3{
  font-size:1rem;font-weight:700;margin-bottom:20px;letter-spacing:.04em;
}
.contact-phone .tel{
  font-size:2.4rem;font-weight:900;letter-spacing:.03em;margin-bottom:12px;
}
.contact-phone .tel a{color:#fff}
.contact-phone .tel a:hover{opacity:.8}
.contact-phone .note{font-size:.85rem;opacity:.7}
.contact-email{
  background:#fff;padding:56px 48px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;
}
.contact-email-icon{
  width:48px;height:48px;fill:var(--accent);opacity:.3;margin-bottom:16px;
}
.contact-email h3{
  font-size:1rem;font-weight:700;color:var(--text);margin-bottom:16px;letter-spacing:.04em;
}
.contact-email .badge-24h{
  display:inline-block;background:rgba(0,160,118,.1);color:var(--accent);
  font-size:.78rem;font-weight:700;padding:4px 14px;border-radius:6px;
  letter-spacing:.04em;margin-bottom:16px;
}
.contact-email p{
  font-size:.92rem;color:var(--text-sub);margin-bottom:24px;line-height:1.8;
}
.mail-btn{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent);color:#fff;
  padding:16px 36px;border-radius:5px;font-weight:700;font-size:.95rem;
  letter-spacing:.03em;transition:all .3s;
  border-bottom:3px solid rgba(0,0,0,.15);
}
.mail-btn:hover{background:#00b888;transform:translateY(-1px);box-shadow:var(--shadow-md)}
.mail-btn svg{width:18px;height:18px;fill:#fff}

/* ============================================
   Footer
   ============================================ */
.footer{background:#fff;color:var(--text-body);padding:0;border-top:4px solid var(--accent)}
.footer-grid{
  max-width:var(--max-w);margin:0 auto;padding:48px 48px 0;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;
  margin-bottom:52px;
}
.footer-logo{display:flex;flex-direction:column;gap:18px}
.footer-logo-mark{
  display:flex;align-items:center;gap:12px;
  align-self:flex-start;margin-bottom:4px;
}
.footer-logo-mark img{width:36px;height:36px;object-fit:contain}
.footer-logo-mark span{
  font-size:1.5rem;font-weight:900;color:var(--navy);
  letter-spacing:-.01em;
}
.footer-logo p{font-size:.84rem;line-height:2.1;color:var(--text-body)}
.footer-logo a{color:var(--text-body);transition:color .2s}
.footer-logo a:hover{color:var(--navy)}
.footer-links h5{
  font-size:.78rem;margin-bottom:20px;color:var(--accent);
  font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding-bottom:12px;border-bottom:1px solid var(--border-light);
}
.footer-links a{display:block;margin-bottom:14px;font-size:.86rem;color:var(--text-body);font-weight:500;transition:color .2s;letter-spacing:.03em}
.footer-links a:hover{color:var(--navy)}
.footer-news h5{
  font-size:.78rem;margin-bottom:20px;color:var(--accent);
  font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding-bottom:12px;border-bottom:1px solid var(--border-light);
}
.footer-news-item{display:flex;gap:12px;align-items:flex-start;margin-bottom:18px}
.footer-news-item .date{font-size:.75rem;color:var(--accent);font-weight:600;white-space:nowrap;margin-top:2px}
.footer-news-item .text{font-size:.83rem;color:var(--text-body);line-height:1.7}
a.footer-news-item,a.footer-news-item:hover,a.footer-news-item:focus,a.footer-news-item:visited{text-decoration:none!important;color:inherit;border-bottom:none}
.footer a,.footer a:hover,.footer a:focus,.footer a:visited{text-decoration:none!important}
a.footer-news-item:hover .text{color:var(--accent)}
.copyright{
  max-width:var(--max-w);margin:0 auto;padding:28px 48px;
  border-top:1px solid var(--border-light);
  text-align:center;font-size:.74rem;color:var(--text-sub);letter-spacing:.06em;
}

/* ============================================
   Section Label (common)
   ============================================ */
.sec-label{
  font-size:.8rem;font-weight:700;letter-spacing:.2em;
  color:var(--accent);text-transform:uppercase;margin-bottom:14px;
}
.sec-heading{
  font-size:clamp(2rem,3.5vw,2.8rem);font-weight:900;
  color:var(--text);letter-spacing:.04em;line-height:1.35;
}
.sec-heading-white{color:#fff}
.sec-heading-bar{
  display:block;width:48px;height:3px;background:var(--accent);margin-top:20px;
}

/* ============================================
   Animations
   ============================================ */
.fade-in{opacity:0;transform:translateY(24px);transition:.7s ease-out}
.fade-in.is-active{opacity:1;transform:translateY(0)}

/* ============================================
   Responsive
   ============================================ */
@media(max-width:900px){
  .header{height:60px}
  .header.scrolled{height:56px}
  .header-inner{padding:0 16px}
  .logo-icon{width:28px;height:28px}
  .logo-main{font-size:1.15rem}
  .logo-sub{display:none}
  .logo-group{margin-right:0}
  .gnav{display:none}
  .header-right{display:none}
  .hamburger{display:flex}
  .mobile-sticky{display:block}
  .container{padding:0 20px}
  .hero{min-height:auto;height:clamp(480px,75vh,640px)}
  .hero-content{padding:0 20px}
  .hero-content h2{font-size:2rem}
  .hero-side-label{display:none}
  .hero-clip{height:40px}
  .banner-cards{grid-template-columns:1fr;margin-top:-32px;padding:0 20px;gap:12px}
  .banner-card{height:150px}
  .news{padding:60px 0 48px}
  .news::before,.news::after{display:none}
  .business{padding:64px 0}
  .business::before{display:none}
  .biz{margin-bottom:64px}
  .biz-01,.biz-02,.biz-03{
    grid-template-columns:1fr;gap:24px;padding:0 20px;
  }
  .biz-01 .biz-img,.biz-02 .biz-img,.biz-03 .biz-img{
    height:240px;border-radius:8px;
  }
  .biz-02 .biz-img{transform:none}
  .biz-num{font-size:5rem !important;top:-20px !important}
  .numbers-clip-top,.numbers-clip-btm{height:30px}
  .numbers{padding:64px 0 72px}
  .numbers-grid{grid-template-columns:1fr 1fr;gap:16px}
  .num-card:nth-child(2){transform:translateY(-6px)}
  .about{padding:80px 0 100px}
  .about::before{clip-path:polygon(0 4%,100% 0,100% 96%,0 100%)}
  .about-grid{grid-template-columns:1fr;gap:32px}
  .about-photos{min-height:360px}
  .about-img-main{width:90%;height:280px}
  .about-img-sub{width:50%;height:160px;bottom:-10px;right:0}
  .about-photos::before{width:90%;height:280px;top:10px;left:10px}
  .recruit-content{padding:56px 20px;flex-direction:column}
  .recruit-img{max-width:100%}
  .recruit-float-card{display:none}
  .recruit-clip{height:30px}
  .contact-methods{grid-template-columns:1fr;max-width:100%;border-radius:6px}
  .contact-phone{padding:40px 24px}
  .contact-phone .tel{font-size:2rem}
  .contact-email{padding:40px 24px}
  .footer-grid{grid-template-columns:1fr;gap:32px;padding:0 20px}
  .copyright{padding:20px 20px}
  .cta-banner{padding:48px 0}
}
@media(max-width:600px){
  .hero-btns{flex-direction:column;align-items:flex-start}
  .hero-btns .btn{width:100%;max-width:300px;justify-content:center}
  .numbers-grid{gap:12px}
  .num-card{padding:20px 12px}
  .numbers-val{font-size:2.2rem !important}
  .recruit-btns{flex-direction:column}
  .recruit-btns .btn{width:100%;justify-content:center}
  .recruit-merits{flex-direction:column}
}

/* ============================================
   Page KV (sub-page key visual)
   ============================================ */
.page-kv{
  position:relative;height:340px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--navy-dark) 0%,var(--navy) 50%,var(--navy-light) 100%);
}
.page-kv-bg{position:absolute;inset:0}
.page-kv-bg img{width:100%;height:100%;object-fit:cover;object-position:center 70%}
.page-kv-overlay{
  position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(30,58,48,.95) 0%,rgba(43,76,63,.88) 50%,rgba(30,58,48,.93) 100%);
}
.page-kv-en{font-size:.85rem;font-weight:700;letter-spacing:.15em;color:#1ab88a!important;text-transform:uppercase;margin-bottom:16px}
.page-kv::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(168deg, transparent 30%, rgba(0,160,118,.06) 31%, rgba(0,160,118,.06) 31.3%, transparent 31.6%),
    linear-gradient(168deg, transparent 55%, rgba(0,160,118,.04) 55.3%, rgba(0,160,118,.04) 55.6%, transparent 55.9%);
}
.page-kv-content{
  position:relative;z-index:2;height:100%;
  max-width:var(--max-w);margin:0 auto;padding:0 48px;
  display:flex;flex-direction:column;justify-content:center;color:#fff;
}
.page-kv-label{
  display:inline-flex;align-items:center;gap:12px;
  font-size:.72rem;font-weight:700;letter-spacing:.2em;
  color:var(--accent-light);text-transform:uppercase;margin-bottom:16px;
}
.page-kv-label::before{
  content:"";display:block;width:40px;height:2px;background:var(--accent);
}
.page-kv-content h1{
  font-size:clamp(2.2rem,4.5vw,3.2rem);font-weight:900;
  letter-spacing:.06em;line-height:1.25;
  text-shadow:0 2px 24px rgba(0,0,0,.3);
}
.page-kv-clip{
  position:absolute;bottom:-1px;left:0;right:0;z-index:3;
  height:60px;overflow:hidden;
}
.page-kv-clip svg{display:block;width:100%;height:100%}

/* ============================================
   Breadcrumb
   ============================================ */
.breadcrumb{
  background:var(--bg);border-bottom:1px solid var(--border-light);
  padding:16px 0;font-size:.85rem;color:var(--text-sub);
}
.breadcrumb .container{max-width:var(--max-w);margin:0 auto;padding:0 48px}
.breadcrumb a{color:var(--text-sub);transition:color .2s;font-weight:500}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{margin:0 10px;opacity:.5}

/* ============================================
   Article Body (single post layout)
   ============================================ */
.article-body{max-width:960px;margin:0 auto;padding:80px 48px}
.article-meta{display:flex;align-items:center;gap:16px;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--border-light)}
.article-date{font-size:.85rem;color:var(--accent);font-weight:600}
.article-cat{font-size:.75rem;font-weight:600;color:var(--navy);background:var(--bg-light);padding:4px 12px;border-radius:3px;letter-spacing:.04em}
.article-body h1{font-size:clamp(1.5rem,3vw,2rem);font-weight:900;color:var(--text);line-height:1.5;margin-bottom:40px;letter-spacing:.02em}
.article-body p{font-size:1rem;color:var(--text-body);line-height:2;margin-bottom:20px}
.article-body img{max-width:100%;height:auto;border-radius:var(--radius);margin:24px 0}
.article-back{text-align:center;margin-top:48px;padding-top:40px;border-top:1px solid var(--border-light)}
.article-back a{display:inline-flex;align-items:center;gap:8px;font-size:.9rem;font-weight:600;color:var(--navy);padding:14px 32px;border:1.5px solid var(--border);border-radius:var(--radius);transition:all .2s}
.article-back a:hover{border-color:var(--navy);background:var(--bg-light)}
@media(max-width:768px){
  .article-body{padding:48px 20px}
}

/* ============================================
   Article Format (single post typography)
   ============================================ */
.entry-content {
  font-size: 16px;
  line-height: 2.0;
  color: #1A2B21;
}

/* Paragraph */
.entry-content p {
  margin-bottom: 1.8em;
}
.entry-content p:last-child {
  margin-bottom: 0;
}

/* Headings */
.entry-content h2 {
  font-size: 24px;
  font-weight: 700;
  color: #1A2B21;
  padding-left: 16px;
  border-left: 4px solid #17643D;
  margin: 3em 0 1.2em;
  line-height: 1.6;
  letter-spacing: .04em;
}
.entry-content h3 {
  font-size: 20px;
  font-weight: 700;
  color: #1A2B21;
  padding-bottom: 8px;
  border-bottom: 2px solid #DDE5DF;
  margin: 2.5em 0 1em;
  line-height: 1.6;
  letter-spacing: .03em;
}
.entry-content h4 {
  font-size: 17px;
  font-weight: 700;
  color: #17643D;
  margin: 2em 0 .8em;
  line-height: 1.6;
}

/* First heading no top margin */
.entry-content > h2:first-child,
.entry-content > h3:first-child,
.entry-content > h4:first-child {
  margin-top: 0;
}

/* Lists */
.entry-content ul,
.entry-content ol {
  margin: 1.5em 0;
  padding-left: 1.5em;
}
.entry-content li {
  margin-bottom: .6em;
  line-height: 1.9;
}
.entry-content ul li::marker {
  color: #17643D;
}

/* Blockquote */
.entry-content blockquote {
  background: #F7FAF8;
  border-left: 4px solid #2E8B57;
  margin: 2em 0;
  padding: 24px 28px;
  border-radius: 0 8px 8px 0;
  font-size: 15px;
  color: #6B7A72;
}
.entry-content blockquote p {
  margin-bottom: 0;
}

/* Images */
.entry-content img {
  border-radius: 8px;
  margin: 2em 0;
  box-shadow: 0 2px 12px rgba(0,0,0,.06);
}
.entry-content .wp-caption {
  max-width: 100%;
  margin: 2em 0;
}
.entry-content .wp-caption-text {
  font-size: 13px;
  color: #6B7A72;
  text-align: center;
  margin-top: 8px;
}

/* Table */
.entry-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 2em 0;
  font-size: 15px;
}
.entry-content th {
  background: #17643D;
  color: #fff;
  font-weight: 600;
  padding: 12px 16px;
  text-align: left;
  font-size: 14px;
  letter-spacing: .03em;
}
.entry-content td {
  padding: 12px 16px;
  border-bottom: 1px solid #DDE5DF;
}
.entry-content tr:nth-child(even) td {
  background: #F7FAF8;
}

/* Links */
.entry-content a {
  color: #17643D;
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color .2s;
}
.entry-content a:hover {
  color: #125432;
}

/* Strong / Bold */
.entry-content strong {
  font-weight: 700;
  color: #1A2B21;
}

/* Horizontal Rule */
.entry-content hr {
  border: none;
  border-top: 1px solid #DDE5DF;
  margin: 3em 0;
}

/* Show entry-header on single posts (hidden by Astra Override) */
.entry-header {
  display: block !important;
  max-width: 800px;
  margin-bottom: 40px;
  padding-bottom: 20px;
  border-bottom: 1px solid #DDE5DF;
}

/* Article Title */
.entry-title {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: .04em;
  color: #1A2B21;
  margin-bottom: 12px;
}

/* Post Meta */
.entry-meta {
  font-size: 13px;
  color: #6B7A72;
}

/* ============================================
   Single Post Article Container (Astra override)
   ============================================ */
.single-post #page{font-family:'Noto Sans JP',sans-serif;color:var(--text-body);line-height:1.85;font-size:17px}
.single-post .site-content{background:#fff}
.single-post .ast-container{max-width:100%;margin:0;padding:0}
.single-post #primary{width:100%!important;max-width:100%!important}
.single-post .site-main{width:100%!important}
.single-post #secondary{display:none!important}
.single-post .entry-header{margin-bottom:40px;padding-bottom:20px;border-bottom:1px solid var(--border-light)}
.single-post .entry-title{font-size:1.65rem!important;font-weight:900!important;color:var(--text)!important;letter-spacing:.04em;line-height:1.5!important}
.single-post .entry-meta{font-size:.82rem;color:var(--text-sub)}
.single-post .entry-meta .posted-on a{color:var(--text-sub)}
.single-post .entry-meta .byline{display:none}
.single-post .ast-article-single{background:#fff}

/* Single post responsive */
@media(max-width:900px){
  .page-kv{height:200px}
  .page-kv-content{padding:0 20px}
  .page-kv-content h1{font-size:1.8rem}
  .page-kv-clip{height:30px}
  .breadcrumb .container{padding:0 20px}
  .single-post .ast-container{padding:0}
}

/* ============================================
   CF7 Contact Form
   ============================================ */
.contact-form-section{padding:80px 0;background-color:#f8faf9}
.cf7-wrapper{max-width:680px;margin:0 auto;background-color:#fff;border-radius:16px;padding:48px 40px;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.cf7-form-group{margin-bottom:24px}
.cf7-form-group label{display:block;font-size:.9rem;font-weight:700;color:#333;margin-bottom:8px}
.cf7-req{display:inline-block;background-color:var(--accent);color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:4px;margin-left:8px;vertical-align:middle}
.cf7-form-group input[type="text"],
.cf7-form-group input[type="email"],
.cf7-form-group input[type="tel"],
.cf7-form-group select,
.cf7-form-group textarea{width:100%;padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .2s;background-color:#fafafa;box-sizing:border-box}
.cf7-form-group input:focus,
.cf7-form-group select:focus,
.cf7-form-group textarea:focus{outline:none;border-color:var(--accent);background-color:#fff}
.cf7-form-group textarea{min-height:160px;resize:vertical}
.cf7-form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23666' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:20px}
.cf7-privacy{margin:32px 0 0;padding:20px 24px;background-color:#f0f7f4;border-radius:8px;border:1px solid #e0ede6;text-align:center}
.cf7-privacy p{margin:0}
.cf7-privacy br{display:none!important}
.cf7-privacy label.cf7-privacy-label{display:inline!important;font-size:.95rem;line-height:2;font-weight:400}
.cf7-privacy .wpcf7-form-control-wrap,
.cf7-privacy .wpcf7-acceptance,
.cf7-privacy .wpcf7-list-item{display:inline!important;margin:0}
.cf7-privacy input[type="checkbox"]{width:18px;height:18px;vertical-align:middle;margin-right:8px;accent-color:var(--accent);cursor:pointer}
.cf7-privacy a{color:var(--accent);font-weight:700;text-decoration:underline}
.cf7-submit-wrap{text-align:center;margin-top:32px}
.cf7-submit-wrap input[type="submit"]{display:inline-block;background-color:var(--accent);color:#fff;border:none;padding:16px 56px;border-radius:50px;font-size:1.05rem;font-weight:700;cursor:pointer;letter-spacing:.08em;transition:background-color .2s,transform .2s}
.cf7-submit-wrap input[type="submit"]:hover{background-color:var(--accent-dark,#00856A);transform:translateY(-2px)}
.cf7-submit-wrap input[type="submit"]:disabled{opacity:.3;pointer-events:none;cursor:not-allowed}
.cf7-submit-wrap input[type="submit"]:not(:disabled){opacity:1}
.wpcf7-response-output{margin:24px 0 0!important;padding:16px!important;border-radius:8px!important;font-size:.9rem}
.wpcf7-not-valid-tip{color:#e74c3c;font-size:.8rem;margin-top:4px}
.wpcf7 br{display:none}
.contact-form-section .sec-heading-bar{margin:20px auto 0}
@media(max-width:900px){
  .contact-form-section{padding:56px 0}
  .cf7-wrapper{padding:32px 20px;border-radius:12px}
}
