/* ============================================================
   EGG BASE LAB — m-zec.com faithful clone
   ============================================================ */

/* ====== VARIABLES ====== */
:root {
  --red:      #C30D23;
  --red-dk:   #9a0b1c;
  --purple:   #352380;
  --purple2:  #3B1F83;
  --gray:     #7C8EA0;
  --gray-bg:  #F1F3F5;
  --text:     #555555;
  --text-dk:  #222222;
  --white:    #ffffff;
  --border:   #EDEDED;
  --header-h: 100px;
  --font:     'Zen Kaku Gothic New', 'Noto Sans JP', sans-serif;
  --font-en:  'Barlow', 'Ubuntu', sans-serif;
  --tr:       0.28s ease;
  /* grad */
  --grad:     linear-gradient(to right, #352380, #C30D23);
  /* aliases */
  --blue:     #352380;
  --blue-dark:#2a1b6a;
  --blue-light:#f0eeff;
  --orange:   #C30D23;
  --text-light:#666;
  --shadow:   0 2px 14px rgba(0,0,0,.07);
  --shadow-lg:0 4px 28px rgba(0,0,0,.14);
  --radius:   4px;
  --radius-lg:8px;
  --container:1080px;
}

/* ====== RESET ====== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font);
  color:var(--text);
  background:#fff;
  font-size:15px;
  line-height:1.85;
  -webkit-font-smoothing:antialiased;
  min-width:320px;
}
img{max-width:100%;height:auto;display:block;}
a{text-decoration:none;color:inherit;transition:opacity var(--tr);}
ul{list-style:none;}
address{font-style:normal;}
button{cursor:pointer;font-family:inherit;border:none;background:none;}

/* ====== CONTAINERS ====== */
.inner,.container{max-width:var(--container);margin-inline:auto;padding-inline:40px;}
.con_1054{max-width:1054px;margin-inline:auto;padding-inline:40px;}
.con_1160{max-width:1160px;margin-inline:auto;padding-inline:40px;}
.container-sm{max-width:820px;margin-inline:auto;padding-inline:40px;}

/* ====== GRADIENT UTILITIES ====== */
.grd-text {
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.grd-text-white {
  background: linear-gradient(to right, #fff, rgba(255,255,255,.65));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
/* ====== SHARED SECTION TITLE: large EN word (gradient) + small JP ====== */
.con-tit {
  font-family: var(--font-en);
  font-weight: 700;
  font-size: clamp(40px, 6vw, 72px);
  line-height: 1;
  letter-spacing: .04em;
  display: block;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 4px;
}
.con-s-tit {
  display: block;
  font-size: 13px;
  color: var(--gray);
  letter-spacing: .1em;
  margin-bottom: 24px;
}
/* ≡ prefix heading style (for News / Contact) */
.sec-bar-heading {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}
.sec-bar-heading::before {
  content: '≡';
  font-size: 28px;
  font-weight: 900;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
}
.sec-bar-heading .en-word {
  font-family: var(--font-en);
  font-size: clamp(26px, 3.5vw, 42px);
  font-weight: 700;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
}
.enb {
  font-family: var(--font-en);
  font-weight: 600;
  letter-spacing: .06em;
}

/* ====== HEADER — Image#16 style ====== */
#header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  height: var(--header-h);
  background: #fff;
  transition: height var(--tr), box-shadow var(--tr);
}
#header.scrolled {
  height: 72px;
  box-shadow: 0 2px 20px rgba(0,0,0,.08);
}
.header__inner {
  max-width: 1280px;
  margin-inline: auto;
  padding-inline: 36px;
  height: 100%;
  display: flex;
  align-items: center;
  gap: 0;
}

/* ---- Logo ---- */
.header-logo { flex-shrink: 0; margin-right: auto; }
.header-logo a { display: flex; flex-direction: column; align-items: flex-start; text-decoration: none; }
.header-logo-svg { display: block; }

/* ---- Desktop nav ---- */
#header-nav {
  display: flex;
  align-items: center;
  justify-content: center;
}
#header-nav ul {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
}
#header-nav li a {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 6px 20px;
  text-decoration: none;
  border: none;
  white-space: nowrap;
  transition: opacity var(--tr);
}
#header-nav li a:hover { opacity: .65; }
.nav-jp {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-dk);
  line-height: 1.3;
  font-family: var(--font);
}
.nav-en {
  font-family: var(--font-en);
  font-size: 10px;
  color: var(--gray);
  letter-spacing: .1em;
  margin-top: 3px;
  font-weight: 400;
}

/* ---- Hamburger (always visible) ---- */
.hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 7px;
  padding: 10px 12px;
  flex-shrink: 0;
  margin-left: 28px;
  cursor: pointer;
  background: none;
  border: none;
}
.hamburger span {
  display: block;
  width: 28px;
  height: 2.5px;
  background: var(--text-dk);
  border-radius: 2px;
  transition: transform var(--tr), opacity var(--tr);
}
.hamburger.active span:nth-child(1) { transform: translateY(9.5px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity: 0; }
.hamburger.active span:nth-child(3) { transform: translateY(-9.5px) rotate(-45deg); }

/* ---- Nav Drawer (slide from right) ---- */
.nav-drawer {
  position: fixed;
  top: 0; right: 0;
  width: min(340px, 88vw);
  height: 100vh;
  background: #fff;
  z-index: 1001;
  transform: translateX(100%);
  transition: transform .38s cubic-bezier(.4,0,.2,1);
  overflow-y: auto;
  box-shadow: -4px 0 32px rgba(0,0,0,.12);
  display: flex;
  flex-direction: column;
}
.nav-drawer.active { transform: translateX(0); }

.nav-drawer__header {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 20px 24px;
  border-bottom: 1px solid var(--border);
}
.nav-drawer__close {
  background: none;
  border: none;
  font-size: 22px;
  color: var(--text-dk);
  cursor: pointer;
  padding: 4px 8px;
  line-height: 1;
  transition: color var(--tr);
}
.nav-drawer__close:hover { color: var(--red); }

.nav-drawer__logo {
  padding: 28px 32px 20px;
  border-bottom: 1px solid var(--border);
}
.nav-drawer__nav { padding: 16px 0; flex: 1; }
.nav-drawer__nav ul { list-style: none; }
.nav-drawer__nav li {
  border-bottom: 1px solid var(--border);
}
.nav-drawer__nav li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 32px;
  font-size: 15px;
  font-weight: 500;
  color: var(--text-dk);
  text-decoration: none;
  transition: color var(--tr), padding-left var(--tr);
}
.nav-drawer__nav li a:hover { color: var(--purple); padding-left: 40px; opacity: 1; }
.nav-drawer__nav li a::after {
  content: '›';
  font-size: 18px;
  color: var(--gray);
}
.nav-drawer__nav li.drawer-contact a {
  color: var(--red);
  font-weight: 700;
}
.nav-drawer__footer {
  padding: 24px 32px;
  border-top: 1px solid var(--border);
  font-size: 11px;
  color: var(--gray);
}

/* ---- Nav overlay ---- */
.nav-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 1000;
}
.nav-overlay.active { display: block; }


/* ====== HERO (MV) — m-zec hexagonal clip-path ====== */
#mv {
  position: relative;
  margin-top: var(--header-h);
  background: #fff;
  overflow: hidden;
}

/* The ul/slider container — this gets the clip-path */
.mv-slide {
  position: relative;
  width: 100%;
  height: clamp(380px, 58vw, 680px);
}

/* Each slide: fills container, hexagonal clip-path applied */
.kv-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateX(60px);
  transition: opacity 1s ease, transform 1s ease;
  /* m-zec exact hexagon: left-concave, right-pointed */
  clip-path: polygon(
    0%    0.7%,
    93.2% 0.7%,
    99.3% 49.3%,
    93.8% 99.2%,
    0.4%  99.2%,
    6.1%  50.6%
  );
}
.kv-slide.active { opacity: 1; transform: translateX(0); }
.kv-slide img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
/* Subtle left-side dark overlay so text is readable */
.kv-slide::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(35,18,90,.35) 0%, transparent 60%);
}

/* Hero text — sits in the white left area (outside the clipped image) */
.kv-text-area {
  position: absolute;
  left: 76px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  max-width: 400px;
}
.kv-catch {
  font-size: clamp(22px, 3.5vw, 46px);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: .04em;
  /* Gradient text matching m-zec purple→red */
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 14px;
}
.kv-catch-en {
  font-family: var(--font-en);
  font-size: clamp(11px, 1.3vw, 14px);
  color: var(--gray);
  letter-spacing: .08em;
  line-height: 1.7;
}

/* KV controls */
.kv-prev,.kv-next{
  position:absolute;top:50%;translate:0 -50%;
  z-index:10;width:44px;height:44px;
  background:rgba(255,255,255,.7);
  border:1px solid var(--border);
  border-radius:50%;
  color:var(--text-dk);font-size:15px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background var(--tr);
}
.kv-prev{left:20px;}
.kv-next{right:80px;}
.kv-prev:hover,.kv-next:hover{background:rgba(255,255,255,.95);}
.kv-dots{
  position:absolute;bottom:16px;
  left:calc(6.1% + 20px);
  z-index:10;display:flex;gap:8px;
}
.kv-dot{
  width:7px;height:7px;border-radius:100px;
  background:rgba(100,80,180,.35);
  border:none;cursor:pointer;
  transition:background var(--tr),width var(--tr);padding:0;
}
.kv-dot.active{background:var(--purple);width:24px;}
.kv-scroll-label{
  position:absolute;bottom:24px;right:30px;
  z-index:10;
  font-family:var(--font-en);font-size:10px;
  color:var(--gray);letter-spacing:.2em;
  writing-mode:vertical-rl;
}


/* ====== INTRO SECTION ====== */
.intro {
  background: #fff;
  padding: 80px 0 70px;
  overflow: hidden;
}
.intro-inner {
  position: relative;
}

/* Floating images with m-zec hex clip-path */
.intro-img {
  position: absolute;
  overflow: hidden;
  clip-path: polygon(
    0%    2.8%,
    91.9% 2.8%,
    97.8% 47.4%,
    94.2% 97.4%,
    1.6%  97.4%,
    6.0%  52.9%
  );
}
.intro-img img { width:100%;height:100%;object-fit:cover;display:block; }
.intro-img.img01 {
  width: 220px; height: 320px;
  left: 0; top: 40px;
}
.intro-img.img02 {
  width: 180px; height: 260px;
  right: 0; top: 80px;
}

.intro-text {
  text-align: center;
  padding: 0 260px;
  position: relative;
  z-index: 1;
}
.intro-text p {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.intro-text span {
  display: block;
  font-size: 14.5px;
  line-height: 2.1;
  color: var(--text);
}
.intro-text span:first-child {
  font-size: 16px;
  font-weight: 700;
  color: var(--text-dk);
}

.intro-tagline {
  margin-top: 60px;
  text-align: center;
  position: relative;
  z-index: 1;
}
.intro-tagline h2 {
  font-size: clamp(24px, 4vw, 50px);
  font-weight: 900;
  line-height: 1.25;
  letter-spacing: .02em;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: inline-block;
}
.intro-tagline-en {
  display: block;
  font-family: var(--font-en);
  font-size: 13px;
  color: var(--gray);
  letter-spacing: .1em;
  margin-top: 12px;
  background: none;
  -webkit-text-fill-color: var(--gray);
}
.read-more-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 24px;
  font-family: var(--font-en);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--purple);
  border: 1px solid var(--purple);
  padding: 10px 24px;
  border-radius: 2px;
  transition: all var(--tr);
}
.read-more-btn::after { content: ' ›'; font-size: 16px; transition: transform var(--tr); }
.read-more-btn:hover { background: var(--purple); color: #fff; opacity: 1; }
.read-more-btn:hover::after { transform: translateX(4px); }

/* gradient version for dark bg */
.read-more-btn-grd {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 24px;
  font-family: var(--font-en);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .12em;
  color: #fff;
  background: var(--grad);
  padding: 10px 28px;
  border-radius: 2px;
  transition: opacity var(--tr);
}
.read-more-btn-grd::after { content: ' ›'; font-size: 16px; }
.read-more-btn-grd:hover { opacity: .85; }


/* ====== BOOKMARK ICON (■ arrow shape) ====== */
.sec-bookmark-icon {
  display: inline-block;
  width: 16px; height: 24px;
  background: var(--purple);
  clip-path: polygon(0% 0%, 70% 0%, 100% 50%, 70% 100%, 0% 100%);
  flex-shrink: 0;
}

/* ====== INTRO — 2-column: text left, photos right ====== */
.intro {
  background: #fff;
  padding: 120px 0 110px;
  overflow: hidden;
}
.intro-wrap {
  display: flex;
  align-items: stretch;
  max-width: 1160px;
  margin-inline: auto;
  padding-inline: 40px;
  gap: 0;
}

/* Left column */
.intro-left {
  flex: 0 0 50%;
  padding-right: 60px;
  border-left: 3px solid;
  border-image: var(--grad) 1;
  padding-left: 32px;
  display: flex;
  align-items: center;
}
.intro-left-inner { display: flex; flex-direction: column; gap: 22px; }
/* 各段落を上から下へ紺→紫→赤と色を変化させる */
.intro-para {
  font-size: 14.5px;
  line-height: 2.2;
}
.intro-left-inner .intro-para:nth-child(1) { color: #14105a; }
.intro-left-inner .intro-para:nth-child(2) { color: #1e1570; }
.intro-left-inner .intro-para:nth-child(3) { color: #2c1a7e; }
.intro-left-inner .intro-para:nth-child(4) { color: #3d1f80; }
.intro-para--grad {
  background: linear-gradient(to bottom, #4a208a 0%, #8a1560 50%, #C30D23 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 700;
  font-size: 15px;
}

/* Right column */
.intro-right {
  flex: 1;
  position: relative;
  min-height: 520px;
}
.intro-right-bg {
  position: absolute;
  right: -20px; top: 10%;
  width: 340px; height: 80%;
  background: var(--gray-bg);
  clip-path: polygon(
    0%    0.7%,
    93.2% 0.7%,
    99.3% 49.3%,
    93.8% 99.2%,
    0.4%  99.2%,
    6.1%  50.6%
  );
  z-index: 0;
}
.intro-photo {
  position: absolute;
  margin: 0;
  overflow: hidden;
  clip-path: polygon(
    0%    2.8%,
    91.9% 2.8%,
    97.8% 47.4%,
    94.2% 97.4%,
    1.6%  97.4%,
    6.0%  52.9%
  );
  z-index: 1;
}
.intro-photo img { width:100%; height:100%; object-fit:cover; display:block; }
.intro-photo--1 { width: 200px; height: 270px; left: 10px; top: 0; }
.intro-photo--2 { width: 170px; height: 230px; left: 140px; top: 130px; }
.intro-photo--3 { width: 200px; height: 270px; left: 20px; top: 260px; }

/* ====== SERVICE SECTION ====== */
.section-service { background: #fff; padding: 0 0 110px; }

.service-upper {
  display: flex;
  align-items: stretch;
}
/* Left: image with clip-path */
.service-upper__img-wrap {
  flex: 0 0 55%;
  position: relative;
  overflow: hidden;
  /* clip-path mirrored (right side concave) */
  clip-path: polygon(
    0%    0%,
    90%   0%,
    95%   50%,
    90%   100%,
    0%    100%
  );
}
.service-upper__img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  min-height: 500px;
}
/* Service image slider overlay */
.serv-slider {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 500px;
}
.serv-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1s ease;
}
.serv-slide.active { opacity: 1; }
.serv-slide img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}

/* Right: text panel */
.service-upper__text {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 60px 50px 60px 40px;
  background: var(--gray-bg);
}
.service-upper__text .con-s-tit { color: var(--gray); }
.service-upper__desc {
  font-size: 14px;
  line-height: 2.1;
  color: var(--text);
  margin-bottom: 28px;
}

/* Service 3 boxes */
.service-boxes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--border);
}
.service-box {
  display: block;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  background: var(--white);
  border-right: 1px solid var(--border);
  transition: background var(--tr);
}
.service-box:last-child { border-right: none; }
.service-box__bg {
  height: 200px;
  background-size: cover;
  background-position: center;
  position: relative;
  clip-path: polygon(0% 0%, 93% 0%, 97% 50%, 93% 100%, 0% 100%);
  transition: clip-path var(--tr);
}
.service-box:hover .service-box__bg {
  clip-path: polygon(0% 0%, 95% 0%, 100% 50%, 95% 100%, 0% 100%);
}
.service-box__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(53,35,128,.55) 0%, rgba(195,13,35,.35) 100%);
  transition: opacity var(--tr);
}
.service-box:hover .service-box__bg::after { opacity: .7; }
.service-box__num {
  position: absolute;
  bottom: 12px; left: 16px;
  z-index: 2;
  font-family: var(--font-en);
  font-size: 11px;
  font-weight: 700;
  color: rgba(255,255,255,.8);
  letter-spacing: .14em;
}
.service-box__body {
  padding: 24px 22px 22px;
}
.service-box__body h3 {
  font-size: 17px;
  font-weight: 700;
  color: var(--purple);
  margin-bottom: 10px;
  line-height: 1.4;
}
.service-box__body p {
  font-size: 13px;
  color: var(--text);
  line-height: 1.9;
  margin-bottom: 12px;
}
.service-box__body h4 .enb {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  color: var(--red);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.service-box__body h4 .enb::after {
  content: '›';
  font-size: 15px;
  font-family: var(--font-en);
  transition: transform var(--tr);
}
.service-box:hover .service-box__body h4 .enb::after { transform: translateX(4px); }


/* ====== SPECIAL SECTION ====== */
.section-special {
  background: var(--gray-bg);
  padding: 120px 0;
  position: relative;
  overflow: hidden;
}
.special-inner { max-width: 1160px; margin-inline: auto; padding-inline: 40px; }

/* Main large link */
.special-main-link { margin-bottom: 14px; }
.special-main {
  display: block;
  position: relative;
  height: 320px;
  background-size: cover;
  background-position: center;
  overflow: hidden;
  clip-path: polygon(
    0%    0.7%,
    93.2% 0.7%,
    99.3% 49.3%,
    93.8% 99.2%,
    0.4%  99.2%,
    6.1%  50.6%
  );
  text-decoration: none;
  transition: clip-path var(--tr);
}
.special-main:hover {
  clip-path: polygon(
    0%    0%,
    94%   0%,
    100%  50%,
    94%   100%,
    0%    100%,
    5%    50%
  );
}
.special-main__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(53,35,128,.72) 0%, rgba(195,13,35,.45) 60%, rgba(53,35,128,.2) 100%);
  transition: opacity var(--tr);
}
.special-main:hover .special-main__overlay { opacity: .85; }
.special-main__text {
  position: absolute;
  left: 9%;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  color: #fff;
}
.special-main__text h3 {
  font-size: clamp(20px, 3vw, 34px);
  font-weight: 700;
  margin-bottom: 8px;
  line-height: 1.3;
}
.special-main__text p {
  font-size: 13px;
  color: rgba(255,255,255,.75);
  margin-bottom: 16px;
}
.special-main__text .enb {
  font-size: 12px;
  letter-spacing: .14em;
  color: rgba(255,255,255,.75);
  border: 1px solid rgba(255,255,255,.45);
  padding: 6px 18px;
  display: inline-block;
  border-radius: 2px;
  transition: all var(--tr);
}
.special-main:hover .special-main__text .enb { background: rgba(255,255,255,.15); }

/* Sub links */
.special-sub-links {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}
.special-sub a {
  display: block;
  position: relative;
  height: 190px;
  background-size: cover;
  background-position: center;
  overflow: hidden;
  clip-path: polygon(
    0%    0.7%,
    93.2% 0.7%,
    99.3% 49.3%,
    93.8% 99.2%,
    0.4%  99.2%,
    6.1%  50.6%
  );
  text-decoration: none;
  transition: clip-path var(--tr);
}
.special-sub a:hover {
  clip-path: polygon(
    0%    0%,
    94%   0%,
    100%  50%,
    94%   100%,
    0%    100%,
    5%    50%
  );
}
.special-sub__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(53,35,128,.6), rgba(195,13,35,.4));
  transition: opacity var(--tr);
}
.special-sub a:hover .special-sub__overlay { opacity: .75; }
.special-sub__text {
  position: absolute;
  left: 10%;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  color: #fff;
}
.special-sub__text h4 {
  font-size: clamp(17px, 2.2vw, 24px);
  font-weight: 700;
  margin-bottom: 8px;
  line-height: 1.3;
}
.special-sub__text .enb {
  font-size: 11px;
  letter-spacing: .14em;
  color: rgba(255,255,255,.65);
  border: 1px solid rgba(255,255,255,.35);
  padding: 4px 14px;
  display: inline-block;
  border-radius: 2px;
}


/* ====== WORKS SECTION ====== */
.section-works {
  background: #fff;
  padding: 80px 0;
}
.sec-title-row { margin-bottom: 40px; }
.works-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.work-card {
  background: var(--white);
  border-radius: 4px;
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: transform var(--tr), box-shadow var(--tr);
}
.work-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.work-card__thumb {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: #e0dff0;
  clip-path: polygon(0% 0%, 93% 0%, 97% 50%, 93% 100%, 0% 100%);
}
.work-card__thumb img {
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s ease;display:block;
}
.work-card:hover .work-card__thumb img { transform: scale(1.05); }
.work-card__body { padding: 16px 18px; }
.work-card__cat { font-size: 10.5px; font-weight: 700; color: var(--red); letter-spacing: .08em; margin-bottom: 6px; text-transform: uppercase; }
.work-card__title { font-size: 14px; font-weight: 700; color: var(--text-dk); line-height: 1.5; }
.work-card:hover .work-card__title { color: var(--purple); }
.section-btn-wrap { text-align: center; margin-top: 44px; }


/* ====== NEWS SECTION — Image#3: horizontal header + clip-path cards ====== */
.section-news {
  background: var(--gray-bg);
  padding: 120px 0;
}

/* Header row: heading + CATEGORY + pills on one line */
.news-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 28px;
}
.news-heading-group {
  display: flex;
  align-items: center;
  gap: 10px;
}
.news-en {
  font-size: clamp(24px, 3vw, 38px);
  font-weight: 700;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
}
.news-ja {
  font-size: 13px;
  color: var(--gray);
  letter-spacing: .06em;
}
.news-cats-group {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.news-cat-label {
  font-size: 10px;
  color: var(--gray);
  letter-spacing: .18em;
  margin-right: 4px;
}
.nc-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  color: var(--gray);
  border: 1px solid var(--border);
  border-radius: 100px;
  padding: 4px 14px;
  transition: all var(--tr);
  text-decoration: none;
  white-space: nowrap;
}
.nc-pill:hover, .nc-pill.active {
  color: #fff;
  background: var(--purple);
  border-color: var(--purple);
  opacity: 1;
}
.nc-pill-icon { font-size: 9px; }

/* Card rows */
.news-cards { display: flex; flex-direction: column; }
.news-card-row {
  display: flex;
  align-items: center;
  gap: 18px;
  background: #fff;
  padding: 18px 22px;
  margin-bottom: 6px;
  text-decoration: none;
  color: var(--text);
  clip-path: polygon(0% 0%, 97% 0%, 100% 50%, 97% 100%, 0% 100%);
  transition: clip-path var(--tr), background var(--tr);
  position: relative;
}
.news-card-row:hover {
  background: #f0eeff;
  clip-path: polygon(0% 0%, 98% 0%, 100% 50%, 98% 100%, 0% 100%);
  opacity: 1;
}
.nc-date {
  font-size: 12px;
  color: var(--gray);
  letter-spacing: .06em;
  white-space: nowrap;
  min-width: 90px;
  flex-shrink: 0;
}
.nc-icon {
  font-size: 10px;
  color: var(--purple);
  flex-shrink: 0;
}
.nc-title {
  flex: 1;
  font-size: 14px;
  color: var(--text-dk);
  line-height: 1.5;
}
.nc-more {
  font-size: 11px;
  color: var(--red);
  letter-spacing: .1em;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 5px;
  opacity: 0;
  transition: opacity var(--tr);
}
.news-card-row:hover .nc-more { opacity: 1; }
.nc-dot { color: var(--red); font-size: 8px; }

/* Keep old news styles for inner pages */
.news-con {
  display: flex;
  gap: 56px;
  align-items: flex-start;
}
.news-tit-area {
  flex: 0 0 260px;
  position: sticky;
  top: calc(var(--header-h) + 20px);
}
.news-tit-area > p {
  font-size: 13px;
  color: var(--gray);
  letter-spacing: .1em;
  margin-bottom: 20px;
  margin-left: 40px; /* indent past the ≡ */
}
.news-cate-area {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.news-cate-area > span.enb {
  font-size: 10px;
  color: var(--gray);
  letter-spacing: .18em;
  margin-bottom: 4px;
  display: block;
}
.nc-btn {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 700;
  color: var(--gray);
  padding: 5px 14px;
  border: 1px solid var(--border);
  border-radius: 100px;
  transition: all var(--tr);
  cursor: pointer;
  width: fit-content;
}
.nc-btn:hover, .nc-btn.active {
  color: #fff;
  background: var(--purple);
  border-color: var(--purple);
  opacity: 1;
}
/* News color dots */
.nc-btn::before {
  content: '●';
  font-size: 8px;
  margin-right: 6px;
}
.nc-all::before { color: var(--gray); }
.nc-news::before { color: var(--purple); }
.nc-blog::before { color: var(--red); }
.nc-works::before { color: var(--gray); }

/* News list */
.news-link-list { flex: 1; }
.news-link-wrap { border-bottom: 1px solid var(--border); }
.news-link-wrap:first-child { border-top: 1px solid var(--border); }
.news-link-item {
  display: block;
  padding: 20px 16px 20px 12px;
  transition: background var(--tr);
  text-decoration: none;
  color: var(--text);
  position: relative;
}
.news-link-item::after {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--grad);
  transform: scaleY(0);
  transition: transform var(--tr);
  transform-origin: bottom;
}
.news-link-item:hover { background: rgba(53,35,128,.04); opacity: 1; }
.news-link-item:hover::after { transform: scaleY(1); }
.news-link-item > div {
  display: flex;
  align-items: center;
  gap: 16px;
}
.news-link-item .day {
  font-family: var(--font-en);
  font-size: 11.5px;
  color: var(--gray);
  letter-spacing: .06em;
  white-space: nowrap;
  flex-shrink: 0;
  min-width: 86px;
}
.news-link-item p {
  flex: 1;
  font-size: 14px;
  color: var(--text-dk);
  line-height: 1.55;
}
.news-link-item .more {
  font-family: var(--font-en);
  font-size: 11px;
  color: var(--red);
  letter-spacing: .1em;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity var(--tr), transform var(--tr);
  transform: translateX(-6px);
}
.news-link-item:hover .more { opacity: 1; transform: none; }


/* ====== CONTACT CTA SECTION — Image#10 style ====== */
.section-contact-cta {
  background: #e8e8e8;
  padding: 120px 0 0;
  position: relative;
  overflow: hidden;
}
/* Right-pointing pentagon background (fills right ~40% of section) */
.contact-hex-deco {
  position: absolute;
  right: 0; top: 0; bottom: 0;
  width: 46%;
  background: #dcdcdc;
  clip-path: polygon(8% 0%, 100% 0%, 100% 100%, 8% 100%, 0% 50%);
  pointer-events: none;
  z-index: 0;
}
.contact-wrap { position: relative; z-index: 1; padding-bottom: 0; }

/* ■ Contact heading */
.contact-heading-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 32px;
}
.contact-en {
  font-size: clamp(26px, 3.5vw, 44px);
  font-weight: 700;
  line-height: 1;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.contact-ja {
  font-size: 13px;
  color: var(--gray);
  letter-spacing: .06em;
}

/* Tel | divider | number+hours | Mail | divider | button */
.contact-tel-mail {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 0;
  padding: 28px 0;
}
/* Tel / Mail labels */
.ctm-tel, .ctm-mail {
  flex-shrink: 0;
  padding: 0 28px 0 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 5px;
}
.ctm-mail { padding: 0 28px; }
.ctm-label {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}
.ctm-label-en {
  font-family: var(--font-en);
  font-size: 28px;
  font-weight: 700;
  color: var(--purple);
  letter-spacing: .04em;
  line-height: 1;
}
.ctm-label-ja {
  font-size: 11px;
  color: var(--gray);
  letter-spacing: .04em;
}
/* Vertical dividers */
.ctm-divider {
  width: 1px;
  height: 56px;
  background: #aaa;
  flex-shrink: 0;
}
/* Phone number + hours */
.ctm-tel-content {
  flex: 1;
  padding: 0 36px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ctm-number {
  font-size: clamp(28px, 3.2vw, 44px);
  font-weight: 700;
  font-family: var(--font-en);
  color: var(--purple);
  text-decoration: none;
  letter-spacing: .03em;
  line-height: 1;
  transition: opacity var(--tr);
}
.ctm-number:hover { opacity: .75; }
.ctm-note { font-size: 12px; color: #666; }
/* Form button — white with thin border */
.ctm-form-btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: #fff;
  color: var(--text-dk);
  border: 1px solid #bbb;
  padding: 22px 44px;
  font-size: 15.5px;
  font-weight: 400;
  letter-spacing: .02em;
  text-decoration: none;
  transition: all var(--tr);
  flex-shrink: 0;
  white-space: nowrap;
  line-height: 1;
  min-width: 260px;
  justify-content: center;
  margin-left: 32px;
}
.ctm-form-btn:hover {
  border-color: var(--purple);
  color: var(--purple);
  opacity: 1;
}
.ctm-form-btn__icon { display: flex; align-items: center; color: #aaa; flex-shrink: 0; width: 20px; height: 20px; }
.ctm-form-btn__icon svg { width: 20px; height: 20px; }
.ctm-form-btn:hover .ctm-form-btn__icon { color: var(--purple); }
.ctm-dot { font-size: 9px; color: #bbb; margin-left: 8px; }

/* Building illustration */
.contact-illust {
  margin-top: 40px;
  width: 100%;
  overflow: hidden;
  line-height: 0;
}
.contact-illust svg { width: 100%; height: auto; display: block; }

/* keep legacy aliases */
.tell-mail {
  display: flex;
  justify-content: center;
  gap: 80px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.tm-con { text-align: center; }
.tel-number {
  display: block;
  font-family: var(--font-en);
  font-size: clamp(30px, 4.5vw, 52px);
  font-weight: 700;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-decoration: none;
  letter-spacing: .04em;
  margin-bottom: 8px;
  transition: opacity var(--tr);
}
.tel-number:hover { opacity: .75; }
.mail-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--grad);
  color: #fff;
  padding: 16px 36px;
  border-radius: 2px;
  font-size: 14.5px;
  font-weight: 700;
  letter-spacing: .04em;
  text-decoration: none;
  transition: opacity var(--tr), transform var(--tr);
  margin-bottom: 10px;
}
.mail-btn::after { content: ' ›'; font-family: var(--font-en); font-size: 18px; }
.mail-btn:hover { opacity: .85; transform: translateY(-2px); }


/* ====== FOOTER — Image#5: white 3-column ====== */
#footer {
  background: #fff;
  color: var(--text);
  border-top: 1px solid var(--border);
}
.footer-new {
  padding: 56px 0 0;
  position: relative;
  overflow: hidden;
}
/* Right-side hex decoration */
.footer-new::after {
  content: '';
  position: absolute;
  right: -60px; top: 20px;
  width: 380px; height: 380px;
  background: var(--gray-bg);
  clip-path: polygon(
    0%    0.7%,
    93.2% 0.7%,
    99.3% 49.3%,
    93.8% 99.2%,
    0.4%  99.2%,
    6.1%  50.6%
  );
  pointer-events: none;
  z-index: 0;
}
.footer-new .inner {
  display: grid;
  grid-template-columns: 220px 200px 1fr;
  gap: 48px;
  align-items: start;
  max-width: 1200px;
  position: relative;
  z-index: 1;
}

/* Col 1: Logo + address */
.footer-col-brand {}
.footer-logo-svg { margin-bottom: 4px; }
.footer-logo-svg svg { display: block; }
.footer-brand-name { display: none; } /* name is now inside SVG */
.footer-logo-bars {
  display: flex;
  gap: 5px;
  align-items: flex-end;
  margin-bottom: 12px;
}
.footer-logo-bars span {
  display: block;
  width: 6px;
  background: var(--purple);
  border-radius: 2px;
}
.footer-logo-bars span:nth-child(1) { height: 18px; }
.footer-logo-bars span:nth-child(2) { height: 26px; background: var(--red); }
.footer-logo-bars span:nth-child(3) { height: 14px; }
.footer-logo-bars span:nth-child(4) { height: 22px; background: var(--red); }
.footer-logo-bars span:nth-child(5) { height: 10px; }
.footer-brand-name {
  font-family: var(--font-en);
  font-weight: 700;
  font-size: 16px;
  color: var(--purple);
  letter-spacing: .06em;
  margin-bottom: 4px;
  display: block;
}
.footer-brand-ja {
  font-size: 10.5px;
  color: var(--gray);
  margin-bottom: 20px;
  display: block;
}
.footer-addr-block {
  background: var(--gray-bg);
  clip-path: polygon(0% 0%, 88% 0%, 100% 50%, 88% 100%, 0% 100%);
  padding: 18px 40px 18px 20px;
  margin-bottom: 14px;
}
.footer-addr {
  font-size: 12.5px;
  color: var(--text);
  line-height: 2;
}
.footer-copy-line {
  font-size: 11px;
  color: var(--gray);
  margin-top: 4px;
}

/* Col 2: Main Contents nav with dividers */
.footer-col-nav h3,
.footer-col-special h3 {
  font-family: var(--font-en);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .12em;
  margin-bottom: 14px;
  padding-bottom: 0;
  border-bottom: none;
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.footer-nav-list { list-style: none; }
.footer-nav-list li {
  border-bottom: 1px solid var(--border);
}
.footer-nav-list li a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 4px;
  font-size: 13px;
  color: var(--text-dk);
  transition: color var(--tr), padding-left var(--tr);
}
.footer-nav-list li a:hover {
  color: var(--purple);
  padding-left: 8px;
  opacity: 1;
}
.footer-nav-list li a::after { display: none; }
.footer-nav-plus {
  float: right;
  font-size: 16px;
  color: var(--gray);
  font-weight: 300;
}

/* Col 3: Special Contents — 3 portrait image cards in horizontal row */
.footer-col-special {}
.footer-special-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.footer-special-card {
  display: block;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  aspect-ratio: 3/4;
  background: #1a1a2e;
  transition: opacity var(--tr);
}
.footer-special-card:hover { opacity: .88; }
.footer-special-card__img {
  position: absolute;
  inset: 0;
}
.footer-special-card__img img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}
.footer-special-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.65) 0%, rgba(0,0,0,.1) 50%, transparent 100%);
}
.footer-special-card__body {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 16px 16px 18px;
  z-index: 2;
}
.footer-special-card__title {
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  line-height: 1.4;
  margin-bottom: 8px;
}
.footer-special-card__more {
  font-family: var(--font-en);
  font-size: 11px;
  color: rgba(255,255,255,.85);
  letter-spacing: .1em;
  display: flex;
  align-items: center;
  gap: 5px;
}
.footer-special-card__dot { font-size: 7px; color: rgba(255,255,255,.7); }

/* Bottom bar */
.footer-bottom-bar {
  margin-top: 44px;
  padding: 16px 0;
  border-top: 1px solid var(--border);
  text-align: center;
}
.footer-bottom-bar p {
  font-size: 11px;
  color: var(--gray);
  letter-spacing: .04em;
}

/* Legacy purple footer aliases (kept for inner pages) */
.footer-top {
  padding: 52px 0 40px;
  border-bottom: 1px solid var(--border);
}
.footer-top .inner {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 56px;
  align-items: start;
}
.footer-logo-text {
  font-family: var(--font-en);
  font-weight: 700;
  font-size: 18px;
  color: var(--purple);
  letter-spacing: .06em;
  margin-bottom: 10px;
}
.footer-company { font-size: 12px; color: var(--gray); margin-bottom: 14px; }
.footer-address { font-size: 13px; color: var(--text); line-height: 2; }
.footer-nav-cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.footer-nav-col h3 {
  font-size: 13px; font-weight: 700; color: var(--purple);
  margin-bottom: 12px; padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}
.footer-nav-col a {
  display: block; font-size: 12.5px;
  color: var(--text);
  padding: 4px 0;
  transition: color var(--tr);
}
.footer-nav-col a:hover { color: var(--purple); opacity: 1; }
.footer-bottom { padding: 18px 0; text-align: center; border-top: 1px solid var(--border); }
.footer-copy { font-size: 12px; color: var(--gray); letter-spacing: .04em; }
.footer__in{display:flex;flex-direction:column;align-items:center;gap:22px;text-align:center;padding:40px 24px 20px;}
.footer-logo{display:flex;align-items:center;gap:10px;}
.footer-logo__name{font-family:var(--font-en);font-weight:700;font-size:18px;color:var(--purple);letter-spacing:.06em;}
.footer-nav__list{display:flex;flex-wrap:wrap;justify-content:center;gap:6px 16px;}
.footer-nav__list a{font-size:13px;color:var(--text);transition:color var(--tr);}
.footer-nav__list a:hover{color:var(--purple);opacity:1;}

/* ====== BACK TO TOP ====== */
.pagetop,.back-to-top{
  position:fixed;bottom:26px;right:26px;z-index:900;
  width:50px;height:50px;border-radius:50%;
  background:var(--grad);
  color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 18px rgba(0,0,0,.2);
  opacity:0;visibility:hidden;transform:translateY(10px);
  transition:opacity var(--tr),visibility var(--tr),transform var(--tr);
  border:none;cursor:pointer;
}
.pagetop.visible,.back-to-top.is-visible{opacity:1;visibility:visible;transform:none;}
.pagetop:hover,.back-to-top:hover{opacity:.85;}


/* ====== INNER PAGE STYLES ====== */
.page-hero {
  margin-top: var(--header-h);
  background: var(--grad);
  padding: 60px 0;
  text-align: center;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.page-hero__en,.page-hero-subtitle{font-family:var(--font-en);font-weight:700;font-size:clamp(40px,5.5vw,64px);letter-spacing:.06em;line-height:1;margin-bottom:12px;display:block;color:#fff;}
.page-hero__ja,.page-hero-title{font-size:16px;color:rgba(255,255,255,.7);display:block;}

.section{padding:80px 0;}
.section-sm{padding:54px 0;}
.section-gray{background:var(--gray-bg);}
.section-purple{background:var(--purple);color:#fff;}

.sec-title{text-align:center;margin-bottom:52px;}
.sec-title h2{font-size:clamp(22px,2.8vw,30px);font-weight:700;color:var(--text-dk);}
.sec-title h2 span{display:block;font-family:var(--font-en);font-size:12px;font-weight:400;letter-spacing:3px;color:var(--gray);margin-top:8px;text-transform:uppercase;}
.sec-title::after{content:'';display:block;width:48px;height:3px;background:var(--grad);margin:14px auto 0;border-radius:2px;}
.section-label{display:block;font-family:var(--font-en);font-size:11px;font-weight:700;letter-spacing:.22em;color:var(--red);text-transform:uppercase;margin-bottom:10px;}

/* About */
.about-row,.about-twocol,.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.about-heading{font-size:clamp(18px,2.2vw,24px);font-weight:700;color:var(--purple);line-height:1.5;margin-bottom:18px;}
.about-lead{font-size:15px;color:var(--text);line-height:2;margin-bottom:14px;}
.about-nums{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:24px;}
.about-num-item{background:#fff;border-radius:4px;padding:18px 10px;text-align:center;box-shadow:var(--shadow);}
.about-num-val{font-family:var(--font-en);font-weight:700;font-size:34px;color:var(--purple);line-height:1;}
.about-num-val span{font-size:14px;color:var(--gray);}
.about-num-lbl{font-size:11px;color:var(--gray);margin-top:4px;}
.about-col-img img{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);object-fit:cover;display:block;}
.about-number-item{background:#fff;border-radius:4px;padding:28px 20px;text-align:center;box-shadow:var(--shadow);}
.about-number-item .num{font-family:var(--font-en);font-weight:700;font-size:48px;color:var(--purple);line-height:1;margin-bottom:8px;}
.about-number-item .num span{font-size:20px;color:var(--gray);}
.about-number-item .label{font-size:12px;color:var(--gray);}

/* Strengths */
.strengths-grid,.strengths{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.strength-card,.str-card{display:flex;gap:16px;background:#fff;padding:24px;border-radius:4px;border-left:4px solid var(--red);box-shadow:var(--shadow);transition:transform var(--tr),box-shadow var(--tr);}
.strength-card:hover,.str-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.strength-number,.str-num{font-family:var(--font-en);font-weight:700;font-size:42px;color:rgba(195,13,35,.12);line-height:1;flex-shrink:0;width:56px;text-align:center;}
.strength-content-title,.str-title{font-size:16px;font-weight:700;color:var(--purple);margin-bottom:8px;}
.strength-content-text,.str-text{font-size:13.5px;color:var(--text);line-height:1.9;}

/* Steps */
.steps-flow{position:relative;}
.steps-flow::before{content:'';position:absolute;left:35px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom, var(--red), rgba(195,13,35,.08));}
.step-row{display:flex;gap:24px;align-items:flex-start;margin-bottom:30px;position:relative;}
.step-row:last-child{margin-bottom:0;}
.step-badge{width:70px;height:70px;border-radius:50%;background:var(--grad);color:#fff;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1;}
.step-badge .sn{font-size:9px;letter-spacing:.1em;opacity:.8;}
.step-badge .sv{font-family:var(--font-en);font-weight:700;font-size:22px;line-height:1;}
.step-box{flex:1;background:#fff;border-radius:4px;padding:20px 24px;box-shadow:var(--shadow);margin-top:12px;}
.step-title{font-size:16px;font-weight:700;color:var(--purple);margin-bottom:6px;}
.step-text{font-size:13.5px;color:var(--text);line-height:1.9;}
.step-dur{display:inline-block;margin-top:8px;font-size:12px;color:var(--red);background:rgba(195,13,35,.08);padding:2px 12px;border-radius:2px;}

/* Company */
.co-table{width:100%;border-collapse:collapse;}
.co-table th,.co-table td{padding:16px 20px;font-size:14px;text-align:left;border-bottom:1px solid var(--border);}
.co-table th{width:160px;font-weight:700;color:var(--purple);background:var(--gray-bg);white-space:nowrap;}

/* Contact form */
.contact-form{max-width:620px;margin:0 auto;}
.form-group{margin-bottom:24px;}
.form-label{display:block;font-size:14px;font-weight:700;margin-bottom:8px;}
.form-label .req{margin-left:8px;font-size:11px;color:#fff;background:var(--red);padding:2px 8px;border-radius:2px;}
.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:4px;font-size:15px;font-family:var(--font);transition:border-color var(--tr);background:#fff;}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--purple2);box-shadow:0 0 0 2px rgba(59,31,131,.08);}
.form-textarea{min-height:160px;resize:vertical;}
.form-submit{text-align:center;margin-top:32px;}
.form-privacy{font-size:13px;color:var(--text);margin-bottom:24px;text-align:center;}
.form-privacy a{color:var(--red);border-bottom:1px solid rgba(195,13,35,.3);}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 30px;border-radius:4px;font-size:14px;font-weight:700;letter-spacing:.04em;transition:all var(--tr);cursor:pointer;border:2px solid transparent;}
.btn-red,.btn-primary,.btn-orange{background:var(--red);color:#fff;border-color:var(--red);}
.btn-red:hover,.btn-primary:hover,.btn-orange:hover{background:var(--red-dk);border-color:var(--red-dk);transform:translateY(-2px);opacity:1;}
.btn-purple,.btn-blue{background:var(--purple);color:#fff;border-color:var(--purple);}
.btn-purple:hover,.btn-blue:hover{background:var(--purple2);border-color:var(--purple2);transform:translateY(-2px);opacity:1;}
.btn-outline-red,.btn-outline-blue{background:transparent;color:var(--red);border-color:var(--red);}
.btn-outline-red:hover,.btn-outline-blue:hover{background:var(--red);color:#fff;transform:translateY(-2px);opacity:1;}
.btn-white,.btn-white-fill{background:#fff;color:var(--purple);border-color:#fff;box-shadow:0 3px 14px rgba(0,0,0,.14);}
.btn-white:hover,.btn-white-fill:hover{background:#f0eeff;transform:translateY(-2px);opacity:1;}
.btn-outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.6);}
.btn-outline-white:hover{background:rgba(255,255,255,.14);transform:translateY(-2px);opacity:1;}

/* CTA / News inner aliases */
.cta-band,.cta-section{background:var(--purple);padding:80px 0;text-align:center;color:#fff;}
.cta-band .inner,.cta-section .inner{display:flex;flex-direction:column;align-items:center;gap:20px;}
.cta-band__title,.cta-title{font-size:clamp(22px,3vw,30px);font-weight:700;line-height:1.5;color:#fff;}
.cta-band__text,.cta-text{font-size:15px;color:rgba(255,255,255,.8);line-height:1.95;}
.cta-band__btns,.cta-btns,.cta-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;}
.news-list{border-top:2px solid var(--border);}
.news-item{display:flex;align-items:center;gap:14px;padding:16px 10px;border-bottom:1px solid var(--border);transition:background var(--tr);}
.news-item:hover{background:#f8f7fc;}
.news-date{font-family:var(--font-en);font-size:12.5px;color:var(--gray);min-width:92px;white-space:nowrap;flex-shrink:0;}
.news-cat{font-size:11px;font-weight:700;color:#fff;background:var(--red);padding:2px 10px;border-radius:2px;white-space:nowrap;flex-shrink:0;}
.news-title{font-size:14.5px;color:var(--text-dk);line-height:1.5;transition:color var(--tr);}
a.news-title:hover{color:var(--red);}
.single-wrap{display:grid;grid-template-columns:1fr 280px;gap:44px;align-items:start;}
.post-meta{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.post-date{font-size:12px;color:var(--gray);}
.post-cat{font-size:11px;font-weight:700;color:#fff;background:var(--red);padding:2px 10px;border-radius:2px;}
.post-title{font-size:clamp(18px,2.5vw,26px);font-weight:700;color:var(--purple);line-height:1.4;margin-bottom:24px;}
.post-thumb{width:100%;border-radius:4px;margin-bottom:28px;}
.post-body{font-size:15px;line-height:2;color:var(--text);}
.post-body h2{font-size:20px;color:var(--purple);margin:36px 0 12px;padding-left:14px;border-left:4px solid var(--red);}
.post-body h3{font-size:17px;color:var(--purple);margin:26px 0 10px;}
.post-body p{margin-bottom:18px;}
.post-body ul,.post-body ol{padding-left:22px;margin-bottom:18px;}
.post-body li{margin-bottom:7px;list-style:disc;}
.post-body a{color:var(--red);border-bottom:1px solid rgba(195,13,35,.3);}
.sidebar-widget{background:#fff;border-radius:4px;padding:22px;box-shadow:var(--shadow);margin-bottom:22px;}
.sidebar-widget-title{font-family:var(--font-en);font-weight:700;font-size:15px;color:var(--purple);margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid rgba(53,35,128,.12);}
.pagination{display:flex;justify-content:center;gap:8px;margin-top:44px;}
.pagination a,.pagination span{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:14px;font-weight:700;transition:background var(--tr),color var(--tr);}
.pagination a{color:var(--red);background:rgba(195,13,35,.08);}
.pagination a:hover{background:var(--red);color:#fff;opacity:1;}
.pagination .current{background:var(--red);color:#fff;}


/* ====== INNER PAGE — SERVICE ROWS ====== */
.serv-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
  padding: 72px 0;
  border-bottom: 1px solid var(--border);
}
.serv-row:last-child { border-bottom: none; }
.serv-row--rev .serv-row__img { order: 2; }
.serv-row--rev .serv-row__txt  { order: 1; }
.serv-row__img {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--gray-bg);
  clip-path: polygon(0% 0%, 93% 0%, 97% 50%, 93% 100%, 0% 100%);
}
.serv-row__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.serv-row__num {
  font-family: var(--font-en);
  font-size: 72px;
  font-weight: 700;
  color: rgba(53,35,128,.07);
  line-height: 1;
  margin-bottom: -4px;
}
.serv-row__title {
  font-size: clamp(20px,2.4vw,26px);
  font-weight: 700;
  color: var(--purple);
  line-height: 1.4;
  margin-bottom: 14px;
  padding-left: 14px;
  border-left: 4px solid var(--red);
}
.serv-row__text { font-size: 14.5px; color: var(--text); line-height: 2; margin-bottom: 18px; }
.serv-row__list { list-style: none; }
.serv-row__list li {
  font-size: 13.5px;
  color: var(--text);
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 10px;
}
.serv-row__list li::before {
  content: '';
  width: 5px;
  height: 5px;
  background: var(--red);
  border-radius: 50%;
  flex-shrink: 0;
}

/* ====== INNER PAGE — CONTACT ====== */
.contact-page-wrap {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 60px;
  align-items: start;
}
.cp-info-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 20px 0;
  border-bottom: 1px solid var(--border);
}
.cp-info-item:first-child { border-top: 1px solid var(--border); }
.cp-info-icon {
  width: 44px;
  height: 44px;
  background: var(--gray-bg);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--purple);
}
.cp-info-label { font-size: 10.5px; font-weight: 700; letter-spacing: .12em; color: var(--gray); text-transform: uppercase; margin-bottom: 3px; }
.cp-info-value { font-size: 15px; font-weight: 700; color: var(--text-dk); }
.cp-info-note { font-size: 12px; color: var(--gray); margin-top: 2px; }

/* Form tags */
.form-req { margin-left: 8px; font-size: 11px; font-weight: 700; color: #fff; background: var(--red); padding: 2px 8px; border-radius: 2px; }
.form-opt { margin-left: 8px; font-size: 11px; color: var(--gray); background: var(--gray-bg); padding: 2px 8px; border-radius: 2px; }
.form-notice { font-size: 12px; color: var(--gray); line-height: 1.8; margin: 20px 0; text-align: center; }
.form-notice a { color: var(--red); border-bottom: 1px solid rgba(195,13,35,.3); }
.form-submit-btn {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; padding: 18px 24px;
  background: var(--purple); color: #fff;
  font-size: 15px; font-weight: 700;
  border: none; border-radius: 4px;
  cursor: pointer;
  transition: background var(--tr), transform var(--tr);
  font-family: var(--font);
  letter-spacing: .04em;
}
.form-submit-btn:hover { background: var(--purple2); transform: translateY(-2px); }

/* ====== INNER PAGE — WORKS filter ====== */
.works-filter { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 40px; }
.works-filter__btn {
  font-size: 13px; font-weight: 700;
  padding: 7px 20px;
  border-radius: 2px;
  border: 2px solid var(--border);
  color: var(--gray); background: #fff;
  cursor: pointer;
  transition: all var(--tr);
  font-family: var(--font);
}
.works-filter__btn.active,
.works-filter__btn:hover { border-color: var(--red); color: var(--red); }

/* works card desc */
.work-card__desc { font-size: 13px; color: var(--text); line-height: 1.7; margin-top: 5px; }

/* ====== INNER PAGE — ABOUT equipment ====== */
.equip-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 40px;
}
.equip-card {
  background: #fff;
  border-radius: 4px;
  padding: 22px 20px;
  box-shadow: var(--shadow);
  border-top: 3px solid var(--purple);
}
.equip-card__name { font-size: 14px; font-weight: 700; color: var(--purple); margin-bottom: 8px; }
.equip-card__spec { font-size: 12.5px; color: var(--text); line-height: 1.85; }

/* ====== SCROLL ANIMATIONS ====== */
.js-reveal{opacity:0;translate:0 1.8rem;transition:opacity .5s ease, translate .5s ease;}
.js-reveal.revealed{opacity:1;translate:0 0;}
.js-reveal[data-delay="1"]{transition-delay:.12s;}
.js-reveal[data-delay="2"]{transition-delay:.24s;}
.js-reveal[data-delay="3"]{transition-delay:.36s;}
.js-reveal-left{opacity:0;translate:-2.5rem 0;transition:opacity .5s ease, translate .5s ease;}
.js-reveal-left.revealed{opacity:1;translate:0 0;}
.js-reveal-right{opacity:0;translate:2.5rem 0;transition:opacity .5s ease, translate .5s ease;}
.js-reveal-right.revealed{opacity:1;translate:0 0;}
.scr-anin{opacity:0;scale:0.92;transition:opacity .45s ease, scale .45s cubic-bezier(0.44,0.42,0.24,1.55);}
.scr-anin.scr-anin--on{opacity:1;scale:1;}
.fadein{opacity:0;translate:0 2rem;transition:opacity .5s ease, translate .5s ease;}
.fadein.scroll-fade{opacity:1;translate:0 0;}
.fadein-left{opacity:0;translate:-2.5rem 0;transition:opacity .5s ease, translate .5s ease;}
.fadein-left.scroll-fade{opacity:1;translate:0 0;}
.fadein-right{opacity:0;translate:2.5rem 0;transition:opacity .5s ease, translate .5s ease;}
.fadein-right.scroll-fade{opacity:1;translate:0 0;}


/* ====== RESPONSIVE ====== */
@media (max-width: 1024px) {
  .works-grid{grid-template-columns:repeat(2,1fr);}
  .footer-new .inner{grid-template-columns:1fr 1fr;gap:32px;}
  .intro-img{display:none;}
  .intro-wrap{flex-direction:column;gap:40px;}
  .intro-left{flex:none;border-left:none;border-top:3px solid;border-image:var(--grad) 1;padding-left:0;padding-right:0;padding-top:20px;}
  .intro-right{min-height:380px;}
  .news-con{flex-direction:column;gap:28px;}
  .news-tit-area{position:static;flex:none;}
  .news-cate-area{flex-direction:row;flex-wrap:wrap;gap:6px;}
  .contact-tel-mail{flex-wrap:wrap;}
  .ctm-tel-content{flex:1 1 200px;}
  .ctm-form-btn{margin:16px auto;width:100%;justify-content:center;}
}

@media (max-width: 768px) {
  :root{--header-h:68px;}
  .hamburger{display:flex;}
  #header-nav { display: none; }

  .mv-slide{height:clamp(280px, 70vw, 480px);}
  .kv-slide{
    clip-path: polygon(
      4%   0%,
      96%  0%,
      100% 50%,
      96%  100%,
      4%   100%,
      0%   50%
    );
  }
  .kv-text-area{left:20px;max-width:55%;}
  .kv-catch{font-size:clamp(18px,5vw,28px);}
  .kv-next{right:40px;}
  .kv-scroll-label{display:none;}

  .intro{padding:50px 0 40px;}
  .intro-text{padding:0 20px;}
  .intro-tagline h2{font-size:clamp(20px,6vw,34px);}

  .service-upper{flex-direction:column;}
  .service-upper__img-wrap{flex:none;width:100%;clip-path:polygon(0% 0%,100% 0%,93% 100%,0% 100%);min-height:280px;}
  .service-upper__img-wrap img{min-height:280px;}
  .serv-slider{min-height:280px;}
  .service-upper__text{padding:36px 24px;}
  .service-boxes{grid-template-columns:1fr;}
  .service-box{border-right:none;border-bottom:1px solid var(--border);}
  .service-box:last-child{border-bottom:none;}

  .special-sub-links{grid-template-columns:1fr;}
  .special-main{height:240px;}
  .special-sub a{height:160px;}

  .works-grid{grid-template-columns:repeat(2,1fr);}
  .work-card__thumb{clip-path:none;}

  .section,.section-works,.section-special,.section-news,.section-contact-cta{padding:56px 0;}
  .about-row,.about-twocol,.about-inner{grid-template-columns:1fr;gap:32px;}
  .strengths-grid,.strengths{grid-template-columns:1fr;}
  .serv-row{grid-template-columns:1fr;gap:32px;}
  .serv-row--rev .serv-row__img{order:0;}
  .serv-row--rev .serv-row__txt{order:0;}
  .serv-row__img{clip-path:none;}
  .contact-page-wrap{grid-template-columns:1fr;gap:40px;}
  .equip-grid{grid-template-columns:repeat(2,1fr);}
  .single-wrap{grid-template-columns:1fr;}
  .footer-new .inner{grid-template-columns:1fr;}
  .footer-nav-cols{grid-template-columns:1fr 1fr;}
  .cta-band__btns,.cta-btns,.cta-actions{flex-direction:column;align-items:center;}
  .tell-mail{flex-direction:column;gap:40px;}
  .news-con{flex-direction:column;gap:28px;}
  .news-tit-area{position:static;}
  .news-cate-area{flex-direction:row;flex-wrap:wrap;}
  .news-link-item .more{display:none;}
  .news-header-row{flex-direction:column;align-items:flex-start;}
  .contact-tel-mail{flex-direction:column;}
  .ctm-divider{width:100%;height:1px;align-self:auto;}
  .ctm-tel,.ctm-mail{flex-direction:row;gap:12px;padding:16px 20px;}
  .ctm-tel-content{padding:12px 20px;}
  .ctm-form-btn{margin:0;width:100%;border-radius:0;justify-content:center;border:none;border-top:1px solid var(--border);}
  .nc-more{display:none;}
}

@media (max-width: 480px) {
  .kv-prev,.kv-next{display:none;}
  .works-grid{grid-template-columns:1fr;}
  .footer-nav-cols{grid-template-columns:1fr;}
  .btn{padding:12px 22px;}
  .inner,.container,.con_1054,.con_1160{padding-inline:20px;}
  .service-boxes{grid-template-columns:1fr;}
  .equip-grid{grid-template-columns:1fr;}
}
