/* ============================================================
   base.css — リセット + CSS変数 + 共通タイポグラフィ
   HIDAMARI DENTAL — DELTA CLINIC アンカー（無彩色プレミアム）
   ============================================================ */

/* --- CSS Custom Properties（デザイン憲法 §3.6 実測値） --- */
:root {
  /* Surface（無彩色・温かいグレージュ基調） */
  --bg:        #F5F3F2;   /* 地色 */
  --bg-2:      #ECEAE6;   /* 一段沈めたパネル */
  --bg-3:      #E4E1DC;   /* もう一段 */
  --white:     #FFFFFF;
  --dark:      #1B1B1B;   /* ダーク面（治療/CTA/フッター） */
  --dark-2:    #111111;

  /* Ink */
  --ink:       #0A0A0A;   /* 主文字 */
  --ink-2:     #555555;   /* 副文字 */
  --ink-3:     #8C8A86;   /* 三次/キャプション */
  --line:      #D6D4CF;   /* 罫線 */
  --grey:      #B0B0AE;
  --on-dark:   #F5F3F2;
  --on-dark-2: rgba(245,243,242,0.62);
  --on-dark-3: rgba(245,243,242,0.38);
  --hair-dark: rgba(245,243,242,0.14);

  /* Easing（DELTA実測踏襲） */
  --ease-smooth: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --ease-mask:   cubic-bezier(0.65, 0, 0.2, 1);
  --ease-delta:      cubic-bezier(0.4, 0, 0, 1);   /* DELTA セクションreveal */
  --ease-delta-hero: cubic-bezier(0.25, 0, 0, 1);  /* DELTA FV reveal */

  /* Font */
  --font-en: 'Montserrat', -apple-system, 'Segoe UI', sans-serif;
  --font-ja: 'Noto Sans JP', -apple-system, 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', Meiryo, sans-serif;

  /* Layout */
  --container: 1080px;
  --container-narrow: 720px;
  --gutter: clamp(22px, 6vw, 64px);
  --header-h: 84px;
  --header-h-sp: 64px;

  /* Section rhythm（極端に広い余白＝最大のAI tell対策） */
  --pad-section: clamp(96px, 13vw, 200px);
  --pad-section-sm: clamp(72px, 9vw, 130px);
}

/* --- Reset --- */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html {
  -webkit-text-size-adjust: 100%;
  /* スムーススクロールはJSで制御せず素の挙動に任せる（§1③） */
}

body {
  font-family: var(--font-ja);
  font-size: 15px;
  font-weight: 400;
  line-height: 2.0;
  letter-spacing: 0.05em;
  color: var(--ink);
  background-color: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  line-break: strict;          /* 和文の行頭・行末禁則を厳格化（句読点孤立を防ぐ・日本語改行フロー書準拠） */
  overflow-wrap: anywhere;     /* 極端な狭幅でのみ任意位置で折る保険（keep-allは使わない） */
}

img, video, svg { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { font-family: inherit; font-size: inherit; cursor: pointer; border: none; background: none; color: inherit; }
table { border-collapse: collapse; }
input, textarea, select { font-family: inherit; font-size: inherit; }

/* --- アクセシビリティ --- */
.skip-link {
  position: absolute; left: 8px; top: -64px; z-index: 2000;
  background: var(--dark); color: var(--on-dark);
  padding: 10px 18px; font-size: 13px; font-weight: 700; letter-spacing: 0.04em;
  transition: top 0.2s var(--ease-smooth);
}
.skip-link:focus { top: 0; }

a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible, [tabindex]:focus-visible {
  outline: 2px solid var(--ink); outline-offset: 3px;
}

/* 現在ページ */
.header__nav-link[aria-current="page"] { color: var(--ink); }
.header__nav-link[aria-current="page"]::after { width: 100%; }
.footer__nav-link[aria-current="page"] { color: var(--on-dark); font-weight: 600; }
.sp-menu-overlay__link[aria-current="page"] { opacity: 1; }

/* ============================================================
   レイアウト・ユーティリティ
   ============================================================ */
.u-container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.u-narrow { max-width: var(--container-narrow); }
.u-section { padding-block: var(--pad-section); }
.u-section-sm { padding-block: var(--pad-section-sm); }
.u-dark { background: var(--dark); color: var(--on-dark); }

/* ============================================================
   セクション見出し — 巨大英字 ＋ 小さな和文（DELTA署名）
   ============================================================ */
.sec-head { margin-bottom: clamp(48px, 6vw, 88px); }
.sec-head--center { text-align: center; }

/* 巨大英字（行マスクreveal対応） */
.sec-en {
  font-family: var(--font-en);
  font-weight: 500;
  font-size: clamp(44px, 8.5vw, 110px);
  line-height: 0.98;
  letter-spacing: 0.005em;
  color: var(--ink);
  text-transform: uppercase;
  display: block;
}
.u-dark .sec-en { color: var(--on-dark); }

/* 小さな和文サブ */
.sec-jp {
  font-family: var(--font-ja);
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.18em;
  color: var(--ink-2);
  display: block;
  margin-top: 22px;
}
.u-dark .sec-jp { color: var(--on-dark-2); }

/* 旧クラス互換（各ページが参照） */
.section-label {
  font-family: var(--font-en);
  font-size: 13px; font-weight: 500; letter-spacing: 0.22em;
  color: var(--ink-2); text-transform: uppercase; display: block; margin-bottom: 14px;
}
.u-dark .section-label { color: var(--on-dark-2); }
.section-heading {
  font-family: var(--font-ja); font-size: clamp(24px, 3.2vw, 34px);
  font-weight: 500; letter-spacing: 0.04em; line-height: 1.55; color: var(--ink); margin-bottom: 10px;
}
.u-dark .section-heading { color: var(--on-dark); }
.section-sub {
  font-family: var(--font-ja); font-size: 15px; font-weight: 400;
  letter-spacing: 0.04em; line-height: 1.8; color: var(--ink-2);
}
.u-dark .section-sub { color: var(--on-dark-2); }
.section-title--center { text-align: center; }
.section-title--center .section-label::after { margin-inline: auto; }

/* 本文・キャプション */
.body-text { font-size: 15px; line-height: 2.0; letter-spacing: 0.05em; color: var(--ink); }
.lead { font-size: clamp(17px, 2vw, 21px); line-height: 1.95; letter-spacing: 0.06em; font-weight: 500; }
.caption {
  font-family: var(--font-en); font-size: 12px; font-weight: 500;
  letter-spacing: 0.14em; color: var(--ink-3); text-transform: uppercase;
}
.num-en {
  font-family: var(--font-en); font-weight: 600; line-height: 1;
  font-size: clamp(40px, 6vw, 72px); letter-spacing: 0.01em; color: var(--ink);
}

/* ============================================================
   ボタン — チャコールのpill / アウトライン（無彩色）
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--font-en); font-size: 13px; font-weight: 500; letter-spacing: 0.12em;
  text-transform: uppercase; padding: 17px 34px; border-radius: 100px;
  transition: background 0.4s var(--ease-out), color 0.4s var(--ease-out), transform 0.4s var(--ease-out), border-color 0.4s;
  white-space: nowrap;
}
.btn__arrow { width: 30px; height: 8px; flex-shrink: 0; }
.btn--solid { background: var(--dark); color: var(--on-dark); }
.btn--solid:hover { background: var(--dark-2); transform: translateY(-2px); }
.btn--outline { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
.btn--outline:hover { background: var(--ink); color: var(--bg); }
.u-dark .btn--outline { color: var(--on-dark); border-color: var(--on-dark-2); }
.u-dark .btn--outline:hover { background: var(--on-dark); color: var(--dark); }
.btn--light { background: var(--bg); color: var(--ink); }
.btn--light:hover { background: var(--white); transform: translateY(-2px); }

/* VIEW MORE 風の線付きラベルリンク */
.link-more {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--font-en); font-size: 13px; font-weight: 500; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ink);
}
.link-more::after {
  content: ''; width: 46px; height: 1px; background: currentColor;
  transition: width 0.4s var(--ease-out);
}
.link-more:hover::after { width: 72px; }
.u-dark .link-more { color: var(--on-dark); }

/* ============================================================
   スクロール/ロード アニメーション（DELTA忠実 — JS gated）
   初期の不可視状態は html.js-ready の時だけ適用＝no-JSでも全要素が見える
   ============================================================ */
/* 基本フェード（IO で .is-visible） */
html.js-ready .fade-up { opacity: 0; transform: translateY(40px); transition: opacity 1s var(--ease-delta), transform 1.1s var(--ease-delta); }
html.js-ready .fade-in { opacity: 0; transition: opacity 1.1s var(--ease-delta); }
html.js-ready .slide-in-left { opacity: 0; transform: translateX(-46px); transition: opacity 1s var(--ease-delta), transform 1.1s var(--ease-delta); }
html.js-ready .slide-in-right { opacity: 0; transform: translateX(46px); transition: opacity 1s var(--ease-delta), transform 1.1s var(--ease-delta); }
html.js-ready .fade-up.is-visible, html.js-ready .fade-in.is-visible,
html.js-ready .slide-in-left.is-visible, html.js-ready .slide-in-right.is-visible { opacity: 1; transform: translate(0,0); }

.stagger-1 { transition-delay: 0.09s; }
.stagger-2 { transition-delay: 0.18s; }
.stagger-3 { transition-delay: 0.27s; }
.stagger-4 { transition-delay: 0.36s; }
.stagger-5 { transition-delay: 0.45s; }
.stagger-6 { transition-delay: 0.54s; }

/* 語句リビール（DELTA c-word：マスク内をトークン単位でせり上げ・JSで分割） */
.reveal-mask { display: block; }
html.js-ready .reveal-mask .rw { display: inline-block; overflow: hidden; vertical-align: top; }
html.js-ready .reveal-mask .rw__in { display: inline-block; transform: translateY(110%); transition: transform 1.15s var(--ease-delta); will-change: transform; }
html.js-ready .reveal-mask.is-visible .rw__in { transform: translateY(0); }
/* ヒーロー用タイミング */
html.js-ready .reveal-mask--hero .rw__in { transition-duration: 1s; transition-timing-function: var(--ease-delta-hero); }
/* 旧マークアップ（JS未分割時）フォールバック */
html.js-ready .reveal-mask > span:not(.rw) { display: block; overflow: hidden; }
html.js-ready .reveal-mask > span:not(.rw) > span { display: block; transform: translateY(110%); transition: transform 1.1s var(--ease-delta); }
html.js-ready .reveal-mask.is-visible > span:not(.rw) > span { transform: translateY(0); }

/* 画像マスクリビール（カーテンが上へ抜ける＋内側がスケール settle） */
html.js-ready .reveal-img { position: relative; overflow: hidden; }
html.js-ready .reveal-img::after {
  content: ''; position: absolute; inset: 0; z-index: 3; background: var(--bg);
  transform: translateY(0); transition: transform 1.15s var(--ease-delta);
}
html.js-ready .reveal-img.is-visible::after { transform: translateY(-101%); }
html.js-ready .reveal-img > img, html.js-ready .reveal-img > picture img { transform: scale(1.14); transition: transform 1.5s var(--ease-delta); }
html.js-ready .reveal-img.is-visible > img, html.js-ready .reveal-img.is-visible > picture img { transform: scale(1); }
.u-dark .reveal-img::after, .reveal-img--dark::after { background: var(--dark); }

/* スクロール連動パララックス（JSが --par を毎フレーム更新） */
html.js-ready .js-par { transform: translate3d(0, var(--par, 0px), 0); will-change: transform; }

/* ============================================================
   OP ローダー（円形リング → フェードアウト）
   ============================================================ */
.op-loader {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg);
  transition: opacity 0.7s var(--ease-out) 0.2s, visibility 0.7s 0.2s;
}
.op-loader__inner { display: flex; flex-direction: column; align-items: center; gap: 24px; }
.op-loader__logo {
  font-family: var(--font-en); font-size: 12px; font-weight: 500;
  letter-spacing: 0.34em; color: var(--ink); text-transform: uppercase;
  opacity: 0; transform: translateY(6px); animation: op-logo 0.9s var(--ease-out) 0.25s forwards;
}
.op-loader__ring { width: 46px; height: 46px; }
.op-loader__ring circle { fill: none; stroke-width: 1.4; }
.op-loader__ring .op-bg { stroke: var(--line); }
.op-loader__ring .op-fg {
  stroke: var(--ink); stroke-linecap: round;
  stroke-dasharray: 126; stroke-dashoffset: 126;
  transform: rotate(-90deg); transform-origin: 50% 50%;
  animation: op-ring 1.5s var(--ease-out) forwards;
}
@keyframes op-ring { to { stroke-dashoffset: 0; } }
@keyframes op-logo { to { opacity: 1; transform: none; } }
html.is-loaded .op-loader { opacity: 0; visibility: hidden; pointer-events: none; }

/* ============================================================
   HERO イントロ（ロード完了後に .hero.is-in で発火）
   ============================================================ */
html.js-ready .hero__eyebrow, html.js-ready .hero__lead,
html.js-ready .hero__buttons, html.js-ready .hero__banner, html.js-ready .hero__scroll {
  opacity: 0; transform: translateY(28px); transition: opacity 1s var(--ease-out), transform 1.1s var(--ease-out);
}
html.js-ready .hero__marquee, html.js-ready .hero__mark, html.js-ready .hero__vtag { opacity: 0; transition: opacity 1.5s var(--ease-out); }
.hero.is-in .hero__vtag { opacity: 1; transition-delay: 1.1s; }
.hero.is-in .hero__eyebrow { opacity: 1; transform: none; transition-delay: 0.15s; }
.hero.is-in .hero__lead    { opacity: 1; transform: none; transition-delay: 0.6s; }
.hero.is-in .hero__buttons { opacity: 1; transform: none; transition-delay: 0.75s; }
.hero.is-in .hero__scroll  { opacity: 1; transform: none; transition-delay: 1.05s; }
.hero.is-in .hero__marquee { opacity: 1; transition-delay: 0.1s; }
.hero.is-in .hero__mark    { opacity: 1; transition-delay: 0.35s; }
.hero.is-in .hero__banner  { opacity: 1; transform: none; }
.hero.is-in .hero__banner:nth-child(1) { transition-delay: 0.85s; }
.hero.is-in .hero__banner:nth-child(2) { transition-delay: 0.95s; }
.hero.is-in .hero__banner:nth-child(3) { transition-delay: 1.05s; }
.hero.is-in .hero__banner:nth-child(4) { transition-delay: 1.15s; }

/* --- ユーティリティ --- */
.visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* SP固定CTAバー分の下部余白 */
@media (max-width: 767px) { body { padding-bottom: 76px; } }

/* クライアント判断（2026-06）：参考サイト(DELTA)同様に prefers-reduced-motion を無視し、
   どの環境でも常にフルアニメーションを再生する。よって低減用の無効化ブロックは置かない。 */
