@charset "UTF-8";
/* CSS Document */

/* =========================
   GemiD Basic CSS (2026)
   Update: no radius / no shadow / bg #efede8
   ========================= */

/* ---- Reset-ish ---- */
*,
*::before,
*::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: #444;
  background: #efede8; /* ★統一背景 */
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: geometricPrecision;
font-family: var(--gm-body-font);
}

img, video {
  max-width: 100%;
  height: auto;
  display: block;
}

a { color: inherit; text-decoration: none; }
button { font: inherit; }

.center{text-align: center!importantimportant;}

.gm-body,
.gm-copy-ja,
.gm-title,
.gm-eyebrow,
.gm-label {
  font-family: var(--gm-body-font); /* 日本語も含めて全体統一 */
}

/* ---- Tokens ---- */
:root{
  --gm-max: 1440px;
  --gm-pad: clamp(22px, 4vw, 64px);
  --gm-gap: clamp(18px, 2.6vw, 44px);
  --gm-secY: clamp(56px, 7vw, 110px);

  --gm-border: rgba(20,20,20,.16);
  --gm-border-strong: rgba(20,20,20,.24);

  --gm-title-font: "Bodoni Moda", serif;
   --gm-body-font: "Noto Sans JP", system-ui, -apple-system, "Hiragino Sans", "Noto Sans JP", "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* ---- Layout ---- */
.gm-container{
  width: min(var(--gm-max), 100% - (var(--gm-pad) * 2));
  margin-inline: auto;
}

.gm-main{ overflow-x: clip; }

/* ---- Header ---- */
.gm-header{
  height: 80px;
  position: sticky;
  top: 0;
  z-index: 50;
  background: #c7c1b8; /* ★背景に馴染ませる */
  backdrop-filter: blur(10px);
}

.gm-header__inner{
  height: 100%;
  display: grid;
  place-items: center;
  padding-inline: var(--gm-pad);
}

.gm-brand__logo{
  height: 28px;
  width: auto;
}

/* ---- Hero ---- */
.gm-hero{
  min-height: calc(100svh - 80px);
  position: relative;
  background: #000;
}

.gm-hero__videoWrap{
  width: 100%;
  height: calc(100svh - 80px);
  overflow: hidden;
}

.gm-hero__video{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.gm-hero__overlay{
  position: absolute;
  inset: auto 0 clamp(18px, 3vw, 36px) 0;
  padding-inline: var(--gm-pad);
  pointer-events: none;
}

.gm-hero__kicker{
  margin: 0;
  color: rgba(255,255,255,.88);
  letter-spacing: .18em;
  font-size: 12px;
  text-transform: uppercase;
}

/* ---- リブランドメッセージ ---- */

.gm-section--rebrand{
  text-align: center;  /* センター合わせ */
  padding-block: clamp(36px, 5vw, 72px);
}

.gm-section--rebrand::before{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.08); /* わずかなグラデーション */
  z-index: -1;
}

.gm-rebrand-date{
  margin: 0;
  font-family: var(--gm-body-font);
  font-size: clamp(18px, 2vw, 20px);
  font-weight: 500;
  color: rgba(20,20,20,.62);
}

.gm-title--rebrand{
  margin: 14px 0;
  font-family: var(--gm-title-font);
  font-weight: 400;
  letter-spacing: .02em;
  font-size: clamp(26px, 3vw, 36px);
  color: rgba(20,20,20,.92);
}

.gm-copy-ja{
  font-size: clamp(15px, 1.05vw, 16px);  /* 他のテキストサイズと同じに調整 */
  line-height: 1.7;
  color: rgba(20,20,20,.86);
  margin: 0;
}



/* ---- Typography ---- */
.gm-eyebrow{
  margin: 0 0 12px;
  letter-spacing: .20em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(20,20,20,.62);
}

.gm-title{
  font-family: var(--gm-title-font);
  font-weight: 400;
  letter-spacing: .01em;
  line-height: 1.18;
  margin: 0 0 14px;
  font-size: clamp(28px, 3.2vw, 46px);
}

.gm-title--section{
  font-size: clamp(26px, 2.7vw, 40px);
}

/* ---- Japanese Key Copy ---- */
.gm-split__content .gm-copy-ja{
  font-family: var(--gm-body-font);
  font-weight: 500;
  margin: 26px 0 26px;
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.9;
  letter-spacing: .05em;
  color: rgba(20,20,20,.92);
}

.gm-body{
  margin: 0;
  font-family: var(--gm-body-font);
  font-size: clamp(15px, 1.05vw, 16px);
  color: rgba(20,20,20,.86);
}

.gm-body--light{ color: rgba(20,20,20,.86); } /* ★統一背景なので白文字は使わない */

.gm-br--pc{ display: none; }
@media (min-width: 960px){
  .gm-br--pc{ display: inline; }
}

/* ---- Sections ---- */
.gm-section{
  padding-block: var(--gm-secY);
}

/* ---- Split blocks (5段) ---- */
.gm-section--splits .gm-container{
  display: grid;
  gap: clamp(36px, 6vw, 90px);
}

.gm-split{
  display: grid;
  gap: var(--gm-gap);
  align-items: center;
}

.gm-split__media{
  margin: 0;
  overflow: hidden;
  background: transparent;
  border: none;         /* ★枠なし */
  border-radius: 0;     /* ★角丸なし */
  box-shadow: none;     /* ★影なし */
}

.gm-split__media img{
  width: 100%;
  height: auto;     /* ★画像の比率を保持 */
  object-fit: initial; /* ★トリミングしない */
}

.gm-split__content{
  padding-block: clamp(6px, 1vw, 12px);
}

/* PC: 5:5, 反転対応 */
@media (min-width: 960px){
  .gm-split{
    grid-template-columns: 1fr 1fr;
    column-gap: clamp(34px, 4vw, 70px);
  }
  .gm-split--reverse .gm-split__media{ order: 2; }
  .gm-split--reverse .gm-split__content{ order: 1; }
}



/* ---- Products grid ---- */
.gm-sectionHeader{
  margin-bottom: clamp(22px, 3vw, 38px);
}

.gm-grid{
  display: grid;
  gap: clamp(18px, 2.2vw, 26px);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (min-width: 720px){
  .gm-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (min-width: 1100px){
  .gm-grid{ grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

/* ★商品ごとの枠線・影を無くす */
.gm-card{
  border: none;
  border-radius: 0;
  padding: 0;
  text-align: center; 
  background: transparent;
  box-shadow: none;
}

.gm-card__media{
  margin: 0 0 12px;
  overflow: hidden;
  background: transparent;
  border: none;
  border-radius: 0;
}

.gm-card__media img{
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.gm-card__name{
  margin: 0 0 10px;
  font-family: var(--gm-title-font);
  font-weight: 400;
  letter-spacing: .02em;
  line-height: 1.4;
  font-size: 16px;
}

.gm-card__meta{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;   /* ← 追加 */
}

/* メタ情報だけは“細いボーダーの角丸なし”で維持 */
.gm-pill{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border: 1px solid var(--gm-border-strong);
  border-radius: 0; /* ★角丸なし */
  font-size: 12px;
  letter-spacing: .06em;
  color: rgba(20,20,20,.74);
  white-space: nowrap;
  background: transparent;
}

/* ---- Commitment placeholder ---- */
.gm-placeholder{
  height: clamp(220px, 30vw, 420px);
  border: 1px dashed rgba(20,20,20,.22);
  border-radius: 0; /* ★角丸なし */
  background: rgba(0,0,0,.02);
}

/* ---- CTA (背景統一：#efede8) ---- */
.gm-cta{
  padding-block: clamp(52px, 6vw, 90px);
  background: #efede8;
}

.gm-cta__banner{
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;

  padding: clamp(40px, 6vw, 80px); /* 少し余白を広げる */

  border: none;          /* 枠線なし */
  border-radius: 0;      /* 角丸なし */
  background: url("https://gemid.jp/img/bg/2026rn_bg_online.jpg") center/cover no-repeat;
  color: #444;
  overflow: hidden;
}


.gm-title--cta{
  font-size: clamp(28px, 3vw, 44px);
  margin-bottom: 10px;
}

.gm-eyebrow--light{ color: rgba(20,20,20,.62); }
.gm-cta__arrow{
  font-size: 22px;
  opacity: .85;
}


/* ---- ラインナップ日本語 ---- */
.gm-section-copy-ja{
  margin-top: 18px;
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.9;
  letter-spacing: .04em;
  font-weight: 500;
  color: rgba(20,20,20,.85);
}

/* ---- Footer ---- */
.gm-footer{
  padding-block: clamp(26px, 3vw, 44px);
  background: #c7c1b8; /* header合わせ */
}

.gm-footer__inner{
  display: grid;
  gap: 12px;
  align-items: start;
}

.gm-footer__brand{
  font-family: var(--gm-title-font);
  font-weight: 400;
  letter-spacing: .04em;
  font-size: 18px;
}

.gm-footer__links{
  display: flex;
  flex-wrap: wrap;
  gap: 14px 18px;
  font-size: 13px;
  color: rgba(20,20,20,.62);
}

.gm-footer__links a:hover{ color: rgba(20,20,20,.9); }

.gm-footer__copy{
  font-size: 12px;
  color: rgba(20,20,20,.55);
}

/* ---- PageTop tab ---- */
.gm-pagetop{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 60;

  display: inline-flex;
  align-items: center;
  gap: 8px;

  padding: 10px 12px;
  border-radius: 0; /* ★角丸なし */
  border: 1px solid rgba(20,20,20,.18);
  background: rgba(239,237,232,.90); /* ★統一背景 */
  backdrop-filter: blur(10px);

  cursor: pointer;

  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
  transition: opacity .28s ease, transform .28s ease;
	
  color:#444;
}

.gm-pagetop:hover,
.gm-pagetop:focus {
  color: #444; /* ホバー時やフォーカス時も同様 */
}

/* gm-pagetop 内のテキストリンク部分も統一 */
.gm-pagetop__text {
  color: #444; /* テキストリンク部分 */
}

.gm-pagetop__text:hover,
.gm-pagetop__text:focus {
  color: #444; /* リンクのホバー時も統一 */
}


.gm-pagetop.is-show{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.gm-pagetop__icon{
  font-size: 14px;
  line-height: 1;
}

.gm-pagetop__text{
  font-size: 11px;
  letter-spacing: .18em;
}

/* ---- Minor responsive tweaks ---- */
@media (max-width: 767px){
  .gm-header{ height: 76px; }
  .gm-hero,
  .gm-hero__videoWrap{ min-height: calc(100svh - 76px); height: calc(100svh - 76px); }
  .gm-brand__logo{ height: 26px; }
  .gm-pagetop{ right: 14px; bottom: 14px; }
}


/* =========================
   Company page styles
   ========================= */

.gm-container--narrow{
  width: min(1300px, 100% - (var(--gm-pad) * 2));
  margin-inline: auto;
}

.gm-pageHero{
  padding-block: clamp(44px, 6vw, 92px);
}

.gm-pageKicker{
  margin: 0 0 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(20,20,20,.62);
}

.gm-pageTitle{
  margin: 0 0 14px;
  font-family: var(--gm-title-font);
  font-weight: 400;
  letter-spacing: .01em;
  line-height: 1.15;
  font-size: clamp(34px, 3.4vw, 54px);
}

.gm-pageLead{
  margin: 0;
  font-family: var(--gm-body-font);
  font-size: clamp(15px, 1.1vw, 16px);
  line-height: 1.9;
  color: rgba(20,20,20,.82);
}

.gm-inlineLink{
  text-decoration: underline;
  text-underline-offset: 3px;
}

.gm-company{
  padding-top: 0; /* hero直後なので詰める */
}

.gm-companyBlock{
  padding-block: clamp(34px, 4vw, 56px);
  border-top: 1px solid rgba(0,0,0,.14);
}

.gm-companyBlock:first-child{
  border-top: 1px solid rgba(0,0,0,.14);
}

.gm-companyList{
  margin: 22px 0 0;
}

.gm-companyRow{
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 18px;
  padding-block: 14px;
  border-bottom: 1px solid rgba(0,0,0,.10);
}

.gm-companyRow dt{
  font-size: 13px;
  letter-spacing: .10em;
  color: rgba(20,20,20,.62);
}

.gm-companyRow dd{
  margin: 0;
  font-family: var(--gm-body-font);
  font-size: 15px;
  color: rgba(20,20,20,.86);
}

.gm-companyBullets{
  margin: 0;
  padding-left: 1.2em;
}

.gm-companyBullets li{
  margin: 4px 0;
}

.gm-locations{
  display: grid;
  gap: 18px;
  margin-top: 22px;
}

.gm-locationTitle{
  margin: 0 0 8px;
  font-family: var(--gm-title-font);
  font-weight: 400;
  letter-spacing: .01em;
  font-size: 18px;
}

.gm-locationBody{
  margin: 0;
  font-family: var(--gm-body-font);
  font-size: 15px;
  line-height: 1.9;
  color: rgba(20,20,20,.86);
}

.gm-linkList{
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.gm-companyCta{
  margin-top: clamp(34px, 4vw, 56px);
}

/* Responsive */
@media (max-width: 820px){
  .gm-companyRow{
    grid-template-columns: 1fr;
    gap: 8px;
  }
}

