/* =========================================================
   REFIGHT — Corporate Site
   Design tokens, layout, components, animations
   ========================================================= */

/* ---------- Tokens ---------- */
:root {
  --c-bg:        #0b0907;
  --c-bg-soft:   #131009;
  --c-panel:     #15110b;
  --c-cream:     #f3ece1;
  --c-cream-dim: #b8ad9c;
  --c-mute:      #6f665a;
  --c-line:      rgba(243, 236, 225, 0.12);
  --c-gold:      #cda66c;
  --c-gold-soft: #e2c592;
  --c-ember:     #d9772f;

  --ff-jp:    "Shippori Mincho", "Noto Sans JP", serif;
  --ff-sans:  "Noto Sans JP", sans-serif;
  --ff-en:    "Cormorant Garamond", "Shippori Mincho", serif;

  --maxw: 1320px;
  --pad: clamp(1.25rem, 5vw, 6rem);

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-power: cubic-bezier(0.76, 0, 0.24, 1);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-stopped { overflow: hidden; }

body {
  background: var(--c-bg);
  color: var(--c-cream);
  font-family: var(--ff-sans);
  font-weight: 300;
  line-height: 1.85;
  letter-spacing: 0.02em;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img { display: block; width: 100%; height: 100%; object-fit: cover; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
::selection { background: var(--c-gold); color: var(--c-bg); }

/* a11y: keyboard skip link */
.skip-link { position: fixed; top: 0; left: 50%; z-index: 10001; transform: translate(-50%, -130%); background: var(--c-gold); color: var(--c-bg); padding: 0.7rem 1.4rem; border-radius: 0 0 6px 6px; font-size: 0.85rem; letter-spacing: 0.04em; transition: transform .3s var(--ease); }
.skip-link:focus { transform: translate(-50%, 0); outline: 2px solid var(--c-cream); outline-offset: 2px; }

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

/* =========================================================
   LOADER
   ========================================================= */
.loader {
  position: fixed; inset: 0; z-index: 10000;
  background: var(--c-bg);
  display: grid; place-items: center;
}
.loader__inner { width: min(420px, 70vw); text-align: center; }
.loader__logo { display: flex; align-items: baseline; justify-content: center; gap: 0.6rem; margin-bottom: 2.2rem; }
.loader__mark { font-family: var(--ff-en); font-size: 2.6rem; color: var(--c-gold); line-height: 1; }
.loader__word { font-family: var(--ff-en); letter-spacing: 0.5em; font-size: 1.1rem; color: var(--c-cream); padding-left: 0.5em; }
.loader__bar { height: 1px; width: 100%; background: var(--c-line); overflow: hidden; }
.loader__bar-fill { display: block; height: 100%; width: 0%; background: var(--c-gold); }
.loader__count { font-family: var(--ff-en); font-size: 0.9rem; color: var(--c-mute); margin-top: 1rem; letter-spacing: 0.2em; }
.loader__count::after { content: "%"; font-size: 0.7em; margin-left: 2px; }

/* =========================================================
   CURSOR
   ========================================================= */
.cursor {
  position: fixed; top: 0; left: 0; z-index: 9500;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--c-gold);
  pointer-events: none;
  transform: translate(-50%, -50%);
  transition: width .35s var(--ease), height .35s var(--ease), background .35s var(--ease), opacity .3s;
  mix-blend-mode: difference;
  opacity: 0;
}
.cursor.is-hover { width: 56px; height: 56px; background: var(--c-cream); }
@media (hover: none) { .cursor { display: none; } }

/* =========================================================
   HEADER
   ========================================================= */
.header {
  position: fixed; top: 0; left: 0; width: 100%; z-index: 1000;
  display: flex; align-items: center; justify-content: space-between;
  padding: clamp(1.1rem, 2.5vw, 1.9rem) var(--pad);
  transition: padding .5s var(--ease);
}
/* Glass background lives on a pseudo-element so the header itself never
   creates a containing block (which would trap the fixed mobile menu). */
.header::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: rgba(11, 9, 7, 0.82);
  -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--c-line);
  opacity: 0; transition: opacity .5s var(--ease);
}
.header.is-scrolled::before { opacity: 1; }
.header.is-scrolled { padding-top: 1rem; padding-bottom: 1rem; }
.header__logo { display: flex; align-items: baseline; gap: 0.5rem; }
.header__logo-mark { font-family: var(--ff-en); font-size: 1.7rem; color: var(--c-gold); line-height: 1; }
.header__logo-text { font-family: var(--ff-en); letter-spacing: 0.42em; font-size: 0.95rem; padding-left: 0.42em; }

.nav { display: flex; align-items: center; gap: clamp(1.5rem, 3vw, 3rem); }
.nav__list { display: flex; gap: clamp(1.3rem, 2.4vw, 2.6rem); }
.nav__link { position: relative; display: inline-flex; flex-direction: column; align-items: center; gap: 2px; padding: 4px 0; overflow: hidden; }
.nav__link span { font-family: var(--ff-en); font-size: 0.95rem; letter-spacing: 0.08em; transition: transform .45s var(--ease), color .45s; }
.nav__link em { font-style: normal; font-size: 0.62rem; letter-spacing: 0.2em; color: var(--c-mute); transition: color .45s; }
.nav__link::after { content: ""; position: absolute; bottom: 0; left: 0; width: 100%; height: 1px; background: var(--c-gold); transform: scaleX(0); transform-origin: right; transition: transform .5s var(--ease); }
.nav__link:hover span { color: var(--c-gold-soft); }
.nav__link:hover em { color: var(--c-cream-dim); }
.nav__link:hover::after { transform: scaleX(1); transform-origin: left; }

.nav__cta {
  font-family: var(--ff-en); font-size: 0.9rem; letter-spacing: 0.1em;
  padding: 0.7rem 1.5rem; border: 1px solid var(--c-line); border-radius: 100px;
  transition: background .45s var(--ease), color .45s, border-color .45s;
}
.nav__cta:hover { background: var(--c-gold); color: var(--c-bg); border-color: var(--c-gold); }

.burger { display: none; width: 34px; height: 18px; position: relative; z-index: 1001; }
.burger span { position: absolute; left: 0; width: 100%; height: 1.5px; background: var(--c-cream); transition: transform .4s var(--ease), opacity .3s; }
.burger span:nth-child(1) { top: 2px; }
.burger span:nth-child(2) { bottom: 2px; }
.burger.is-open span:nth-child(1) { top: 8px; transform: rotate(45deg); }
.burger.is-open span:nth-child(2) { bottom: 8px; transform: rotate(-45deg); }

/* =========================================================
   HERO
   ========================================================= */
.hero { position: relative; height: 100svh; min-height: 600px; overflow: hidden; display: flex; flex-direction: column; justify-content: flex-end; }
.hero__media { position: absolute; inset: 0; z-index: -1; overflow: hidden; }
.hero__img { transform: scale(1.18); will-change: transform; }
.hero__overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(11,9,7,0.55) 0%, rgba(11,9,7,0.15) 35%, rgba(11,9,7,0.55) 75%, rgba(11,9,7,0.95) 100%),
    radial-gradient(120% 80% at 50% 120%, rgba(205,166,108,0.18), transparent 60%);
}
.hero__content { padding: 0 var(--pad); margin-bottom: clamp(2rem, 8vh, 5rem); max-width: 1100px; }
.hero__eyebrow { font-family: var(--ff-en); letter-spacing: 0.35em; font-size: clamp(0.7rem, 1.2vw, 0.85rem); color: var(--c-gold-soft); margin-bottom: 1.6rem; overflow: hidden; }
.hero__title {
  font-family: var(--ff-jp); font-weight: 600;
  font-size: clamp(2.8rem, 9vw, 7.5rem);
  line-height: 1.08; letter-spacing: 0.02em;
  text-shadow: 0 8px 50px rgba(0,0,0,0.5);
}
.hero__title .line { display: block; overflow: hidden; }
.hero__title .line > span { display: block; }
.hero__lead { margin-top: 1.8rem; font-size: clamp(0.95rem, 1.8vw, 1.25rem); color: var(--c-cream-dim); font-weight: 300; letter-spacing: 0.06em; overflow: hidden; }

.hero__foot { display: flex; align-items: flex-end; justify-content: space-between; padding: 0 var(--pad) clamp(1.5rem, 4vh, 2.5rem); }
.hero__scroll { display: flex; flex-direction: column; align-items: center; gap: 0.8rem; }
.hero__scroll span:first-child { font-family: var(--ff-en); font-size: 0.7rem; letter-spacing: 0.3em; color: var(--c-cream-dim); writing-mode: vertical-rl; }
.hero__scroll-line { width: 1px; height: 60px; background: linear-gradient(var(--c-gold), transparent); position: relative; overflow: hidden; }
.hero__scroll-line::after { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 40%; background: var(--c-cream); animation: scrollDot 2.2s var(--ease) infinite; }
@keyframes scrollDot { 0% { transform: translateY(-100%); } 60%,100% { transform: translateY(250%); } }
.hero__place { font-family: var(--ff-en); font-size: clamp(0.65rem, 1.3vw, 0.8rem); letter-spacing: 0.18em; color: var(--c-cream-dim); text-align: right; line-height: 1.9; }

/* =========================================================
   SECTION HEAD (shared)
   ========================================================= */
.section-head { display: flex; align-items: baseline; gap: 1.2rem; padding: 0 var(--pad); margin-bottom: clamp(2.5rem, 6vw, 4.5rem); }
.section-head__num { font-family: var(--ff-en); font-size: 0.9rem; color: var(--c-gold); letter-spacing: 0.1em; }
.section-head__en { font-family: var(--ff-en); font-size: clamp(1.6rem, 4vw, 2.6rem); letter-spacing: 0.04em; }
.section-head__ja { font-size: 0.78rem; letter-spacing: 0.25em; color: var(--c-mute); }
.section-head__en--center { display: block; text-align: center; color: var(--c-gold-soft); margin-bottom: 1.5rem; }

/* =========================================================
   CONCEPT
   ========================================================= */
.concept { padding: clamp(5rem, 13vw, 11rem) 0; max-width: var(--maxw); margin: 0 auto; }
.concept__grid { display: grid; grid-template-columns: 0.85fr 1fr; gap: clamp(2.5rem, 6vw, 6rem); align-items: center; padding: 0 var(--pad); }
.concept__visual { position: relative; }
.concept__img-wrap { position: relative; aspect-ratio: 3/4; overflow: hidden; border-radius: 2px; }
.concept__img-wrap img { transform: scale(1.15); will-change: transform; }
.concept__caption { display: inline-block; margin-top: 1rem; font-family: var(--ff-en); font-style: italic; font-size: 0.95rem; color: var(--c-gold-soft); letter-spacing: 0.05em; }

.concept__title { font-family: var(--ff-jp); font-weight: 600; font-size: clamp(1.8rem, 4.2vw, 3.3rem); line-height: 1.45; margin-bottom: 2rem; }
.concept__title .accent { color: var(--c-gold); }
.concept__text p { color: var(--c-cream-dim); font-size: clamp(0.95rem, 1.4vw, 1.05rem); margin-bottom: 1.4rem; }
.concept__text strong { color: var(--c-gold-soft); font-weight: 500; }

.concept__stats { display: flex; gap: clamp(1.5rem, 4vw, 3.5rem); margin-top: 3rem; padding-top: 2.5rem; border-top: 1px solid var(--c-line); }
.stat { display: flex; flex-direction: column; gap: 0.4rem; }
.stat__num { font-family: var(--ff-en); font-size: clamp(1.8rem, 4vw, 2.8rem); color: var(--c-cream); line-height: 1; }
.stat__label { font-size: 0.7rem; letter-spacing: 0.2em; color: var(--c-mute); }

/* =========================================================
   BUSINESS
   ========================================================= */
.business { padding: clamp(5rem, 13vw, 11rem) 0; background: var(--c-bg-soft); border-top: 1px solid var(--c-line); }
.business__lead { font-family: var(--ff-jp); font-weight: 500; font-size: clamp(1.7rem, 4.5vw, 3.4rem); line-height: 1.4; padding: 0 var(--pad); margin-bottom: clamp(2.5rem, 6vw, 4rem); max-width: var(--maxw); margin-left: auto; margin-right: auto; }

.biz-list { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad); }
.biz-item {
  display: grid; grid-template-columns: 60px 1fr 1.4fr 40px; align-items: center;
  gap: clamp(1rem, 3vw, 2.5rem);
  padding: clamp(1.8rem, 3.5vw, 2.6rem) 0;
  border-top: 1px solid var(--c-line);
  position: relative;
  transition: background .5s var(--ease);
}
.biz-item:last-child { border-bottom: 1px solid var(--c-line); }
.biz-item::before { content: ""; position: absolute; left: calc(var(--pad) * -1); right: calc(var(--pad) * -1); top: 0; bottom: 0; background: linear-gradient(90deg, transparent, rgba(205,166,108,0.06), transparent); opacity: 0; transition: opacity .5s; z-index: -1; }
.biz-item:hover::before { opacity: 1; }
.biz-item__no { font-family: var(--ff-en); font-size: 1rem; color: var(--c-gold); }
.biz-item__title { font-family: var(--ff-jp); font-weight: 500; font-size: clamp(1.3rem, 2.8vw, 2rem); line-height: 1.3; transition: transform .5s var(--ease); }
.biz-item__en { font-family: var(--ff-en); font-size: 0.85rem; letter-spacing: 0.1em; color: var(--c-mute); margin-top: 0.3rem; }
.biz-item__desc { font-size: 0.92rem; color: var(--c-cream-dim); line-height: 1.8; }
.biz-item__arrow { font-size: 1.3rem; color: var(--c-gold); justify-self: end; transition: transform .5s var(--ease); }
.biz-item:hover .biz-item__title { transform: translateX(10px); }
.biz-item:hover .biz-item__arrow { transform: translateX(10px); }

/* =========================================================
   BRANDS
   ========================================================= */
.brands { padding: clamp(5rem, 13vw, 11rem) 0; max-width: var(--maxw); margin: 0 auto; }
.brands__lead { font-family: var(--ff-jp); font-weight: 500; font-size: clamp(1.7rem, 4.5vw, 3.4rem); line-height: 1.4; padding: 0 var(--pad); margin-bottom: clamp(2.5rem, 6vw, 4rem); }
.brand-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.2rem, 2.5vw, 2rem); padding: 0 var(--pad); }
.brand-card { position: relative; overflow: hidden; }
.brand-card__media { aspect-ratio: 3/4; overflow: hidden; position: relative; }
.brand-card__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 22%, rgba(11,9,7,0.5) 52%, rgba(11,9,7,0.92)); }
.brand-card__media img { transform: scale(1.02); transition: transform 1.1s var(--ease); }
.brand-card:hover .brand-card__media img { transform: scale(1.12); }
.brand-card__body { position: absolute; left: 0; bottom: 0; width: 100%; padding: clamp(1.3rem, 2.5vw, 2rem); z-index: 2; }
.brand-card__type { display: inline-block; font-size: 0.7rem; letter-spacing: 0.2em; color: var(--c-gold-soft); padding: 0.3rem 0.8rem; border: 1px solid var(--c-line); border-radius: 100px; margin-bottom: 0.9rem; }
.brand-card__name { font-family: var(--ff-jp); font-weight: 600; font-size: clamp(1.5rem, 3vw, 2.1rem); line-height: 1.2; }
.brand-card__name span { font-family: var(--ff-en); font-style: italic; font-size: 0.6em; color: var(--c-gold-soft); margin-left: 0.4rem; }
.brand-card__desc { font-size: 0.85rem; color: var(--c-cream-dim); line-height: 1.7; margin-top: 0.8rem; max-height: 0; opacity: 0; overflow: hidden; transition: max-height .6s var(--ease), opacity .6s var(--ease), margin-top .6s var(--ease); }
.brand-card:hover .brand-card__desc { max-height: 160px; opacity: 1; }

/* 実店舗の詳細メタ（ホバー展開 / モバイル常時表示） */
.brand-card__meta { display: grid; gap: 0.45rem; max-height: 0; opacity: 0; overflow: hidden; margin-top: 0; transition: max-height .6s var(--ease), opacity .6s var(--ease), margin-top .6s var(--ease); }
.brand-card:hover .brand-card__meta { max-height: 280px; opacity: 1; margin-top: 0.9rem; }
.brand-card__meta > div { display: grid; grid-template-columns: 4.5em 1fr; gap: 0.7rem; }
.brand-card__meta dt { font-size: 0.62rem; letter-spacing: 0.14em; color: var(--c-gold-soft); padding-top: 0.2em; }
.brand-card__meta dd { font-size: 0.76rem; color: var(--c-cream-dim); line-height: 1.55; }

/* =========================================================
   RECRUIT
   ========================================================= */
.recruit { position: relative; padding: clamp(6rem, 16vw, 12rem) var(--pad); text-align: center; overflow: hidden; }
.recruit__media { position: absolute; inset: 0; z-index: -1; overflow: hidden; }
.recruit__media img { transform: scale(1.2); will-change: transform; }
.recruit__overlay { position: absolute; inset: 0; background: linear-gradient(rgba(11,9,7,0.78), rgba(11,9,7,0.9)); }
.recruit__content { max-width: 820px; margin: 0 auto; }
.recruit__title { font-family: var(--ff-jp); font-weight: 600; font-size: clamp(2rem, 5.5vw, 4rem); line-height: 1.3; margin-bottom: 1.8rem; }
.recruit__text { color: var(--c-cream-dim); font-size: clamp(0.95rem, 1.6vw, 1.1rem); margin-bottom: 2.8rem; }

/* =========================================================
   BUTTONS
   ========================================================= */
.btn { display: inline-flex; align-items: center; gap: 0.9rem; font-family: var(--ff-sans); font-size: 0.95rem; letter-spacing: 0.05em; padding: 1.05rem 2.2rem; border-radius: 100px; position: relative; overflow: hidden; transition: color .5s var(--ease); }
.btn__arrow { transition: transform .5s var(--ease); }
.btn:hover .btn__arrow { transform: translateX(6px); }
.btn--ghost { border: 1px solid var(--c-gold); color: var(--c-gold-soft); }
.btn--ghost::before, .btn--solid::before { content: ""; position: absolute; inset: 0; background: var(--c-gold); transform: scaleX(0); transform-origin: right; transition: transform .55s var(--ease-power); z-index: -1; }
.btn--ghost:hover, .btn--solid:hover { color: var(--c-bg); }
.btn--ghost:hover::before, .btn--solid:hover::before { transform: scaleX(1); transform-origin: left; }
.btn--solid { background: var(--c-gold); color: var(--c-bg); }
.btn--solid::before { background: var(--c-cream); }

/* =========================================================
   COMPANY
   ========================================================= */
.company { padding: clamp(5rem, 13vw, 11rem) 0; background: var(--c-bg-soft); border-top: 1px solid var(--c-line); }
.company__grid { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad); display: grid; grid-template-columns: 0.5fr 1fr; gap: clamp(2rem, 5vw, 5rem); }
.company__title { font-family: var(--ff-en); font-size: clamp(2rem, 5vw, 3.4rem); line-height: 1.2; position: sticky; top: 120px; height: max-content; }
.info { border-top: 1px solid var(--c-line); }
.info__row { display: grid; grid-template-columns: 200px 1fr; gap: 1.5rem; padding: 1.4rem 0; border-bottom: 1px solid var(--c-line); }
.info__row dt { font-size: 0.82rem; letter-spacing: 0.15em; color: var(--c-gold-soft); }
.info__row dd { font-size: 0.95rem; color: var(--c-cream); }
.info__purposes { display: flex; flex-direction: column; gap: 0.55rem; }
.info__purposes li { position: relative; padding-left: 1.4rem; color: var(--c-cream-dim); font-size: 0.92rem; }
.info__purposes li::before { content: ""; position: absolute; left: 0; top: 0.7em; width: 5px; height: 5px; background: var(--c-gold); border-radius: 50%; }

/* =========================================================
   CONTACT
   ========================================================= */
.contact { padding: clamp(6rem, 16vw, 13rem) var(--pad); text-align: center; position: relative; }
.contact::before { content: ""; position: absolute; inset: 0; background: radial-gradient(70% 60% at 50% 50%, rgba(205,166,108,0.07), transparent 70%); pointer-events: none; }
.contact__inner { max-width: 760px; margin: 0 auto; position: relative; }
.contact__eyebrow { font-family: var(--ff-en); letter-spacing: 0.3em; color: var(--c-gold); font-size: 0.85rem; margin-bottom: 1.5rem; }
.contact__title { font-family: var(--ff-jp); font-weight: 700; font-size: clamp(2.4rem, 8vw, 5.5rem); line-height: 1.1; margin-bottom: 1.8rem; }
.contact__title .line { display: block; overflow: hidden; }
.contact__title .line > span { display: block; }
.contact__text { color: var(--c-cream-dim); font-size: clamp(0.95rem, 1.6vw, 1.1rem); margin-bottom: 2.4rem; }
.contact__tel { display: inline-flex; align-items: baseline; gap: 0.9rem; margin-bottom: 2.4rem; transition: color .4s var(--ease); }
.contact__tel-label { font-family: var(--ff-en); font-size: 0.85rem; letter-spacing: 0.25em; color: var(--c-gold); }
.contact__tel-num { font-family: var(--ff-en); font-size: clamp(2rem, 6vw, 3.4rem); letter-spacing: 0.04em; line-height: 1; }
.contact__tel:hover { color: var(--c-gold-soft); }
.contact__btns { display: flex; justify-content: center; }

.info__link { position: relative; color: var(--c-cream); transition: color .4s; }
.info__link::after { content: ""; position: absolute; left: 0; bottom: -2px; width: 100%; height: 1px; background: var(--c-gold); transform: scaleX(0); transform-origin: right; transition: transform .45s var(--ease); }
.info__link:hover { color: var(--c-gold-soft); }
.info__link:hover::after { transform: scaleX(1); transform-origin: left; }

.footer__tel { display: inline-block; font-size: 0.85rem; letter-spacing: 0.08em; color: var(--c-cream-dim); margin-top: 0.3rem; transition: color .4s; width: max-content; }
.footer__tel:hover { color: var(--c-gold); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer { background: var(--c-bg); border-top: 1px solid var(--c-line); padding: clamp(3rem, 7vw, 5rem) var(--pad) 2rem; }
.footer__top { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 2.5rem; padding-bottom: 3rem; border-bottom: 1px solid var(--c-line); }
.footer__brand { display: flex; flex-direction: column; gap: 0.5rem; }
.footer__mark { font-family: var(--ff-en); font-size: 2.5rem; color: var(--c-gold); line-height: 1; }
.footer__name { font-family: var(--ff-en); letter-spacing: 0.4em; font-size: 1rem; }
.footer__addr { font-size: 0.82rem; color: var(--c-mute); margin-top: 0.6rem; }
.footer__nav { display: grid; grid-template-columns: repeat(2, auto); gap: 0.8rem 3rem; align-content: start; }
.footer__nav a { font-family: var(--ff-en); font-size: 0.95rem; letter-spacing: 0.05em; color: var(--c-cream-dim); transition: color .4s; position: relative; width: max-content; }
.footer__nav a:hover { color: var(--c-gold); }
.footer__bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; padding-top: 2rem; }
.footer__bottom span { font-size: 0.75rem; letter-spacing: 0.1em; color: var(--c-mute); }
.footer__top-btn { font-family: var(--ff-en); font-size: 0.8rem; letter-spacing: 0.15em; color: var(--c-cream-dim); transition: color .4s; }
.footer__top-btn:hover { color: var(--c-gold); }

/* =========================================================
   REVEAL ANIMATIONS (gated by .is-animated on <html>)
   ========================================================= */
.is-animated .reveal { opacity: 0; transform: translateY(40px); }
.is-animated .reveal-line > span { display: inline-block; transform: translateY(110%); }
.is-animated .hero__title .line > span { transform: translateY(110%); }
.is-animated .contact__title .line > span { transform: translateY(110%); }
/* fallback: no JS / no GSAP → everything visible */

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 980px) {
  .concept__grid { grid-template-columns: 1fr; }
  .concept__visual { max-width: 440px; }
  .company__grid { grid-template-columns: 1fr; }
  .company__title { position: static; }
  .brand-grid { grid-template-columns: 1fr 1fr; }
  .biz-item { grid-template-columns: 44px 1fr; grid-template-areas: "no main" "desc desc"; row-gap: 1rem; }
  .biz-item__no { grid-area: no; }
  .biz-item__main { grid-area: main; }
  .biz-item__desc { grid-area: desc; }
  .biz-item__arrow { display: none; }
  .brand-card__desc { max-height: 160px; opacity: 1; margin-top: 0.8rem; }
  .brand-card__meta { max-height: 320px; opacity: 1; margin-top: 0.9rem; }
}

@media (max-width: 720px) {
  .burger { display: block; }
  .nav {
    position: fixed; inset: 0; z-index: 1000;
    flex-direction: column; justify-content: center;
    gap: 2.5rem;
    background: rgba(11,9,7,0.97); backdrop-filter: blur(20px);
    clip-path: circle(0% at calc(100% - 40px) 40px);
    transition: clip-path .7s var(--ease-power);
    pointer-events: none;
  }
  .nav.is-open { clip-path: circle(150% at calc(100% - 40px) 40px); pointer-events: auto; }
  .nav__list { flex-direction: column; gap: 1.8rem; text-align: center; }
  .nav__link span { font-size: 1.6rem; }
  .nav__link em { font-size: 0.7rem; }
  .brand-grid { grid-template-columns: 1fr; }
  .concept__stats { flex-wrap: wrap; gap: 1.5rem 2.5rem; }
  .info__row { grid-template-columns: 1fr; gap: 0.4rem; }
  .info__row dt { color: var(--c-gold); }
  .footer__top { flex-direction: column; }
  .hero__foot { padding-bottom: 1.5rem; }
}

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; scroll-behavior: auto !important; }
  .is-animated .reveal, .is-animated .reveal-line > span, .is-animated .hero__title .line > span, .is-animated .contact__title .line > span { opacity: 1 !important; transform: none !important; }
}
