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

:root{
  --ink:#111111;
  --black:#111111;
  --gray900:#1f1f1f;
  --gray700:#4a4a4a;
  --gray500:#767676;
  --gray300:#d9d9d9;
  --gray200:#eeeeee;
  --gray100:#f7f7f7;
  --white:#ffffff;
  --line:#dedede;
  --shadow:0 18px 54px rgba(0,0,0,.08);
  --font-serif:"Cormorant Garamond","Noto Serif TC","Source Han Serif TC","Source Han Serif","思源宋體","Songti TC","PMingLiU",serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:#ffffff;
  color:var(--black);
  font-family:var(--font-serif);
  line-height:1.82;
  letter-spacing:.035em;
  font-weight:400;
}
a{color:inherit;text-decoration:none}
a[href*="helori-scent-lab"],
a[href*="helori.hanascent.com"],
.helori-hero h1,
.grid3 .card:first-child h3{
  text-transform:uppercase;
}
html body .page-hero h1,
html body .helori-hero h1{
  font-size:clamp(39.6px,5.22vw,68.4px)!important;
}
html body .hero-title{
  font-size:clamp(36px,4.86vw,79.2px)!important;
}
html body .hero-title span{
  font-size:clamp(23.4px,2.7vw,38.7px)!important;
}
html body h2{
  font-size:clamp(27px,3.06vw,43.2px)!important;
}
html body .cta h2{
  font-size:clamp(34.2px,4.5vw,61.2px)!important;
}
html body a.text-link{
  font-size:15.4px!important;
  line-height:1.8!important;
}
img{display:block;max-width:100%}
button,input,textarea,select{font:inherit}

.site-nav{
  position:sticky;
  top:0;
  z-index:100;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:16px 5vw;
  background:rgba(255,255,255,.94);
  backdrop-filter: blur(18px);
  border-bottom:1px solid var(--line);
}
.logo{
  font-size:19px;
  letter-spacing:.28em;
  font-weight:600;
  white-space:nowrap;
}
.nav-links{
  display:flex;
  align-items:center;
  gap:20px;
  font-size:14px;
  color:var(--gray700);
}
.nav-links a{
  padding:6px 0;
  border-bottom:1px solid transparent;
}
.nav-links a:hover,
.nav-links a.active{
  color:var(--black);
  border-color:var(--black);
}
.nav-cta{
  border:1px solid var(--black)!important;
  padding:8px 14px!important;
}
.mobile-note{display:none}

.hero{
  padding:32px 5vw 68px;
  background:#ffffff;
}
.hero-shell{
  max-width:1320px;
  margin:0 auto;
}
.hero-visual{
  position:relative;
  overflow:hidden;
  border:1px solid var(--line);
  background:#ffffff;
  box-shadow:var(--shadow);
}
.hero-visual img{
  width:100%;
  height:auto;
}
.hero-panel{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:32px;
  align-items:end;
  margin-top:34px;
}
.eyebrow,
.kicker{
  margin:0 0 14px;
  color:var(--gray500);
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:14px;
  font-weight:500;
}
.hero-title{
  font-size:clamp(40px,5.4vw,88px);
  line-height:.96;
  letter-spacing:.16em;
  margin:0 0 18px;
  font-weight:500;
}
.hero-title span{
  display:block;
  font-size:clamp(26px,3vw,43px);
  letter-spacing:.24em;
  margin-top:18px;
  font-weight:500;
}
.hero-text{
  margin:0;
  color:var(--gray700);
  font-size:19px;
  max-width:620px;
}
.hero-actions,
.actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:12px 20px;
  border:1px solid var(--black);
  color:var(--black);
  background:#ffffff;
  font-size:15px;
  letter-spacing:.12em;
  transition:.18s ease;
}
.btn:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 24px rgba(0,0,0,.08);
}
.btn.primary{
  background:var(--black);
  color:#ffffff;
}
.btn.light{
  border-color:#ffffff;
  color:#ffffff;
  background:transparent;
}
.btn.light.primary{
  background:#ffffff;
  color:var(--black);
}
.btn.red{
  border-color:var(--gray700);
  color:var(--gray700);
  font-weight:500;
  transform:rotate(-1deg);
}

section{
  padding:96px 6vw;
  border-top:1px solid var(--line);
  background:#ffffff;
}
.wrap{
  max-width:1180px;
  margin:0 auto;
}
.section-head{
  display:grid;
  grid-template-columns:minmax(180px,.34fr) 1fr;
  gap:48px;
  align-items:start;
  margin-bottom:42px;
}
h1,h2,h3,p{overflow-wrap:anywhere}
h2{
  margin:0;
  font-size:clamp(30px,3.4vw,48px);
  line-height:1.25;
  letter-spacing:.12em;
  font-weight:500;
}
.lead{
  margin:16px 0 0;
  color:var(--gray700);
  font-size:19px;
  max-width:760px;
}
.split{
  display:grid;
  grid-template-columns:.92fr 1.08fr;
  gap:52px;
  align-items:center;
}
.photo-card{
  padding:18px;
  border:1px solid var(--line);
  background:#ffffff;
}
.photo-card img{
  filter:grayscale(.08) contrast(.98);
}
.large-quote{
  margin:0 0 24px;
  font-size:clamp(32px,4vw,58px);
  line-height:1.36;
  letter-spacing:.1em;
  font-weight:500;
}
.meta-line{
  margin-top:22px;
  color:var(--gray500);
  font-size:15px;
  letter-spacing:.12em;
}
.grid3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.grid2{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
}
.card,
.project-card,
.course-card,
.notice,
.form-card{
  background:#ffffff;
  border:1px solid var(--line);
  padding:28px;
}
.card{
  min-height:260px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.num{
  display:block;
  font-size:48px;
  color:#c8c8c8;
  line-height:1;
  margin-bottom:18px;
}
.project-card h3,
.course-card h3{
  margin:0 0 12px;
  font-size:25px;
  line-height:1.34;
  letter-spacing:.12em;
  font-weight:500;
}
.card p,
.project-card p,
.course-card p{
  margin:0;
  color:var(--gray700);
}
.text-link{
  display:inline-block;
  width:max-content;
  margin-top:26px;
  border-bottom:1px solid var(--black);
  font-size:14px;
  letter-spacing:.15em;
}

.dark-band{
  background:var(--black);
  color:#ffffff;
  border-top:none;
}
.dark-band .kicker{
  color:#bfbfbf;
}
.dark-band .lead,
.dark-band p{
  color:#e5e5e5;
}
.dark-panel{
  background:#191919;
  border:1px solid #3a3a3a;
  padding:30px;
}
.service-list{
  display:grid;
  gap:14px;
  margin-top:28px;
}
.service-row{
  display:grid;
  grid-template-columns:150px 1fr;
  gap:18px;
  padding:18px 0;
  border-bottom:1px solid #3a3a3a;
}
.service-row b{
  letter-spacing:.16em;
  color:#ffffff;
  font-weight:500;
}
.project-card,
.course-card{
  min-height:230px;
}
.project-card small,
.course-card small{
  display:block;
  margin-bottom:12px;
  letter-spacing:.18em;
  color:var(--gray500);
  font-size:13px;
}
.course-card{
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.course-meta{
  margin-top:24px;
  padding-top:16px;
  border-top:1px solid var(--line);
  color:var(--gray500);
  font-size:15px;
}

.timeline{
  counter-reset:step;
  display:grid;
  grid-template-columns:repeat(5,1fr);
  border:1px solid var(--line);
  background:#ffffff;
}
.timeline-item{
  min-height:178px;
  padding:24px;
  border-right:1px solid var(--line);
}
.timeline-item:last-child{border-right:none}
.timeline-item::before{
  counter-increment:step;
  content:"0" counter(step);
  display:block;
  margin-bottom:14px;
  font-size:32px;
  color:#c8c8c8;
}
.timeline-item b{
  display:block;
  margin-bottom:8px;
  letter-spacing:.12em;
  font-weight:500;
}
.timeline-item span{
  color:var(--gray700);
  font-size:15px;
}

.cta{
  text-align:center;
  background:var(--black);
  color:#ffffff;
  border-top:none;
}
.cta .wrap{max-width:900px}
.cta h2{
  font-size:clamp(38px,5vw,68px);
  letter-spacing:.16em;
  font-weight:500;
}
.cta p{
  margin:22px auto 30px;
  max-width:660px;
  color:#e5e5e5;
  font-size:19px;
}

.footer{
  padding:44px 6vw;
  background:#111111;
  color:#d0d0d0;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr;
  gap:28px;
  max-width:1180px;
  margin:0 auto;
  font-size:14px;
}
.footer b{
  letter-spacing:.24em;
  color:#ffffff;
  font-weight:500;
}

.page-hero{
  padding:82px 6vw 72px;
  background:
    linear-gradient(rgba(255,255,255,.94), rgba(255,255,255,.98)),
    url("homepage-cover.png") center/cover no-repeat;
  border-bottom:1px solid var(--line);
}
.page-hero .wrap{max-width:980px}
.page-hero h1{
  margin:0;
  font-size:clamp(42px,5vw,78px);
  line-height:1.1;
  letter-spacing:.14em;
  font-weight:500;
}
.page-hero p{
  max-width:720px;
  margin:22px 0 0;
  font-size:19px;
  color:var(--gray700);
}

.price-table{
  width:100%;
  border-collapse:collapse;
  background:#ffffff;
  border:1px solid var(--line);
}
.price-table th,
.price-table td{
  padding:18px;
  border-bottom:1px solid var(--line);
  text-align:left;
  vertical-align:top;
}
.price-table th{
  letter-spacing:.15em;
  color:var(--gray700);
  background:#f7f7f7;
  font-weight:500;
}
.notice{
  color:var(--gray700);
}
.field{
  display:grid;
  gap:7px;
  margin-bottom:16px;
}
.field label{
  font-size:14px;
  letter-spacing:.13em;
  color:var(--gray700);
}
.field input,
.field textarea,
.field select{
  width:100%;
  border:1px solid var(--line);
  background:#ffffff;
  padding:12px 13px;
  color:var(--black);
}
.field textarea{
  min-height:130px;
  resize:vertical;
}
.badge{
  display:inline-block;
  padding:4px 10px;
  border:1px solid var(--gray700);
  color:var(--gray700);
  font-size:12px;
  letter-spacing:.12em;
  transform:rotate(-1deg);
}

@media (max-width:980px){
  html body .page-hero h1,
  html body .helori-hero h1{
    font-size:clamp(34.2px,9vw,50.4px)!important;
  }
  html body .hero-title{
    font-size:clamp(36px,8.4vw,50.4px)!important;
  }
  html body .hero-title span{
    font-size:clamp(23.4px,6vw,34.2px)!important;
  }
  html body h2{
    font-size:clamp(27px,8.2vw,43.2px)!important;
  }
  html body a.text-link{
    font-size:16px!important;
  }
  .nav-links{display:none}
  .mobile-note{display:block;font-size:12px;color:var(--gray500)}
  .hero-panel,
  .section-head,
  .split,
  .footer-grid{
    grid-template-columns:1fr;
    gap:26px;
  }
  .grid3,
  .grid2,
  .timeline{
    grid-template-columns:1fr;
  }
  .timeline-item{
    border-right:none;
    border-bottom:1px solid var(--line);
  }
  .timeline-item:last-child{border-bottom:none}
  .service-row{grid-template-columns:1fr}
  section{padding:72px 22px}
  .hero{padding:18px 18px 50px}
  .site-nav{padding:15px 20px}
  .logo{font-size:16px;letter-spacing:.2em}
  .hero-title{letter-spacing:.10em}
  .hero-title span{letter-spacing:.16em}
}