/* Shared page components */
.hero-subtitle {
  max-width: 920px;
  margin: 0 auto 38px;
  color: var(--muted);
  font-size: var(--body-lg);
  line-height: 1.8;
}
.hero-eyebrow { margin: 0 0 18px; color: var(--muted); }
.lang-switcher {
  display: flex;
  gap: 8px;
  align-items: center;
}
.lang-btn {
  width: 40px;
  height: 32px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(250,249,245,.28);
  color: rgba(250,249,245,.9);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.lang-btn:hover,
.lang-btn.is-active {
  background: var(--page-bg);
  color: var(--black);
  border-color: var(--page-bg);
}
.page-main {
  padding-top: 160px;
  padding-bottom: 140px;
}
.page-hero {
  padding: 30px 0 80px;
}
.page-eyebrow { margin: 0 0 18px; color: var(--muted); }
.page-title {
  margin: 0 0 22px;
  font-family: var(--font-display, var(--font-main));
  font-size: clamp(48px, 6.2vw, 92px);
  line-height: 1.02;
  letter-spacing: -.05em;
}
.page-lead {
  max-width: 900px;
  color: var(--muted);
  font-size: var(--body-lg);
  line-height: 1.8;
  margin: 0;
}
.page-section {
  padding: 34px 0 90px;
}
.panel {
  background: rgba(255,253,248,.72);
  border: 1px solid rgba(217,215,208,.5);
  box-shadow: var(--shadow-soft);
  border-radius: var(--radius-xl);
}
.content-grid {
  display: grid;
  grid-template-columns: minmax(280px, 360px) 1fr;
  gap: 34px;
  align-items: stretch;
}
.service-nav {
  padding: 28px;
}
.service-nav .label { color: var(--muted); display:block; margin-bottom: 18px; }
.service-list { display: grid; gap: 12px; }
.service-button {
  width: 100%;
  text-align: left;
  padding: 18px 18px 18px 20px;
  background: transparent;
  border: 1px solid rgba(217,215,208,.4);
  border-radius: 20px;
  cursor: pointer;
  transition: border-color .25s ease, transform .25s ease, background .25s ease;
}
.service-button:hover, .service-button.is-active {
  background: var(--white-card);
  border-color: rgba(255, 90, 40, .35);
  transform: translateY(-1px);
}
.service-button strong { display:block; font-size: 18px; margin-bottom: 6px; }
.service-button span { color: var(--muted); font-size: 14px; line-height: 1.6; }
.service-display { overflow: hidden; }
.service-display-image {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
}
.service-display-copy { padding: 28px 30px 34px; }
.service-display-copy p { margin: 0; color: var(--muted); line-height: 1.8; font-size: 17px; }
.service-display-meta { margin: 0 0 8px; color: var(--muted); }
.service-display-copy h2 { margin: 0 0 12px; font-size: clamp(28px, 3vw, 42px); line-height: 1.14; }
.category-grid, .contact-grid, .shop-grid, .detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
}
.category-card, .detail-card, .contact-card, .shop-card {
  overflow: hidden;
}
.category-card img, .shop-card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display:block;
}
.card-copy { padding: 22px 24px 26px; }
.card-copy h3 { margin: 0 0 8px; font-size: 26px; line-height: 1.16; }
.card-copy p { margin: 0; color: var(--muted); line-height: 1.75; }
.process-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.process-step {
  padding: 24px;
}
.process-step .step-no {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--black);
  color: var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 18px;
}
.process-step h3 { margin: 0 0 10px; font-size: 22px; }
.process-step p { margin: 0; color: var(--muted); line-height: 1.75; }
.company-banner {
  width: 100%;
  border-radius: var(--radius-xl);
  aspect-ratio: 16 / 7;
  object-fit: cover;
  box-shadow: var(--shadow-soft);
  border: 1px solid rgba(217,215,208,.55);
}
.shop-hero-grid {
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 32px;
  align-items: center;
}
.shop-side-points {
  display:grid;
  gap: 16px;
}
.point-card { padding: 20px; }
.point-card h3 { margin: 0 0 8px; font-size: 20px; }
.point-card p { margin: 0; color: var(--muted); line-height: 1.7; }
.contact-grid {
  grid-template-columns: .9fr 1.1fr;
  align-items: start;
}
.contact-card { padding: 28px; }
.contact-list { display:grid; gap: 18px; }
.contact-list p { margin: 0; color: var(--muted); line-height: 1.75; }
.contact-form-card { padding: 34px; }
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.field { display: grid; gap: 8px; }
.field.full { grid-column: 1 / -1; }
.field label { font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.field input, .field textarea {
  width: 100%;
  border: 1px solid rgba(217,215,208,.8);
  background: var(--white-card);
  border-radius: 18px;
  padding: 14px 16px;
  font-size: 15px;
  color: var(--text);
}
.field textarea { min-height: 180px; resize: vertical; }
.form-note {
  margin: 0 0 18px;
  padding: 14px 18px;
  border-radius: 16px;
  font-size: 14px;
}
.form-note.is-success { background: rgba(38,160,89,.12); color: #1b5f34; }
.form-note.is-error { background: rgba(197,58,58,.12); color: #8a2323; }
.company-main { padding-top: 150px; }
.company-hero { padding-top: 28px; padding-bottom: 36px; }
.company-title, .company-lead { max-width: 980px; }
.company-title {
  margin: 0 0 24px;
  font-family: var(--font-display, var(--font-main));
  font-size: clamp(44px, 5vw, 74px);
  line-height: 1.04;
  letter-spacing: -.04em;
}
.company-lead { margin: 0; color: var(--muted); line-height: 1.8; font-size: var(--body-lg); }
.company-intro { padding-top: 24px; padding-bottom: 56px; }
.company-intro-card { padding: 40px; border-radius: var(--radius-xl); background: rgba(255,253,248,.72); border: 1px solid rgba(217,215,208,.55); box-shadow: var(--shadow-soft); }
.company-intro-card h2 { margin: 0 0 14px; font-size: clamp(28px, 3vw, 40px); line-height: 1.14; }
.company-intro-card p { margin: 0; color: var(--muted); line-height: 1.8; }
.company-table { border-radius: var(--radius-xl); overflow: hidden; border: 1px solid rgba(217,215,208,.55); box-shadow: var(--shadow-soft); }
.company-table-row { display: grid; grid-template-columns: 220px 1fr; }
.company-table-row:nth-child(odd) { background: rgba(255,253,248,.78); }
.company-table-row:nth-child(even) { background: rgba(244,243,239,.8); }
.company-table-label, .company-table-value { padding: 18px 22px; line-height: 1.8; }
.company-table-label { font-weight: 800; }
.company-map-card, .company-contact-card { padding: 26px; border-radius: var(--radius-xl); background: rgba(255,253,248,.72); border: 1px solid rgba(217,215,208,.55); box-shadow: var(--shadow-soft); }
.company-access { padding-top: 48px; padding-bottom: 120px; }
.company-access-grid { display: grid; grid-template-columns: .95fr 1.05fr; gap: 28px; }
.company-map-top { display:flex; align-items:center; justify-content:space-between; margin-bottom: 18px; }
.company-map-card iframe { width: 100%; height: 480px; border: 0; border-radius: 24px; }
@media (max-width: 1100px) {
  .content-grid, .contact-grid, .shop-hero-grid, .company-access-grid { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 768px) {
  .page-main { padding-top: 132px; padding-bottom: 96px; }
  .page-hero, .page-section { padding-bottom: 56px; }
  .category-grid, .contact-grid, .shop-grid, .detail-grid { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: 1fr; }
  .company-table-row { grid-template-columns: 1fr; }
  .company-map-card iframe { height: 360px; }
  .form-grid { grid-template-columns: 1fr; }
  .contact-form-card, .contact-card { padding: 24px; }
  .lang-switcher { gap: 6px; }
  .lang-btn { width: 36px; }
}

/* V3: stronger interaction module + unified editorial image tone */
.hero-media img,
.category-card img,
.shop-card img,
.service-display-image,
.company-banner,
.growth-visual img,
.update-card img,
.image-card img {
  filter: saturate(.86) contrast(.96) brightness(1.02);
}

.section-desc {
  max-width: 760px;
  margin: -24px 0 44px;
  color: var(--muted);
  font-size: var(--body-md);
  line-height: 1.8;
}

.growth-lab {
  padding: 26px;
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 26px;
  align-items: stretch;
  background:
    radial-gradient(circle at 86% 10%, rgba(255, 255, 255, .86), transparent 32%),
    linear-gradient(135deg, rgba(255,253,248,.78), rgba(240,239,235,.82));
}

.growth-lab-sidebar {
  display: grid;
  gap: 12px;
  align-content: start;
}

.growth-lab-sidebar .label {
  color: var(--muted);
  margin-bottom: 6px;
}

.growth-tab {
  width: 100%;
  text-align: left;
  border: 1px solid rgba(217,215,208,.62);
  background: rgba(255,253,248,.52);
  border-radius: 22px;
  padding: 18px 18px;
  cursor: pointer;
  transition: transform .25s ease, background .25s ease, border-color .25s ease, box-shadow .25s ease;
}

.growth-tab strong {
  display: block;
  font-size: 18px;
  line-height: 1.2;
  margin-bottom: 6px;
}

.growth-tab span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}

.growth-tab:hover,
.growth-tab.is-active {
  transform: translateY(-1px);
  background: var(--white-card);
  border-color: rgba(255, 92, 46, .42);
  box-shadow: 0 18px 54px rgba(27,27,27,.07);
}

.growth-lab-stage {
  min-height: 640px;
  display: grid;
  grid-template-rows: minmax(340px, 1fr) auto;
  overflow: hidden;
  border-radius: 32px;
  border: 1px solid rgba(217,215,208,.55);
  background: rgba(255,253,248,.68);
}

.growth-visual {
  position: relative;
  overflow: hidden;
  background: var(--panel-bg);
}

.growth-visual img {
  width: 100%;
  height: 100%;
  min-height: 380px;
  object-fit: cover;
  transform: scale(1.01);
  transition: opacity .28s ease, transform .6s ease;
}

.growth-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to top, rgba(0,0,0,.36), rgba(0,0,0,0) 58%),
    radial-gradient(circle at 82% 18%, rgba(255,255,255,.32), transparent 34%);
  pointer-events: none;
}

.growth-overlay {
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 24px;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.growth-chip {
  min-height: 74px;
  border-radius: 18px;
  padding: 12px 13px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(255,255,255,.72);
  backdrop-filter: blur(18px);
  display: flex;
  align-items: end;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.35;
}

.growth-copy {
  padding: 28px 30px 32px;
}

.growth-copy .label {
  color: var(--muted);
  margin: 0 0 10px;
}

.growth-copy h2 {
  margin: 0 0 12px;
  font-size: clamp(30px, 3vw, 46px);
  line-height: 1.08;
  letter-spacing: -.035em;
}

.growth-copy > p {
  margin: 0;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.8;
}

.growth-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 22px;
}

.growth-point {
  border-radius: 16px;
  background: rgba(244,243,239,.78);
  border: 1px solid rgba(217,215,208,.5);
  padding: 14px;
  color: var(--text);
  font-size: 14px;
  line-height: 1.55;
  font-weight: 700;
}

.mail-note {
  margin-top: 18px;
  color: var(--muted);
  line-height: 1.75;
  font-size: 13px;
}

@media (max-width: 1100px) {
  .growth-lab { grid-template-columns: 1fr; }
  .growth-lab-stage { min-height: unset; }
}

@media (max-width: 768px) {
  .growth-lab { padding: 18px; border-radius: 28px; }
  .growth-overlay { grid-template-columns: repeat(2, minmax(0, 1fr)); left: 16px; right: 16px; bottom: 16px; }
  .growth-points { grid-template-columns: 1fr; }
  .growth-copy { padding: 24px; }
}
.company-main .company-hero {
  text-align: left;
}

.company-main .company-eyebrow,
.company-main .company-title,
.company-main .company-lead {
  text-align: left;
  margin-left: 0;
  margin-right: auto;
}

.company-main .company-title,
.company-main .company-lead {
  max-width: 980px;
}