/* =========================================================
   SIMRAN — v3 layer : depth, 3D, "fly-into" page transitions
   loads after styles.css + v2.css
   ========================================================= */

/* ---------------------------------------------------------
   PAGE TRANSITION — "fly into" the next page
   --------------------------------------------------------- */
/* noise overlay removed per request */
.grain{display:none !important;}

.xfade{position:fixed;inset:0;z-index:200;pointer-events:none;opacity:0;
  background:radial-gradient(120% 90% at 50% 50%,#13212a 0%,#070d11 70%);
  display:flex;align-items:center;justify-content:center;}
.xfade .mark{font-family:var(--font-lat);font-weight:700;font-size:clamp(40px,8vw,90px);
  letter-spacing:.18em;color:#fff;opacity:0;transform:scale(.6);}
.xfade .mark i{color:var(--gold);font-style:normal;}
/* leaving: zoom the page forward, sweep overlay in */
body.is-leaving .stage{animation:flyOut .5s cubic-bezier(.6,0,.8,.2) forwards;}
body.is-leaving .xfade{animation:xfadeIn .5s ease forwards;pointer-events:all;}
body.is-leaving .xfade .mark{animation:markIn .5s cubic-bezier(.2,1,.36,1) .04s forwards;}
@keyframes flyOut{to{transform:scale(1.18);opacity:0;filter:blur(6px);}}
@keyframes xfadeIn{to{opacity:1;}}
@keyframes markIn{to{opacity:1;transform:scale(1);}}
/* arriving: page flies in from depth */
body.is-entering .stage{animation:flyIn .72s cubic-bezier(.16,1,.3,1) both;}
@keyframes flyIn{from{transform:scale(.94) translateY(14px);opacity:0;filter:blur(4px);}
  to{transform:none;opacity:1;filter:none;}}

@media (prefers-reduced-motion:reduce){
  body.is-leaving .stage,body.is-entering .stage{animation:none;}
  .scene h1 .l,.scene .lead,.scene .actions{animation:none;opacity:1;}
  .xfade{display:none;}
}

/* ---------------------------------------------------------
   DEPTH HERO — layered parallax that reacts to pointer + scroll
   --------------------------------------------------------- */
.scene{position:relative;min-height:100svh;overflow:hidden;
  perspective:1400px;transform-style:preserve-3d;display:flex;align-items:center;
  background:#070d11;}
.scene .layer{position:absolute;inset:-6%;will-change:transform;}
.scene .layer img{width:100%;height:100%;object-fit:cover;}
.scene .l-photo{filter:brightness(.66) saturate(1.05) contrast(1.05);}
.scene .l-photo video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;transition:opacity 1.1s ease;}
.scene .l-photo video.on{opacity:1;}
.scene.shown h1 .l,.scene.shown .lead,.scene.shown .actions{opacity:1 !important;transform:none !important;}

/* ---------- language toggle (top-right) ---------- */
.nav-inner .brand{margin-right:auto;}
.lang-toggle{display:inline-flex;align-items:center;border:1px solid rgba(255,255,255,.26);
  border-radius:999px;overflow:hidden;order:9;margin-left:18px;flex:none;}
.lang-btn{background:none;border:0;color:var(--ink-2);font-family:var(--font-lat);
  font-size:11.5px;letter-spacing:.04em;padding:6px 11px;cursor:pointer;transition:.2s;line-height:1;white-space:nowrap;}
.lang-btn:hover{color:#fff;}
.lang-btn.active{background:var(--gold);color:#241402;}
@media(max-width:920px){
  .lang-toggle{position:absolute;top:50%;right:calc(var(--pad) + 52px);transform:translateY(-50%);margin:0;}
}
.scene .l-tint{background:
  linear-gradient(102deg,rgba(7,13,17,.95) 6%,rgba(7,13,17,.55) 46%,rgba(7,13,17,.2) 100%),
  linear-gradient(0deg,#070d11 1%,transparent 30%);inset:0;}
.scene .l-glow{inset:0;background:radial-gradient(60% 70% at 78% 30%,rgba(201,162,75,.16),transparent 60%);}
.scene.warm .l-tint{background:
  linear-gradient(102deg,rgba(22,7,2,.95) 6%,rgba(40,12,4,.55) 46%,rgba(90,30,12,.2) 100%),
  linear-gradient(0deg,#160702 1%,transparent 30%);}
.scene.warm{background:#160702;}
.scene.warm .l-glow{background:radial-gradient(60% 70% at 78% 30%,rgba(232,133,43,.22),transparent 60%);}
.scene.warm h1 .gold{color:#ffce8a;}
.scene.warm .scene-kicker{color:#ffce8a;}
.scene.warm .scene-kicker::before{background:#ffce8a;}
.scene.warm .wm span{-webkit-text-stroke-color:rgba(255,206,138,.1);}
.scene-body{position:relative;width:100%;padding-top:96px;transform-style:preserve-3d;}
.scene-kicker{display:flex;align-items:center;gap:16px;margin-bottom:30px;
  font-family:var(--font-lat);font-size:12px;letter-spacing:.3em;color:var(--gold);}
.scene-kicker::before{content:'';width:46px;height:1px;background:var(--gold);}
.scene h1{font-family:var(--font-min);font-weight:800;
  font-size:clamp(46px,8.2vw,116px);line-height:1.12;letter-spacing:.01em;color:#fff;
  text-shadow:0 8px 50px rgba(0,0,0,.5);}
.scene h1 .gold{color:var(--gold-2);}
.scene h1 .l{display:inline-block;opacity:1;transform-origin:bottom;
  animation:charIn .8s cubic-bezier(.2,1,.36,1) both;animation-delay:var(--d,0s);}
@keyframes charIn{from{opacity:0;transform:translateY(.7em) rotateX(-40deg);}to{opacity:1;transform:none;}}
.scene .lead{font-size:clamp(15px,1.4vw,17.5px);color:var(--ink-2);max-width:540px;
  margin-top:32px;line-height:2.1;opacity:1;animation:sceneUp 1s ease .7s both;}
.scene .actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:40px;opacity:1;
  animation:sceneUp 1s ease .9s both;}
@keyframes sceneUp{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}
.scene .wm{position:absolute;left:0;right:0;bottom:-.16em;pointer-events:none;overflow:hidden;line-height:1;}
.scene .wm span{display:block;font-family:var(--font-lat);font-weight:700;
  font-size:clamp(120px,22vw,320px);letter-spacing:.05em;color:transparent;
  -webkit-text-stroke:1px rgba(255,255,255,.07);white-space:nowrap;}
.scene .badge-row{position:absolute;bottom:34px;left:var(--pad);display:flex;gap:30px;
  font-family:var(--font-lat);font-size:11px;letter-spacing:.16em;color:var(--muted);}
.scene .badge-row b{color:var(--gold-2);font-weight:500;}
@media(max-height:680px){.scene .badge-row{display:none;}}

/* ---------------------------------------------------------
   3D TILT CARDS (generic)
   --------------------------------------------------------- */
[data-tilt]{transform-style:preserve-3d;transition:transform .3s cubic-bezier(.2,.7,.3,1);will-change:transform;}
[data-tilt] .pop{transform:translateZ(40px);transition:transform .3s;}

/* ---------------------------------------------------------
   BUSINESS STACK — 3 services as deep 3D cards (home)
   --------------------------------------------------------- */
.biz-stack{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;perspective:1500px;}
.biz3{position:relative;border-radius:18px;overflow:hidden;min-height:clamp(380px,42vw,480px);
  display:flex;align-items:flex-end;border:1px solid var(--line);background:#0c161c;
  transform-style:preserve-3d;transition:transform .4s cubic-bezier(.2,.7,.3,1),box-shadow .4s;
  box-shadow:0 30px 60px -40px rgba(0,0,0,.9);}
.biz3 .ph{position:absolute;inset:0;}
.biz3 .ph img{width:100%;height:100%;object-fit:cover;
  filter:brightness(.6) saturate(1.05);transition:transform .7s cubic-bezier(.2,.7,.3,1),filter .5s;}
.biz3 .ov{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(7,13,17,.05) 18%,rgba(7,13,17,.62) 60%,rgba(7,13,17,.95));transition:.4s;}
.biz3 .bc{position:relative;padding:30px 30px 32px;transform:translateZ(50px);transform-style:preserve-3d;}
.biz3 .n{font-family:var(--font-lat);font-size:13px;letter-spacing:.18em;color:var(--gold);}
.biz3 .en{font-family:var(--font-lat);font-size:11px;letter-spacing:.24em;color:var(--muted);
  margin-top:4px;display:block;}
.biz3 h3{font-family:var(--font-min);font-size:clamp(22px,2.5vw,28px);color:#fff;margin:16px 0 12px;}
.biz3 p{font-size:13.8px;color:var(--ink-2);line-height:1.85;max-height:0;opacity:0;overflow:hidden;
  transition:max-height .5s ease,opacity .4s ease,margin .4s;}
.biz3 .more{display:inline-flex;align-items:center;gap:9px;margin-top:18px;
  font-family:var(--font-lat);font-size:12.5px;letter-spacing:.08em;color:var(--gold-2);}
.biz3 .more .ar{transition:transform .3s;}
.biz3:hover{box-shadow:0 50px 90px -40px rgba(0,0,0,1),0 0 0 1px rgba(201,162,75,.4);}
.biz3:hover .ph img{transform:scale(1.07);filter:brightness(.72) saturate(1.1);}
.biz3:hover .ov{background:linear-gradient(180deg,rgba(7,13,17,.1) 8%,rgba(20,14,4,.55) 50%,rgba(7,13,17,.96));}
.biz3:hover p{max-height:8em;opacity:1;margin-top:2px;}
.biz3:hover .more .ar{transform:translateX(6px);}
.biz3 .idx{position:absolute;top:24px;right:26px;font-family:var(--font-lat);font-weight:700;
  font-size:clamp(40px,5vw,68px);color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.18);
  transform:translateZ(30px);transition:.4s;}
.biz3:hover .idx{-webkit-text-stroke-color:rgba(201,162,75,.6);color:rgba(201,162,75,.12);}
.biz3.food:hover .idx{-webkit-text-stroke-color:rgba(232,133,43,.7);}
.biz3.food:hover .ov{background:linear-gradient(180deg,rgba(40,10,4,.12),rgba(60,18,6,.6) 52%,rgba(20,7,2,.96));}

/* ---------------------------------------------------------
   PHILOSOPHY / SIMRAN MEANING
   --------------------------------------------------------- */
.meaning{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(34px,6vw,90px);align-items:center;}
.meaning .word{font-family:var(--font-min);font-weight:800;color:#fff;line-height:1;}
.meaning .word .romaji{font-family:var(--font-lat);font-size:clamp(54px,8vw,104px);letter-spacing:.04em;
  display:block;}
.meaning .word .deva{display:block;font-size:clamp(30px,4vw,54px);color:var(--gold-2);margin-top:8px;
  font-family:var(--font-min);}
.meaning .word .gloss{display:block;font-family:var(--font-jp);font-weight:500;
  font-size:14px;letter-spacing:.24em;color:var(--muted);margin-top:22px;}
.meaning .body .lead-min{font-family:var(--font-min);font-size:clamp(20px,2.3vw,27px);
  line-height:1.95;color:#fff;}
.meaning .body p{color:var(--ink-2);margin-top:20px;font-size:15.5px;}
.meaning .body p + p{margin-top:14px;}

/* ---------------------------------------------------------
   HOTEL CLIENT DECK — 3D layered cards
   --------------------------------------------------------- */
.hotel-deck{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px;
  perspective:1400px;}
.hcard{position:relative;border:1px solid var(--line);border-radius:14px;
  background:linear-gradient(160deg,#101c23,#0b141a);padding:24px 22px 22px;
  transform-style:preserve-3d;transition:transform .35s cubic-bezier(.2,.7,.3,1),
    border-color .35s,box-shadow .35s;overflow:hidden;min-height:128px;display:flex;flex-direction:column;
  justify-content:space-between;}
.hcard::before{content:'';position:absolute;inset:0;
  background:radial-gradient(120% 80% at 90% 0%,rgba(201,162,75,.10),transparent 55%);opacity:0;transition:.35s;}
.hcard:hover{transform:translateY(-6px) rotateX(6deg) rotateY(-4deg);
  border-color:rgba(201,162,75,.5);box-shadow:0 30px 50px -30px rgba(0,0,0,.9);}
.hcard:hover::before{opacity:1;}
.hcard .num{font-family:var(--font-lat);font-size:12px;letter-spacing:.16em;color:var(--gold);
  transform:translateZ(20px);}
.hcard .nm{font-family:var(--font-min);font-weight:600;font-size:clamp(15px,1.5vw,17.5px);
  color:#fff;line-height:1.55;transform:translateZ(34px);margin-top:14px;}
.hcard .loc{font-family:var(--font-lat);font-size:10.5px;letter-spacing:.14em;color:var(--muted);
  margin-top:10px;transform:translateZ(20px);}

/* ---------------------------------------------------------
   COMPANY PROFILE (refined)
   --------------------------------------------------------- */
.profile{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(34px,6vw,80px);align-items:start;}
.profile .ttl-side .big{font-family:var(--font-min);font-size:clamp(30px,3.6vw,46px);
  color:#fff;line-height:1.5;}
.profile .ttl-side .big em{font-style:normal;color:var(--gold-2);}
.prof-table{border-top:1px solid var(--line);}
.prof-table .row{display:grid;grid-template-columns:170px 1fr;gap:24px;padding:20px 4px;
  border-bottom:1px solid var(--line);transition:background .3s;}
.prof-table .row:hover{background:linear-gradient(90deg,rgba(201,162,75,.05),transparent);}
.prof-table dt{font-family:var(--font-lat);font-size:12.5px;letter-spacing:.1em;color:var(--gold);margin:0;}
.prof-table dd{margin:0;color:var(--ink);font-size:15px;line-height:1.85;}
.prof-table dd a{color:var(--gold-soft);}

/* ---------------------------------------------------------
   DUCT DIAGRAM (CSS-built, since literal photos are scarce)
   --------------------------------------------------------- */
.duct-scene{position:relative;border:1px solid var(--line);border-radius:18px;overflow:hidden;
  background:linear-gradient(160deg,#0d171d,#0a1217);min-height:clamp(320px,40vw,440px);}
.duct-scene .grid-bg{position:absolute;inset:0;opacity:.4;
  background-image:linear-gradient(rgba(201,162,75,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(201,162,75,.06) 1px,transparent 1px);background-size:40px 40px;}
.duct{position:absolute;border-radius:8px;background:linear-gradient(180deg,#22323b,#16242c);
  border:1px solid #2c3f49;box-shadow:inset 0 2px 0 rgba(255,255,255,.06),0 18px 30px -20px #000;}
.duct .flow{position:absolute;inset:0;border-radius:8px;overflow:hidden;}
.duct .flow::after{content:'';position:absolute;top:0;left:-40%;width:40%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(201,162,75,.5),transparent);
  animation:ductflow 2.6s linear infinite;}
@keyframes ductflow{to{left:130%;}}
.duct.d-h{height:46px;}.duct.d-v{width:46px;}
.duct-label{position:absolute;font-family:var(--font-lat);font-size:11px;letter-spacing:.12em;
  color:var(--gold-soft);background:rgba(7,13,17,.7);border:1px solid var(--line);
  padding:6px 12px;border-radius:999px;backdrop-filter:blur(4px);}
.hood{position:absolute;background:linear-gradient(180deg,#27373f,#18272f);border:1px solid #314550;
  clip-path:polygon(14% 0,86% 0,100% 100%,0 100%);}
@media (prefers-reduced-motion:reduce){.duct .flow::after{animation:none;}}

/* ---------------------------------------------------------
   STAT / PROCESS STRIP
   --------------------------------------------------------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:16px;overflow:hidden;}
.process .st{background:var(--bg);padding:30px 26px;position:relative;transition:background .3s;}
.process .st:hover{background:var(--panel);}
.process .st .no{font-family:var(--font-lat);font-size:12px;letter-spacing:.16em;color:var(--gold);}
.process .st h4{font-family:var(--font-min);font-size:18px;color:#fff;margin:14px 0 8px;}
.process .st p{font-size:13.4px;color:var(--muted);line-height:1.8;}

/* full-bleed photo band (reused) */
.pband{position:relative;height:clamp(320px,48vw,560px);overflow:hidden;}
.pband img{width:100%;height:114%;object-fit:cover;}
.pband .sc{position:absolute;inset:0;background:
  linear-gradient(0deg,rgba(7,13,17,.9),rgba(7,13,17,.1) 55%,transparent),
  linear-gradient(90deg,rgba(7,13,17,.55),transparent 60%);}
.pband.warm .sc{background:linear-gradient(0deg,rgba(20,7,2,.9),rgba(20,7,2,.1) 55%,transparent),
  linear-gradient(90deg,rgba(40,10,4,.55),transparent 60%);}
.pband .cap{position:absolute;left:0;right:0;bottom:clamp(28px,5vw,54px);}
.pband .cap p{font-family:var(--font-min);color:#fff;font-size:clamp(24px,3.4vw,44px);
  line-height:1.5;margin-top:10px;max-width:20ch;}

/* mini gallery 3D */
.mgal{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:clamp(110px,13vw,170px);
  gap:14px;perspective:1600px;}
.mgal figure{margin:0;overflow:hidden;border-radius:14px;border:1px solid var(--line);
  position:relative;transform-style:preserve-3d;transition:transform .4s,box-shadow .4s;}
.mgal figure img{width:100%;height:100%;object-fit:cover;transition:transform .6s;}
.mgal figure:hover{transform:translateZ(30px);box-shadow:0 30px 50px -30px rgba(0,0,0,.9);z-index:2;}
.mgal figure:hover img{transform:scale(1.06);}
.mgal figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;
  background:linear-gradient(0deg,rgba(7,13,17,.85),transparent);
  font-family:var(--font-min);color:#fff;font-size:14px;}
.mgal .big{grid-column:span 7;grid-row:span 2;}
.mgal .tall{grid-column:span 5;grid-row:span 2;}
.mgal .wide{grid-column:span 7;}
.mgal .sq{grid-column:span 5;}

/* welcome + affordability + menu prices (restaurant) */
.welcome{display:grid;grid-template-columns:1.3fr .9fr;gap:clamp(28px,5vw,64px);align-items:center;}
.welcome .lead-min{font-family:var(--font-min);font-size:clamp(22px,2.6vw,32px);color:#fff;}
.price-callout{border:1px solid var(--line);border-radius:16px;padding:26px 28px;
  background:linear-gradient(160deg,rgba(232,133,43,.12),rgba(20,7,2,.25));}
.price-callout .lat{color:#ffce8a;}
.pc-row{display:flex;justify-content:space-between;align-items:baseline;padding:13px 0;
  border-bottom:1px solid rgba(255,255,255,.08);}
.pc-row span{color:var(--ink);font-size:14.5px;}
.pc-row b{font-family:var(--font-lat);font-size:23px;color:#fff;font-weight:500;}
.price-callout p{margin-top:16px;font-size:12.5px;color:var(--muted);line-height:1.75;}
.menu-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,4vw,46px) clamp(28px,5vw,70px);}
.menu-group h4{font-family:var(--font-min);font-size:17px;color:#ffce8a;margin:0 0 6px;
  padding-bottom:12px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:baseline;}
.menu-group h4 span{font-family:var(--font-lat);font-size:10.5px;letter-spacing:.18em;color:#8a6a52;}
.menu-row{display:flex;align-items:baseline;gap:10px;padding:9px 0;}
.menu-row .nm{color:#fff;font-size:14.5px;}
.menu-row .en{color:var(--muted);font-size:10.5px;font-family:var(--font-lat);letter-spacing:.04em;margin-left:6px;}
.menu-row .dots{flex:1;border-bottom:1px dotted rgba(255,255,255,.18);transform:translateY(-4px);}
.menu-row .pr{color:#ffce8a;font-family:var(--font-lat);font-size:14px;white-space:nowrap;}
@media(max-width:760px){.welcome{grid-template-columns:1fr;}.menu-cols{grid-template-columns:1fr;}}

@media(max-width:920px){
  .biz-stack{grid-template-columns:1fr;}
  .biz3 p{max-height:8em;opacity:1;}
  .meaning,.profile{grid-template-columns:1fr;}
  .process{grid-template-columns:1fr 1fr;}
  .mgal{grid-template-columns:1fr 1fr;grid-auto-rows:140px;}
  .mgal .big,.mgal .tall,.mgal .wide,.mgal .sq{grid-column:span 2;grid-row:span 1;}
}
@media(max-width:560px){.process{grid-template-columns:1fr;}}

.tel-note{font-size:12.5px;color:#e2574d;letter-spacing:.02em;margin-top:8px;}

/* ---------------------------------------------------------
   Japanese line-break hygiene + mobile typographic scaling
   - keeps trailing 。、 from being orphaned on their own line
   - shrinks large display type so phrases fit a phone width
   --------------------------------------------------------- */
:lang(ja) .scene h1,
:lang(ja) h2,
:lang(ja) h3,
:lang(ja) .cta-band h2,
:lang(ja) .lead-min,
:lang(ja) .meaning .word .gloss,
:lang(ja) .pband .cap p{ line-break: strict; word-break: normal; overflow-wrap: normal; }

@media(max-width:600px){
  .scene h1{ font-size:clamp(29px,8.4vw,46px); line-height:1.28; }
  .scene .lead{ font-size:14.5px; line-height:2; }
  .cta-band h2{ font-size:20px; line-height:1.7; }
  .meaning .body .lead-min,
  .duct-scene + * .lead-min,
  .lead-min{ font-size:18px; line-height:1.85; }
  .pband .cap p{ font-size:clamp(20px,5.4vw,26px); }
  .sec-head h2,
  h2[data-split]{ font-size:clamp(24px,7vw,34px); }
}
