
/* TOKI CREATIVE CINEMATIC INTRO */
.toki-cinematic-intro{
  position:fixed;
  inset:0;
  z-index:9999;
  overflow:hidden;
  background:
    radial-gradient(circle at 50% 40%, rgba(214,38,27,.10), transparent 28%),
    linear-gradient(180deg, #050506 0%, #0a090b 100%);
  pointer-events:auto;
}

body.intro-locked{
  overflow:hidden;
}

body.intro-locked main,
body.intro-locked .phone-shell,
body.intro-locked nav,
body.intro-locked .sticky-bar{
  filter:blur(10px);
  transform:scale(1.025);
  transition:filter .9s ease, transform .9s ease;
}

.intro-backdrop-glow{
  position:absolute;
  inset:auto -10% -16% -10%;
  height:46%;
  background:
    radial-gradient(circle at 50% 30%, rgba(214,38,27,.20), transparent 40%),
    radial-gradient(circle at 50% 70%, rgba(202,163,102,.10), transparent 46%);
  filter:blur(34px);
}

.intro-door{
  position:absolute;
  top:0;
  bottom:0;
  width:50.25%;
  perspective:1400px;
  transition:transform 1.25s cubic-bezier(.76,0,.24,1), opacity 1.25s ease;
  will-change:transform;
}

.intro-door-left{ left:0; transform-origin:left center; }
.intro-door-right{ right:0; transform-origin:right center; }

.toki-cinematic-intro.is-open .intro-door-left{
  transform:translateX(-105%) rotateY(8deg);
  opacity:.92;
}
.toki-cinematic-intro.is-open .intro-door-right{
  transform:translateX(105%) rotateY(-8deg);
  opacity:.92;
}

.intro-door-surface{
  position:absolute;
  inset:0;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.18)),
    radial-gradient(circle at 50% 50%, rgba(214,38,27,.06), transparent 38%),
    linear-gradient(180deg, #0b0b0d 0%, #09090b 100%);
  box-shadow:inset 0 0 0 1px rgba(202,163,102,.10);
}

.intro-door-pattern{
  position:absolute;
  inset:0;
  opacity:.28;
  background:
    repeating-linear-gradient(90deg, rgba(202,163,102,.08) 0 1px, transparent 1px 46px),
    repeating-linear-gradient(0deg, rgba(202,163,102,.05) 0 1px, transparent 1px 58px),
    radial-gradient(circle at 30% 22%, rgba(214,38,27,.12), transparent 18%),
    radial-gradient(circle at 74% 72%, rgba(214,38,27,.08), transparent 24%);
}

.intro-door-frame{
  position:absolute;
  inset:20px;
  border:1px solid rgba(202,163,102,.22);
  border-radius:10px;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.02),
    0 0 0 1px rgba(0,0,0,.20);
}

.intro-door-kanji{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  font-family:"Noto Serif JP", serif;
  font-size:clamp(90px, 16vw, 160px);
  color:rgba(214,38,27,.18);
  text-shadow:0 0 34px rgba(214,38,27,.10);
  letter-spacing:.04em;
  user-select:none;
}
.intro-door-left .intro-door-kanji{ right:38px; }
.intro-door-right .intro-door-kanji{ left:38px; }

.intro-seam{
  position:absolute;
  top:10%;
  bottom:10%;
  left:50%;
  width:1px;
  transform:translateX(-50%);
  background:linear-gradient(180deg, transparent, rgba(202,163,102,.8), transparent);
  box-shadow:0 0 16px rgba(202,163,102,.25);
  transition:opacity .32s ease;
}
.toki-cinematic-intro.is-open .intro-seam{ opacity:0; }

.intro-emblem{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  align-content:center;
  z-index:2;
  pointer-events:none;
  transition:opacity .45s ease, transform .45s ease;
}

.toki-cinematic-intro.is-open .intro-emblem{
  opacity:0;
  transform:translateY(10px) scale(.97);
}

.intro-enso-wrap{
  position:relative;
  width:172px;
  height:172px;
  margin:0 auto 18px;
  animation:introFloat 2.8s ease-in-out infinite;
}

.intro-enso{
  position:absolute;
  inset:0;
  border-radius:50%;
  border:10px solid rgba(202,163,102,.18);
  border-top-color:rgba(202,163,102,.74);
  border-right-color:rgba(214,38,27,.42);
  border-bottom-color:rgba(214,38,27,.16);
  transform:rotate(-24deg) scale(.82);
  opacity:0;
  animation:introEnso .95s cubic-bezier(.2,.8,.2,1) .15s forwards;
}

.intro-sun{
  position:absolute;
  left:50%;
  top:50%;
  width:62px;
  height:62px;
  border-radius:50%;
  transform:translate(-50%,-50%) scale(.6);
  background:radial-gradient(circle at 40% 40%, #f06a57 0%, #d6261b 62%, #8f120d 100%);
  box-shadow:0 0 34px rgba(214,38,27,.28);
  opacity:0;
  animation:introSun .8s ease .42s forwards;
}

.intro-brand{
  display:grid;
  justify-items:center;
  gap:6px;
}

.intro-brand-main{
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(64px, 10vw, 102px);
  line-height:.9;
  font-weight:900;
  letter-spacing:-.08em;
  color:#d6261b;
  opacity:0;
  transform:translateY(12px);
  animation:introText .8s ease .55s forwards;
  text-shadow:0 10px 24px rgba(0,0,0,.24);
}

.intro-brand-sub{
  font-family:Inter, system-ui, sans-serif;
  font-size:12px;
  font-weight:900;
  letter-spacing:.38em;
  color:#caa366;
  text-transform:uppercase;
  opacity:0;
  transform:translateY(8px);
  animation:introText .7s ease .68s forwards;
}

.intro-brand-meta{
  font-family:Inter, system-ui, sans-serif;
  font-size:10px;
  font-weight:700;
  letter-spacing:.22em;
  color:rgba(255,242,223,.68);
  opacity:0;
  transform:translateY(8px);
  animation:introText .7s ease .82s forwards;
}

.intro-ripples{
  position:relative;
  width:170px;
  height:36px;
  margin:24px auto 0;
  opacity:0;
  animation:introText .7s ease .95s forwards;
}
.intro-ripples span{
  position:absolute;
  left:0;
  right:0;
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg, transparent, rgba(202,163,102,.18), rgba(214,38,27,.75), rgba(202,163,102,.18), transparent);
  animation:introRipple 1.6s ease-in-out infinite;
}
.intro-ripples span:nth-child(1){ top:0; }
.intro-ripples span:nth-child(2){ top:12px; animation-delay:.15s; opacity:.75; }
.intro-ripples span:nth-child(3){ top:24px; animation-delay:.3s; opacity:.5; }

@keyframes introEnso{
  0%{ opacity:0; transform:rotate(-80deg) scale(.55); }
  100%{ opacity:1; transform:rotate(-24deg) scale(1); }
}
@keyframes introSun{
  0%{ opacity:0; transform:translate(-50%,-50%) scale(.55); }
  100%{ opacity:1; transform:translate(-50%,-50%) scale(1); }
}
@keyframes introText{
  0%{ opacity:0; transform:translateY(10px); }
  100%{ opacity:1; transform:translateY(0); }
}
@keyframes introRipple{
  0%{ transform:translateX(-18px) scaleX(.7); opacity:.24; }
  50%{ transform:translateX(0) scaleX(1); opacity:1; }
  100%{ transform:translateX(18px) scaleX(.7); opacity:.24; }
}
@keyframes introFloat{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-6px); }
}

@media (prefers-reduced-motion:reduce){
  .toki-cinematic-intro{ display:none; }
  body.intro-locked main,
  body.intro-locked .phone-shell,
  body.intro-locked nav,
  body.intro-locked .sticky-bar{
    filter:none;
    transform:none;
  }
}

:root{
  --black:#050506;
  --deep:#0a0708;
  --card:#130c0d;
  --card2:#1a1011;
  --red:#d6261b;
  --red2:#940f0b;
  --cream:#fff2df;
  --muted:rgba(255,242,223,.62);
  --line:rgba(255,242,223,.10);
  --gold:#c9a462;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  background:
    radial-gradient(circle at 80% 10%, rgba(214,38,27,.18), transparent 30%),
    radial-gradient(circle at 20% 75%, rgba(214,38,27,.10), transparent 34%),
    #050506;
  color:var(--cream);
  font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;
}
body:before{
  content:"";
  position:fixed;
  inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E");
  pointer-events:none;
  z-index:0;
}
a{color:inherit;text-decoration:none}
.phone-shell{
  position:relative;
  z-index:1;
  width:min(100%, 460px);
  margin:0 auto;
  padding:12px 12px 96px;
}
.hero-card{
  min-height:82svh;
  position:relative;
  overflow:hidden;
  border-radius:0 0 34px 34px;
  background:#111;
  border:1px solid var(--line);
  box-shadow:0 30px 80px rgba(0,0,0,.45);
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:18px;
}
.hero-image{
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.28), rgba(0,0,0,.90)),
    url("assets/toki-site-hero.png") center/cover no-repeat;
  transform:scale(1.04);
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(214,38,27,.18), transparent 42%),
    radial-gradient(circle at 50% 100%, rgba(214,38,27,.30), transparent 45%);
}
.top-badge{
  align-self:flex-start;
  position:relative;
  z-index:1;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 12px;
  border-radius:999px;
  background:rgba(0,0,0,.46);
  border:1px solid rgba(255,242,223,.14);
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
}
.status-dot{
  width:8px;height:8px;border-radius:99px;background:var(--red);
  box-shadow:0 0 0 6px rgba(214,38,27,.15);
}
.brand-block{
  position:relative;
  z-index:1;
  text-align:center;
  margin-top:42px;
}
.logo-img{
  width:min(78%, 290px);
  margin:0 auto;
  filter:drop-shadow(0 14px 28px rgba(0,0,0,.65));
}
.brand-sub{
  margin:18px 0 0;
  color:rgba(255,242,223,.72);
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.18em;
}
.hero-bottom{
  position:relative;
  z-index:1;
  padding:0 4px 8px;
}
.micro{
  color:var(--red);
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.10em;
  margin:0 0 14px;
}
h1,h2{
  margin:0;
  font-family:"Noto Serif JP", serif;
  line-height:.98;
  letter-spacing:-.05em;
}
h1{
  font-size:clamp(42px, 13vw, 62px);
}
.hero-text{
  max-width:360px;
  color:rgba(255,242,223,.76);
  line-height:1.55;
  margin:16px 0 0;
  font-size:15px;
}
section{
  padding:30px 4px 0;
}
.section-label{
  margin:0 0 13px;
  color:var(--red);
  font-size:11px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.review-card{
  display:flex;
  flex-direction:column;
  gap:8px;
  position:relative;
  overflow:hidden;
  padding:26px;
  border-radius:30px;
  background:
    linear-gradient(135deg, rgba(214,38,27,.22), rgba(214,38,27,.06)),
    linear-gradient(180deg, rgba(255,242,223,.08), rgba(255,242,223,.02));
  border:1px solid rgba(214,38,27,.42);
  box-shadow:0 24px 60px rgba(214,38,27,.13);
}
.review-card:before{
  content:"";
  position:absolute;
  right:-60px;
  top:-80px;
  width:190px;
  height:190px;
  background:radial-gradient(circle, rgba(255,242,223,.13), transparent 60%);
}
.review-kicker{
  color:rgba(255,242,223,.62);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.12em;
}
.stars{
  color:#ffc94b;
  letter-spacing:.08em;
  font-size:23px;
  text-shadow:0 0 20px rgba(255,201,75,.22);
}
.review-card strong{
  font-size:25px;
  line-height:1.05;
}
.review-copy{
  color:rgba(255,242,223,.68);
  font-size:14px;
}
.action-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.action{
  min-height:124px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:18px;
  border-radius:24px;
  background:linear-gradient(180deg, rgba(255,242,223,.07), rgba(255,242,223,.03));
  border:1px solid var(--line);
  transition:transform .18s ease, border-color .18s ease;
}
.action:active{transform:scale(.98);border-color:rgba(214,38,27,.55)}
.action-red{
  background:linear-gradient(135deg, var(--red), var(--red2));
  border-color:rgba(255,242,223,.16);
}
.icon{
  width:38px;
  height:38px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:rgba(0,0,0,.26);
  font-size:21px;
}
.action span:not(.icon){
  font-size:18px;
  font-weight:900;
}
.action small{
  color:rgba(255,242,223,.58);
  font-size:12px;
  line-height:1.25;
}
.menu{
  padding-top:34px;
}
.menu-head{
  padding:22px;
  border-radius:28px 28px 0 0;
  background:linear-gradient(180deg, rgba(255,242,223,.06), rgba(255,242,223,.02));
  border:1px solid var(--line);
  border-bottom:0;
}
.menu-intro{
  margin:0;
  color:rgba(255,242,223,.72);
  line-height:1.58;
}
.menu-intro b{color:var(--cream)}
.menu-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:21px 22px;
  background:#0d0809;
  border:1px solid var(--line);
  border-top:0;
}
.menu-row:last-child{
  border-radius:0 0 28px 28px;
}
.menu-row span{
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:13px;
}
.menu-row em{
  font-style:normal;
  color:var(--red);
  font-size:12px;
  font-weight:900;
}
.river-card{
  position:relative;
  overflow:hidden;
  padding:28px;
  border-radius:30px;
  min-height:290px;
  background:
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.78)),
    url("assets/toki-red-water-bg.jpg") center/cover no-repeat;
  border:1px solid rgba(255,242,223,.12);
}
.river-lines{
  position:absolute;
  inset:auto -20px 0 -20px;
  height:120px;
  background:repeating-linear-gradient(172deg, transparent 0 14px, rgba(214,38,27,.25) 15px, transparent 16px);
  animation:flow 5s linear infinite;
  opacity:.6;
}
@keyframes flow{
  from{transform:translateX(-20px)}
  to{transform:translateX(20px)}
}
.jp{
  margin:0 0 24px;
  color:rgba(214,38,27,.52);
  font-family:"Noto Serif JP", serif;
  font-size:74px;
  line-height:.8;
}
.river-card h2{
  font-size:34px;
  max-width:310px;
}
.river-card p:not(.jp){
  max-width:340px;
  color:rgba(255,242,223,.70);
  line-height:1.58;
}
.promo-ticket{
  position:relative;
  padding:26px;
  border-radius:30px;
  background:linear-gradient(135deg, rgba(255,242,223,.10), rgba(255,242,223,.03));
  border:1px dashed rgba(214,38,27,.48);
  text-align:center;
}
.promo-ticket span{
  color:var(--red);
  text-transform:uppercase;
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
}
.promo-ticket strong{
  display:block;
  margin:7px 0 8px;
  font-size:24px;
}
.promo-ticket p{
  margin:0;
  color:rgba(255,242,223,.62);
  line-height:1.45;
  font-size:14px;
}
.info-list{
  display:grid;
  gap:10px;
}
.info-list div{
  padding:18px;
  border-radius:22px;
  background:rgba(255,242,223,.045);
  border:1px solid var(--line);
}
.info-list span{
  display:block;
  color:var(--red);
  text-transform:uppercase;
  letter-spacing:.15em;
  font-size:10px;
  font-weight:900;
  margin-bottom:6px;
}
.info-list strong{
  font-size:14px;
  line-height:1.5;
}
.footer{
  padding:42px 10px 14px;
  text-align:center;
  color:rgba(255,242,223,.42);
  font-size:12px;
}
.footer img{
  width:128px;
  margin:0 auto 14px;
  opacity:.68;
}
.sticky-bar{
  position:fixed;
  left:50%;
  transform:translateX(-50%);
  bottom:12px;
  z-index:20;
  width:min(calc(100% - 24px), 436px);
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:8px;
  padding:8px;
  border-radius:999px;
  background:rgba(8,5,6,.82);
  backdrop-filter:blur(18px);
  border:1px solid rgba(255,242,223,.14);
  box-shadow:0 18px 60px rgba(0,0,0,.55);
}
.sticky-bar a{
  padding:13px 10px;
  border-radius:999px;
  text-align:center;
  font-size:13px;
  font-weight:900;
  background:rgba(255,242,223,.075);
}
.sticky-bar a:nth-child(2){
  background:linear-gradient(135deg, var(--red), var(--red2));
}
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .65s ease, transform .65s ease;
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}
@media (min-width:720px){
  body{
    background:
      radial-gradient(circle at center, rgba(214,38,27,.14), transparent 28%),
      #050506;
  }
  .phone-shell{
    margin:34px auto;
    padding-bottom:104px;
  }
  .hero-card{
    border-radius:38px;
  }
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}


/* V2 improvement: more original-site inspired red/black polish */
:root{
  --toki-red:#d6261b;
  --toki-red-dark:#8f120d;
  --toki-black:#050506;
  --toki-cream:#fff2df;
}
.hero-card,.masthead,.top-card{
  border-color:rgba(214,38,27,.28)!important;
}
.hero-overlay,.masthead-river{
  background:
    linear-gradient(90deg, rgba(214,38,27,.24), transparent 46%),
    radial-gradient(circle at 50% 100%, rgba(214,38,27,.30), transparent 45%)!important;
}
.top-badge,.mini-pill,.tap-label{
  border-color:rgba(214,38,27,.34)!important;
}
.micro,.lead-in,.section-label,.eyebrow,.menu-row em,.menu-link em,.info-list span,.info-row span{
  color:var(--toki-red)!important;
}
.review-card,.review-hero,.review-btn{
  position:relative;
  border-color:rgba(214,38,27,.55)!important;
  background:
    linear-gradient(135deg, rgba(214,38,27,.26), rgba(214,38,27,.07)),
    linear-gradient(180deg, rgba(255,242,223,.08), rgba(255,242,223,.02))!important;
}
.review-card::after,.review-hero::after,.review-btn::after{
  content:"Google Review";
  position:absolute;
  right:18px;
  top:18px;
  padding:6px 9px;
  border-radius:999px;
  background:rgba(0,0,0,.24);
  color:rgba(255,242,223,.78);
  font-size:10px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.action-red,.orbit-card-primary,.main-action,.quick-chip-primary,.sticky-bar a:nth-child(2),.bottom-dock a.primary,.dock .active{
  background:linear-gradient(135deg, var(--toki-red), var(--toki-red-dark))!important;
}
h1{text-wrap:balance}
.hero-text,.hero-copy,.sub{max-width:360px}


/* Logo fix — remove ugly raster logo and use a cleaner CSS wordmark */
.toki-wordmark{
  display:grid;
  justify-items:center;
  gap:4px;
  margin:0 auto;
  filter:drop-shadow(0 14px 28px rgba(0,0,0,.48));
}
.toki-main{
  font-family:Georgia, "Times New Roman", serif;
  font-size:clamp(62px, 15vw, 92px);
  font-weight:900;
  line-height:.9;
  letter-spacing:-.08em;
  color:#d6261b;
  text-transform:uppercase;
}
.toki-sub{
  font-family:Inter, system-ui, sans-serif;
  font-size:12px;
  font-weight:900;
  letter-spacing:.34em;
  color:#d6261b;
  text-transform:uppercase;
}
.brand-block .toki-wordmark{
  width:min(82%, 300px);
  margin-top:2px;
}
.toki-wordmark-footer{
  transform:scale(.72);
  transform-origin:center;
  margin-bottom:2px;
}
footer .toki-wordmark,
.footer .toki-wordmark{
  opacity:.9;
}

/* Hide old image styling if any image tags remain */
.logo-img,
.brand-logo,
.logo{
  max-width:100%;
}

/* Slightly tighter brand area */
.brand-block{
  margin-top:36px;
}
.brand-sub{
  margin-top:14px;
  letter-spacing:.14em;
}

/* More authentic original-site vibe */
.micro{
  color:#d6261b!important;
  font-weight:900;
  letter-spacing:.10em;
}
.hero-text{
  color:rgba(255,242,223,.78);
}
