/* ========================================
   HOSMEDI COMMON v2
   共通：header / footer / FAB / fade-in
   ======================================== */

.site-header-v2 { background: rgba(251, 248, 241, 0.92); border-bottom: 0.5px solid rgba(13, 13, 13, 0.18); position: sticky; top: 0; z-index: 50; backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); margin: 0; padding: 0; }
.site-header-v2__inner { max-width: 1160px; margin: 0 auto; padding: 12px 22px; display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.brand-mini { font-family: 'Cormorant Garamond', 'Times New Roman', serif; font-style: italic; font-size: 18px; letter-spacing: 0.2em; color: #0d0d0d; text-decoration: none; font-weight: 500; }
.nav-mini { display: flex; gap: 22px; }
.nav-mini a { font-family: 'Shippori Mincho', serif; font-size: 13px; letter-spacing: 0.08em; color: #0d0d0d; text-decoration: none; transition: color .15s ease; }
.nav-mini a:hover { color: #a8261c; }
.nav-mini a.is-active { color: #a8261c; }
@media (max-width: 540px) { .nav-mini { gap: 14px; } .nav-mini a { font-size: 11.5px; } }

.site-footer-v2 { background: #fbf8f1; border-top: 6px double #1a1a1a; padding: 56px 22px 24px; margin: 0; }
.footer-grid-v2 { max-width: 1160px; margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: 36px; padding-bottom: 36px; border-bottom: 0.5px solid rgba(13, 13, 13, 0.18); }
@media (min-width: 720px) { .footer-grid-v2 { grid-template-columns: 1.2fr 1fr 1fr; } }
.footer-col-v2 h4 { font-family: 'Shippori Mincho', serif; font-size: 12px; letter-spacing: 0.3em; color: #0d0d0d; margin: 0 0 16px; font-weight: 700; }
.footer-col-v2 ul { list-style: none; padding: 0; margin: 0; }
.footer-col-v2 li { margin-bottom: 10px; }
.footer-col-v2 a { font-family: 'Shippori Mincho', serif; font-size: 13px; color: #3a3530; text-decoration: none; transition: color .15s ease; }
.footer-col-v2 a:hover { color: #a8261c; }
.footer-brand-v2__name { font-family: 'Cormorant Garamond', 'Times New Roman', serif; font-style: italic; font-size: 22px; letter-spacing: 0.2em; color: #0d0d0d; margin-bottom: 8px; }
.footer-brand-v2__desc { font-family: 'Shippori Mincho', serif; font-size: 12px; line-height: 1.9; color: #6b645c; max-width: 320px; }
.footer-fine-v2 { max-width: 1160px; margin: 24px auto 0; text-align: center; font-family: 'Cormorant Garamond', 'Times New Roman', serif; font-style: italic; font-size: 11px; letter-spacing: 2px; color: #6b645c; padding-top: 24px; }

.fab-line { position: fixed; bottom: 18px; right: 18px; z-index: 100; display: inline-flex; align-items: center; gap: 10px; background: #0d0d0d; color: #fbf8f1; padding: 12px 18px 12px 14px; border-radius: 999px; text-decoration: none; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25); transition: transform .25s ease; }
.fab-line:hover { transform: translateY(-2px); }
.fab-line__icon { width: 28px; height: 28px; background: #06c755; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; font-family: 'Shippori Mincho', serif; font-weight: 700; font-size: 13px; }
.fab-line__text { font-family: 'Shippori Mincho', serif; font-size: 13px; letter-spacing: 0.08em; font-weight: 600; }
@media (max-width: 720px) { .fab-line__text { display: none; } .fab-line { padding: 10px; } }

.back-top-v2 { position: fixed; bottom: 18px; left: 18px; z-index: 99; width: 38px; height: 38px; border-radius: 50%; background: rgba(13, 13, 13, 0.7); color: #fbf8f1; display: none; align-items: center; justify-content: center; cursor: pointer; border: none; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 14px; }
.back-top-v2.is-visible { display: flex; }

.fade-in { opacity: 0; transform: translateY(20px); transition: opacity 0.8s ease, transform 0.8s ease; }
.fade-in.is-visible { opacity: 1; transform: translateY(0); }

/* LINE add modal */
.line-modal { border: none; padding: 0; max-width: 520px; width: 92%; background: #fbf8f1; color: #0d0d0d; border-radius: 0; box-shadow: 0 30px 80px rgba(0, 0, 0, 0.4); }
.line-modal::backdrop { background: rgba(13, 13, 13, 0.72); backdrop-filter: blur(4px); }
.line-modal[open] { animation: lineModalIn 0.25s ease; }
@keyframes lineModalIn { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.line-modal__close { position: absolute; top: 12px; right: 14px; border: none; background: transparent; font-family: 'Cormorant Garamond', serif; font-size: 28px; cursor: pointer; color: #6b645c; line-height: 1; padding: 4px 10px; transition: color .15s; }
.line-modal__close:hover { color: #a8261c; }
.line-modal__inner { padding: 56px 30px 44px; text-align: center; }
.line-modal__kicker { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 11px; letter-spacing: 4px; color: #a8261c; margin-bottom: 14px; }
.line-modal__kicker::before, .line-modal__kicker::after { content: "—"; margin: 0 10px; }
.line-modal__title { font-family: 'Shippori Mincho', serif; font-size: 22px; font-weight: 700; letter-spacing: 0.08em; line-height: 1.55; margin-bottom: 20px; color: #0d0d0d; }
.line-modal__title em { font-style: normal; color: #a8261c; }
.line-modal__list { font-family: 'Shippori Mincho', serif; font-size: 13.5px; line-height: 2.1; color: #3a3530; max-width: 380px; margin: 0 auto 26px; text-align: left; list-style: none; padding: 0; }
.line-modal__list li { padding-left: 22px; position: relative; }
.line-modal__list li::before { content: "✓"; position: absolute; left: 0; color: #06c755; font-weight: 700; }
.line-modal__body { font-family: 'Shippori Mincho', serif; font-size: 13px; line-height: 1.95; color: #6b645c; margin-bottom: 22px; }
.line-modal__btn-wrap { display: inline-flex; flex-direction: column; align-items: center; gap: 10px; }
.line-modal__id { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 12px; letter-spacing: 3px; color: #6b645c; }
.line-modal__note { margin-top: 22px; font-family: 'Shippori Mincho', serif; font-size: 11.5px; line-height: 1.95; color: #6b645c; max-width: 360px; margin-left: auto; margin-right: auto; padding-top: 18px; border-top: 0.5px solid rgba(13, 13, 13, 0.18); }
@media (max-width: 540px) { .line-modal__inner { padding: 48px 20px 36px; } .line-modal__title { font-size: 19px; } }

/* hide old fab if exists on a page */
.consult-fab { display: none !important; }

/* print: hide site chrome */
@media print {
  .site-header-v2, .site-footer-v2, .fab-line, .back-top-v2 { display: none !important; }
}
