:root{
  --ink:#0c0a07;
  --ink-2:#13100a;
  --ink-3:#181309;
  --line:rgba(243,236,224,.14);
  --line-2:rgba(243,236,224,.26);
  --line-soft:rgba(243,236,224,.07);

  --cream:#f3ece0;
  --cream-dim:#bfb4a3;
  --muted:#857b69;

  --flame:#ff5a1e;
  --flame-2:#ff7a3c;
  --flame-ink:#1a0c04;

  --maxw:1240px;
  --pad:clamp(20px,5vw,60px);

  --f-display:"Fraunces",Georgia,serif;
  --f-body:"Manrope",system-ui,sans-serif;
  --f-jp:"Shippori Mincho","Hiragino Mincho ProN",serif;

  --ease:cubic-bezier(.4,0,.1,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--ink);color:var(--cream-dim);
  font-family:var(--f-body);font-size:clamp(15px,1.02vw,16.5px);
  line-height:1.7;font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--flame);color:var(--flame-ink)}

h1,h2,h3,h4{
  font-family:var(--f-display);color:var(--cream);font-weight:500;
  line-height:1.04;letter-spacing:-.018em;margin:0;font-optical-sizing:auto;
}
.it{font-style:italic;font-weight:400}
.fl{color:var(--flame)}

.grain{
  position:fixed;inset:0;z-index:9;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}

.disc{position:absolute;border-radius:50%;background:var(--flame)}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);position:relative;z-index:1}
section{position:relative}

.eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-size:.72rem;font-weight:700;letter-spacing:.34em;text-transform:uppercase;color:var(--flame);
}
.eyebrow .jp{font-family:var(--f-jp);font-size:1.05rem;letter-spacing:0;color:var(--cream);font-weight:500}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--flame)}

.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:20px var(--pad);
  border-bottom:1px solid transparent;
  transition:background .35s var(--ease),padding .35s var(--ease),border-color .35s;
}
.nav.scrolled{background:var(--ink);border-bottom-color:var(--line);padding-block:13px}
.brand{display:flex;align-items:center;gap:.65rem;z-index:2}
.brand__mark{
  width:34px;height:34px;flex:none;border-radius:50%;
  display:grid;place-items:center;background:var(--flame);
  font-family:var(--f-jp);color:var(--flame-ink);font-size:1.05rem;font-weight:700;
}
.brand__txt{line-height:1.1}
.brand__txt b{
  display:block;font-family:var(--f-body);color:var(--cream);font-weight:700;
  font-size:.95rem;letter-spacing:.16em;text-transform:uppercase;
}
.brand__txt span{font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}

.nav__links{display:flex;align-items:center;gap:2.1rem;list-style:none;margin:0;padding:0}
.nav__links a{position:relative;font-size:.86rem;font-weight:600;color:var(--cream-dim);letter-spacing:.02em;transition:color .2s}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-7px;width:0;height:1px;background:var(--flame);transition:width .28s var(--ease)}
.nav__links a:hover{color:var(--cream)}
.nav__links a:hover::after{width:100%}

.nav__cta{display:flex;align-items:center;gap:1.3rem}
.nav__phone{font-weight:700;color:var(--cream);font-size:.88rem;display:flex;align-items:center;gap:.45rem}
.nav__phone svg{width:14px;height:14px;stroke:var(--flame)}

.burger{display:none;background:none;border:0;cursor:pointer;width:40px;height:40px;position:relative;z-index:60}
.burger span{position:absolute;left:9px;right:9px;height:2px;background:var(--cream);transition:.32s var(--ease)}
.burger span:nth-child(1){top:15px}.burger span:nth-child(2){top:21px}.burger span:nth-child(3){top:27px}
body.menu-open .burger span:nth-child(1){top:21px;transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){top:21px;transform:rotate(-45deg)}

.btn{
  display:inline-flex;align-items:center;gap:.6rem;cursor:pointer;border:1px solid transparent;
  padding:.92em 1.6em;border-radius:2px;font-weight:700;font-size:.88rem;letter-spacing:.02em;
  transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);white-space:nowrap;
}
.btn svg{width:16px;height:16px}
.btn--flame{background:var(--flame);color:var(--flame-ink);border-color:var(--flame)}
.btn--flame:hover{background:transparent;color:var(--flame)}
.btn--ghost{background:transparent;color:var(--cream);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--flame);color:var(--flame)}

.hero{min-height:100svh;display:flex;align-items:center;padding-top:128px;padding-bottom:64px}
.hero__grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(30px,4.5vw,72px);align-items:center;width:100%}
.hero__kanji{
  position:absolute;top:0;bottom:0;right:calc(50% - 30px);writing-mode:vertical-rl;
  font-family:var(--f-jp);font-size:clamp(4rem,11vw,10.5rem);color:var(--line-soft);
  font-weight:700;letter-spacing:.1em;display:flex;align-items:center;user-select:none;pointer-events:none;z-index:0;
}
.hero__eyebrow{margin-bottom:1.7rem}
.hero h1{font-size:clamp(2.5rem,6.6vw,5.4rem);font-weight:500}
.hero h1 .line{display:block}
.hero__lead{margin:1.7rem 0 2.3rem;max-width:33ch;font-size:clamp(1rem,1.35vw,1.16rem);color:var(--cream-dim)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.hero__meta{display:flex;flex-wrap:wrap;gap:0;margin-top:3rem;border-top:1px solid var(--line)}
.hero__meta div{padding:1.4rem 1.6rem 0 0;margin-right:1.6rem;border-right:1px solid var(--line)}
.hero__meta div:last-child{border-right:0;margin-right:0;padding-right:0}
.hero__meta b{display:block;font-family:var(--f-display);color:var(--cream);font-size:1.5rem;font-weight:600;line-height:1}
.hero__meta span{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

.hero__art{position:relative;aspect-ratio:1/1.12;width:100%}
.hero__disc{width:58%;aspect-ratio:1;right:-3%;top:-4%;z-index:0}
.hero__photo{position:absolute;inset:0;overflow:hidden;z-index:1;border:1px solid var(--line-2)}
.hero__photo img{width:100%;height:100%;object-fit:cover}
.hero__photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(12,10,7,.5))}
.hero__badge{
  position:absolute;z-index:2;left:-14px;bottom:34px;background:var(--ink-2);
  border:1px solid var(--line-2);padding:.85rem 1.1rem;display:flex;align-items:center;gap:.75rem;
}
.hero__badge .jp{font-family:var(--f-jp);color:var(--flame);font-size:1.7rem;line-height:1}
.hero__badge b{display:block;color:var(--cream);font-family:var(--f-body);font-weight:700;font-size:.9rem}
.hero__badge span{font-size:.72rem;color:var(--muted);letter-spacing:.04em}

.scrollcue{position:absolute;bottom:28px;left:var(--pad);display:flex;align-items:center;gap:.8rem;z-index:2;font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--muted)}
.scrollcue i{width:42px;height:1px;background:var(--line-2);position:relative;overflow:hidden}
.scrollcue i::after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:var(--flame);animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{left:-60%}60%,100%{left:120%}}

.manifest{padding:clamp(72px,9vw,124px) 0 clamp(40px,6vw,76px)}
.manifest__q{max-width:24ch;font-family:var(--f-display);font-weight:400;font-size:clamp(1.9rem,4.4vw,3.5rem);line-height:1.1;color:var(--cream)}
.manifest__sub{max-width:54ch;margin:1.7rem 0 0;color:var(--cream-dim)}
.marquee{margin-top:clamp(48px,6vw,84px);overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1.3rem 0}
.marquee__row{display:flex;gap:2.6rem;width:max-content;animation:scroll 38s linear infinite}
.marquee__row span{display:inline-flex;align-items:center;gap:1.2rem;font-family:var(--f-display);font-size:clamp(1.2rem,2.4vw,1.9rem);color:var(--cream);font-style:italic;font-weight:400;white-space:nowrap}
.marquee__row .jp{font-family:var(--f-jp);font-style:normal;color:var(--flame);font-weight:500}
.marquee__row .dot{color:var(--muted);font-style:normal}
@keyframes scroll{to{transform:translateX(-50%)}}

.oferta{padding:clamp(40px,7vw,88px) 0 clamp(72px,9vw,128px)}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:clamp(36px,5vw,60px)}
.sec-head h2{font-size:clamp(2rem,4.8vw,3.5rem);max-width:15ch}
.sec-head p{max-width:38ch;color:var(--cream-dim);margin:0}

.feature{display:grid;grid-template-columns:1.08fr 1fr;border:1px solid var(--line);background:var(--ink-2);margin-bottom:22px}
.feature__media{position:relative;min-height:360px;overflow:hidden}
.feature__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.feature:hover .feature__media img{transform:scale(1.04)}
.feature__media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 60%,rgba(19,16,10,.55))}
.feature__tag{position:absolute;top:0;left:0;z-index:2;background:var(--flame);color:var(--flame-ink);font-weight:800;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;padding:.55em 1em}
.feature__body{padding:clamp(28px,3.4vw,52px);display:flex;flex-direction:column;justify-content:center}
.feature__num{font-family:var(--f-display);font-size:.92rem;color:var(--flame);letter-spacing:.18em;margin-bottom:1.1rem;text-transform:uppercase}
.feature__body h3{font-size:clamp(1.6rem,2.9vw,2.4rem);margin-bottom:1.1rem;display:flex;align-items:baseline;gap:.7rem;flex-wrap:wrap}
.feature__body h3 .jp{font-family:var(--f-jp);font-size:1.2rem;color:var(--muted);font-weight:500}
.feature__body p{margin:0 0 1.6rem;color:var(--cream-dim)}
.tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.9rem}
.tags span{font-size:.74rem;color:var(--cream-dim);border:1px solid var(--line);padding:.42em .85em;letter-spacing:.02em}
.linkmore{display:inline-flex;align-items:center;gap:.5rem;color:var(--flame);font-weight:700;font-size:.85rem;letter-spacing:.06em;text-transform:uppercase;align-self:flex-start;transition:gap .25s}
.linkmore svg{width:17px;height:17px;transition:transform .25s}
.linkmore:hover{gap:.8rem}.linkmore:hover svg{transform:translateX(3px)}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{position:relative;border:1px solid var(--line);background:var(--ink-2);display:flex;flex-direction:column;transition:border-color .3s var(--ease)}
.card:hover{border-color:var(--flame)}
.card__media{position:relative;aspect-ratio:16/11;overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.card:hover .card__media img{transform:scale(1.05)}
.card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(19,16,10,.8),transparent 60%)}
.card__num{position:absolute;top:13px;right:15px;z-index:2;font-family:var(--f-display);color:var(--cream);font-size:1rem}
.card__jp{position:absolute;left:15px;bottom:11px;z-index:2;font-family:var(--f-jp);color:var(--flame);font-size:1.4rem}
.card__body{padding:1.5rem 1.5rem 1.6rem;display:flex;flex-direction:column;gap:.7rem;flex:1}
.card__body h3{font-size:1.28rem;font-weight:600}
.card__body p{margin:0;font-size:.9rem;color:var(--cream-dim);flex:1}
.card .linkmore{margin-top:.5rem;font-size:.78rem}

.foot{border-top:1px solid var(--line);padding:clamp(42px,5vw,64px) 0;margin-top:clamp(40px,6vw,80px)}
.foot__top{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:center}
.foot__cta h3{font-size:clamp(1.5rem,3vw,2.2rem);max-width:18ch}
.foot__cta p{margin:.6rem 0 0;color:var(--cream-dim)}
.foot__soc{display:flex;gap:.7rem}
.foot__soc a{width:44px;height:44px;border:1px solid var(--line-2);display:grid;place-items:center;color:var(--cream);transition:background .25s,color .25s,border-color .25s}
.foot__soc a:hover{background:var(--flame);color:var(--flame-ink);border-color:var(--flame)}
.foot__soc svg{width:18px;height:18px}
.foot__bar{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;align-items:center;margin-top:2.8rem;padding-top:1.6rem;border-top:1px solid var(--line);font-size:.8rem;color:var(--muted)}
.footer__made{display:inline-flex;align-items:center;gap:.45rem;color:var(--muted);transition:color .25s}
.footer__made:hover{color:var(--cream-dim)}
.footer__made img{height:17px;width:auto;opacity:.8}

.mobile{position:fixed;inset:0;z-index:55;background:var(--ink);display:flex;flex-direction:column;justify-content:center;padding:var(--pad);gap:.2rem;opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s}
body.menu-open .mobile{opacity:1;visibility:visible}
.mobile a{font-family:var(--f-display);font-size:clamp(1.9rem,8.5vw,2.8rem);color:var(--cream);padding:.32rem 0;transition:color .2s,padding-left .25s var(--ease)}
.mobile a:hover{color:var(--flame);padding-left:.5rem}
.mobile__foot{margin-top:2.4rem;display:flex;flex-direction:column;gap:.35rem;color:var(--muted)}
.mobile__foot a{font-family:var(--f-body);font-size:1rem;color:var(--cream-dim)}

.rv{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.07s}.rv-d2{transition-delay:.14s}.rv-d3{transition-delay:.21s}

.js .hero .anim{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .hero__art{opacity:0;transition:opacity .9s var(--ease) .1s}
.hero.go .anim,.hero.go .hero__art{opacity:1;transform:none}
.hero.go .anim.d1{transition-delay:.06s}.hero.go .anim.d2{transition-delay:.16s}
.hero.go .anim.d3{transition-delay:.26s}.hero.go .anim.d4{transition-delay:.36s}.hero.go .anim.d5{transition-delay:.46s}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .rv,.js .hero .anim,.js .hero__art{opacity:1!important;transform:none!important}
}

@media (max-width:1080px){.hero__grid{grid-template-columns:1fr 1fr}}
@media (max-width:900px){
  .nav__links,.nav__phone{display:none}
  .burger{display:block}
  .hero{min-height:auto;padding-top:120px;padding-bottom:54px}
  .hero__grid{grid-template-columns:1fr;gap:38px}
  .hero__kanji{right:auto;left:-1%;opacity:.7}
  .hero__art{max-width:440px}
  .scrollcue{display:none}
  .feature{grid-template-columns:1fr}
  .feature__media{min-height:240px}
  .cards{grid-template-columns:1fr 1fr}
}
@media (max-width:640px){
  .cards{grid-template-columns:1fr}
  .hero h1{font-size:clamp(1.95rem,8.4vw,2.8rem)}
  .hero__meta b{font-size:1.3rem}
  .eyebrow{letter-spacing:.12em;font-size:.6rem}
  .eyebrow::before{display:none}
  .nav__cta .btn{display:none}


  .hero__copy{text-align:center}
  .hero .eyebrow{justify-content:center;flex-wrap:wrap;max-width:100%}
  .hero__lead{margin-inline:auto}
  .hero__cta{flex-direction:column;align-items:center}
  .hero__cta .btn{width:100%;max-width:300px;justify-content:center;padding-block:1em}
  .hero__meta{justify-content:center;gap:1.3rem}
  .hero__meta div{border-right:0;margin-right:0;padding:1.3rem .3rem 0}
  .hero__art{margin-inline:auto}

  .manifest{text-align:center}
  .manifest__q,.manifest__sub{margin-inline:auto}

  .sec-head{flex-direction:column;align-items:center;text-align:center}
  .sec-head .eyebrow{justify-content:center}
  .sec-head p{margin-inline:auto}

  .feature__body{text-align:center;align-items:center}
  .feature__body h3{justify-content:center}
  .tags{justify-content:center}
  .linkmore{align-self:center}
  .card__body{text-align:center;align-items:center}

  .foot__bar{flex-direction:column;align-items:flex-start}
}
