/* ============================================================================
   FlowerHub テーマCSS（ユーザー本物デザイン準拠 / v1.0.6）
   ・詳細ページ（reception）と一覧ページ（list）の全スタイルを統合
   ・★このCSSはデザインの心臓部。色・余白・フォントを変えたいときはここを編集
   ============================================================================ */

  .fh *{ margin:0; padding:0; box-sizing:border-box; }
  .fh{
    /* === FlowerHub トンマナ === */
    --green:#1F3A2B; --green-d:#16291E; --green-pale:#EAF0EC;
    --bordeaux:#6B1D2F; --bordeaux-90:#7D2538;
    --ink:#2C2C2A; --ink2:#56564f; --ink3:#9a988e;
    --line:#E6E4DD; --line-soft:#EFEDE6;
    --bg:#F9F9F7; --bg2:#FCFBF8; --warm:#F2EFE8; --accent:#6B1D2F;
    --font-jp:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
    --font-en:"Cormorant Garamond","Times New Roman",serif;
    --font-serif:"Shippori Mincho","Hiragino Mincho ProN","Yu Mincho",serif;
    font-family:var(--font-jp); color:var(--ink); line-height:2.0; font-size:15px; background:var(--bg);
    letter-spacing:.02em;
  }
  .fh img{ max-width:100%; display:block; }
  .fh a{ color:inherit; text-decoration:none; }
  .fh .wrap{ max-width:1120px; margin:0 auto; padding:0 32px; }
  .fh .narrow{ max-width:760px; margin-left:auto; margin-right:auto; }
  .fh .en{ font-family:var(--font-en); }
  .fh .serif{ font-family:var(--font-serif); }

  /* ===== 画像プレースホルダ ===== */
  .fh .ph{ position:relative; background:
      repeating-linear-gradient(135deg,#efece4 0 14px,#eae6dc 14px 28px);
    color:#a59a86; display:flex; align-items:center; justify-content:center;
    font-family:var(--font-en); font-size:13px; letter-spacing:.14em; min-height:60px; }
  .fh .ph::after{ content:attr(data-ph); position:absolute; }

  /* ===== 装飾オーナメント ===== */
  .fh-orn{ display:flex; align-items:center; justify-content:center; gap:14px; color:var(--bordeaux); }
  .fh-orn::before,.fh-orn::after{ content:""; width:46px; height:1px; background:currentColor; opacity:.5; }
  .fh-orn span{ width:6px; height:6px; transform:rotate(45deg); border:1px solid currentColor; }
  .fh-vline{ width:1px; height:64px; margin:0 auto; background:linear-gradient(var(--line),transparent); }

  /* ===== ヘッダー ===== */
  .fh-header{ background:rgba(249,249,247,.86); backdrop-filter:blur(10px);
    border-bottom:1px solid var(--line-soft); position:sticky; top:0; z-index:50; }
  .fh-header-in{ max-width:1180px; margin:0 auto; padding:15px 32px; display:flex; align-items:center; gap:34px; min-height:50px; }
  .fh-logo{ display:flex; align-items:center; line-height:1; }
  .fh-logo img{ height:22px; width:auto; display:block; }
  .fh-gnav{ display:flex; gap:30px; margin-left:18px; }
  .fh-gnav a{ color:var(--ink2); font-size:13px; font-weight:500; letter-spacing:.04em; transition:color .2s; white-space:nowrap; }
  .fh-gnav a:hover{ color:var(--bordeaux); }
  .fh-gnav a.current{ color:var(--bordeaux); }
  .fh-hactions{ margin-left:auto; display:flex; gap:12px; align-items:center; }
  .fh-hactions a{ font-family:var(--font-jp); font-size:12.5px; font-weight:700; letter-spacing:.04em; padding:8px 18px; border-radius:999px; background:#6B1D2F; color:#fff; transition:.2s; white-space:nowrap; }
  .fh-hactions a:hover{ background:#591726; transform:translateY(-1px); }
  .fh-hactions a.ghost{ background:rgba(249,249,247,.78); color:#6b6b66; border:1px solid #b3b3b3; }
  .fh-hactions a.ghost:hover{ background:#b3b3b3; color:#fff; border-color:#b3b3b3; transform:none; }
  .fh-burger{ display:none; margin-left:auto; width:30px; height:22px; background:none; border:none; cursor:pointer; padding:0; position:relative; }
  .fh-burger span{ display:block; position:absolute; left:0; width:100%; height:1.5px; background:var(--ink); transition:.3s; }
  .fh-burger span:nth-child(1){ top:1px; } .fh-burger span:nth-child(2){ top:10px; } .fh-burger span:nth-child(3){ top:19px; }
  .fh-burger.open span:nth-child(1){ top:10px; transform:rotate(45deg); }
  .fh-burger.open span:nth-child(2){ opacity:0; }
  .fh-burger.open span:nth-child(3){ top:10px; transform:rotate(-45deg); }
  .fh-drawer{ display:none; flex-direction:column; border-top:1px solid var(--line); background:var(--bg); }
  .fh-drawer.open{ display:flex; }
  .fh-drawer a{ padding:16px 32px; border-bottom:1px solid var(--line-soft); font-size:14px; color:var(--ink); font-weight:500; }
  .fh-drawer a.mypage{ color:var(--bordeaux); font-weight:700; }

  /* ===== ヒーロー（詳細ページ） ===== */
  .fh-hero{ position:relative; height:clamp(480px,72vh,680px);
    background-image:url('https://gigaplus.makeshop.jp/flowerhub/img/sub/reception01.webp'); background-size:cover; background-position:center; background-repeat:no-repeat;
    background-attachment:fixed; }
  .fh-hero::after{ content:""; position:absolute; inset:0; pointer-events:none; background:linear-gradient(180deg,rgba(22,41,30,.52),rgba(22,41,30,.40) 38%,rgba(22,41,30,.66)); }
  .fh-hero-inner{ position:absolute; inset:0; z-index:2; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; color:#fff; padding:32px 32px 64px; }
  .fh-hero-eyebrow{ font-family:var(--font-en); font-size:15px; letter-spacing:.42em; text-transform:uppercase; color:rgba(255,255,255,.92); padding-left:.42em; }
  .fh-hero-rule{ width:1px; height:40px; background:rgba(255,255,255,.6); margin:22px 0; }
  .fh-hero-title{ font-family:var(--font-serif); font-weight:600; font-size:clamp(25px,4.6vw,46px); letter-spacing:.07em; line-height:1.3; white-space:normal; text-shadow:0 2px 18px rgba(0,0,0,.28); }
  .fh-hero-sub{ font-family:var(--font-serif); font-weight:500; font-size:clamp(13px,1.7vw,17px); letter-spacing:.16em; margin-top:22px; color:rgba(255,255,255,.94); }
  .fh-hero-tag{ margin-top:30px; font-size:12px; letter-spacing:.16em; padding:9px 26px; border:1px solid rgba(255,255,255,.55); border-radius:999px; }

  /* ===== スクロール誘導 ===== */
  .fh-scroll{ position:absolute; left:50%; transform:translateX(-50%); bottom:0; width:60px; height:92px; z-index:4; display:block; text-decoration:none; cursor:pointer; }
  .fh-scroll span{ position:absolute; left:calc(50% + 7px); bottom:24px; color:rgba(255,255,255,.92); font-size:12px; font-family:'Josefin Sans',sans-serif; font-weight:400; letter-spacing:.28em; writing-mode:vertical-lr; text-transform:uppercase; text-shadow:0 1px 6px rgba(0,0,0,.45); }
  .fh-scroll::after{ content:""; position:absolute; bottom:0; left:50%; transform:translateX(-50%); width:1px; height:74px; background:rgba(255,255,255,.6); box-shadow:0 1px 6px rgba(0,0,0,.35); }
  .fh-scroll::before{ content:""; position:absolute; bottom:0; left:50%; margin-left:-5px; width:10px; height:10px; border-radius:50%; background:#fff; box-shadow:0 1px 5px rgba(0,0,0,.35); }
  @media(prefers-reduced-motion:no-preference){
    .fh-scroll::before{ animation:fh-scroll-move 1.8s ease-in-out infinite, fh-scroll-fade 1.8s ease-out infinite; }
  }
  @keyframes fh-scroll-move{ 0%{bottom:74px;} 100%{bottom:0;} }
  @keyframes fh-scroll-fade{ 0%{opacity:0;} 50%{opacity:1;} 80%{opacity:.9;} 100%{opacity:0;} }

  /* ===== セクションインジケーター ===== */
  .fh-rail{ position:fixed; right:24px; top:50%; transform:translateY(-50%); z-index:55;
    display:flex; flex-direction:column; align-items:flex-end; gap:6px; }
  .fh-rail.hide{ display:none; }
  .fh-rail__item{ position:relative; display:flex; align-items:center; justify-content:flex-end; gap:0; height:28px; padding:0 6px;
    background:none; border:none; cursor:pointer; color:#b1afa8;
    font-family:'Josefin Sans',sans-serif; font-size:11.5px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; line-height:1; }
  .fh-rail__item[hidden]{ display:none; }
  .fh-rail__label{ white-space:nowrap; opacity:0; transform:translateX(5px);
    transition:opacity .28s ease, transform .28s ease, color .28s ease, margin .28s ease; }
  .fh-rail__lead{ display:none; }
  .fh-rail__dot{ width:7px; height:7px; border-radius:50%; border:1px solid currentColor; background:transparent; flex:none; transition:width .3s ease, height .3s ease, background .3s ease, border-color .3s ease; }
  .fh-rail__item:hover{ color:#56564f; }
  .fh-rail__item:hover .fh-rail__label{ opacity:1; transform:translateX(0); margin-right:8px; color:#56564f; }
  .fh-rail__item.active{ color:#2C2C2A; }
  .fh-rail__item.active .fh-rail__dot{ width:9px; height:9px; background:#2C2C2A; border-color:#2C2C2A; }
  .fh-rail__item.active .fh-rail__label{ opacity:1; transform:translateX(0); margin-right:8px; color:#2C2C2A; }
  .fh-rail--on-dark .fh-rail__item{ color:rgba(255,255,255,.5); }
  .fh-rail--on-dark .fh-rail__item:hover{ color:rgba(255,255,255,.82); }
  .fh-rail--on-dark .fh-rail__item:hover .fh-rail__label{ color:rgba(255,255,255,.82); }
  .fh-rail--on-dark .fh-rail__item.active{ color:#fff; }
  .fh-rail--on-dark .fh-rail__item.active .fh-rail__dot{ background:#fff; border-color:#fff; }
  .fh-rail--on-dark .fh-rail__item.active .fh-rail__label{ color:#fff; }
  @media(max-width:1080px){ .fh-rail{ display:none; } }

  /* ===== タブ ===== */
  .fh-tabs{ background:var(--bg); border-bottom:1px solid var(--line-soft); }
  .fh-tabs .row{ display:flex; justify-content:center; gap:8px; }
  .fh-tab{ appearance:none; background:transparent; border:none; border-bottom:1.5px solid transparent;
    padding:22px 30px; font-family:var(--font-serif); font-size:16px; cursor:pointer; color:var(--ink3); font-weight:500; letter-spacing:.08em; transition:.2s; }
  .fh-tab:hover{ color:var(--ink2); }
  .fh-tab.active{ color:var(--bordeaux); border-bottom-color:var(--bordeaux); }

  /* ===== セクション枠組み ===== */
  .fh-sec{ padding:clamp(78px,11vw,140px) 0; }
  .fh-sec.bg{ background:var(--bg2); }
  .fh-sec.warm{ background:var(--warm); }
  .fh-head{ text-align:center; margin-bottom:56px; }
  .fh-head .e{ display:block; font-family:var(--font-en); font-size:15px; font-weight:600; letter-spacing:.34em; text-transform:uppercase; color:var(--bordeaux); }
  .fh-head .j{ display:block; font-family:var(--font-serif); font-size:clamp(24px,3.4vw,33px); font-weight:600; color:#2C2C2A; margin-top:14px; letter-spacing:.06em; line-height:1.5; }
  .fh-head .d{ margin:22px auto 0; }

  /* ===== ページタイトル＋リード ===== */
  .fh-intro{ padding:clamp(70px,9vw,110px) 0 clamp(48px,6vw,72px); text-align:center; }
  .fh-intro h1,.fh-intro h2{ font-family:var(--font-serif); font-size:clamp(23px,3.4vw,34px); font-weight:600; letter-spacing:.07em; line-height:1.55; color:var(--green); }
  .fh-intro .sub{ font-family:var(--font-serif); font-size:14px; color:var(--ink3); margin-top:18px; letter-spacing:.12em; }
  .fh-intro .lead{ margin:40px auto 0; max-width:680px; color:var(--ink2); font-size:15px; line-height:2.2; }

  /* ===== 受付情報 ===== */
  .fh-detail{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); max-width:940px; margin:0 auto;
    display:grid; grid-template-columns:repeat(4,1fr); }
  .fh-detail-item{ padding:0 26px; min-height:120px; display:flex; flex-direction:column; justify-content:center; }
  .fh-detail-item + .fh-detail-item{ border-left:1px solid var(--line); }
  .fh-detail-item .ic{ display:none; }
  .fh-detail-item .e{ font-family:var(--font-en); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--bordeaux); font-weight:600; line-height:1; }
  .fh-detail-item .j{ font-size:11px; color:var(--ink3); letter-spacing:.08em; margin-top:5px; }
  .fh-detail-item .val{ font-family:var(--font-serif); font-size:18px; font-weight:600; color:var(--ink); letter-spacing:.03em; line-height:1.45; margin-top:12px; }
  .fh-detail-item .val.sm{ font-size:13px; line-height:1.55; margin-top:10px; }

  /* ===== 代表挨拶 ===== */
  .fh-greet{ display:grid; grid-template-columns:300px 1fr; gap:64px; align-items:center; max-width:940px; margin:0 auto; }
  .fh-greet.no-photo{ grid-template-columns:1fr; max-width:760px; text-align:center; }
  .fh-greet.no-photo .who{ justify-content:center; }
  .fh-greet .portrait{ aspect-ratio:3/4; }
  .fh-greet .portrait img{ width:100%; height:100%; object-fit:cover; }
  .fh-greet .who{ display:flex; align-items:baseline; gap:14px; margin-bottom:22px; }
  .fh-greet .who .co{ font-size:12.5px; color:var(--ink3); letter-spacing:.08em; white-space:nowrap; }
  .fh-greet .who .nm{ font-family:var(--font-serif); font-size:21px; font-weight:600; color:#2C2C2A; letter-spacing:.05em; }
  .fh-greet p{ color:var(--ink2); margin-bottom:18px; line-height:2.15; font-size:14.5px; text-align:left; }
  .fh-greet p:last-child{ margin-bottom:0; }

  /* ===== FlowerHub サービス紹介 ===== */
  .fh-svc-lead{ max-width:660px; margin:0 auto 64px; text-align:center; color:var(--ink2); font-size:14.5px; line-height:2.2; }
  .fh-feats{ display:grid; grid-template-columns:repeat(3,1fr); gap:54px; max-width:960px; margin:0 auto; }
  .fh-feat{ text-align:center; }
  .fh-feat .ic{ width:62px; height:62px; margin:0 auto 22px; border-radius:50%; border:1px solid var(--line);
    display:flex; align-items:center; justify-content:center; color:var(--green); background:var(--bg); }
  .fh-feat h3{ font-family:var(--font-serif); font-size:16.5px; font-weight:600; color:#2C2C2A; margin-bottom:12px; letter-spacing:.04em; }
  .fh-feat p{ font-size:13px; color:var(--ink2); line-height:1.95; }
  .fh-note-bar{ max-width:720px; margin:56px auto 0; text-align:center; font-size:13px; color:var(--ink2);
    background:var(--bg); border:1px solid var(--line); border-radius:4px; padding:18px 24px; }

  /* ===== 流れるギャラリー（マルキー） ===== */
  .fh-recline{ white-space:nowrap; }
  @media(max-width:760px){ .fh-recline{ white-space:normal; font-size:15px !important; line-height:1.95; } }
  .fh-marquee{ margin-top:clamp(48px,7vw,80px); overflow:hidden; }
  .fh-marquee__row{ display:flex; width:max-content; gap:24px; animation:fh-marquee-scroll 52s linear infinite; }
  .fh-marquee:hover .fh-marquee__row{ animation-play-state:paused; }
  .fh-marquee__item{ flex:0 0 auto; width:200px; height:134px; overflow:hidden; background:var(--warm); }
  .fh-marquee__item img{ display:block; width:100%; height:100%; object-fit:cover; }
  @keyframes fh-marquee-scroll{ from{transform:translateX(0);} to{transform:translateX(-50%);} }
  @media(prefers-reduced-motion:reduce){ .fh-marquee__row{ animation:none; } }
  @media(max-width:768px){
    .fh-marquee__row{ gap:16px; }
    .fh-marquee__item{ width:150px; height:100px; }
  }

  /* ===== コース ===== */
  .fh-course-lead{ text-align:center; max-width:680px; margin:0 auto 56px; }
  .fh-course-lead p{ color:var(--ink2); font-size:14px; line-height:2.05; }
  .fh-course-lead .warn{ color:var(--bordeaux); font-size:12.5px; margin-top:14px; letter-spacing:.04em; }
  .fh-courses{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; max-width:1120px; margin:0 auto; }
  .fh-course{ background:var(--bg); display:flex; flex-direction:column; }
  .fh-course .imgw{ position:relative; overflow:hidden; }
  .fh-course .img{ width:100%; aspect-ratio:4/5; transition:transform .6s var(--ease,cubic-bezier(.22,.61,.36,1)); object-fit:cover; }
  .fh-course:hover .img{ transform:scale(1.05); }
  .fh-course .rank{ position:absolute; z-index:2; top:14px; left:14px; font-family:var(--font-en); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:#fff; background:rgba(31,58,43,.78); padding:5px 12px; }
  .fh-course .body{ padding:20px 6px 4px; display:flex; flex-direction:column; flex:1; }
  .fh-course .price{ font-family:var(--font-serif); font-size:23px; font-weight:600; color:var(--ink); letter-spacing:.02em; }
  .fh-course .price small{ font-size:11px; color:var(--ink3); font-weight:400; font-family:var(--font-jp); }
  .fh-course .nm{ font-size:12px; color:var(--ink2); line-height:1.75; margin-top:8px; min-height:40px; }
  .fh-course .btn{ margin-top:18px; display:block; text-align:center; background:transparent; color:var(--green);
    border:1px solid rgba(31,58,43,.78); font-size:12.5px; font-weight:600; letter-spacing:.04em; padding:12px; transition:.2s; }
  .fh-course .btn:hover{ background:rgba(31,58,43,.78); border-color:rgba(31,58,43,.78); color:#fff; }

  /* ===== FAQ ===== */
  .fh-faq{ max-width:780px; margin:0 auto; border-top:1px solid var(--line); }
  .fh-q{ border-bottom:1px solid var(--line); }
  .fh-q summary{ list-style:none; cursor:pointer; padding:26px 40px 26px 0; position:relative; font-size:15px; font-weight:500; color:var(--ink); letter-spacing:.03em; }
  .fh-q summary::-webkit-details-marker{ display:none; }
  .fh-q summary .qn{ font-family:var(--font-en); color:var(--bordeaux); font-weight:600; font-size:17px; margin-right:14px; }
  .fh-q summary::after{ content:""; position:absolute; right:6px; top:31px; width:9px; height:9px; border-right:1.5px solid var(--ink3); border-bottom:1.5px solid var(--ink3); transform:rotate(45deg); transition:.25s; }
  .fh-q[open] summary::after{ transform:rotate(-135deg); top:35px; }
  .fh-q .ans{ padding:0 40px 28px 0; color:var(--ink2); font-size:13.5px; line-height:2.05; }

  /* ===== お問い合わせ（詳細ページ） ===== */
  .fh-contact{ display:grid; grid-template-columns:1fr 1fr; gap:0; max-width:880px; margin:0 auto; border:1px solid var(--line); }
  .fh-cbox{ padding:48px 40px; text-align:center; }
  .fh-cbox:first-child{ border-right:1px solid var(--line); }
  .fh-cbox h3{ font-family:var(--font-serif); font-size:16px; font-weight:600; color:var(--green); margin-bottom:22px; letter-spacing:.05em; }
  .fh-cbox .e{ font-family:var(--font-en); font-size:13px; letter-spacing:.2em; color:var(--bordeaux); }
  .fh-cbox .tel{ font-family:var(--font-en); font-size:33px; font-weight:600; color:var(--green); letter-spacing:.02em; line-height:1.3; }
  .fh-cbox .hours{ font-size:12px; color:var(--ink3); margin-top:8px; line-height:1.8; }
  .fh-cbox p{ font-size:13.5px; color:var(--ink2); line-height:1.9; }
  .fh-cbox .btn{ display:inline-flex; align-items:center; gap:9px; margin-top:22px; background:var(--bordeaux); color:#fff; padding:14px 32px; border-radius:999px; font-size:13.5px; font-weight:600; letter-spacing:.04em; transition:.2s; }
  .fh-cbox .btn:hover{ background:var(--bordeaux-90); }
  .fh-cbox .btn svg{ width:16px; height:16px; }

  /* ===== フッター ===== */
  .fh-footer{ background:#142A1F; color:#fff; padding:76px 0 30px; }
  .fh-footer .fx-in{ max-width:1200px; margin:0 auto; padding:0 32px; display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:48px; }
  .fh-footer .fx-brand .lg{ display:block; height:26px; width:auto; margin:0 0 14px; filter:brightness(0) invert(1); }
  .fh-footer .fx-brand .sub{ font-size:11.5px; letter-spacing:.06em; color:rgba(255,255,255,.6); margin:0 0 26px; }
  .fh-footer .fx-brand .tel{ font-family:var(--font-serif); font-size:25px; font-weight:600; letter-spacing:.02em; display:flex; align-items:center; gap:10px; margin:0 0 4px; color:#fff; }
  .fh-footer .fx-brand .tel svg{ width:18px; height:18px; opacity:.85; }
  .fh-footer .fx-brand .hours{ font-size:12.5px; color:rgba(255,255,255,.6); margin:0 0 14px; }
  .fh-footer .fx-brand .mail{ font-size:13px; color:rgba(255,255,255,.8); display:flex; align-items:center; gap:10px; }
  .fh-footer .fx-brand .mail svg{ width:16px; height:16px; opacity:.85; }
  .fh-footer .fx-social{ display:flex; align-items:center; gap:12px; margin-top:24px; }
  .fh-footer .fx-social a{ display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; border:1px solid rgba(255,255,255,.28); border-radius:50%; color:rgba(255,255,255,.85); transition:.2s; }
  .fh-footer .fx-social a:hover{ background:#E7C9A0; border-color:#E7C9A0; color:#142A1F; }
  .fh-footer .fx-social svg{ width:18px; height:18px; display:block; }
  .fh-footer .fx-col h4{ font-family:var(--font-serif); font-weight:600; font-size:14px; letter-spacing:.08em; color:#E7C9A0; margin:0 0 18px; }
  .fh-footer .fx-col ul{ list-style:none; margin:0; padding:0; }
  .fh-footer .fx-col li{ margin-bottom:13px; }
  .fh-footer .fx-col a{ font-size:13px; color:rgba(255,255,255,.78); transition:color .2s; }
  .fh-footer .fx-col a:hover{ color:#E7C9A0; }
  .fh-footer .fx-copy{ max-width:1200px; margin:54px auto 0; padding:22px 32px 0; border-top:1px solid rgba(255,255,255,.12); text-align:center; font-size:11px; letter-spacing:.06em; color:rgba(255,255,255,.5); }
  @media(max-width:768px){ .fh-footer .fx-in{ grid-template-columns:1fr; gap:34px; } }

  /* ===== 納品報告タブ ===== */
  .fh-rep-hero{ width:100%; height:clamp(320px,46vh,480px); object-fit:cover; }
  .fh-rep-greet{ display:grid; grid-template-columns:1fr 280px; gap:56px; align-items:start; max-width:980px; margin:0 auto; }
  .fh-rep-greet h3{ font-family:var(--font-serif); font-size:23px; font-weight:600; color:var(--green); line-height:1.7; margin-bottom:24px; letter-spacing:.04em; }
  .fh-rep-greet p{ color:var(--ink2); font-size:14px; margin-bottom:14px; line-height:2.1; }
  .fh-rep-greet .img{ width:100%; aspect-ratio:4/3; }
  .fh-rep-greet .img img{ width:100%; height:100%; object-fit:cover; }
  .fh-rep-meta{ list-style:none; margin-top:26px; border-top:1px solid var(--line); padding-top:22px; }
  .fh-rep-meta li{ font-size:13px; color:var(--ink2); margin-bottom:10px; }
  .fh-rep-meta .k{ display:inline-block; width:96px; color:var(--ink3); font-family:var(--font-en); font-size:11px; letter-spacing:.14em; text-transform:uppercase; }
  .fh-sub-head{ font-family:var(--font-serif); font-size:21px; font-weight:600; color:var(--green); margin:0 auto 40px; text-align:center; letter-spacing:.06em; max-width:980px; }
  .fh-rep-msgcard{ border:1px solid var(--line); background:var(--bg); padding:40px; max-width:880px; margin:0 auto; }
  .fh-rep-msgcard .top{ display:flex; align-items:center; gap:18px; padding-bottom:22px; margin-bottom:22px; border-bottom:1px solid var(--line); }
  .fh-rep-msgcard .top .ph{ width:62px; height:62px; border-radius:50%; flex:none; }
  .fh-rep-msgcard .co{ font-family:var(--font-serif); font-size:17px; font-weight:600; color:var(--green); }
  .fh-rep-msgcard .ro{ font-size:12.5px; color:var(--ink3); margin-top:3px; }
  .fh-rep-msgcard p{ color:var(--ink2); font-size:14px; line-height:2.15; }
  .fh-rep-items{ max-width:980px; margin:0 auto; }
  .fh-rep-item{ display:grid; grid-template-columns:1fr 300px; gap:52px; align-items:center; padding:48px 0; border-bottom:1px solid var(--line); }
  .fh-rep-item:last-child{ border-bottom:none; }
  .fh-rep-item:nth-child(even){ direction:rtl; }
  .fh-rep-item:nth-child(even) > *{ direction:ltr; }
  .fh-rep-item h4{ font-family:var(--font-serif); font-size:19px; font-weight:600; color:var(--green); margin-bottom:16px; letter-spacing:.04em; }
  .fh-rep-item h4::before{ content:""; display:inline-block; width:22px; height:1px; background:var(--bordeaux); vertical-align:middle; margin-right:13px; }
  .fh-rep-item p{ color:var(--ink2); font-size:13.5px; margin-bottom:10px; line-height:2.05; }
  .fh-rep-item p.em{ color:var(--ink); }
  .fh-rep-item .img{ width:100%; aspect-ratio:4/3; }
  .fh-rep-item .img img{ width:100%; height:100%; object-fit:cover; }

  /* ===== 追従ボタン（コースへ） ===== */
  .fh-float{ position:fixed; right:28px; bottom:28px; z-index:60; background:#6B1D2F !important; color:#fff !important;
    width:96px; height:96px; border-radius:50% !important; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:5px; text-align:center;
    font-size:11.5px; line-height:1.4; font-weight:600; letter-spacing:.08em; text-decoration:none;
    font-family:"Noto Sans JP",sans-serif; box-shadow:0 10px 30px rgba(107,29,47,.30); border:none; transition:transform .25s ease, background .2s ease; }
  .fh-float:hover{ background:#7D2538 !important; transform:scale(1.06); }
  .fh-float .fl{ width:26px; height:26px; display:block; }
  .fh-float .fl .petal{ transform-box:view-box; transform-origin:13px 13px; }
  .fh-float .fl .p2{ transform:rotate(72deg); }
  .fh-float .fl .p3{ transform:rotate(144deg); }
  .fh-float .fl .p4{ transform:rotate(216deg); }
  .fh-float .fl .p5{ transform:rotate(288deg); }
  @media(prefers-reduced-motion:no-preference){
    .fh-float:hover .fl{ animation:fh-bloom 4s linear infinite; transform-origin:13px 13px; transform-box:view-box; }
  }
  @keyframes fh-bloom{ to{ transform:rotate(360deg); } }
  .fh-float.hide{ display:none !important; }

  /* ============================================================
     一覧ページ固有スタイル
     ============================================================ */
  /* ヒーロー（一覧） */
  .fh-hero--list{ height:clamp(480px,68vh,620px); background-color:#16291E;
    background-image:url('https://gigaplus.makeshop.jp/flowerhub/img/sub/list_hero.webp');
    background-attachment:fixed; border-bottom:1px solid var(--line); }
  .fh-hero--list .fh-hero-inner{ padding:32px 32px 104px; }
  .fh-hero--list .fh-hero-title{ white-space:normal; letter-spacing:.14em; font-size:clamp(28px,5vw,48px); }

  /* イントロ（一覧） */
  .fh-list-intro{ background:var(--bg); padding:clamp(48px,7vw,76px) 0 clamp(40px,6vw,60px); text-align:center; }
  .fh-list-intro-lead{ max-width:760px; margin:0 auto; font-family:var(--font-serif); color:var(--ink); font-size:clamp(15px,1.9vw,18px); font-weight:500; line-height:2.1; letter-spacing:.06em; }

  /* フィルタバー */
  .fh-filter{ background:var(--bg); border-bottom:1px solid var(--line-soft); position:sticky; top:80px; z-index:40; }
  .fh-filter .row{ display:flex; justify-content:center; gap:4px; flex-wrap:wrap; padding:6px 0; }
  .fh-fbtn{ appearance:none; background:transparent; border:none; border-radius:999px; white-space:nowrap;
    padding:13px 20px; font-family:"Noto Sans JP",sans-serif; font-size:15px; cursor:pointer; color:var(--ink3); font-weight:500; letter-spacing:.08em;
    transition:color .25s ease, background .25s ease; display:inline-flex; align-items:center; gap:8px; line-height:1; }
  .fh-fbtn:hover{ color:var(--ink2); }
  .fh-fbtn .ct{ font-family:var(--font-en); font-size:11.5px; font-weight:600; letter-spacing:.04em; color:#b1afa8; transition:color .25s ease; }
  .fh-fbtn:hover .ct{ color:var(--ink3); }
  .fh-fbtn.active{ color:var(--bordeaux); background:#F3ECEC; }
  .fh-fbtn.active .ct{ color:var(--bordeaux); opacity:.7; }

  /* 案件カードグリッド */
  .fh-listsec{ padding:clamp(56px,7vw,84px) 0 clamp(78px,11vw,128px); }
  .fh-case-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:52px 44px; max-width:1120px; margin:0 auto; }
  .fh-case{ background:var(--bg); display:flex; flex-direction:column; border:1px solid var(--line-soft); transition:border-color .3s ease; }
  .fh-case:hover{ border-color:var(--line); }
  .fh-case .imgw{ position:relative; overflow:hidden; }
  .fh-case .img{ width:100%; aspect-ratio:3/2; transition:transform .8s var(--ease,cubic-bezier(.22,.61,.36,1)); background-size:cover; background-position:center; background-color:var(--warm); }
  .fh-case:hover .img{ transform:scale(1.04); }
  .fh-badge{ position:absolute; z-index:2; top:14px; left:14px; font-family:var(--font-jp); font-size:11px; font-weight:700; letter-spacing:.1em; color:#fff; padding:6px 13px; border-radius:999px; backdrop-filter:blur(2px); }
  .fh-badge.open{ background:rgba(31,58,43,.86); }
  .fh-badge.soon{ background:rgba(107,29,47,.88); }
  .fh-badge.closed{ background:rgba(90,89,84,.82); }
  .fh-case.is-closed .img{ filter:grayscale(.5) brightness(.96); }
  .fh-case .body{ padding:24px 24px 26px; display:flex; flex-direction:column; flex:1; }
  .fh-case .evt{ font-family:var(--font-en); font-size:11.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--bordeaux); font-weight:600; }
  .fh-case .evt:empty{ display:none; }
  .fh-case .nm{ font-family:var(--font-serif); font-size:19px; font-weight:600; color:#2C2C2A; letter-spacing:.04em; line-height:1.5; margin-top:9px; }
  .fh-case .sub{ font-size:12.5px; color:var(--ink2); margin-top:6px; line-height:1.7; }
  .fh-case .sub:empty{ display:none; }
  .fh-case .meta{ list-style:none; margin:18px 0 0; padding:18px 0 0; border-top:1px solid var(--line); }
  .fh-case .meta li{ display:flex; gap:12px; font-size:12.5px; color:var(--ink2); line-height:1.85; }
  .fh-case .meta li + li{ margin-top:7px; }
  .fh-case .meta .k{ flex:none; width:62px; color:var(--ink3); font-size:11px; letter-spacing:.06em; }
  .fh-case .meta .v{ color:var(--ink); }
  .fh-case .meta .v.em{ color:var(--bordeaux); font-weight:600; }
  .fh-case .btn{ margin-top:22px; display:block; text-align:center; background:transparent; color:var(--green);
    border:1px solid rgba(31,58,43,.78); font-size:12.5px; font-weight:600; letter-spacing:.04em; padding:12px; transition:.2s; }
  .fh-case .btn:hover{ background:rgba(31,58,43,.78); border-color:rgba(31,58,43,.78); color:#fff; }
  .fh-case.is-closed .btn{ color:var(--ink3); border-color:var(--line); }
  .fh-case.is-closed .btn:hover{ background:var(--ink3); border-color:var(--ink3); color:#fff; }
  .fh-case[hidden]{ display:none; }
  .fh-empty{ max-width:1120px; margin:0 auto; text-align:center; padding:64px 0; color:var(--ink3); font-size:14px; }
  .fh-empty[hidden]{ display:none; }

  /* お問い合わせ誘導（一覧末尾・緑地） */
  .fh-cta{ background:var(--green); color:#fff; padding:clamp(56px,8vw,88px) 0; text-align:center; }
  .fh-cta .e{ font-family:var(--font-en); font-size:13px; letter-spacing:.3em; text-transform:uppercase; color:#E7C9A0; }
  .fh-cta h3{ font-family:var(--font-serif); font-size:clamp(20px,2.8vw,27px); font-weight:600; margin-top:14px; letter-spacing:.06em; line-height:1.6; }
  .fh-cta p{ max-width:560px; margin:18px auto 0; font-size:13.5px; line-height:2; color:rgba(255,255,255,.82); }
  .fh-cta__boxes{ display:grid; grid-template-columns:1fr 1fr; gap:0; max-width:760px; margin:36px auto 0; border:1px solid rgba(255,255,255,.2); background:var(--bg2); text-align:center; }
  .fh-cta__box{ padding:44px 34px; display:flex; flex-direction:column; justify-content:center; }
  .fh-cta__box + .fh-cta__box{ border-left:1px solid var(--line); }
  .fh-cta__box h4{ font-family:var(--font-serif); font-size:16px; font-weight:600; color:var(--green); margin:0 0 20px; letter-spacing:.05em; }
  .fh-cta__box .lbl{ font-family:var(--font-en); font-size:13px; letter-spacing:.2em; color:var(--bordeaux); font-weight:600; }
  .fh-cta__box .tel{ font-family:var(--font-serif); font-size:30px; font-weight:600; color:var(--green); letter-spacing:.02em; line-height:1.3; margin-top:4px; }
  .fh-cta__box .hours{ font-size:12px; color:var(--ink3); margin-top:10px; line-height:1.8; }
  .fh-cta__box p{ font-size:13.5px; color:var(--ink2); line-height:1.9; margin:0; }
  .fh-cta__box .cbtn{ display:inline-flex; align-items:center; justify-content:center; gap:9px; margin:20px auto 0; background:var(--bordeaux); color:#fff; padding:13px 30px; border-radius:999px; font-size:13.5px; font-weight:700; letter-spacing:.04em; transition:.2s; }
  .fh-cta__box .cbtn:hover{ background:var(--bordeaux-90); transform:translateY(-2px); }
  .fh-cta__box .cbtn svg{ width:16px; height:16px; }

  /* ページ上部へ戻るボタン */
  .fh-top{ position:fixed; right:28px; bottom:28px; z-index:60; width:52px; height:52px; border-radius:50%;
    background:rgba(31,58,43,.92); color:#fff; border:none; cursor:pointer; display:flex; align-items:center; justify-content:center;
    box-shadow:0 10px 26px rgba(31,58,43,.28); opacity:0; pointer-events:none; transform:translateY(10px); transition:opacity .3s ease, transform .3s ease, background .2s ease; }
  .fh-top.show{ opacity:1; pointer-events:auto; transform:translateY(0); }
  .fh-top:hover{ background:var(--bordeaux); }
  .fh-top svg{ width:18px; height:18px; }

  /* ===== レスポンシブ ===== */
  @media(max-width:960px){
    .fh-case-grid{ grid-template-columns:repeat(2,1fr); gap:40px 32px; }
  }
  @media(max-width:900px){
    .fh-greet{ grid-template-columns:1fr; gap:36px; }
    .fh-greet .portrait{ max-width:280px; margin:0 auto; aspect-ratio:3/4; }
    .fh-courses{ grid-template-columns:repeat(2,1fr); }
    .fh-feats{ grid-template-columns:1fr; gap:44px; max-width:340px; }
    .fh-rep-greet,.fh-rep-item{ grid-template-columns:1fr; gap:28px; }
    .fh-rep-item:nth-child(even){ direction:ltr; }
  }
  @media(max-width:768px){
    .fh-gnav,.fh-hactions{ display:none; }
    .fh-burger{ display:block; }
    .fh-hero{ background-attachment:scroll; }
    .fh-filter{ top:72px; }
    .fh-hero--list{ background-attachment:scroll; height:clamp(380px,52vh,520px); }
  }
  @media(max-width:760px){
    .fh-detail{ grid-template-columns:repeat(2,1fr); }
    .fh-detail-item{ border-left:none !important; min-height:96px; padding:18px 24px; }
    .fh-detail-item:nth-child(even){ border-left:1px solid var(--line) !important; }
    .fh-detail-item:nth-child(3),.fh-detail-item:nth-child(4){ border-top:1px solid var(--line); }
  }
  @media(max-width:620px){
    .fh-contact{ grid-template-columns:1fr; }
    .fh-cbox:first-child{ border-right:none; border-bottom:1px solid var(--line); }
    .fh-cta__boxes{ grid-template-columns:1fr; }
    .fh-cta__box + .fh-cta__box{ border-left:none; border-top:1px solid var(--line); }
  }
  @media(max-width:560px){
    .fh .wrap{ padding:0 20px; }
    .fh-header-in{ padding:16px 20px; }
    .fh-courses{ grid-template-columns:1fr 1fr; gap:14px; }
    .fh-rep-msgcard{ padding:26px 20px; }
    .fh-case-grid{ grid-template-columns:1fr; max-width:420px; }
    .fh-fbtn{ padding:11px 15px; font-size:14px; gap:7px; }
  }
  @media(max-width:430px){
    .fh-detail{ grid-template-columns:1fr; }
    .fh-detail-item{ border-left:none !important; border-top:1px solid var(--line); min-height:0; padding:18px 24px; }
    .fh-detail-item:first-child{ border-top:none; }
    .fh-detail-item:nth-child(even){ border-left:none !important; }
  }

  /* ============================================================
     共通ヘッダー（fhx-header / 全ページ統一・トップLP準拠）
     ============================================================ */
  .fhx-header{ position:sticky; top:0; z-index:100; background:rgba(255,255,255,.92); -webkit-backdrop-filter:saturate(180%) blur(8px); backdrop-filter:saturate(180%) blur(8px); border-bottom:1px solid #E2E0D8; }
  .fhx-header__in{ max-width:1200px; margin:0 auto; padding:15px 24px; display:flex; align-items:center; gap:34px; }
  .fhx-logo{ display:flex; align-items:center; text-decoration:none; height:22px; overflow:hidden; font-size:18px; font-weight:700; color:#2C2C2A; max-width:160px; }
  .fhx-logo img{ display:block; height:22px; width:auto; }
  .fhx-nav{ display:flex; gap:28px; margin-left:8px; }
  .fhx-nav a{ font-family:"Noto Sans JP",sans-serif; font-weight:500; font-size:14px; letter-spacing:.04em; color:#3a3a36; text-decoration:none; transition:color .2s; white-space:nowrap; }
  .fhx-nav a:hover{ color:#6B1D2F; }
  .fhx-header__cta{ margin-left:auto; font-family:"Noto Sans JP",sans-serif; font-weight:700; font-size:12.5px; letter-spacing:.04em; color:#fff; background:#6B1D2F; padding:8px 18px; border-radius:999px; text-decoration:none; transition:background .25s, transform .25s; white-space:nowrap; }
  .fhx-header__cta:hover{ background:#591726; transform:translateY(-1px); }
  /* ハンバーガー（スマホ用） */
  .fhx-burger{ display:none; margin-left:auto; width:30px; height:22px; background:none; border:none; cursor:pointer; padding:0; position:relative; flex:none; }
  .fhx-burger span{ display:block; position:absolute; left:0; width:100%; height:2px; background:#2C2C2A; transition:.3s; border-radius:2px; }
  .fhx-burger span:nth-child(1){ top:1px; } .fhx-burger span:nth-child(2){ top:10px; } .fhx-burger span:nth-child(3){ top:19px; }
  .fhx-burger.open span:nth-child(1){ top:10px; transform:rotate(45deg); }
  .fhx-burger.open span:nth-child(2){ opacity:0; }
  .fhx-burger.open span:nth-child(3){ top:10px; transform:rotate(-45deg); }
  .fhx-drawer{ display:none; flex-direction:column; border-top:1px solid #E2E0D8; background:#fff; }
  .fhx-drawer.open{ display:flex; }
  .fhx-drawer a{ padding:15px 24px; border-bottom:1px solid #EFEDE6; font-size:15px; color:#2C2C2A; font-weight:500; text-decoration:none; }
  .fhx-drawer a.cta{ color:#6B1D2F; font-weight:700; }
  @media (max-width:820px){
    .fhx-nav{ display:none; }
    .fhx-header__cta{ display:none; }
    .fhx-burger{ display:block; }
    .fhx-header__in{ gap:0; }
  }

  /* ============================================================
     スマホ追加強化（詳細・一覧 / 横はみ出し防止・可読性）
     ============================================================ */
  /* 全体：横スクロール防止 */
  html, body{ overflow-x:hidden; }
  .fh img{ max-width:100%; height:auto; }

  @media(max-width:768px){
    /* 詳細ヒーロー：長い案件名でも収まるよう調整 */
    .fh-hero-title{ font-size:clamp(22px,6.4vw,30px) !important; line-height:1.35; white-space:normal !important; padding:0 12px; }
    .fh-hero-sub{ font-size:14px !important; letter-spacing:.08em !important; padding:0 16px; }
    .fh-hero-eyebrow{ font-size:12px; letter-spacing:.3em; }
    .fh-hero-inner{ padding:32px 20px 56px; }
    /* タブ */
    .fh-tab{ padding:18px 18px; font-size:15px; }
    /* セクション見出し */
    .fh-head .j{ font-size:clamp(20px,5.4vw,26px); padding:0 12px; }
    /* コース：2列を維持しつつ余白調整 */
    .fh-courses{ gap:14px; }
    .fh-course .price{ font-size:20px; }
    /* 受付情報 */
    .fh-detail-item .val{ font-size:16px; }
    /* 納品報告 */
    .fh-rep-item h4{ font-size:17px; }
    .fh-sub-head{ font-size:18px; padding:0 16px; }
  }
  @media(max-width:560px){
    /* 一覧カード：1列で見やすく */
    .fh-case-grid{ gap:24px; }
    .fh-case .nm{ font-size:18px; }
    /* コース：狭い端末でも2列キープ、文字を少し小さく */
    .fh-courses{ grid-template-columns:1fr 1fr; gap:12px; }
    .fh-course .nm{ font-size:11px; }
    .fh-course .btn{ font-size:11px; padding:10px; }
    /* フィルタボタン */
    .fh-fbtn{ padding:10px 14px; font-size:14px; }
  }
  @media(max-width:380px){
    .fh-courses{ grid-template-columns:1fr; max-width:280px; margin-left:auto; margin-right:auto; }
  }
