@charset "UTF-8";
/* ============================================================
   マスダ造園 提案見本 スタイルシート
   構成：
   1. 変数・リセット・基礎
   2. 注釈バー／ヘッダー
   3. ヒーロー（固定写真＋SCROLL合図）
   4. リ・ガーデン宣言（魔法の登場演出）
   5. 本編セクション（について／施工例／業務内容／会社概要）
   6. お問い合わせ（電話・フォーム）
   7. フッター／スマホ固定電話ボタン
   8. レスポンシブ
   ============================================================ */

/* ---------- 1. 変数・リセット・基礎 ---------- */
:root{
  --ink:#2b2f2a;        /* 基本の文字色 */
  --pine:#3a5a40;       /* 松葉色（ボタン等） */
  --pine-deep:#2c4432;  /* 深い松葉色（見出し等） */
  --paper:#f7f4ee;      /* 生成りの背景 */
  --sand:#ece6da;       /* 砂色（罫線・影） */
  --gold:#b08d57;       /* 金色（アクセント） */
  --white:#ffffff;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:91px} /* 着地位置はJSが実測で上書き */
body{
  font-family:"Zen Kaku Gothic New",sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.9;
  letter-spacing:.04em;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- 2. 注釈バー／ヘッダー ---------- */
.proposal-note{
  background:#5c5648;color:#f5f1e8;
  font-size:12px;line-height:1.6;
  padding:8px 16px;text-align:center;
}
header{
  position:sticky;top:0;z-index:100;
  background:rgba(247,244,238,.95);
  border-bottom:1px solid var(--sand);
  backdrop-filter:blur(6px);
}
.header-inner{
  max-width:1080px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 20px;gap:24px;flex-wrap:nowrap;
}
.brand{
  font-family:"Shippori Mincho",serif;font-size:24px;font-weight:700;
  color:var(--pine-deep);white-space:nowrap;line-height:1.2;
}
.brand small{display:block;font-size:10px;font-weight:500;letter-spacing:.2em;color:var(--gold)}
nav{flex:1;min-width:0}
nav ul{display:flex;gap:2px;list-style:none;justify-content:center;flex-wrap:nowrap}
nav a{font-size:13px;padding:5px 12px;border-radius:20px;transition:.2s;white-space:nowrap}
nav a:hover{background:var(--pine);color:#fff}
.header-tel{text-align:right;white-space:nowrap}
.header-tel a{
  font-family:"Shippori Mincho",serif;
  font-size:22px;font-weight:700;color:var(--pine-deep);
}
.header-tel span{display:block;font-size:10.5px;color:#6b6b5f}

/* ---------- 3. ヒーロー ----------
   写真は画面に固定（.hero-bg）。文字だけがスクロールで上へ流れる。
   高さはJSが「画面 −（注釈バー＋ヘッダー）」を計算し、初期表示1ページ丁度にする */
.hero{
  position:relative;
  height:var(--hero-h,72vh);min-height:420px;
  background:rgba(28,34,28,.18); /* 宣言ページと共通の薄いベール */
}
.hero-bg{
  position:fixed;top:0;left:0;
  width:100vw;height:100vh;
  object-fit:cover;
  filter:brightness(.5) saturate(.9); /* 全ページ共通のトーン */
  z-index:-1;
}
.hero-copy{
  position:absolute;inset:0;z-index:1;
  display:flex;flex-direction:column;justify-content:center;
  max-width:1080px;margin:0 auto;padding:0 24px;color:#fff;
}
.hero-copy h1{
  font-family:"Shippori Mincho",serif;
  font-size:clamp(30px,5.4vw,54px);
  font-weight:700;line-height:1.5;
  text-shadow:0 2px 18px rgba(0,0,0,.45);
}
.hero-copy p{
  margin-top:14px;font-size:clamp(14px,2vw,17px);
  text-shadow:0 1px 10px rgba(0,0,0,.55);
}
.hero-badges{display:flex;gap:10px;margin-top:22px;flex-wrap:wrap}
.hero-badges span{
  background:rgba(44,68,50,.85);border:1px solid rgba(255,255,255,.45);
  font-size:12.5px;padding:6px 14px;border-radius:4px;
}
/* 1ページ目の下端：ここで区切り、の合図 */
.scroll-cue{
  position:absolute;bottom:16px;left:50%;transform:translateX(-50%);z-index:1;
  color:rgba(255,255,255,.8);font-size:10px;letter-spacing:.35em;
  font-family:"Shippori Mincho",serif;text-align:center;
}
.scroll-cue::after{
  content:"";display:block;width:1px;height:32px;
  background:linear-gradient(to bottom, rgba(255,255,255,.85), rgba(255,255,255,0));
  margin:8px auto 0;
  animation:cuePulse 2.2s ease-in-out infinite;
}
@keyframes cuePulse{
  0%,100%{opacity:.35}
  50%{opacity:1}
}

/* ---------- 4. リ・ガーデン宣言 ----------
   丸ごと1ページ・文字は画面の真ん中。背景は薄いベールで固定写真が透ける。
   スクロールで見えたら、霧の中から順に像を結ぶ（JSが .in を付け外しする） */
.statement{
  background:rgba(28,34,28,.18);
  text-align:center;padding:60px 20px;
  min-height:var(--page-h,100vh);
  display:flex;flex-direction:column;justify-content:center;align-items:center;
}
.statement .inner{position:relative}
.statement-divider{
  display:block;width:70px;height:1px;background:var(--gold);
  margin:0 auto 28px;
  opacity:0;transform:scaleX(0);
  transition:opacity 1s ease,transform 1s ease;
}
.statement-en{
  color:#d9bd8a;font-size:13px;letter-spacing:.45em;
  font-family:"Shippori Mincho",serif;
  text-shadow:0 1px 12px rgba(0,0,0,.4);
  opacity:0;filter:blur(10px);transform:translateY(10px);
  transition:opacity 1.1s ease .5s,filter 1.1s ease .5s,transform 1.1s ease .5s;
}
.statement-copy{
  font-family:"Shippori Mincho",serif;
  font-size:clamp(28px,5vw,50px);font-weight:700;color:#fff;
  line-height:1.75;margin:18px 0 26px;
  text-shadow:0 2px 18px rgba(0,0,0,.45);
  opacity:0;filter:blur(16px);transform:translateY(14px);
  transition:opacity 1.5s ease 1s,filter 1.5s ease 1s,transform 1.5s ease 1s;
}
.statement-copy em{font-style:normal;color:#e8dcc3}
.statement-sub{
  font-size:15px;color:rgba(247,244,238,.92);line-height:2.1;
  text-shadow:0 1px 10px rgba(0,0,0,.5);
  opacity:0;filter:blur(10px);transform:translateY(10px);
  transition:opacity 1.2s ease 1.9s,filter 1.2s ease 1.9s,transform 1.2s ease 1.9s;
}
.statement.in .statement-divider{opacity:1;transform:scaleX(1)}
.statement.in .statement-en{opacity:1;filter:blur(0);transform:none}
.statement.in .statement-copy{
  opacity:1;filter:blur(0);transform:none;
  animation:magicGlow 2.8s ease 1s both; /* 現れる瞬間、金色の光が灯って消える */
}
.statement.in .statement-sub{opacity:1;filter:blur(0);transform:none}
@keyframes magicGlow{
  0%{text-shadow:0 0 30px rgba(232,220,195,.95), 0 0 70px rgba(217,189,138,.55)}
  100%{text-shadow:0 2px 18px rgba(0,0,0,.45)}
}
/* 魔法の粉（JSが生成する小さな星） */
.sparkle{
  position:absolute;pointer-events:none;z-index:2;
  color:#e8dcc3;line-height:1;
  text-shadow:0 0 10px rgba(255,252,240,.95);
  opacity:0;
  animation:twinkle 1.6s ease-in-out both;
}
@keyframes twinkle{
  0%{opacity:0;transform:scale(0) rotate(0deg)}
  35%{opacity:1;transform:scale(1) rotate(45deg)}
  100%{opacity:0;transform:scale(.15) rotate(100deg)}
}

/* ---------- 5. 本編セクション共通 ---------- */
section{padding:72px 20px}
.inner{max-width:1080px;margin:0 auto}
.sec-label{
  font-family:"Shippori Mincho",serif;
  color:var(--gold);font-size:13px;letter-spacing:.3em;text-align:center;
}
.sec-label--left{text-align:left}
h2{
  font-family:"Shippori Mincho",serif;
  font-size:clamp(24px,3.6vw,34px);font-weight:600;
  text-align:center;color:var(--pine-deep);
  margin:6px 0 40px;
}

/* マスダ造園について */
.regarden{background:var(--white)}
.regarden-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.regarden-text p{margin-bottom:1.2em}
.regarden-text .lead{
  font-family:"Shippori Mincho",serif;
  font-size:clamp(20px,2.6vw,26px);color:var(--pine-deep);line-height:1.8;
  margin-bottom:.8em;
}
.regarden-photo{position:relative}
.regarden-photo img{border-radius:6px;box-shadow:12px 12px 0 var(--sand)}
.sign-photo{
  position:absolute;right:-12px;bottom:-40px;width:104px;
  border:4px solid #fff;border-radius:4px;box-shadow:0 6px 20px rgba(0,0,0,.25);
}

/* 施工例 */
.works{background:var(--paper)}
.works-group{margin-bottom:56px}
.works-group h3{
  font-family:"Shippori Mincho",serif;font-size:21px;color:var(--pine-deep);
  border-left:4px solid var(--gold);padding-left:14px;margin-bottom:8px;
}
.works-group .note{font-size:13.5px;color:#6b6b5f;margin-bottom:20px}
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.works-grid figure{
  background:#fff;border-radius:6px;overflow:hidden;
  box-shadow:0 2px 10px rgba(43,47,42,.08);
}
.works-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:.35s}
.works-grid figure:hover img{transform:scale(1.04)}
.works-grid figcaption{font-size:12.5px;padding:10px 12px;color:#55554a}

/* 業務内容 */
.services{background:var(--pine-deep);color:#f2efe7}
.services .sec-label{color:#cbb287}
.services h2{color:#fff}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.service-card{
  border:1px solid rgba(255,255,255,.22);border-radius:6px;
  padding:26px 20px;background:rgba(255,255,255,.05);
}
.service-card h3{
  font-family:"Shippori Mincho",serif;font-size:17px;font-weight:600;
  margin-bottom:10px;color:#e8dcc3;
}
.service-card p{font-size:13.5px;line-height:1.8;opacity:.9}

/* 会社概要（信頼カード＋表） */
.trust{background:var(--white)}
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:44px}
.trust-card{
  text-align:center;padding:30px 18px;
  background:var(--paper);border-radius:6px;border-top:3px solid var(--gold);
}
.trust-card .num{
  font-family:"Shippori Mincho",serif;
  font-size:34px;font-weight:700;color:var(--pine-deep);line-height:1.3;
}
.trust-card .num small{font-size:15px}
.trust-card p{font-size:13px;color:#6b6b5f;margin-top:6px}
.company-table{
  width:100%;max-width:760px;margin:0 auto;border-collapse:collapse;font-size:14.5px;
}
.company-table th,.company-table td{
  border-bottom:1px solid var(--sand);padding:16px 12px;text-align:left;vertical-align:top;
}
.company-table th{
  width:130px;font-family:"Shippori Mincho",serif;font-weight:600;
  color:var(--pine-deep);white-space:nowrap;
}
.company-table ul{list-style:none}
.company-table li{padding-left:1em;text-indent:-1em}
.company-table li::before{content:"・"}
/* アクセス（Googleマップ） */
.map-wrap{max-width:760px;margin:48px auto 0}
.map-title{
  font-family:"Shippori Mincho",serif;font-size:17px;font-weight:600;
  color:var(--pine-deep);text-align:center;margin-bottom:16px;
}
.map-wrap iframe{
  display:block;width:100%;height:340px;border:0;
  border-radius:8px;box-shadow:0 2px 14px rgba(43,47,42,.12);
}

/* ---------- 6. お問い合わせ ---------- */
.contact{background:var(--paper);text-align:center}
.contact .lead{max-width:640px;margin:0 auto 30px}
.tel-box{
  display:inline-block;background:#fff;border:2px solid var(--pine-deep);
  border-radius:8px;padding:26px 44px;margin-bottom:18px;
}
.tel-box .label{font-size:13px;color:var(--pine-deep);letter-spacing:.2em}
.tel-box a{
  font-family:"Shippori Mincho",serif;
  font-size:clamp(30px,6vw,44px);font-weight:700;color:var(--pine-deep);
  line-height:1.4;display:block;
}
.tel-box .sub{font-size:12.5px;color:#6b6b5f}
.contact .free{
  display:inline-block;background:var(--gold);color:#fff;
  font-size:14px;padding:6px 20px;border-radius:20px;margin-bottom:26px;
}
.contact .area{font-size:13.5px;color:#55554a}

/* お問い合わせフォーム（見本のため送信はデモ動作） */
.contact-form{
  max-width:560px;margin:34px auto 30px;padding:34px 30px;
  background:#fff;border-radius:8px;text-align:left;
  box-shadow:0 2px 14px rgba(43,47,42,.08);
}
.form-title{
  font-family:"Shippori Mincho",serif;font-size:17px;font-weight:600;
  color:var(--pine-deep);text-align:center;margin-bottom:22px;
}
.form-row{margin-bottom:16px}
.form-row label{
  display:block;font-size:13px;font-weight:700;color:var(--pine-deep);
  margin-bottom:6px;
}
.form-row input,.form-row select,.form-row textarea{
  width:100%;padding:11px 12px;font-size:15px;
  font-family:inherit;color:var(--ink);
  border:1px solid #d8d2c4;border-radius:6px;background:var(--paper);
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{
  outline:2px solid var(--pine);border-color:var(--pine);background:#fff;
}
.form-submit{
  display:block;width:auto;min-width:230px;margin:14px auto 0;
  padding:14px 40px;
  background:var(--pine);color:#fff;font-size:16px;font-weight:700;
  font-family:inherit;border:none;border-radius:30px;cursor:pointer;
  box-shadow:0 3px 10px rgba(58,90,64,.35);
  transition:transform .15s, box-shadow .15s, background .15s;
}
.form-submit::after{content:"→";margin-left:10px;font-weight:400}
.form-submit:hover{
  background:var(--pine-deep);
  transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(58,90,64,.45);
}
.form-submit:active{
  transform:translateY(1px);
  box-shadow:0 1px 4px rgba(58,90,64,.4);
}
.form-note{font-size:11.5px;color:#8a8577;margin-top:12px;text-align:center;line-height:1.7}
.form-note.sent{color:var(--pine-deep);font-weight:700}

/* ---------- 7. フッター／スマホ固定電話ボタン ---------- */
footer{
  background:var(--pine-deep);color:#cfcabb;text-align:center;
  padding:30px 16px;font-size:12px;line-height:1.8;
}
footer .foot-note{max-width:720px;margin:12px auto 0;font-size:11px;opacity:.75}
.sp-call{
  display:none;position:fixed;bottom:14px;left:14px;right:14px;z-index:200;
  background:var(--pine);color:#fff;text-align:center;
  padding:14px;border-radius:30px;font-size:16px;font-weight:700;
  box-shadow:0 6px 18px rgba(0,0,0,.3);
}

/* ---------- 8. レスポンシブ ---------- */
@media (max-width:920px){
  .header-inner{flex-wrap:wrap;gap:8px 24px}
  nav{order:3;flex-basis:100%}
  nav ul{flex-wrap:wrap;justify-content:center}
}
@media (max-width:820px){
  .regarden-grid{grid-template-columns:1fr;gap:56px}
  .works-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .trust-grid{grid-template-columns:1fr;gap:12px}
  section{padding:56px 16px}
}
@media (max-width:520px){
  .header-tel{display:none}
  .sp-call{display:block}
  .works-grid{grid-template-columns:1fr 1fr;gap:8px}
  .services-grid{grid-template-columns:1fr}
  body{padding-bottom:70px}
}

/* 「視差効果を減らす」設定の人には演出なしで表示（酔い対策） */
@media (prefers-reduced-motion:reduce){
  .statement-divider,.statement-en,.statement-copy,.statement-sub{
    opacity:1 !important;transform:none !important;
    transition:none !important;filter:none !important;animation:none !important;
  }
  .scroll-cue::after{animation:none}
  .sparkle{display:none}
}
