@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600;700&family=Cormorant+Garamond:wght@400;500;600&display=swap');

/* =========================================================
   Reset
   ========================================================= */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Noto Sans JP","Hiragino Sans","Helvetica Neue",Arial,sans-serif;
  color:#2a2a2a;
  background:#fafaf8;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,picture,svg,video{display:block;max-width:100%;height:auto;}
ul,ol{margin:0;padding:0;list-style:none;}
h1,h2,h3,h4,h5,h6,p,figure,blockquote,dl,dd{margin:0;}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;}

/* =========================================================
   Design tokens
   ========================================================= */
:root{
  --hl-color-primary:#1f3a4d;
  --hl-color-primary-2:#284a63;
  --hl-color-accent:#b88746;
  --hl-color-accent-2:#a17533;
  --hl-color-bg:#fafaf8;
  --hl-color-bg-soft:#f1ece4;
  --hl-color-bg-deep:#1a2f3e;
  --hl-color-line:#e6e1d8;
  --hl-color-text:#2a2a2a;
  --hl-color-text-muted:#6a6a6a;
  --hl-color-white:#ffffff;

  --hl-font-jp:"Noto Sans JP","Hiragino Sans",sans-serif;
  --hl-font-en:"Cormorant Garamond","Noto Serif JP",serif;

  --hl-radius:14px;
  --hl-radius-sm:8px;
  --hl-shadow-sm:0 4px 14px rgba(31,58,77,.06);
  --hl-shadow-md:0 10px 30px rgba(31,58,77,.10);
  --hl-shadow-lg:0 20px 50px rgba(31,58,77,.14);

  --hl-container:1120px;
  --hl-content:880px;

  --hl-ease:cubic-bezier(.2,.7,.2,1);
}

/* =========================================================
   Base
   ========================================================= */
.hl-body{
  font-family:var(--hl-font-jp);
  color:var(--hl-color-text);
  background:var(--hl-color-bg);
}

.hl-page{
  font-family:var(--hl-font-jp);
  color:var(--hl-color-text);
  line-height:1.9;
  font-size:16px;
  letter-spacing:.02em;
  display:block;
}

.hl-container{
  max-width:var(--hl-container);
  margin-inline:auto;
  padding-inline:24px;
}
.hl-narrow{
  max-width:var(--hl-content);
  margin-inline:auto;
  padding-inline:24px;
}

.hl-section{ padding-block:96px; }
.hl-section--soft{ background:var(--hl-color-bg-soft); }
.hl-section--deep{
  background:var(--hl-color-bg-deep);
  color:#fff;
}
.hl-section--deep .hl-section-lead{ color:rgba(255,255,255,.78); }
.hl-section--deep .hl-section-title{ color:#fff; }

.hl-section-head{
  text-align:center;
  margin-bottom:56px;
}
.hl-section-eyebrow{
  display:inline-block;
  font-family:var(--hl-font-en);
  font-size:16px;
  font-weight:600;
  letter-spacing:.32em;
  color:var(--hl-color-accent-2);
  margin-bottom:14px;
  text-transform:uppercase;
}
.hl-section-title{
  font-size:clamp(24px,3.2vw,34px);
  font-weight:700;
  letter-spacing:.04em;
  line-height:1.4;
  margin:0 0 18px;
  color:var(--hl-color-primary);
}
.hl-section-lead{
  font-size:15px;
  line-height:2;
  color:var(--hl-color-text-muted);
  max-width:680px;
  margin:0 auto;
}

/* =========================================================
   Hero
   ========================================================= */
.hl-hero{
  position:relative;
  padding:120px 24px;
  background:
    linear-gradient(180deg,rgba(26,47,62,.55),rgba(26,47,62,.55)),
    url("../img/hero.png") center/cover no-repeat;
  color:#fff;
  text-align:center;
}
.hl-hero-eyebrow{
  font-family:var(--hl-font-en);
  letter-spacing:.4em;
  font-size:13px;
  opacity:.85;
}
.hl-hero-title{
  font-size:clamp(28px,4.2vw,46px);
  font-weight:700;
  letter-spacing:.06em;
  margin:18px 0 24px;
  line-height:1.5;
}
.hl-hero-text{
  max-width:640px;
  margin:0 auto 36px;
  line-height:2;
  font-size:15px;
  opacity:.92;
}

/* =========================================================
   Buttons
   ========================================================= */
.hl-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-width:240px;
  padding:16px 28px;
  font-size:15px;
  font-weight:600;
  letter-spacing:.08em;
  text-decoration:none;
  border-radius:999px;
  transition:transform .25s var(--hl-ease),box-shadow .25s var(--hl-ease),background .25s var(--hl-ease),color .25s var(--hl-ease);
  border:1px solid transparent;
}
.hl-btn--primary{
  background:var(--hl-color-accent);
  color:#fff;
  box-shadow:var(--hl-shadow-md);
}
.hl-btn--primary:hover{
  background:var(--hl-color-accent-2);
  transform:translateY(-2px);
  box-shadow:var(--hl-shadow-lg);
}
.hl-btn--ghost{
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.7);
}
.hl-btn--ghost:hover{
  background:#fff;
  color:var(--hl-color-primary);
}
.hl-btn--outline{
  background:#fff;
  color:var(--hl-color-primary);
  border-color:var(--hl-color-primary);
}
.hl-btn--outline:hover{
  background:var(--hl-color-primary);
  color:#fff;
}
.hl-btn .hl-btn-arrow{
  display:inline-block;
  transition:transform .25s var(--hl-ease);
}
.hl-btn:hover .hl-btn-arrow{ transform:translateX(4px); }

/* =========================================================
   Menu cards
   ========================================================= */
.hl-menu-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:36px;
}
.hl-menu-card{
  position:relative;
  display:flex;
  flex-direction:column;
  background:#fff;
  border:1px solid var(--hl-color-line);
  border-radius:var(--hl-radius);
  text-decoration:none;
  color:inherit;
  overflow:hidden;
  transition:transform .35s var(--hl-ease),box-shadow .35s var(--hl-ease),border-color .35s var(--hl-ease);
}
.hl-menu-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--hl-shadow-md);
  border-color:transparent;
}
.hl-menu-card-media{
  position:relative;
  margin:0;
  padding:14px 14px 0;
  background:#fff;
}
.hl-menu-card-media-inner{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  overflow:hidden;
  border-radius:10px;
  background:var(--hl-color-bg-soft);
}
.hl-menu-card-media-inner img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .6s var(--hl-ease),filter .35s var(--hl-ease);
}
.hl-menu-card:hover .hl-menu-card-media-inner img{ transform:scale(1.04); }
.hl-menu-card-body{
  padding:26px 28px 30px;
  display:flex;
  flex-direction:column;
  flex-grow:1;
}
.hl-menu-card-num{
  font-family:var(--hl-font-en);
  font-size:13px;
  letter-spacing:.25em;
  color:var(--hl-color-accent);
  margin-bottom:10px;
}
.hl-menu-card-title{
  font-size:17px;
  font-weight:700;
  line-height:1.55;
  color:var(--hl-color-primary);
  margin:0 0 14px;
  min-height:54px;
}
.hl-menu-card-desc{
  font-size:14px;
  line-height:1.9;
  color:var(--hl-color-text-muted);
  margin:0 0 22px;
  flex-grow:1;
}
.hl-menu-card-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  font-weight:600;
  color:var(--hl-color-primary);
  letter-spacing:.05em;
}
.hl-menu-card-link::after{
  content:"→";
  transition:transform .25s var(--hl-ease);
}
.hl-menu-card:hover .hl-menu-card-link::after{ transform:translateX(4px); }

/* =========================================================
   About
   ========================================================= */
.hl-about{
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:64px;
  align-items:center;
}
.hl-about-text p{
  margin:0 0 18px;
  line-height:2.05;
  font-size:15.5px;
}
.hl-about-image{
  position:relative;
  aspect-ratio:4/5;
  border-radius:var(--hl-radius);
  overflow:hidden;
  box-shadow:var(--hl-shadow-md);
  background:#dcd7cd url("../img/hero.png") center/cover no-repeat;
}
.hl-about-image::after{
  content:"";
  position:absolute;
  inset:auto -30px -30px auto;
  width:160px;
  height:160px;
  border:1px solid var(--hl-color-accent);
  border-radius:var(--hl-radius);
  z-index:-1;
}

/* =========================================================
   Trouble
   ========================================================= */
.hl-trouble-list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}
.hl-trouble-item{
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:22px 24px;
  background:#fff;
  border-radius:var(--hl-radius-sm);
  border:1px solid var(--hl-color-line);
  font-size:15px;
  line-height:1.7;
}
.hl-trouble-item::before{
  content:"?";
  flex:none;
  width:28px;height:28px;
  border-radius:50%;
  background:var(--hl-color-accent);
  color:#fff;
  font-weight:700;
  display:grid;place-items:center;
  font-size:14px;
  margin-top:2px;
}

/* =========================================================
   Strength
   ========================================================= */
.hl-strength-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
}
.hl-strength-card{
  background:#fff;
  border-radius:var(--hl-radius);
  padding:36px 24px;
  text-align:center;
  border:1px solid var(--hl-color-line);
  transition:transform .3s var(--hl-ease),box-shadow .3s var(--hl-ease);
}
.hl-strength-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--hl-shadow-sm);
}
.hl-strength-icon{
  width:64px;height:64px;
  margin:0 auto 18px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--hl-color-primary),var(--hl-color-primary-2));
  color:#fff;
  display:grid;place-items:center;
  font-family:var(--hl-font-en);
  font-size:22px;
  font-weight:600;
  letter-spacing:.05em;
}
.hl-strength-title{
  font-size:16px;
  font-weight:700;
  margin:0 0 10px;
  color:var(--hl-color-primary);
  line-height:1.5;
}
.hl-strength-desc{
  font-size:13.5px;
  line-height:1.85;
  color:var(--hl-color-text-muted);
  margin:0;
}

/* =========================================================
   Flow
   ========================================================= */
.hl-flow{
  display:grid;
  gap:18px;
  max-width:760px;
  margin:0 auto;
}
.hl-flow-item{
  display:grid;
  grid-template-columns:80px 1fr;
  gap:24px;
  align-items:center;
  background:#fff;
  border:1px solid var(--hl-color-line);
  border-radius:var(--hl-radius);
  padding:22px 28px;
  transition:border-color .25s var(--hl-ease),box-shadow .25s var(--hl-ease);
}
.hl-flow-item:hover{
  border-color:var(--hl-color-accent);
  box-shadow:var(--hl-shadow-sm);
}
.hl-flow-num{
  font-family:var(--hl-font-en);
  font-size:36px;
  font-weight:600;
  color:var(--hl-color-accent);
  letter-spacing:.04em;
  line-height:1;
  text-align:center;
  border-right:1px solid var(--hl-color-line);
  padding-right:24px;
}
.hl-flow-body h4{
  margin:0 0 4px;
  font-size:16px;
  font-weight:700;
  color:var(--hl-color-primary);
}
.hl-flow-body p{
  margin:0;
  font-size:13.5px;
  color:var(--hl-color-text-muted);
  line-height:1.7;
}

/* =========================================================
   CTA
   ========================================================= */
.hl-cta{
  position:relative;
  text-align:center;
  padding:96px 24px;
  color:#fff;
  background:
    linear-gradient(180deg,rgba(26,47,62,.85),rgba(26,47,62,.92)),
    url("../img/hero.png") center/cover no-repeat;
}
.hl-cta-eyebrow{
  font-family:var(--hl-font-en);
  letter-spacing:.4em;
  font-size:13px;
  color:var(--hl-color-accent);
  text-transform:uppercase;
}
.hl-cta-title{
  font-size:clamp(24px,3.2vw,32px);
  font-weight:700;
  letter-spacing:.05em;
  margin:14px 0 18px;
}
.hl-cta-text{
  max-width:520px;
  margin:0 auto 32px;
  line-height:2;
  font-size:15px;
  opacity:.9;
}
.hl-cta-actions{
  display:flex;
  gap:16px;
  justify-content:center;
  flex-wrap:wrap;
}

/* =========================================================
   Header
   ========================================================= */
.l-header.hl-header{
  background:#fff;
  border-bottom:1px solid var(--hl-color-line);
  padding:18px 0;
  position:relative;
  z-index:50;
}
.hl-header-inner{
  max-width:var(--hl-container);
  margin-inline:auto;
  padding-inline:24px;
  display:flex;
  align-items:center;
  gap:32px;
}
.hl-header .p-header-logo{
  margin:0;
  flex:none;
  font-size:0;
}
.hl-header .c-logo{
  display:inline-block;
  text-decoration:none;
}
.hl-header .c-logo__image{
  display:block;
  width:auto;
  height:42px;
}
.hl-header .p-header-nav{
  margin-left:auto;
}
.hl-header .p-header-nav__list{
  display:flex;
  align-items:center;
  gap:32px;
}
.hl-header .p-header-nav__list a{
  position:relative;
  display:inline-block;
  padding:6px 0;
  font-size:14px;
  font-weight:600;
  letter-spacing:.06em;
  color:var(--hl-color-primary);
  transition:color .25s var(--hl-ease);
}
.hl-header .p-header-nav__list a::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:-2px;
  height:2px;
  background:var(--hl-color-accent);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform .3s var(--hl-ease);
}
.hl-header .p-header-nav__list a:hover{ color:var(--hl-color-accent); }
.hl-header .p-header-nav__list a:hover::after{ transform:scaleX(1); }
.hl-header-cta .hl-btn{
  min-width:auto;
  padding:13px 24px;
  font-size:13px;
}

/* =========================================================
   Footer
   ========================================================= */
.l-footer.hl-footer{
  background:var(--hl-color-bg-deep);
  color:rgba(255,255,255,.78);
  padding:80px 24px 28px;
}
.hl-footer-inner{
  max-width:var(--hl-container);
  margin-inline:auto;
}
.hl-footer-top{
  display:grid;
  grid-template-columns:1.2fr 1.5fr;
  gap:64px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.hl-footer-brand .c-logo__image{
  display:block;
  width:auto;
  height:44px;
  filter:brightness(0) invert(1);
  margin-bottom:20px;
}
.hl-footer-tagline{
  font-size:13px;
  line-height:1.95;
  color:rgba(255,255,255,.7);
  margin:0;
  max-width:360px;
}
.hl-footer .p-footer-nav{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px 24px;
}
.hl-footer .p-footer-nav a{
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-size:14px;
  letter-spacing:.04em;
  color:rgba(255,255,255,.78);
  transition:color .25s var(--hl-ease);
}
.hl-footer .p-footer-nav a::before{
  content:"";
  width:18px;height:1px;
  background:var(--hl-color-accent);
  flex:none;
  transition:width .25s var(--hl-ease);
}
.hl-footer .p-footer-nav a:hover{ color:var(--hl-color-accent); }
.hl-footer .p-footer-nav a:hover::before{ width:28px; }
.hl-footer-bottom{
  padding-top:28px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:12px;
}
.hl-footer-copyright{
  font-family:var(--hl-font-en);
  font-size:12px;
  letter-spacing:.18em;
  color:rgba(255,255,255,.45);
  margin:0;
  text-transform:uppercase;
}
.hl-footer-sublinks{
  display:flex;
  gap:20px;
}
.hl-footer-sublinks a{
  font-size:12px;
  color:rgba(255,255,255,.55);
  letter-spacing:.04em;
  transition:color .25s var(--hl-ease);
}
.hl-footer-sublinks a:hover{ color:var(--hl-color-accent); }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:960px){
  .hl-section{ padding-block:72px; }
  .hl-section-head{ margin-bottom:40px; }

  .hl-menu-grid{ grid-template-columns:repeat(2,1fr); gap:24px; }
  .hl-strength-grid{ grid-template-columns:repeat(2,1fr); }
  .hl-trouble-list{ grid-template-columns:1fr; }
  .hl-about{ grid-template-columns:1fr; gap:40px; }
  .hl-about-image{ aspect-ratio:4/3; }

  .hl-header-inner{
    flex-direction:column;
    gap:16px;
    text-align:center;
  }
  .hl-header .p-header-nav{ margin-left:0; }
  .hl-header .p-header-nav__list{
    flex-wrap:wrap;
    justify-content:center;
    gap:18px 22px;
  }
  .hl-header-cta{ width:100%; display:flex; justify-content:center; }

  .hl-footer-top{ grid-template-columns:1fr; gap:36px; }
}

@media (max-width:600px){
  .hl-page{ font-size:15px; }
  .hl-section{ padding-block:56px; }
  .hl-container,.hl-narrow{ padding-inline:18px; }

  .hl-hero{ padding:80px 20px; }

  .hl-menu-grid{ grid-template-columns:1fr; gap:20px; }
  .hl-menu-card-media{ padding:12px 12px 0; }
  .hl-menu-card-body{ padding:22px 22px 26px; }
  .hl-menu-card-title{ min-height:auto; font-size:16px; }

  .hl-strength-grid{ grid-template-columns:1fr; gap:16px; }
  .hl-strength-card{ padding:28px 22px; }

  .hl-flow-item{
    grid-template-columns:60px 1fr;
    padding:18px 20px;
    gap:16px;
  }
  .hl-flow-num{ font-size:28px; padding-right:14px; }

  .hl-btn{ min-width:200px; width:100%; max-width:320px; }
  .hl-cta-actions{ flex-direction:column; align-items:center; }

  .l-header.hl-header{ padding:14px 0; }
  .hl-header .c-logo__image{ height:34px; }
  .hl-header .p-header-nav__list{ font-size:13px; gap:14px 18px; }

  .l-footer.hl-footer{ padding:60px 20px 24px; }
  .hl-footer-top{ padding-bottom:32px; }
  .hl-footer-bottom{
    flex-direction:column;
    align-items:flex-start;
    text-align:left;
  }
  .hl-footer .p-footer-nav{ grid-template-columns:1fr; gap:14px; }
}


/* =========================================================
   Sub-page hero (pagehead)
   下層ページ用のショート版ヒーロー。トップの hl-hero より低めで
   ページタイトル＋リード文に絞った見せ方。
   ========================================================= */
.hl-pagehead-inner{
  max-width:780px;
  margin:0 auto;
}


/* =========================================================
   Note callout（注釈ブロック）— 白基調・上品なバージョン
   ========================================================= */
.hl-note{
  background:#fff;
  border:1px solid var(--hl-color-line);
  border-left:3px solid var(--hl-color-accent);
  border-radius:var(--hl-radius-sm);
  padding:36px 40px;
  margin:0 auto;
  max-width:880px;
  box-shadow:0 1px 0 rgba(31,58,77,.02);
}
.hl-note p{
  margin:0 0 12px;
  font-size:15px;
  line-height:2;
  color:var(--hl-color-text);
}
.hl-note p:last-child{ margin-bottom:0; }
.hl-note p strong{
  display:block;
  font-size:16.5px;
  color:var(--hl-color-primary);
  font-weight:700;
  margin-bottom:6px;
  letter-spacing:.03em;
}

/* =========================================================
   Media row（交互レイアウト：home-services 等の対応サービス）
   原文の .re-media / .re-media-reverse を置換。
   ========================================================= */
.hl-media-stack{
  display:flex;
  flex-direction:column;
  gap:80px;
}
.hl-media-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
}
.hl-media-row--reverse .hl-media-row-text{ order:2; }
.hl-media-row--reverse .hl-media-row-image{ order:1; }
.hl-media-row-text h3,
.hl-media-row-text h4{
  font-size:clamp(19px,2.2vw,24px);
  font-weight:700;
  margin:0 0 18px;
  color:var(--hl-color-primary);
  line-height:1.5;
  letter-spacing:.03em;
}
.hl-media-row-text p{
  margin:0 0 14px;
  line-height:1.95;
  font-size:14.5px;
  color:var(--hl-color-text);
}
.hl-media-row-text .hl-btn{
  margin-top:18px;
  min-width:200px;
  padding:13px 24px;
  font-size:13.5px;
}
.hl-media-row-image{
  aspect-ratio:16/10;
  overflow:hidden;
  border-radius:var(--hl-radius);
  box-shadow:var(--hl-shadow-md);
  background:var(--hl-color-bg-soft);
}
.hl-media-row-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* =========================================================
   Intro block（サブページ本文の導入文）
   ========================================================= */
.hl-intro{
  max-width:760px;
  margin:0 auto;
  text-align:center;
}
.hl-intro h2{
  font-size:clamp(20px,2.4vw,24px);
  font-weight:700;
  color:var(--hl-color-primary);
  line-height:1.6;
  margin:0 0 26px;
  letter-spacing:.04em;
}
.hl-intro p{
  margin:0 0 16px;
  line-height:2;
  font-size:14.5px;
  color:var(--hl-color-text);
  text-align:left;
}
.hl-intro p:last-child{ margin-bottom:0; }

/* =========================================================
   Feature list（reform の箇条書きを置換）
   ========================================================= */
.hl-feature-list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin:0 auto;
  max-width:760px;
}
.hl-feature-item{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:18px 22px;
  background:#fff;
  border:1px solid var(--hl-color-line);
  border-radius:var(--hl-radius-sm);
  font-size:14.5px;
  line-height:1.7;
  color:var(--hl-color-text);
}
.hl-feature-item::before{
  content:"";
  flex:none;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--hl-color-accent);
  margin-top:10px;
}

/* =========================================================
   Lineup grid（商品一覧カード）
   原文の .re-card-list .re-lineup-list を置換。
   ========================================================= */
.hl-lineup-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.hl-lineup-card{
  display:flex;
  flex-direction:column;
  background:#fff;
  border:1px solid var(--hl-color-line);
  border-radius:var(--hl-radius);
  overflow:hidden;
  text-decoration:none;
  color:inherit;
  transition:transform .35s var(--hl-ease),box-shadow .35s var(--hl-ease),border-color .35s var(--hl-ease);
}
.hl-lineup-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--hl-shadow-md);
  border-color:transparent;
}
.hl-lineup-card-en{
  font-family:var(--hl-font-en);
  font-size:18px;
  font-weight:600;
  letter-spacing:.18em;
  color:var(--hl-color-accent);
  margin:0 0 6px;
  text-transform:uppercase;
}
.hl-lineup-card-jp{
  font-size:15.5px;
  font-weight:700;
  color:var(--hl-color-primary);
  margin:0 0 14px;
  line-height:1.55;
  letter-spacing:.02em;
}
.hl-lineup-card-desc{
  font-size:13.5px;
  line-height:1.85;
  color:var(--hl-color-text-muted);
  margin:0 0 22px;
  flex-grow:1;
}
.hl-lineup-card-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  font-weight:600;
  color:var(--hl-color-primary);
  letter-spacing:.04em;
}
.hl-lineup-card-link::after{
  content:"→";
  transition:transform .25s var(--hl-ease);
}
.hl-lineup-card:hover .hl-lineup-card-link::after{ transform:translateX(4px); }

/* ---- Lineup card thumbnail（figure / body 構造） ---- */
.hl-lineup-card-media{
  margin:0;
  aspect-ratio:16/9;
  overflow:hidden;
  background:var(--hl-color-bg-soft);
  border-bottom:1px solid var(--hl-color-line);
}
.hl-lineup-card-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .6s var(--hl-ease);
}
.hl-lineup-card:hover .hl-lineup-card-media img{ transform:scale(1.04); }
.hl-lineup-card-body{
  display:flex;
  flex-direction:column;
  flex-grow:1;
  padding:26px 28px 26px;
}


/* =========================================================
   Product list / Product row（商品詳細：カタログ風）
   原文の .post_row .post_col を置換。
   ========================================================= */
.hl-product-list{
  display:flex;
  flex-direction:column;
  border-top:1px solid var(--hl-color-line);
}
.hl-product-row{
  display:grid;
  grid-template-columns:0.9fr 1.4fr;
  gap:48px;
  padding:44px 0;
  border-bottom:1px solid var(--hl-color-line);
  align-items:center;
}
.hl-product-row-image{
  aspect-ratio:4/3;
  overflow:hidden;
  border-radius:var(--hl-radius);
  background:var(--hl-color-bg-soft);
  box-shadow:var(--hl-shadow-sm);
}
.hl-product-row-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.hl-product-row-body h3{
  font-size:21px;
  font-weight:700;
  color:var(--hl-color-primary);
  margin:0 0 14px;
  line-height:1.5;
  letter-spacing:.02em;
}
.hl-product-row-body p{
  font-size:14.5px;
  line-height:1.95;
  margin:0 0 14px;
  color:var(--hl-color-text);
}
.hl-product-row-price{
  display:inline-flex;
  align-items:baseline;
  gap:6px;
  font-family:var(--hl-font-jp);
  font-size:32px;
  font-weight:700;
  color:var(--hl-color-primary);
  margin:14px 0 22px !important;
  letter-spacing:.01em;
  line-height:1.2;
}
.hl-product-row-price-tax{
  font-family:var(--hl-font-jp);
  font-size:15px;
  color:var(--hl-color-text-muted);
  letter-spacing:.04em;
  font-weight:500;
  margin-left:2px;
}
.hl-product-row-body .hl-btn{
  min-width:auto;
  padding:11px 22px;
  font-size:13px;
  margin-top:6px;
}

/* =========================================================
   Sub-CTA（サブページ最下部の小さめCTA）
   原文の .re-cta を置換。 hl-cta より小さめ。
   ========================================================= */
.hl-subcta{
  position:relative;
  text-align:center;
  padding:80px 24px;
  color:#fff;
  background:
    linear-gradient(180deg,rgba(26,47,62,.86),rgba(26,47,62,.92)),
    url("../img/hero.png") center/cover no-repeat;
}
.hl-subcta-inner{
  max-width:680px;
  margin:0 auto;
}
.hl-subcta h2{
  font-size:clamp(20px,2.6vw,26px);
  font-weight:700;
  letter-spacing:.05em;
  margin:0 0 16px;
  line-height:1.6;
  color:#fff;
}
.hl-subcta p{
  font-size:14.5px;
  line-height:2;
  margin:0 0 28px;
  opacity:.9;
}
.hl-subcta .hl-btn{ margin-top:6px; }

/* =========================================================
   Responsive overrides for sub-pages
   ========================================================= */
@media (max-width:960px){

  .hl-media-stack{ gap:48px; }
  .hl-media-row{
    grid-template-columns:1fr;
    gap:30px;
  }
  .hl-media-row--reverse .hl-media-row-text{ order:2; }
  .hl-media-row--reverse .hl-media-row-image{ order:1; }
  .hl-media-row-image{ aspect-ratio:16/9; }

  .hl-feature-list{ grid-template-columns:1fr; }

  .hl-lineup-grid{ grid-template-columns:repeat(2,1fr); gap:22px; }

  .hl-product-row{
    grid-template-columns:1fr;
    gap:22px;
    padding:36px 0;
  }
  .hl-product-row-image{ aspect-ratio:16/9; }
}

@media (max-width:600px){

  .hl-note{ padding:22px 22px; }
  .hl-note p{ font-size:14px; }

  .hl-media-stack{ gap:40px; }

  .hl-intro p{ font-size:14px; }

  .hl-lineup-grid{ grid-template-columns:1fr; gap:18px; }
  .hl-lineup-card{ padding:26px 22px 22px; }

  .hl-product-row{ padding:28px 0; }
  .hl-product-row-body h3{ font-size:18px; }
  .hl-product-row-price{ font-size:26px; }

  .hl-subcta{ padding:60px 20px; }
}


/* =========================================================
   Spirit block（about-home-labo の精神）
   ========================================================= */
.hl-spirit{
  text-align:center;
  max-width:760px;
  margin:0 auto;
  padding:8px 0;
}
.hl-spirit-eyebrow{
  display:inline-block;
  font-family:var(--hl-font-en);
  font-size:13px;
  letter-spacing:.32em;
  color:var(--hl-color-accent);
  text-transform:uppercase;
  margin-bottom:18px;
}
.hl-spirit-title{
  font-size:clamp(22px,3vw,30px);
  font-weight:700;
  color:var(--hl-color-primary);
  letter-spacing:.05em;
  line-height:1.5;
  margin:0 0 32px;
}
.hl-spirit-title small{
  font-family:var(--hl-font-en);
  font-size:.55em;
  font-weight:500;
  letter-spacing:.16em;
  color:var(--hl-color-accent);
  margin-left:6px;
}
.hl-spirit-text{
  font-size:15.5px;
  line-height:2.2;
  color:var(--hl-color-text);
  margin:0;
}

/* =========================================================
   Charter list（プロフェッショナル7か条）
   ========================================================= */
.hl-charter{
  display:grid;
  gap:18px;
  max-width:880px;
  margin:0 auto;
  list-style:none;
  padding:0;
  counter-reset:none;
}
.hl-charter-item{
  display:grid;
  grid-template-columns:90px 1fr;
  gap:32px;
  align-items:flex-start;
  background:#fff;
  border:1px solid var(--hl-color-line);
  border-radius:var(--hl-radius);
  padding:28px 32px;
  transition:border-color .25s var(--hl-ease),box-shadow .25s var(--hl-ease);
}
.hl-charter-item:hover{
  border-color:var(--hl-color-accent);
  box-shadow:var(--hl-shadow-sm);
}
.hl-charter-num{
  font-family:var(--hl-font-en);
  font-size:36px;
  font-weight:600;
  color:var(--hl-color-accent);
  letter-spacing:.04em;
  line-height:1;
  text-align:center;
  border-right:1px solid var(--hl-color-line);
  padding-right:24px;
}
.hl-charter-body h3{
  margin:0 0 8px;
  font-size:17px;
  font-weight:700;
  color:var(--hl-color-primary);
  line-height:1.5;
  letter-spacing:.04em;
}
.hl-charter-body p{
  margin:0;
  font-size:14.5px;
  line-height:1.95;
  color:var(--hl-color-text);
}

.hl-section-title small{
  font-size:.6em;
  font-weight:500;
  letter-spacing:.04em;
  display:inline-block;
  margin-top:6px;
  color:var(--hl-color-text-muted);
}

/* =========================================================
   Service Flow の STEP 番号バッジ（h3内）
   ========================================================= */
.hl-step-num{
  display:inline-block;
  font-family:var(--hl-font-en);
  font-size:15px;
  letter-spacing:.16em;
  color:var(--hl-color-accent);
  margin-right:6px;
  font-weight:600;
}

/* =========================================================
   Contact: 電話ブロック
   ========================================================= */
.hl-tel-card{
  text-align:center;
  background:#fff;
  border:1px solid var(--hl-color-line);
  border-radius:var(--hl-radius);
  padding:48px 32px;
  max-width:680px;
  margin:0 auto;
  box-shadow:var(--hl-shadow-sm);
}
.hl-tel-eyebrow{
  display:inline-block;
  font-family:var(--hl-font-en);
  font-size:12px;
  letter-spacing:.4em;
  color:var(--hl-color-accent);
  text-transform:uppercase;
  margin-bottom:10px;
}
.hl-tel-title{
  font-size:20px;
  font-weight:700;
  color:var(--hl-color-primary);
  margin:0 0 12px;
  letter-spacing:.04em;
}
.hl-tel-lead{
  font-size:14px;
  color:var(--hl-color-text-muted);
  margin:0 0 22px;
  line-height:1.85;
}
.hl-tel-number{
  margin:0;
}
.hl-tel-number a{
  font-family:var(--hl-font-en);
  font-size:clamp(32px,5vw,44px);
  font-weight:600;
  color:var(--hl-color-primary);
  letter-spacing:.06em;
  text-decoration:none;
  transition:color .25s var(--hl-ease);
}
.hl-tel-number a:hover{ color:var(--hl-color-accent); }

/* =========================================================
   Contact: フォーム未実装通知
   ========================================================= */


/* =========================================================
   Privacy policy（条文レイアウト）
   ========================================================= */
.hl-policy{
  max-width:780px;
  margin:0 auto;
}
.hl-policy-intro{
  font-size:14.5px;
  line-height:2;
  margin:0 0 48px;
  color:var(--hl-color-text);
  padding-bottom:32px;
  border-bottom:1px solid var(--hl-color-line);
}
.hl-policy-article{
  margin:0 0 36px;
}
.hl-policy-article h3{
  font-size:16px;
  font-weight:700;
  color:var(--hl-color-primary);
  margin:0 0 14px;
  padding-left:14px;
  border-left:3px solid var(--hl-color-accent);
  letter-spacing:.04em;
  line-height:1.6;
}
.hl-policy-article p{
  font-size:14px;
  line-height:1.95;
  margin:0 0 10px;
  color:var(--hl-color-text);
}
.hl-policy-contact{
  background:var(--hl-color-bg-soft);
  border-radius:var(--hl-radius-sm);
  padding:24px 28px;
  margin:48px 0 24px;
}
.hl-policy-contact p{
  margin:0;
  font-size:14px;
  line-height:2;
  color:var(--hl-color-text);
}
.hl-policy-meta{
  text-align:right;
  font-size:13px;
  color:var(--hl-color-text-muted);
  line-height:1.85;
  margin:0;
}

/* =========================================================
   Responsive (basic pages)
   ========================================================= */
@media (max-width:960px){
  .hl-charter-item{
    grid-template-columns:64px 1fr;
    gap:20px;
    padding:22px 24px;
  }
  .hl-charter-num{
    font-size:28px;
    padding-right:16px;
  }
  .hl-tel-card{ padding:36px 24px; }
  
}

@media (max-width:600px){
  .hl-spirit-text{ font-size:14.5px; line-height:2; }
  .hl-spirit-title small{ display:block; margin:6px 0 0; }
  .hl-charter-item{
    grid-template-columns:56px 1fr;
    gap:16px;
    padding:18px 20px;
  }
  .hl-charter-num{ font-size:24px; padding-right:12px; }
  .hl-charter-body h3{ font-size:15.5px; }
  .hl-tel-card{ padding:30px 20px; }
  .hl-tel-number a{ font-size:30px; }
  
  
  .hl-policy-article h3{ font-size:15px; padding-left:12px; }
  .hl-policy-contact{ padding:20px 22px; }
}


/* =========================================================
   President's Message（about-home-labo の代表メッセージ仮枠）
   ========================================================= */
.hl-message{
  display:grid;
  grid-template-columns:0.85fr 1.15fr;
  gap:56px;
  align-items:center;
  max-width:1040px;
  margin:0 auto;
}
.hl-message-image{
  margin:0;
  aspect-ratio:3/4;
  overflow:hidden;
  border-radius:var(--hl-radius);
  background:var(--hl-color-bg-soft);
  box-shadow:var(--hl-shadow-md);
}
.hl-message-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.hl-message-body{
  padding:8px 0;
}
.hl-message-title{
  font-size:clamp(22px,2.8vw,28px);
  font-weight:700;
  letter-spacing:.05em;
  color:var(--hl-color-primary);
  margin:0 0 28px;
  line-height:1.5;
}
.hl-message-text p{
  margin:0 0 18px;
  font-size:15px;
  line-height:2.1;
  color:var(--hl-color-text);
}
.hl-message-signature{
  margin:32px 0 0 !important;
  padding-top:20px;
  border-top:1px solid var(--hl-color-line);
  font-size:14px;
  line-height:1.8;
  color:var(--hl-color-text);
}
.hl-message-signature-role{
  font-size:13px;
  color:var(--hl-color-text-muted);
  letter-spacing:.04em;
}
.hl-message-signature-name{
  font-size:18px;
  font-weight:700;
  color:var(--hl-color-primary);
  letter-spacing:.08em;
}
.hl-message-note{
  margin:18px 0 0 !important;
  font-size:12px;
  color:var(--hl-color-text-muted);
  font-style:italic;
}

@media (max-width:960px){
  .hl-message{
    grid-template-columns:1fr;
    gap:32px;
    max-width:680px;
  }
  .hl-message-image{ aspect-ratio:4/5; }
}
@media (max-width:600px){
  .hl-message-title{ font-size:21px; }
  .hl-message-text p{ font-size:14.5px; line-height:2; }
}


/* =========================================================
   Contact form（送信機能はプレビュー版では無効化）
   ========================================================= */

/* 静的プレビュー用 注意書き */
.hl-form-disclaimer{
  max-width:680px;
  margin:-24px auto 32px;
  padding:14px 22px;
  background:#fff;
  border:1px dashed var(--hl-color-accent);
  border-radius:var(--hl-radius-sm);
  font-size:13px;
  line-height:1.8;
  color:var(--hl-color-text-muted);
  text-align:center;
}

/* 属性セレクタ */
.hl-attr-selector{
  max-width:680px;
  margin:0 auto 48px;
  background:#fff;
  border:1px solid var(--hl-color-line);
  border-radius:var(--hl-radius);
  padding:28px 32px;
  box-shadow:var(--hl-shadow-sm);
}
.hl-attr-title{
  display:block;
  font-size:14.5px;
  font-weight:700;
  color:var(--hl-color-primary);
  letter-spacing:.04em;
  margin-bottom:12px;
}
.hl-attr-select{
  width:100%;
  padding:14px 18px;
  font-size:15px;
  font-family:var(--hl-font-jp);
  border:1px solid var(--hl-color-line);
  border-radius:var(--hl-radius-sm);
  background:#fff
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23b88746' d='M6 8L0 0h12z'/></svg>") right 18px center/12px 8px no-repeat;
  -webkit-appearance:none;
  appearance:none;
  cursor:pointer;
  color:var(--hl-color-text);
  transition:border-color .25s var(--hl-ease);
}
.hl-attr-select:focus{
  outline:none;
  border-color:var(--hl-color-accent);
}

/* フォーム本体 */
.hl-form{
  max-width:760px;
  margin:0 auto;
  background:#fff;
  border:1px solid var(--hl-color-line);
  border-radius:var(--hl-radius);
  padding:48px 48px 40px;
  box-shadow:var(--hl-shadow-sm);
}
.hl-form[hidden]{ display:none; }
.hl-form + .hl-form{ margin-top:40px; }

.hl-form-title{
  font-size:22px;
  font-weight:700;
  color:var(--hl-color-primary);
  letter-spacing:.04em;
  margin:0 0 12px;
  padding-bottom:16px;
  border-bottom:1px solid var(--hl-color-line);
}
.hl-form-lead{
  font-size:13.5px;
  line-height:1.95;
  color:var(--hl-color-text-muted);
  margin:0 0 36px;
}

/* fieldset */
.hl-fieldset{
  margin:0 0 32px;
  padding:0;
  border:none;
}
.hl-fieldset:last-of-type{ margin-bottom:24px; }
.hl-legend{
  display:block;
  font-size:14.5px;
  font-weight:700;
  color:var(--hl-color-primary);
  letter-spacing:.04em;
  margin:0 0 16px;
  padding:0 0 10px;
  border-bottom:2px solid var(--hl-color-accent);
  width:100%;
}
.hl-fieldset-lead{
  font-size:12.5px;
  color:var(--hl-color-text-muted);
  margin:-6px 0 14px;
  line-height:1.7;
}

/* field */
.hl-field{
  margin:0 0 16px;
}
.hl-field:last-child{ margin-bottom:0; }
.hl-label{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:13.5px;
  font-weight:600;
  color:var(--hl-color-text);
  margin:0 0 8px;
  letter-spacing:.03em;
}
.hl-required{
  display:inline-block;
  font-size:10.5px;
  font-weight:700;
  color:#fff;
  background:#c33;
  padding:2px 6px;
  border-radius:3px;
  letter-spacing:.04em;
  line-height:1.3;
}

/* input / textarea */
.hl-input,
.hl-textarea{
  width:100%;
  padding:12px 14px;
  font-size:14.5px;
  font-family:var(--hl-font-jp);
  color:var(--hl-color-text);
  background:#fff;
  border:1px solid var(--hl-color-line);
  border-radius:var(--hl-radius-sm);
  line-height:1.6;
  transition:border-color .25s var(--hl-ease),box-shadow .25s var(--hl-ease);
}
.hl-input:focus,
.hl-textarea:focus{
  outline:none;
  border-color:var(--hl-color-accent);
  box-shadow:0 0 0 3px rgba(184,135,70,.12);
}
.hl-textarea{
  resize:vertical;
  min-height:90px;
}

/* checkbox */
.hl-checkbox-group{
  display:flex;
  flex-wrap:wrap;
  gap:10px 16px;
  margin:0 0 14px;
}
.hl-checkbox-group--stack{
  flex-direction:column;
  gap:10px;
}
.hl-checkbox{
  display:inline-flex;
  align-items:center;
  gap:9px;
  font-size:13.5px;
  line-height:1.55;
  color:var(--hl-color-text);
  cursor:pointer;
  user-select:none;
  padding:8px 14px;
  background:#fff;
  border:1px solid var(--hl-color-line);
  border-radius:999px;
  transition:border-color .25s var(--hl-ease),background .25s var(--hl-ease);
}
.hl-checkbox:hover{ border-color:var(--hl-color-accent); }
.hl-checkbox-group--stack .hl-checkbox{
  display:flex;
  border-radius:var(--hl-radius-sm);
  padding:10px 16px;
}
.hl-checkbox-input{
  width:16px;
  height:16px;
  margin:0;
  accent-color:var(--hl-color-accent);
  flex:none;
}
.hl-checkbox:has(input:checked){
  border-color:var(--hl-color-accent);
  background:#fff8ef;
}

/* submit */
.hl-form-actions{
  text-align:center;
  margin-top:36px;
  padding-top:24px;
  border-top:1px solid var(--hl-color-line);
}
.hl-submit{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-width:280px;
  padding:16px 32px;
  font-size:15px;
  font-weight:700;
  letter-spacing:.08em;
  color:#fff;
  background:var(--hl-color-accent);
  border:1px solid var(--hl-color-accent);
  border-radius:999px;
  cursor:pointer;
  transition:transform .25s var(--hl-ease),box-shadow .25s var(--hl-ease),background .25s var(--hl-ease);
  box-shadow:var(--hl-shadow-md);
  font-family:var(--hl-font-jp);
}
.hl-submit:hover{
  background:var(--hl-color-accent-2);
  border-color:var(--hl-color-accent-2);
  transform:translateY(-2px);
  box-shadow:var(--hl-shadow-lg);
}

/* responsive */
@media (max-width:600px){
  .hl-form{ padding:32px 24px 28px; }
  .hl-form-title{ font-size:19px; }
  .hl-attr-selector{ padding:22px 22px; }
  .hl-checkbox{ font-size:13px; padding:7px 12px; }
  .hl-submit{ width:100%; min-width:auto; }
  .hl-form-disclaimer{ margin:-12px auto 28px; font-size:12.5px; padding:12px 18px; }
}
