*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --teal:#5bbcb8;
  --teal-dark:#3d9e9a;
  --teal-mid:#9fd8d5;
  --teal-light:#e4f5f4;
  --teal-bg:#eef8f7;
  --text:#3c3c3c;
  --text-light:#888;
  --white:#fff;
  --f-sans:'Noto Sans JP',sans-serif;
  --f-serif:'Noto Serif JP',serif;
  --f-en:'Cormorant Garamond',serif;
}

html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--f-sans);font-size:16px;font-weight:400;color:var(--text);overflow-x:hidden;background:url('../images/bg.png') center center/cover fixed;}
body>main,body>section{font-family:var(--f-serif);}

/* ── HEADER ── */
body>header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:80px;
  background:rgba(255,255,255,0.97);
  -webkit-backdrop-filter:blur(8px);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(0,0,0,0.06);
  box-shadow:0 2px 12px rgba(0,0,0,0.15);
  transition:box-shadow 0.3s;
}
.h-inner{
  max-width:1100px;margin:0 auto;padding:0 32px;
  height:100%;
  display:flex;align-items:center;
}
.h-logo{display:flex;align-items:center;line-height:1;text-decoration:none;margin-right:auto}
.h-logo-img{height:60px;width:auto;display:block}
.h-info{display:flex;align-items:center;gap:24px;font-size:14px;color:var(--text-light)}
.h-info a{color:var(--text-light);text-decoration:none;transition:color .2s;display:flex;align-items:center;gap:5px}
.h-info a:hover{color:var(--teal)}
.h-tel{display:flex;align-items:center;gap:9px;font-size:22px;font-weight:700;color:#5bbcb8;letter-spacing:0.5px;white-space:nowrap;text-decoration:none}
.h-info a.h-tel{color:#5bbcb8}
.h-info a.h-tel:hover{color:var(--teal-dark)}
.h-tel img{width:30px;height:auto;flex-shrink:0}
.h-icon-btn{
  width:44px;height:44px;border:none;background:transparent;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:var(--text-light);transition:color .2s;padding:0;
}
.h-icon-btn img{width:30px;height:auto}
.h-icon-btn:hover{color:var(--teal)}
.h-btn{
  width:38px;height:38px;border-radius:50%;
  background:var(--teal);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  margin-left:10px;transition:background .2s;flex-shrink:0;
}
.h-btn:hover{background:var(--teal-dark)}
.h-btn span{display:block;width:14px;height:1.5px;background:#fff;position:relative}
.h-btn span::before,.h-btn span::after{content:'';position:absolute;width:14px;height:1.5px;background:#fff;left:0}
.h-btn span::before{top:-4px}
.h-btn span::after{top:4px}

/* ── HEADER responsive ── */
@media(max-width:640px){
  .h-inner{padding:0 16px}
  .h-info{gap:12px}
  .h-tel{font-size:16px;gap:6px}
  .h-tel img{width:22px}
  .h-icon-btn{width:36px;height:36px}
  .h-icon-btn img{width:22px}
  .h-logo-img{height:44px}
}
@media(max-width:380px){
  .h-tel{font-size:14px}
  .h-tel img{width:18px}
}

/* ── HERO ── */
.hero{
  margin-top:80px;
  background-color:#f5f5f5;
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  align-items:stretch;
}
.hero-center{
  display:flex;
  flex-direction:column;
  align-items:center;
  padding:52px 24px 0;
  position:relative;
  z-index:2;
}
.hero-catch{
  font-family:var(--f-serif);
  font-size:clamp(18px,2.2vw,28px);
  font-weight:700;
  color:var(--text);
  letter-spacing:2px;
  line-height:2;
  margin:0;
  text-align:center;
}
.hero-visual{
  width:100%;
  display:flex;
  justify-content:center;
  align-items:center;
  margin-top:16px;
}
.hero-kv-img{
  width:clamp(300px,55%,640px);
  height:auto;
  display:block;
}

.hero-tagline{
  font-family:var(--f-serif);
  font-size:clamp(20px,2.6vw,34px);
  font-weight:700;
  color:#5bbcb8;
  letter-spacing:4px;
  text-align:center;
  margin:0 0 48px;
}

/* ── SECTION LABEL ── */
.sec-label{text-align:center;margin-bottom:44px}
.sec-label .en{
  font-family:var(--f-en);
  font-size:38px;font-style:italic;font-weight:300;
  color:var(--teal);display:block;line-height:1;
}
.sec-label .jp{
  font-size:10px;letter-spacing:3px;
  color:var(--text-light);display:block;margin-top:5px;
}

/* ── SECTION BAND TITLE ── */
.sec-band{
  background:var(--teal);
  text-align:center;
  padding:18px 24px;
  margin-bottom:0;
}
.sec-band .en{
  font-family:var(--f-en);
  font-size:36px;font-style:italic;font-weight:300;
  color:#fff;display:block;line-height:1;
}
.sec-band .jp{
  font-size:14px;letter-spacing:4px;
  color:rgba(255,255,255,0.85);display:block;margin-top:6px;
}

/* ── NEWS ── */
.s-news{background:#fff;padding:56px 0;border-top:1px solid #d8d8d8;}
.news-wrap{
  max-width:900px;margin:0 auto;padding:0 40px;
  display:grid;grid-template-columns:170px 1fr;
}
.news-left{
  display:flex;flex-direction:column;align-items:center;
  border-right:1px solid rgba(91,188,184,0.25);
  padding-right:28px;padding-top:4px;
}
.news-left .en{font-family:var(--f-en);font-size:34px;font-style:italic;color:var(--teal);line-height:1}
.news-left .jp{font-size:14px;letter-spacing:3px;color:var(--text-light);margin-top:4px}
.news-prod{margin-top:22px}
.news-right{padding-left:32px}
.ni{
  display:grid;grid-template-columns:88px 1fr;gap:14px;
  padding:13px 0;border-bottom:1px solid #f0f0f0;
  cursor:pointer;transition:color .2s;
  text-decoration:none;
}
.ni:first-child{padding-top:0}
.ni:hover{color:var(--teal)}
.ni-date{font-size:14px;color:var(--text-light);letter-spacing:1px;padding-top:1px;text-decoration:none}
.ni-title{font-size:14px;line-height:1.6}
.news-more{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:18px;font-size:11px;color:var(--teal);
  text-decoration:none;border-bottom:1px solid rgba(91,188,184,0.4);
  padding-bottom:2px;letter-spacing:1px;transition:all .2s;
}
.news-more:hover{color:var(--teal-dark)}

/* ── COSMETICS ── */
.s-cosme{
  padding:0 0 80px;
}
.cosme-wrap{
  max-width:1080px;margin:0 auto;padding:0 40px;
}
.cosme-title{margin-bottom:56px;}
.cosme-panel{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  align-items:center;
  gap:40px;
}
.cosme-visual{
  position:relative;
  overflow:hidden;
}
.cosme-visual img{
  width:100%;height:auto;display:block;
}
.cosme-copy{
  padding:60px 0px 60px 0px;
  display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
}
.cosme-copy h3{
  font-family:var(--f-serif);
  font-size:clamp(22px,2.6vw,30px);
  font-weight:400;color:var(--text);
  letter-spacing:3px;line-height:1.55;
  margin-bottom:16px;
}
.cosme-copy .cosme-sub{
  font-size:13px;font-weight:500;
  color:var(--teal-dark);letter-spacing:1px;
  margin-bottom:22px;
}
.cosme-copy p{
  color:var(--text);margin-bottom:36px;
}
.btn-more{
  display:inline-flex;align-items:center;gap:14px;
  background:var(--teal);color:#fff;border:none;
  padding:14px 20px 14px 36px;
  font-size:18px;letter-spacing:2px;font-weight:300;
  font-family:var(--f-en);
  border-radius:999px;cursor:pointer;transition:background .25s;
  text-decoration:none;align-self:center;
}
.btn-more:hover{background:var(--teal-dark)}
.btn-more .btn-icon{
  width:32px;height:32px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,0.7);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:border-color .25s;
}
.btn-more:hover .btn-icon{border-color:#fff}
.btn-more .btn-icon svg{width:14px;height:14px;stroke:#fff;stroke-width:1.8;fill:none;transition:transform .25s}
.btn-more:hover .btn-icon svg{transform:translateX(2px)}

/* ── SALON ── */
.s-salon{
  padding:0 0 80px;
}
.salon-title{margin-bottom:56px;}
.salon-wrap{
  max-width:1080px;margin:0 auto;padding:0 40px;
}
.salon-panel{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  align-items:center;
  gap:40px;
}
.salon-copy{
  padding:60px 44px 60px 56px;
  display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
}
.salon-copy h3{
  font-family:var(--f-serif);
  font-size:clamp(22px,2.6vw,30px);
  font-weight:400;color:var(--text);
  letter-spacing:3px;line-height:1.55;
  margin-bottom:16px;
}
.salon-sub{
  font-size:13px;color:var(--teal);letter-spacing:1.5px;
  margin-bottom:20px;
}
.salon-copy p:not(.salon-sub){
  color:var(--text);
  margin-bottom:32px;
}
.salon-visual{
  position:relative;
  overflow:hidden;
}
.salon-visual img{
  width:100%;height:auto;display:block;
}

/* ── COMPANY ── */
.s-company{
  padding:0 0 64px;
}
.company-title{margin-bottom:48px;}
.company-inner{max-width:900px;margin:0 auto;padding:0 40px}
.company-grid{
  display:flex;flex-direction:column;gap:40px;
}
table.ctable{width:100%;border-collapse:collapse;font-size:13px}
.ctable tr{border-bottom:1px solid rgba(91,188,184,0.2)}
.ctable tr:first-child{border-top:1px solid rgba(91,188,184,0.2)}
.ctable th{
  width:110px;padding:14px 16px;
  background:rgba(91,188,184,0.08);
  color:var(--teal-dark);font-weight:400;text-align:left;
  white-space:nowrap;vertical-align:middle;
  letter-spacing:1px;font-size:12px;
}
.ctable td{padding:14px 16px;color:var(--text);line-height:1.8;vertical-align:middle;}
.ctable td[colspan]{width:auto;}
.map-box{
  width:100%;height:420px;border-radius:4px;overflow:hidden;
  box-shadow:0 2px 14px rgba(0,0,0,0.1);
}
.map-box iframe{width:100%;height:100%;border:0;display:block}

/* ── Top sections responsive ── */
@media(max-width:860px){
  .cosme-panel,.salon-panel{
    grid-template-columns:1fr;
    gap:24px;
  }
  .cosme-copy,.salon-copy{padding:0;align-items:center;text-align:center}
  .salon-panel{display:flex;flex-direction:column-reverse}
  .map-box{height:320px}
}
@media(max-width:640px){
  .news-wrap{
    grid-template-columns:1fr;
    padding:0 24px;
  }
  .news-left{
    flex-direction:row;align-items:baseline;gap:12px;
    border-right:none;
    border-bottom:1px solid rgba(91,188,184,0.25);
    padding:0 0 12px;margin-bottom:16px;
  }
  .news-left .en{font-size:28px}
  .news-right{padding-left:0}
  .ni{grid-template-columns:78px 1fr;gap:10px;padding:12px 0}
  .ni-title{font-size:14px}

  .cosme-wrap,.salon-wrap{padding:0 24px}
  .cosme-copy h3,.salon-copy h3{letter-spacing:2px}
  .cosme-copy p,.salon-copy p:not(.salon-sub){font-size:14px;margin-bottom:24px}
  .btn-more{font-size:15px;padding:12px 18px 12px 28px;gap:10px;letter-spacing:1.5px}
  .btn-more .btn-icon{width:26px;height:26px}

  .company-inner{padding:0 20px}
  .ctable,.ctable tbody,.ctable tr,.ctable th,.ctable td{display:block;width:auto}
  .ctable tr{border-bottom:1px solid rgba(91,188,184,0.2);padding:8px 0}
  .ctable tr:first-child{border-top:none}
  .ctable th{
    width:auto;padding:8px 12px;background:rgba(91,188,184,0.08);
    font-size:11px;letter-spacing:1.5px;
  }
  .ctable td{padding:8px 12px;font-size:13px}
  .ctable td[colspan]{padding:8px 12px}
  .map-box{height:260px}
}

/* ── CONTACT ── */
.s-contact{padding:0 0 64px;}
.contact-title{margin-bottom:48px;}
.contact-wrap{max-width:820px;margin:0 auto;padding:20px 28px;position:relative;background:#fff;border-radius:12px;box-shadow:0 4px 24px rgba(0,0,0,0.08);}
@media(max-width:640px){
  .contact-wrap{padding:16px 18px;margin-left:20px;margin-right:20px}
}
.contact-desc{
  text-align:center;color:var(--text);
  line-height:2;margin-bottom:38px;
}
.contact-desc a{color:var(--teal);}
.wpcf7-form{position:relative;z-index:1}
.wpcf7-response-output{
  margin:16px 0 0;padding:12px 16px;
  border-radius:4px;font-size:13px;line-height:1.6;
}
.wpcf7-form.sent .wpcf7-response-output{
  background:#e8f7f6;border:1px solid var(--teal);color:var(--teal-dark);
}
.wpcf7-form.failed .wpcf7-response-output,
.wpcf7-form.spam .wpcf7-response-output,
.wpcf7-form.invalid .wpcf7-response-output{
  background:#fff0f0;border:1px solid #e88;color:#c00;
}
.wpcf7-not-valid-tip{
  display:block;
  margin-top:4px;
  color:#c00;
}
.wpcf7-form-control.wpcf7-not-valid{border-color:#e88 !important;}
.fc-checks{
  display:flex;flex-wrap:wrap;gap:10px 24px;
  padding:10px 14px;
}
.fc-check{
  display:flex;align-items:center;gap:8px;
  cursor:pointer;color:var(--text);padding:0;
}
.fc-check input[type="checkbox"]{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;flex-shrink:0;
  border:1.5px solid #ccc;border-radius:3px;
  background:#fff;cursor:pointer;
  transition:border-color .2s,background .2s;
  position:relative;
}
.fc-check input[type="checkbox"]:checked{
  background:var(--teal);border-color:var(--teal);
}
.fc-check input[type="checkbox"]:checked::after{
  content:'';position:absolute;display:block;
  top:1px;left:5px;
  width:5px;height:9px;
  border:2px solid #fff;border-top:none;border-left:none;
  transform:rotate(45deg);
}
.fg>p>label:has(.wpcf7-checkbox){pointer-events:none;padding:0;}
.wpcf7-checkbox{display:flex;flex-wrap:wrap;gap:10px 24px;padding:10px 14px;}
.wpcf7-checkbox .wpcf7-list-item{
  margin:0;display:flex;align-items:center;gap:8px;
  cursor:pointer;color:var(--text);pointer-events:auto;
}
.wpcf7-checkbox .wpcf7-list-item-label{cursor:pointer;}
.wpcf7-checkbox .wpcf7-list-item input[type="checkbox"]{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;flex-shrink:0;
  border:1.5px solid #ccc;border-radius:3px;
  background:#fff;cursor:pointer;
  transition:border-color .2s,background .2s;
  position:relative;pointer-events:auto;
}
.wpcf7-checkbox .wpcf7-list-item input[type="checkbox"]:checked{background:var(--teal);border-color:var(--teal);}
.wpcf7-checkbox .wpcf7-list-item input[type="checkbox"]:checked::after{
  content:'';position:absolute;display:block;
  top:1px;left:5px;
  width:5px;height:9px;
  border:2px solid #fff;border-top:none;border-left:none;
  transform:rotate(45deg);
}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:0}
.fg{display:flex;flex-direction:column;gap:0;margin-bottom:14px}
.fg label,
.fg .fg-label{
  /* color:var(--text-light); */ letter-spacing:0.5px;
}
.fg label .req{color:var(--teal);margin-left:3px}
.fc,
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form select,
.wpcf7-form textarea{
  border:1px solid #ddd;border-radius:4px;
  padding:10px 14px;font-size:13px;
  font-family:var(--f-serif);font-weight:500;
  color:var(--text);background:#fff;outline:none;
  width:100%;transition:border-color .2s;
}
.fc:focus,
.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus{border-color:var(--teal);box-shadow:0 0 0 2px rgba(91,188,184,0.12)}
.fc::placeholder,
.wpcf7-form input::placeholder,
.wpcf7-form textarea::placeholder{color:#bbb;font-size:12px}
.wpcf7-form select{-webkit-appearance:none;cursor:pointer}
.wpcf7-form textarea,
.fc[name="contact_message"]{
  border:1px solid #ddd;border-radius:4px;
  padding:12px 14px;
  resize:vertical;min-height:160px;
}
.submit-wrap{text-align:center;margin-top:36px;position:relative}
.submit-wrap .wpcf7-spinner{position:absolute;margin-left:8px}
.btn-submit,
.wpcf7-form input[type="submit"]{
  display:block;margin:0 auto;
  background:var(--teal);color:#fff;border:none;
  padding:16px 80px;font-size:14px;letter-spacing:4px;
  font-family:var(--f-serif);font-weight:500;
  cursor:pointer;border-radius:999px;transition:background .25s;
}
.btn-submit:hover,
.wpcf7-form input[type="submit"]:hover{background:var(--teal-dark)}

/* ── FOOTER ── */
footer{
  background:var(--teal);
  padding:48px 0 0;
}
.foot-inner{
  max-width:900px;margin:0 auto;padding:0 40px;
  display:flex;flex-direction:column;align-items:center;gap:20px;
}
.foot-logo{display:block;text-decoration:none;}
.foot-logo img{height:60px;width:auto;display:block;}
.foot-social{display:flex;gap:16px;}
.foot-si{
  width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:opacity .2s;
}
.foot-si:hover{opacity:.7}
.foot-si svg{width:22px;height:22px;fill:#fff;}
.foot-nav{
  display:flex;gap:28px;flex-wrap:wrap;justify-content:center;
  border-top:1px solid rgba(255,255,255,0.25);
  padding-top:20px;width:100%;
}
.foot-nav a{font-size:12px;color:#fff;text-decoration:none;letter-spacing:2px;transition:opacity .2s;}
.foot-nav a:hover{opacity:.7}
.foot-copy{
  font-size:10px;color:rgba(255,255,255,0.7);letter-spacing:1px;
  border-top:1px solid rgba(255,255,255,0.2);
  width:100%;text-align:center;padding:12px 0;margin-top:4px;
}

/* ── DIVIDER ── */
.div{height:1px;background:linear-gradient(90deg,transparent,rgba(91,188,184,0.3),transparent);margin:0 60px}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .75s ease,transform .75s ease}
.reveal.v{opacity:1;transform:none}

/* ── DRAWER NAV ── */
.nav-overlay{
  position:fixed;inset:0;z-index:300;
  background:rgba(0,0,0,0.35);
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
}
.nav-overlay.open{opacity:1;pointer-events:auto}

.nav-drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:301;
  width:min(60vw,760px);
  background:#5bbcb8;
  transform:translateX(100%);
  transition:transform .38s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;
  padding:60px 40px 48px;
  overflow-y:auto;
}
.nav-drawer.open{transform:translateX(0)}

.nav-close{
  position:absolute;top:16px;right:16px;
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,0.18);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
  flex-shrink:0;
}
.nav-close:hover{background:rgba(255,255,255,0.32)}
.nav-close svg{width:16px;height:16px;stroke:#fff;stroke-width:2;fill:none}

.nav-list{
  list-style:none;
}
.nav-list li{
  border-bottom:1px solid rgba(255,255,255,0.25);
}
.nav-list li:first-child{border-top:1px solid rgba(255,255,255,0.25)}

.nav-list a,.nav-list button.nav-parent{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;padding:16px 0;
  font-family:var(--f-serif);font-weight:500;
  font-size:14px;letter-spacing:1.5px;
  color:#fff;text-decoration:none;
  background:none;border:none;cursor:pointer;
  transition:opacity .2s;
}
.nav-list a:hover,.nav-list button.nav-parent:hover{opacity:.75}

.nav-parent--static{
  display:block;width:100%;padding:16px 0;
  font-family:var(--f-serif);font-weight:500;
  font-size:14px;letter-spacing:1.5px;
  color:#fff;
}

.nav-sub{
  list-style:none;
  max-height:0;overflow:hidden;
  transition:max-height .3s ease;
}
.nav-sub.open,.nav-sub--open{max-height:500px}
.nav-sub li{border:none}
.nav-sub a{
  padding:10px 0 10px 16px;
  font-size:12.5px;letter-spacing:1px;
  opacity:.85;
}
.nav-sub a:hover{opacity:.6}

.nav-dot{
  width:6px;height:6px;border-radius:50%;
  background:#f97316;flex-shrink:0;
}

.nav-social{
  display:flex;gap:14px;margin-top:32px;
}
.nav-si{
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,0.18);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .2s;text-decoration:none;
}
.nav-si:hover{background:rgba(255,255,255,0.32)}
.nav-si svg{width:18px;height:18px;fill:#fff}

/* ── PAGE: MICHI ── */
.page-michi{padding-top:80px}

.michi-hero{
  position:relative;
  width:100%;
  height:520px;
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
}
.michi-hero-overlay{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;
  z-index:2;
}
.michi-hero-img{
  position:absolute;
  right:0;bottom:0;
  height:90%;
  width:auto;
  object-fit:contain;
  z-index:1;
}
.michi-hero-brand{
  font-family:var(--f-en);
  font-size:clamp(52px,8vw,96px);
  font-weight:300;font-style:italic;
  color:var(--teal);letter-spacing:8px;line-height:1;
  text-shadow:
    0 0 12px rgba(255,255,255,.95),
    0 0 24px rgba(255,255,255,.85),
    0 0 40px rgba(255,255,255,.7);
}
.michi-hero-sub{
  font-size:clamp(11px,1.4vw,14px);
  color:var(--teal-dark);
  letter-spacing:3px;margin-top:10px;
  font-weight:300;
  text-shadow:
    0 0 8px rgba(255,255,255,.95),
    0 0 16px rgba(255,255,255,.8),
    0 0 28px rgba(255,255,255,.6);
}
.cosme-hero-lead{
  font-size:clamp(11px,1.3vw,13px);
  color:var(--teal-dark);
  line-height:2;margin-top:20px;
  font-weight:300;letter-spacing:.06em;
}

/* ── PAGE: COSME — リードセクション ── */
.cosme-lead-section{
  background:#fff;
  padding:64px 40px;
}
.cosme-lead-inner{
  max-width:800px;margin:0 auto;
  display:flex;align-items:flex-start;gap:56px;
}
.cosme-lead-heading{
  flex-shrink:0;
  display:flex;flex-direction:column;align-items:center;
  gap:12px;
}
.cosme-lead-en{
  font-family:var(--f-en);
  font-size:48px;font-style:italic;font-weight:300;
  color:var(--teal);line-height:1;
}
.cosme-lead-line{
  display:block;width:1px;height:48px;
  background:var(--teal);
}
.cosme-lead-jp{
  font-size:10px;letter-spacing:4px;
  color:var(--teal-dark);
}
.cosme-lead-body{
  padding-top:8px;
  color:var(--text);
}
.cosme-lead-body p{margin:0 0 12px;}
.cosme-lead-body p:last-child{margin:0;}

@media(max-width:640px){
  .cosme-lead-inner{flex-direction:column;gap:24px;}
  .cosme-lead-heading{flex-direction:row;align-items:center;}
  .cosme-lead-line{width:32px;height:1px;}
}

.michi-intro{
  text-align:center;
  padding:56px 24px 48px;
}
.michi-intro-text{
  color:var(--text);
  letter-spacing:0.5px;
}

.michi-products{
  padding:0 0 32px;
}
.michi-products-wrap{
  max-width:1080px;margin:0 auto;padding:0 40px;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:28px;
}

.michi-card{
  background:#fff;
  border-radius:6px;
  overflow:hidden;
  box-shadow:0 2px 16px rgba(0,0,0,0.07);
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:stretch;
  min-height:260px;
  transition:box-shadow .25s;
}
.michi-card:hover{box-shadow:0 6px 28px rgba(91,188,184,0.18)}

.michi-card-img{
  background:var(--teal-light);
  display:flex;align-items:center;justify-content:center;
}
.michi-card-placeholder{
  display:flex;align-items:center;justify-content:center;
  width:100%;height:100%;min-height:220px;
  background:linear-gradient(135deg,#e4f5f4 0%,#c8ebe8 100%);
}
.michi-card-placeholder span{
  font-size:11px;color:var(--teal-dark);letter-spacing:2px;
}

.michi-card-body{
  padding:28px 24px;
  display:flex;flex-direction:column;
  justify-content:center;
}

.michi-card-step{
  display:flex;flex-direction:column;
  margin-bottom:8px;
}
.step-label{
  font-size:9px;letter-spacing:3px;
  color:var(--text-light);
  font-family:var(--f-en);
}
.step-num{
  font-family:var(--f-en);
  font-size:46px;font-weight:300;font-style:italic;
  color:var(--teal);line-height:1;
}

.michi-card-name{
  font-family:var(--f-serif);
  font-size:18px;font-weight:400;
  color:var(--teal-dark);
  letter-spacing:2px;
  margin-bottom:10px;
}

.michi-card-desc{
  font-size:12px;color:var(--text);
  line-height:1.9;margin-bottom:14px;
}

.michi-card-price{
  font-size:13px;font-weight:500;
  color:var(--text);letter-spacing:0.5px;
  margin-bottom:18px;
}

.michi-btn-detail{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;color:var(--teal-dark);
  letter-spacing:2px;text-decoration:none;
  border:1px solid var(--teal);
  border-radius:999px;
  padding:7px 18px;
  align-self:flex-start;
  transition:background .2s,color .2s;
}
.michi-btn-detail:hover{
  background:var(--teal);color:#fff;
}
.michi-btn-detail svg{
  width:14px;height:14px;
  stroke:currentColor;
  transition:transform .2s;
}
.michi-btn-detail:hover svg{transform:translateX(3px)}

.michi-breadcrumb{
  background:var(--teal);
  padding:10px 0;
  font-size:11px;color:#fff;
  letter-spacing:1px;
}
.michi-breadcrumb-inner{
  max-width:1080px;margin:0 auto;padding:0 40px;
  display:flex;align-items:center;gap:8px;
}
.michi-breadcrumb a{
  color:rgba(255,255,255,0.85);text-decoration:none;
  transition:color .2s;
}
.michi-breadcrumb a:hover{color:#fff}
.bc-sep{color:rgba(255,255,255,0.6)}

/* ── PAGE: MICHI responsive ── */
@media(max-width:860px){
  .michi-products-wrap{
    grid-template-columns:1fr;
    padding:0 20px;
  }
  .michi-card{
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:560px){
  .michi-hero{height:340px}
  .michi-hero-img{height:43%}
  .michi-hero-brand{font-size:64px;letter-spacing:4px}
  .michi-hero-sub{font-size:13px;letter-spacing:2px}
  .michi-card{
    grid-template-columns:1fr;
  }
  .michi-card-placeholder{min-height:180px}
  .michi-breadcrumb{padding:10px 20px}
}

/* ── PAGE: MICHI — mc2カード ── */
.mc2{
  background:#fff;
  border:1px solid #d8eeec;
  border-radius:6px;
  overflow:hidden;
  box-shadow:0 2px 12px rgba(0,0,0,0.06);
  display:flex;flex-direction:column;
}
.mc2-header{
  display:flex;align-items:stretch;
  padding:2px;
}
.mc2-cat{
  background:#fff;
  border:1.5px solid var(--teal);
  color:var(--teal-dark);
  font-size:14px;font-weight:bold;letter-spacing:1px;
  padding:6px 14px;
  display:flex;align-items:center;
  width:50%;
  text-align:center;
  justify-content:center;
  border-radius:5px 0 0 0;
}
.mc2-catch{
  background:var(--teal);
  color:#fff;
  font-size:14px;letter-spacing:1px;
  padding:6px 14px;
  display:flex;align-items:center;
  width:50%;
  text-align:center;
  justify-content:center;
  border-radius:0 5px 0 0;
}
.mc2-body{
  display:flex;align-items:center;
  padding:20px;
  gap:16px;
  flex:1;
}
.mc2-img{
  flex-shrink:0;width:200px;height:200px;
  border-radius:50%;
  background:var(--teal-light);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.mc2-img img{width:100%;height:100%;object-fit:cover;}
.mc2-placeholder{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
}
.mc2-placeholder span{font-size:10px;color:var(--teal-dark);letter-spacing:2px;}
.mc2-info{flex:1;}
.mc2-brand{
  font-family:var(--f-serif);
  font-size:20px;font-weight:700;
  color:var(--text);line-height:1.7;
  margin-bottom:8px;
  text-align:center;
}
.mc2-volume{
  color:var(--text);
  letter-spacing:0.5px;
  text-align:center;
}
.mc2-point{
  background:#f0fafa;
  padding:12px 20px;
  border-top:1px solid #d8eeec;
}
.mc2-point-label{
  font-size:18px;font-weight:700;
  color:var(--teal-dark);letter-spacing:1px;
  margin-bottom:6px;
}
.mc2-point ul{
  list-style:none;padding:0;margin:0;
}
.mc2-point ul li{
  color:var(--text);
  padding-left:14px;position:relative;
  margin-top:5px;
  font-size:14px;
}
.mc2-point ul li::before{
  content:'✓';
  position:absolute;left:0;
  color:var(--teal);font-size:10px;
}
.mc2-footer{
  background:var(--teal);
  color:#fff;
  font-size:17px;letter-spacing:2px;
  text-align:center;
  padding:10px;
}

@media(max-width:860px){
  .michi-products-wrap{grid-template-columns:1fr;}
}
@media(max-width:480px){
  .mc2-body{flex-direction:column;text-align:center;}
  .mc2-img{width:100px;height:100px;}
}

/* ── PAGE: COSME — 共通の特徴 ── */
.cosme-features{
  max-width:900px;margin:0 auto;
  padding:48px 40px 64px;
  text-align:center;
}
.cosme-features-catch{
  color:var(--text);
  letter-spacing:.06em;margin-bottom:48px;
}
.cosme-circles{
  display:flex;justify-content:center;align-items:center;
  flex-wrap:nowrap;gap:16px;
  margin-bottom:56px;
}
.cosme-circle{
  flex:0 0 auto;
  width:180px;height:180px;
  border-radius:50%;
  background:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;line-height:1.9;
  color:var(--text);text-align:center;
  padding:12px;
}
.cosme-features-text{
  text-align:center;
  color:var(--text);
}
.cosme-features-text p{margin:0}

/* ── PAGE: COSME — 他の幹細胞との違い ── */
.cosme-diff{
  max-width:1000px;margin:0 auto;
  padding:48px 40px 80px;
}
.cosme-diff > .cosme-section-heading{display:block;width:fit-content;margin-left:auto;margin-right:auto;}
.cosme-diff-lead{
  text-align:center;
  color:var(--text);
  margin-bottom:48px;
}
.cosme-diff-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.cosme-diff-card{
  background:#fff;
  border-radius:12px;
  padding:28px 28px 32px;
  box-shadow:0 2px 16px rgba(0,0,0,0.07);
}
.cosme-diff-card h3{
  font-size:18px;font-weight:700;
  color:var(--text);
  margin:0 0 16px;
  padding-bottom:12px;
  border-bottom:1px solid #e8e8e8;
}
.cosme-diff-card p{
  color:var(--text);margin:0 0 12px;
}
.cosme-diff-card p:last-child{margin:0;}
.cosme-diff-list{
  list-style:none;padding:0;margin:0 0 12px;
}
.cosme-diff-list li{
  position:relative;padding-left:16px;color:var(--text);
  margin-bottom:4px;
}
.cosme-diff-list li::before{
  content:'';position:absolute;left:2px;top:.7em;
  width:6px;height:6px;border-radius:50%;background:var(--teal);
}
.cosme-diff-accent{
  color:var(--teal);font-weight:600;
}

.cosme-section-heading{
  display:inline-block;
  font-size:20px;font-weight:500;letter-spacing:2px;
  color:var(--teal);margin:0 0 28px;
  padding-bottom:8px;
  border-bottom:2px solid var(--teal);
}

/* cosme scene */
.cosme-scene{padding:60px 40px 80px;background:#fafafa}
.cosme-scene-grid{
  max-width:960px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:48px 60px;
}
.cosme-scene-card h3{
  font-size:18px;font-weight:500;letter-spacing:1px;
  color:var(--teal);margin:0 0 16px;
  padding-bottom:10px;border-bottom:1px solid #d8eded;
}
.cosme-scene-card p{
  color:var(--text);margin:0 0 12px;
}
.cosme-scene-list{
  list-style:none;padding:0;margin:0 0 12px;
}
.cosme-scene-list li{
  color:var(--text);
  padding-left:1.2em;position:relative;
}
.cosme-scene-list li::before{
  content:'◉';color:var(--teal);font-size:10px;
  position:absolute;left:0;top:.15em;
}
.cosme-scene-list--inline{display:flex;gap:24px;flex-wrap:wrap}
.cosme-scene-accent{
  color:var(--teal);font-weight:600;font-size:13.5px;
  margin:8px 0 12px !important;
}

/* cosme flow */
.cosme-flow{padding:60px 40px 80px;background:#fff}
.cosme-flow-lead{
  text-align:center;color:var(--text);
  margin:0 0 36px;letter-spacing:.5px;
}
.cosme-flow-grid{
  max-width:960px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.cosme-flow-card{
  border:1.5px solid var(--teal);border-radius:4px;
  padding:20px 16px;
}
.cosme-flow-card h3{
  font-size:17px;font-weight:600;color:var(--teal);
  margin:0 0 14px;letter-spacing:.5px;
}
.cosme-flow-num{margin-right:4px}
.cosme-flow-card p{
  color:var(--text);margin:0;
}
.cosme-flow-cta{text-align:center;margin-top:16px;padding-bottom:64px}

/* cosme lineup */
.cosme-lineup{padding:60px 20px 80px;background:#fff}
.cosme-lineup-inner{max-width:720px;margin:0 auto;text-align:center}
.cosme-lineup-lead{
  color:var(--text);
  margin:0 0 36px;
}
.cosme-lineup-img{
  margin:0 0 40px;
  border:1px solid #d8eded;border-radius:4px;overflow:hidden;
}
.cosme-lineup-img img{width:100%;height:auto;display:block}
.cosme-lineup-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--teal);color:#fff;
  padding:14px 36px;border-radius:40px;
  font-size:14px;letter-spacing:1.5px;text-decoration:none;
  transition:opacity .2s;
}
.cosme-lineup-btn:hover{opacity:.8}
.cosme-lineup-btn svg{width:20px;height:20px;stroke:#fff;flex-shrink:0}

@media(max-width:860px){
  .cosme-diff-grid{grid-template-columns:1fr}
  .cosme-scene-grid{grid-template-columns:1fr}
  .cosme-flow-grid{grid-template-columns:1fr 1fr}
  .cosme-circles{flex-wrap:wrap;gap:16px}
  .cosme-circle{width:170px;height:170px;font-size:13px;line-height:1.8}
}
@media(max-width:560px){
  .cosme-features,.cosme-diff{padding-left:20px;padding-right:20px}
  .cosme-circle{width:150px;height:150px;font-size:12px;line-height:1.7;padding:10px}
  .cosme-flow-grid{grid-template-columns:1fr}
}

/* ── NEWS ARCHIVE / SINGLE ── */
.archive-news,.single-news{padding-top:80px;}
.news-archive-hero{
  background:var(--teal);
  text-align:center;
  padding:56px 20px 48px;
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.news-archive-hero-en{
  font-family:var(--f-en);font-size:42px;font-style:italic;
  color:#fff;line-height:1;letter-spacing:2px;
}
.news-archive-hero-jp{
  font-size:11px;letter-spacing:4px;color:rgba(255,255,255,.75);
}
@media(max-width:640px){
  .news-archive-hero{padding:32px 20px 24px}
  .news-archive-hero-en{font-size:34px}
  .news-archive-wrap{padding:32px 20px 56px}
}

.news-archive-wrap{
  max-width:820px;margin:0 auto;padding:56px 24px 80px;
}
.news-archive-list{list-style:none;}
.news-archive-item{border-bottom:1px solid #e0e0e0;}
.news-archive-item:first-child{border-top:1px solid #e0e0e0;}
.news-archive-link{
  display:flex;align-items:baseline;gap:20px;
  padding:18px 4px;
  text-decoration:none;color:var(--text);
  transition:color .2s;
}
.news-archive-link:hover{color:var(--teal);}
.news-archive-date{
  flex-shrink:0;font-size:11px;color:var(--text-light);
  letter-spacing:1px;padding-top:1px;
}
.news-archive-title{font-size:14px;line-height:1.6;}

.news-archive-pagination{margin-top:40px;text-align:center;}
.news-archive-pagination .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  width:36px;height:36px;margin:0 3px;border-radius:50%;
  font-size:13px;text-decoration:none;color:var(--text);
  border:1px solid #ddd;transition:all .2s;
}
.news-archive-pagination .page-numbers.current,
.news-archive-pagination .page-numbers:hover{
  background:var(--teal);color:#fff;border-color:var(--teal);
}
.news-archive-empty{
  text-align:center;color:var(--text-light);padding:48px 0;
}

.news-single-wrap{
  max-width:820px;margin:0 auto;padding:56px 24px 80px;
}
.news-single-article{background:#fff;border-radius:8px;padding:40px 48px;}
.news-single-header{margin-bottom:32px;border-bottom:1px solid #e8e8e8;padding-bottom:24px;}
.news-single-date{font-size:11px;color:var(--text-light);letter-spacing:1px;margin-bottom:10px;}
.news-single-title{font-size:22px;font-weight:700;line-height:1.5;color:var(--text);}
.news-single-body{line-height:1.9;}
.news-single-body p{margin:0 0 1.2em;}
.news-single-body p:last-child{margin:0;}

.news-single-back{margin-top:32px;}
.news-single-back a{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;color:var(--teal);text-decoration:none;
  transition:opacity .2s;
}
.news-single-back a:hover{opacity:.7;}

@media(max-width:600px){
  .news-archive-link{flex-direction:column;gap:4px;}
  .news-single-wrap{padding:32px 20px 56px;}
  .news-single-article{padding:28px 20px;}
  .news-single-title{font-size:18px;}
}
