*,*::before,*::after{box-sizing:border-box}

:root{
  --home-ink:#102c38;
  --home-copy:#334b5a;
  --home-muted:#7c8a97;
  --home-blue:#68a8d8;
  --home-blue-strong:#4f8fca;
  --home-line:#dfe8f1;
  --home-soft:#eef6ff;
  --home-shell:min(1320px,calc(100% - 96px));
  --home-serif:"Playfair Display","Fraunces","Georgia","Times New Roman",serif;
  --home-sans:"Pretendard Variable","SF Pro KR","SF Pro Text",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,sans-serif;
}

html,body{margin:0;min-height:100%}
body.home-commerce-page{
  background:#fff;
  color:var(--home-ink);
  font-family:var(--home-sans);
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.home-commerce-page a{color:inherit;text-decoration:none}
body.home-commerce-page img,
body.home-commerce-page svg{display:block;max-width:100%}
button,input{font:inherit}
:focus-visible{outline:2px solid rgba(104,168,216,.72);outline-offset:3px}

.home-landing{
  min-height:100svh;
  overflow:hidden;
  background:#fff;
}
.home-shell{
  width:var(--home-shell);
  margin-inline:auto;
}

.home-hero{
  position:relative;
  min-height:515px;
  background:
    radial-gradient(circle at 50% 36%,rgba(255,255,255,.96),rgba(255,255,255,0) 29%),
    linear-gradient(105deg,#f7fbff 0%,#edf7ff 42%,#c9e2f5 100%);
  overflow:hidden;
}
.home-hero__inner{
  position:relative;
  width:var(--home-shell);
  min-height:515px;
  margin-inline:auto;
  padding:74px 0 42px;
}
.home-hero__copy{
  position:relative;
  z-index:2;
  width:min(430px,45vw);
}
.home-hero__eyebrow{
  margin:0 0 20px;
  color:#29404f;
  font-size:12px;
  font-weight:700;
  letter-spacing:.02em;
  text-transform:uppercase;
}
.home-hero h1{
  margin:0;
  color:#102c38;
  font-family:var(--home-serif);
  font-size:clamp(56px,6.35vw,82px);
  font-weight:700;
  line-height:.98;
  letter-spacing:-.045em;
}
.home-hero h1 span{color:#5f9dd1}
.home-hero__lead{
  margin:26px 0 28px;
  color:#263f50;
  font-size:18px;
  font-weight:500;
  line-height:1.65;
  letter-spacing:-.02em;
}
.home-hero__actions{
  display:flex;
  align-items:center;
  gap:22px;
  flex-wrap:wrap;
}
.home-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:13px;
  min-height:46px;
  padding:0 27px;
  border-radius:999px;
  background:#69aee0;
  color:#fff;
  font-size:14px;
  font-weight:800;
  box-shadow:0 12px 28px rgba(89,153,204,.18);
  transition:transform .2s ease,background .2s ease,box-shadow .2s ease;
}
.home-hero__text-link{
  color:#667a88;
  font-size:13px;
  font-weight:800;
  text-decoration:none;
  border-bottom:1px solid rgba(102,122,136,.35);
  transition:color .18s ease,border-color .18s ease;
}
.home-hero__text-link:hover{
  color:#4f8fd8;
  border-color:#4f8fd8;
}
.home-button svg{width:17px;height:17px}
.home-button:hover{
  background:#579bd0;
  transform:translateY(-1px);
  box-shadow:0 18px 36px rgba(89,153,204,.24);
}
.home-button--small{
  min-height:44px;
  padding-inline:23px;
  font-size:13px;
}
.home-hero__visual{
  position:absolute;
  z-index:1;
  right:max(-3vw,-54px);
  bottom:0;
  width:min(760px,58vw);
  height:100%;
  pointer-events:none;
}
.home-hero__visual picture,
.home-hero__visual img{
  width:100%;
  height:100%;
}
.home-hero__visual img{
  object-fit:cover;
  object-position:center bottom;
  filter:saturate(1.02) contrast(.98);
}
.home-hero__features{
  position:absolute;
  z-index:2;
  left:0;
  bottom:30px;
  display:grid;
  grid-template-columns:repeat(3,max-content);
  align-items:center;
  gap:0;
}
.home-feature{
  display:flex;
  align-items:center;
  gap:13px;
  min-width:150px;
  padding-right:30px;
  color:#152e3a;
}
.home-feature + .home-feature{
  padding-left:28px;
  border-left:1px solid rgba(16,44,56,.14);
}
.home-feature svg{
  width:36px;
  height:36px;
  flex:0 0 auto;
}
.home-feature span{display:grid;gap:2px}
.home-feature strong{
  font-size:13px;
  font-weight:800;
  letter-spacing:-.01em;
}
.home-feature small{
  color:#657784;
  font-size:12px;
  font-weight:600;
}

.home-section{
  padding:48px 0 0;
}
.home-categories{
  padding-bottom:58px;
}
.home-section__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:20px;
}
.home-section__head h2,
.home-process__copy h2{
  margin:0;
  color:#102c38;
  font-family:var(--home-serif);
  font-size:28px;
  font-weight:700;
  line-height:1.2;
  letter-spacing:-.03em;
}
.home-section__head a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#70aadc;
  font-size:13px;
  font-weight:800;
}
.home-section__head a svg{width:15px;height:15px}

.home-category-grid{
  width:100%;
  min-width:0;
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:16px;
}
.home-category-card{
  position:relative;
  min-height:152px;
  display:grid;
  grid-template-columns:112px minmax(0,1fr) 16px;
  align-items:center;
  gap:18px;
  overflow:hidden;
  padding:16px 18px 16px 14px;
  border:1px solid #dfe8f1;
  border-radius:8px;
  color:#102c38;
  background:#fff;
  isolation:isolate;
  transition:transform .22s ease,box-shadow .22s ease;
}
.home-category-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 40px rgba(33,70,96,.12);
}
.home-category-card img{
  width:112px;
  height:112px;
  border-radius:8px;
  object-fit:cover;
  mix-blend-mode:multiply;
  opacity:.92;
  background:#eef6ff;
}
.home-category-card span{
  display:grid;
  gap:1px;
  z-index:2;
  min-width:0;
}
.home-category-card strong{
  font-size:14px;
  font-weight:900;
  letter-spacing:-.02em;
}
.home-category-card small{
  color:#526676;
  font-size:12px;
  font-weight:600;
}
.home-category-card > svg{
  width:14px;
  height:14px;
  color:#354a58;
  z-index:2;
}
.tone-blue img{background:#d9ebfb}
.tone-gray img{background:#e6e3e7}
.tone-peach img{background:#f3e4de}
.tone-rose img{background:#eee6e6}
.tone-silver img{background:#e6e8ee}

.home-process{
  margin-top:56px;
  padding:34px 52px;
  display:grid;
  grid-template-columns:285px minmax(0,1fr);
  gap:42px;
  align-items:center;
  border-radius:12px;
  background:#eef5fb;
}
.home-process__copy{
  padding-right:32px;
  border-right:1px solid rgba(16,44,56,.12);
}
.home-process__copy p{
  margin:14px 0 22px;
  color:#5f7280;
  font-size:14px;
  font-weight:600;
  line-height:1.7;
}
.home-process__steps{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  align-items:start;
  gap:34px;
  margin:0;
  padding:0;
  list-style:none;
  counter-reset:process;
}
.home-process__steps li{
  position:relative;
  display:grid;
  justify-items:center;
  text-align:center;
  color:#102c38;
}
.home-process__steps li + li::before{
  content:"";
  position:absolute;
  left:-22px;
  top:32px;
  width:7px;
  height:7px;
  border-top:1.8px solid currentColor;
  border-right:1.8px solid currentColor;
  transform:rotate(45deg);
  opacity:.65;
}
.home-process__steps svg{
  width:62px;
  height:62px;
  margin-bottom:18px;
}
.home-process__steps strong{
  font-size:13px;
  font-weight:900;
  letter-spacing:-.02em;
}
.home-process__steps span{
  margin-top:6px;
  color:#647784;
  font-size:12px;
  font-weight:600;
  line-height:1.45;
}

.home-arrivals{padding-bottom:74px}
.home-product-grid{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:18px;
}
.home-product-card{
  position:relative;
  overflow:hidden;
  min-height:260px;
  border-radius:8px;
  background:#f2f4f7;
  color:#102c38;
  transition:transform .22s ease,box-shadow .22s ease;
}
.home-product-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 40px rgba(33,70,96,.1);
}
.home-product-card img{
  width:100%;
  height:225px;
  object-fit:cover;
}
.home-product-card__badge{
  position:absolute;
  top:12px;
  left:12px;
  z-index:2;
  min-height:18px;
  padding:0 8px;
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  background:#83bce6;
  color:#fff;
  font-size:9px;
  font-weight:900;
  letter-spacing:.04em;
}
.home-product-card strong{
  display:block;
  padding:12px 14px 16px;
  font-size:13px;
  font-weight:850;
  letter-spacing:-.015em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

[data-reveal]{
  opacity:0;
  transform:translate3d(0,18px,0);
  transition:opacity .62s ease,transform .62s ease;
}
[data-reveal].is-visible{
  opacity:1;
  transform:none;
}

@media (max-width:1100px){
  :root{--home-shell:min(100%,calc(100% - 44px))}
  .home-hero__visual{right:-18vw;width:72vw}
  .home-category-grid,
  .home-product-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .home-category-card{grid-template-columns:100px minmax(0,1fr) 16px}
  .home-category-card img{width:100px;height:100px}
  .home-process{grid-template-columns:1fr;padding:32px}
  .home-process__copy{padding:0;border-right:0}
}
@media (max-width:760px){
  :root{--home-shell:min(100%,calc(100% - 28px))}
  .home-hero{min-height:auto}
  .home-hero__inner{min-height:auto;padding:44px 0 0;overflow:hidden}
  .home-hero__copy{width:100%}
  .home-hero h1{font-size:45px}
  .home-hero__lead{font-size:16px}
  .home-hero__visual{
    position:relative;
    right:auto;
    width:calc(100% + 28px);
    height:420px;
    margin:34px -14px 0;
  }
  .home-hero__features{
    position:relative;
    left:auto;
    bottom:auto;
    grid-template-columns:1fr;
    gap:14px;
    padding:24px 0 30px;
  }
  .home-feature,
  .home-feature + .home-feature{
    min-width:0;
    padding:0;
    border-left:0;
  }
  .home-section{padding-top:38px}
  .home-section__head h2,
  .home-process__copy h2{font-size:24px}
  .home-category-grid,
  .home-product-grid{
    display:grid;
    grid-auto-flow:row;
    grid-auto-columns:auto;
    grid-template-columns:1fr;
    gap:14px;
    overflow:visible;
    padding-bottom:8px;
    scroll-snap-type:none;
    scrollbar-width:none;
  }
  .home-category-grid::-webkit-scrollbar,
  .home-product-grid::-webkit-scrollbar{display:none}
  .home-category-card,
  .home-product-card{scroll-snap-align:start}
  .home-category-card{
    min-height:142px;
    grid-template-columns:96px minmax(0,1fr) 16px;
  }
  .home-category-card img{width:96px;height:96px}
  .home-process{margin-top:36px;padding:26px 22px}
  .home-process__steps{grid-template-columns:1fr 1fr;gap:28px 18px}
  .home-process__steps li + li::before{display:none}
}
@media (prefers-reduced-motion:reduce){
  *,
  *::before,
  *::after{scroll-behavior:auto!important;transition:none!important;animation:none!important}
  [data-reveal]{opacity:1;transform:none}
}
