/* ===== Design tokens (wellness / supplement) ===== */
:root{
  --green:#2f6b5a;
  --green-2:#3f8a73;
  --leaf:#7fb8a0;
  --leaf-soft:#cfe6db;
  --gold:#c2a36b;
  --cream:#f6f8f4;
  --ink:#26322d;
  --ink-soft:#5d6b64;
  --line:#e6ece6;
  --radius:18px;
  --maxw:1100px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Noto Sans JP",system-ui,sans-serif;
  color:var(--ink);
  background:#fff;
  line-height:1.9;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:90%;max-width:var(--maxw);margin-inline:auto}
.container.narrow{max-width:760px}
.center{text-align:center}

/* ===== Header ===== */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:50;
  backdrop-filter:saturate(140%) blur(10px);
  background:rgba(47,107,90,.92);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:66px}
.logo{display:flex;align-items:baseline;gap:.45rem;color:#fff;font-family:"Cormorant Garamond",serif;letter-spacing:.14em}
.logo-mark{color:var(--leaf-soft);font-size:1.2rem}
.logo-text{font-size:1.35rem;font-weight:600}
.logo-llc{font-size:.7rem;letter-spacing:.18em;color:var(--leaf-soft)}
.gnav{display:flex;align-items:center;gap:1.8rem}
.gnav a{color:rgba(255,255,255,.85);font-size:.9rem;font-weight:500;transition:color .2s}
.gnav a:hover{color:#fff}
.nav-cta{border:1px solid rgba(255,255,255,.6);border-radius:999px;padding:.45rem 1.1rem}
.nav-cta:hover{background:#fff;color:var(--green)!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:24px;height:2px;background:#fff;transition:.3s}

/* ===== Hero ===== */
.hero{
  position:relative;overflow:hidden;
  min-height:90vh;display:flex;align-items:center;
  background:linear-gradient(135deg,#eaf3ee 0%,#f6f8f4 55%,#fff 100%);
}
.hero-inner{position:relative;z-index:2;padding-block:5rem;display:grid;grid-template-columns:1.05fr .95fr;gap:2rem;align-items:center}
.hero-copy{min-width:0}
.hero-art{justify-self:center;width:100%;max-width:440px}
.hero-art svg{width:100%;height:auto;filter:drop-shadow(0 18px 40px rgba(47,107,90,.18))}
.hero-sub{
  color:var(--green-2);letter-spacing:.3em;font-size:.82rem;font-weight:500;
  font-family:"Cormorant Garamond",serif;font-style:italic;margin-bottom:1.3rem;
}
.hero-title{
  font-size:clamp(2.3rem,6vw,4rem);font-weight:700;line-height:1.35;
  letter-spacing:.03em;color:var(--green);margin-bottom:1.6rem;
}
.hero-lead{color:var(--ink-soft);font-size:clamp(.95rem,1.4vw,1.08rem);margin-bottom:2.4rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}

/* ===== Buttons ===== */
.btn{display:inline-block;padding:.85rem 2rem;border-radius:999px;font-weight:500;font-size:.95rem;transition:.25s;border:1px solid transparent}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-2);transform:translateY(-2px);box-shadow:0 10px 24px rgba(47,107,90,.28)}
.btn-ghost{border-color:var(--green);color:var(--green)}
.btn-ghost:hover{background:var(--green);color:#fff}
.btn-light{background:#fff;color:var(--green)}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.18)}

/* ===== Sections ===== */
.section{padding-block:6rem}
.section-tint{background:var(--cream)}
.section-label{
  color:var(--green-2);letter-spacing:.26em;font-size:.78rem;font-weight:700;margin-bottom:.7rem;
  font-family:"Cormorant Garamond",serif;
}
.section-label.light{color:var(--leaf-soft)}
.section-title{font-size:clamp(1.6rem,3.4vw,2.2rem);font-weight:700;margin-bottom:2.4rem;letter-spacing:.04em;color:var(--green)}
.section-title.light{color:#fff}
.lead-text{font-size:clamp(1.15rem,2vw,1.45rem);font-weight:500;color:var(--green);line-height:1.9;margin-bottom:1.8rem}
.body-text{color:var(--ink-soft)}

/* ===== Business ===== */
.biz-list{display:grid;gap:1.2rem}
.biz{display:flex;gap:1.6rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem;transition:.25s}
.biz:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(38,50,45,.08)}
.biz-no{font-family:"Cormorant Garamond",serif;font-size:2.4rem;color:var(--leaf);font-weight:600;line-height:1;flex-shrink:0}
.biz-body h3{font-size:1.15rem;margin-bottom:.6rem;color:var(--ink)}
.biz-body p{color:var(--ink-soft);font-size:.92rem}

/* ===== Cards ===== */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2.2rem 1.7rem;text-align:center;transition:.25s}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(38,50,45,.1)}
.card-icon{display:flex;justify-content:center;margin-bottom:1.1rem}
.card-icon svg{width:46px;height:46px;color:var(--green-2)}
.card:hover .card-icon svg{color:var(--green)}
.card h3{font-size:1.08rem;margin-bottom:.7rem}
.card p{font-size:.88rem;color:var(--ink-soft);line-height:1.85}

/* ===== Company ===== */
.company-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 8px 22px rgba(38,50,45,.05)}
.company-table th,.company-table td{padding:1.1rem 1.4rem;text-align:left;border-bottom:1px solid var(--line);font-size:.95rem;vertical-align:top}
.company-table tr:last-child th,.company-table tr:last-child td{border-bottom:0}
.company-table th{width:28%;background:#f1f6f2;color:var(--green);font-weight:600;white-space:nowrap}
.todo{color:#b08968;background:#fbf3e9;padding:.1rem .5rem;border-radius:6px;font-size:.85rem}

/* ===== Contact ===== */
.section-contact{background:linear-gradient(135deg,var(--green) 0%,var(--green-2) 100%);text-align:center}
.contact-lead{color:rgba(255,255,255,.88);margin-bottom:2rem}

/* ===== Footer ===== */
.site-footer{background:#23302b;color:rgba(255,255,255,.72);padding-block:2.6rem}
.footer-inner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.2rem}
.footer-logo{color:#fff;font-family:"Cormorant Garamond",serif;font-size:1.2rem;letter-spacing:.12em}
.footer-logo .logo-mark{color:var(--leaf)}
.footer-nav{display:flex;gap:1.4rem;flex-wrap:wrap}
.footer-nav a{font-size:.85rem;transition:color .2s}
.footer-nav a:hover{color:#fff}
.copyright{width:100%;text-align:center;font-size:.78rem;color:rgba(255,255,255,.45);border-top:1px solid rgba(255,255,255,.08);padding-top:1.4rem;margin-top:.6rem}

/* ===== Responsive ===== */
@media(max-width:880px){
  .nav-toggle{display:flex}
  .gnav{
    position:fixed;inset:66px 0 auto 0;flex-direction:column;gap:0;
    background:rgba(47,107,90,.98);padding:1rem 0;
    transform:translateY(-130%);transition:transform .35s;
  }
  .gnav.open{transform:translateY(0)}
  .gnav a{padding:.9rem 9%;width:100%;border-bottom:1px solid rgba(255,255,255,.08)}
  .nav-cta{margin:.8rem 9%;width:auto;text-align:center}
  .cards{grid-template-columns:1fr}
  .hero-inner{grid-template-columns:1fr;text-align:center;gap:1rem;padding-block:4.5rem}
  .hero-actions{justify-content:center}
  .hero-art{order:-1;max-width:300px}
}
@media(max-width:520px){
  .biz{flex-direction:column;gap:.6rem;padding:1.6rem}
  .company-table th{width:38%}
  .section{padding-block:4rem}
}

/* ===== Image slots (hero photo / philosophy image / full-width band) ===== */
/* Hero: 生成写真があれば表示・無ければSVGにフォールバック */
.hero-photo{display:none;width:100%;height:auto;border-radius:24px;box-shadow:0 18px 40px rgba(47,107,90,.2)}
.hero-art.has-photo .hero-photo{display:block}
.hero-art.has-photo .hero-illust{display:none}

/* Philosophy 2カラム＋画像 */
.philosophy-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:center}
.philosophy-copy{min-width:0}
.philosophy-img{
  min-height:340px;border-radius:var(--radius);
  background-color:#cfe6db;
  background-image:linear-gradient(135deg,rgba(127,184,160,.30),rgba(47,107,90,.22)),url('../img/philosophy.jpg');
  background-size:cover;background-position:center;
  box-shadow:0 14px 34px rgba(38,50,45,.1);
}

/* 全幅 画像帯 */
.imgband{
  position:relative;min-height:360px;display:flex;align-items:center;justify-content:center;
  background-color:#2f6b5a;
  background-image:linear-gradient(rgba(26,40,33,.45),rgba(26,40,33,.45)),url('../img/band.jpg');
  background-size:cover;background-position:center;background-attachment:fixed;
}
.imgband-overlay{text-align:center;padding:2rem}
.imgband-text{
  color:#fff;font-size:clamp(1.35rem,3.2vw,2.1rem);font-weight:700;line-height:1.75;
  letter-spacing:.05em;text-shadow:0 2px 16px rgba(0,0,0,.3);margin:0;
}

@media(max-width:880px){
  .philosophy-grid{grid-template-columns:1fr;gap:1.6rem}
  .philosophy-img{min-height:220px;order:-1}
  .imgband{min-height:260px;background-attachment:scroll}
}

/* ===== 生成画像の収まり調整 ===== */
/* ヒーロー写真：縦長でも綺麗なパネルに */
.hero-art.has-photo .hero-photo{
  display:block;width:100%;aspect-ratio:4/5;max-height:560px;
  object-fit:cover;border-radius:24px;
}
/* 事業内容のサムネ画像 */
.biz-img{
  flex-shrink:0;width:180px;align-self:stretch;min-height:140px;border-radius:14px;
  background-size:cover;background-position:center;
}
@media(max-width:680px){
  .biz{flex-wrap:wrap}
  .biz-img{width:100%;height:160px;min-height:0;order:3}
}
