/* ============================================================
   OYA SUSHI & ASIAN BISTRO — shared stylesheet
   "Ink & Ember" — warm charcoal · vermillion · gold
   Fonts: Shippori Mincho (serif) + Zen Kaku Gothic New (body)
   ============================================================ */

:root{
  --ink:#14120e;
  --ink-2:#1b1813;
  --ink-3:#241f18;
  --line:rgba(236,227,208,.12);
  --cream:#ece3d0;
  --cream-dim:#a89e8a;
  --vermillion:#d8553a;
  --vermillion-deep:#b03a23;
  --gold:#c9a35c;
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--cream);
  font-family:'Zen Kaku Gothic New',sans-serif;
  font-weight:300;
  line-height:1.7;
  overflow-x:hidden;
}
::selection{background:var(--vermillion);color:var(--cream)}

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

h1,h2,h3,.serif{font-family:'Shippori Mincho',serif;font-weight:600;line-height:1.2}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 6vw}

/* ---------- reveal animations ---------- */
.rv{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.6,.2,1),transform .9s cubic-bezier(.2,.6,.2,1)}
.rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.12s}.rv-d2{transition-delay:.24s}.rv-d3{transition-delay:.36s}.rv-d4{transition-delay:.48s}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}

/* ---------- nav ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:1.4rem 6vw;display:flex;align-items:center;justify-content:space-between;
  transition:background .4s,padding .4s,border-color .4s;border-bottom:1px solid transparent;
}
nav.scrolled{background:rgba(20,18,14,.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:.85rem 6vw;border-bottom-color:var(--line)}
.nav-logo{font-family:'Shippori Mincho',serif;font-size:1.5rem;font-weight:700;letter-spacing:.14em}
.nav-logo em{color:var(--vermillion);font-style:normal}
.nav-links{display:flex;gap:2.2rem;align-items:center;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase}
.nav-links a{color:var(--cream-dim);transition:color .3s;position:relative}
.nav-links a:hover{color:var(--cream)}
.nav-links a.active{color:var(--cream)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;background:var(--vermillion);transition:width .3s}
.nav-links a:hover::after{width:100%}
.nav-links a.active::after{width:100%}
.nav-cta{
  border:1px solid var(--vermillion);color:var(--cream)!important;padding:.6rem 1.4rem;
  transition:background .3s,color .3s;
}
.nav-cta:hover{background:var(--vermillion)}
.nav-cta::after{display:none}
.nav-cta.active::after{display:none}
/* mobile menu toggle */
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:30px;height:22px;position:relative;z-index:60}
.nav-toggle span{position:absolute;left:0;width:100%;height:2px;background:var(--cream);transition:transform .35s,opacity .25s}
.nav-toggle span:nth-child(1){top:0}
.nav-toggle span:nth-child(2){top:10px}
.nav-toggle span:nth-child(3){top:20px}
.nav-toggle.open span:nth-child(1){transform:translateY(10px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-10px) rotate(-45deg)}
@media(max-width:820px){
  .nav-toggle{display:block}
  .nav-links{
    position:fixed;inset:0;flex-direction:column;justify-content:center;gap:2.4rem;
    background:rgba(20,18,14,.97);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
    font-size:1.1rem;transform:translateX(100%);transition:transform .45s cubic-bezier(.2,.6,.2,1);
  }
  .nav-links.open{transform:none}
  .nav-links a::after{display:none}
}

/* ---------- generic page sub-hero (interior pages) ---------- */
.subhero{
  padding:11rem 6vw 5rem;position:relative;overflow:hidden;
  border-bottom:1px solid var(--line);
}
.subhero .seigaiha{height:100%;opacity:.05}
.subhero-inner{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2}
.subhero .sec-label{justify-content:flex-start}
.subhero h1{font-size:clamp(2.8rem,7vw,5rem);font-weight:800;letter-spacing:.02em;margin:1rem 0 .8rem}
.subhero h1 em{font-style:normal;color:var(--vermillion)}
.subhero p{max-width:34rem;color:var(--cream-dim);font-size:1.08rem}
.subhero .vert-jp{right:2vw;left:auto}

/* ---------- hero (home) ---------- */
header.hero{
  min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  position:relative;padding:9rem 6vw 4rem;
}
.seigaiha{
  position:absolute;left:0;right:0;bottom:0;height:34vh;opacity:.06;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='40' viewBox='0 0 80 40'%3E%3Cg fill='none' stroke='%23ece3d0' stroke-width='1.4'%3E%3Cpath d='M0 40a40 40 0 0 1 80 0M10 40a30 30 0 0 1 60 0M20 40a20 20 0 0 1 40 0M30 40a10 10 0 0 1 20 0'/%3E%3C/g%3E%3C/svg%3E");
  background-size:80px 40px;
  -webkit-mask-image:linear-gradient(to top,black,transparent);
  mask-image:linear-gradient(to top,black,transparent);
}
.hero-art{
  position:absolute;right:3vw;top:50%;transform:translateY(-52%);
  width:min(44vw,560px);aspect-ratio:1;pointer-events:none;
}
.hero-art .sun{
  position:absolute;inset:12%;border-radius:50%;
  background:radial-gradient(circle at 38% 32%,#e8694c,var(--vermillion-deep) 70%);
  opacity:.92;filter:saturate(.95);
  animation:sunrise 1.6s cubic-bezier(.2,.6,.2,1) both .3s;
}
@keyframes sunrise{from{opacity:0;transform:translateY(40px) scale(.96)}to{opacity:.92;transform:none}}
.hero-art svg{position:absolute;inset:0;width:100%;height:100%}
.hero-art .enso{
  fill:none;stroke:var(--cream);stroke-width:7;stroke-linecap:round;opacity:.85;
  stroke-dasharray:1120;stroke-dashoffset:1120;
  animation:draw 2.2s cubic-bezier(.4,0,.2,1) forwards .8s;
}
@keyframes draw{to{stroke-dashoffset:90}}
@media(max-width:900px){
  .hero-art{position:relative;right:auto;top:auto;transform:none;width:min(74vw,380px);margin:3rem auto 0}
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);
}
.hero-eyebrow::before{content:"";width:34px;height:1px;background:var(--gold)}
.hero-title{
  font-size:clamp(4.2rem,11vw,9.5rem);font-weight:800;letter-spacing:.04em;
  line-height:1;margin:1.2rem 0 .4rem;position:relative;z-index:2;
}
.hero-title em{font-style:normal;color:var(--vermillion)}
.hero-sub{
  font-family:'Shippori Mincho',serif;font-size:clamp(1.3rem,3vw,2.1rem);
  letter-spacing:.32em;text-transform:uppercase;color:var(--cream-dim);font-weight:500;
  position:relative;z-index:2;
}
.hero-tag{max-width:34rem;margin:1.8rem 0 2.6rem;font-size:1.08rem;color:var(--cream-dim);position:relative;z-index:2}
.hero-tag strong{color:var(--cream);font-weight:500}
.hero-ctas{display:flex;gap:1.1rem;flex-wrap:wrap;position:relative;z-index:2}
.btn{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:1.05rem 2.3rem;font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:500;transition:all .35s;border:1px solid transparent;cursor:pointer;
}
.btn-primary{background:var(--vermillion);color:#fff}
.btn-primary:hover{background:var(--vermillion-deep);transform:translateY(-2px)}
.btn-ghost{border-color:var(--line);color:var(--cream)}
.btn-ghost:hover{border-color:var(--cream);transform:translateY(-2px)}
.hero-stats{
  display:flex;gap:0;margin-top:4rem;border-top:1px solid var(--line);
  position:relative;z-index:2;max-width:46rem;flex-wrap:wrap;
}
.hero-stats div{padding:1.4rem 2.4rem 0 0;margin-right:2.4rem}
.hero-stats b{display:block;font-family:'Shippori Mincho',serif;font-size:1.7rem;font-weight:700;color:var(--cream)}
.hero-stats b .star{color:var(--gold)}
.hero-stats span{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-dim)}
.vert-jp{
  position:absolute;left:1.4vw;top:50%;transform:translateY(-50%);
  writing-mode:vertical-rl;font-family:'Shippori Mincho',serif;
  font-size:.95rem;letter-spacing:.55em;color:var(--cream-dim);opacity:.4;
}
@media(max-width:900px){.vert-jp{display:none}}

/* ---------- marquee ---------- */
.marquee{
  background:var(--vermillion);color:#fff;overflow:hidden;white-space:nowrap;
  padding:.95rem 0;border-top:1px solid rgba(0,0,0,.15);border-bottom:1px solid rgba(0,0,0,.15);
}
.marquee-track{display:inline-block;animation:scroll 30s linear infinite}
.marquee span{
  font-family:'Shippori Mincho',serif;font-size:1.02rem;letter-spacing:.28em;
  text-transform:uppercase;margin:0 1.6rem;font-weight:600;
}
.marquee .dot{color:rgba(255,255,255,.55)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- sections shared ---------- */
section{padding:8.5rem 0;position:relative}
.sec-label{
  display:flex;align-items:center;gap:1rem;font-size:.78rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--vermillion);margin-bottom:1.4rem;
}
.sec-label::before{content:"";width:34px;height:1px;background:var(--vermillion)}
.sec-title{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:700;letter-spacing:.01em;margin-bottom:1.2rem}
.sec-title em{font-style:normal;color:var(--vermillion)}

/* ---------- story ---------- */
#story{background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.story-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:5rem;align-items:start}
@media(max-width:900px){.story-grid{grid-template-columns:1fr;gap:3rem}}
.story-text p{margin-bottom:1.4rem;color:var(--cream-dim);font-size:1.05rem}
.story-text p strong{color:var(--cream);font-weight:500}
.chloe-card{
  background:var(--ink-3);border:1px solid var(--line);padding:3rem 2.6rem;position:relative;
  margin-top:1rem;
}
.chloe-card::before{
  content:"";position:absolute;top:-1px;left:-1px;width:56px;height:56px;
  border-top:2px solid var(--vermillion);border-left:2px solid var(--vermillion);
}
.chloe-card::after{
  content:"";position:absolute;bottom:-1px;right:-1px;width:56px;height:56px;
  border-bottom:2px solid var(--vermillion);border-right:2px solid var(--vermillion);
}
.chloe-heart{width:54px;height:54px;margin-bottom:1.6rem;color:var(--vermillion)}
.chloe-card h3{font-size:1.7rem;margin-bottom:.9rem}
.chloe-card p{color:var(--cream-dim);margin-bottom:1.3rem}
.chloe-quote{
  border-left:2px solid var(--gold);padding-left:1.2rem;font-family:'Shippori Mincho',serif;
  font-style:italic;color:var(--cream);font-size:1.02rem;line-height:1.6;
}
.chloe-quote small{display:block;margin-top:.6rem;font-family:'Zen Kaku Gothic New',sans-serif;font-style:normal;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-dim)}
.story-points{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:2.6rem;border:1px solid var(--line)}
@media(max-width:560px){.story-points{grid-template-columns:1fr}}
.story-points div{padding:1.6rem 1.7rem;border:1px solid var(--line);margin:-.5px}
.story-points b{display:block;font-family:'Shippori Mincho',serif;font-size:1.05rem;font-weight:600;margin-bottom:.3rem}
.story-points span{font-size:.92rem;color:var(--cream-dim)}

/* ---------- menu (highlights grid, used on home) ---------- */
#menu .sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:3.4rem}
#menu .sec-head p{max-width:30rem;color:var(--cream-dim)}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--line)}
@media(max-width:760px){.menu-grid{grid-template-columns:1fr}}
.menu-item{
  display:flex;justify-content:space-between;gap:2rem;align-items:baseline;
  padding:1.9rem 2.2rem;border:1px solid var(--line);margin:-.5px;
  transition:background .35s;position:relative;
}
.menu-item:hover{background:var(--ink-2)}
.menu-item:hover .mi-name{color:var(--vermillion)}
.mi-name{font-family:'Shippori Mincho',serif;font-size:1.18rem;font-weight:600;transition:color .3s}
.mi-badge{
  display:inline-block;margin-left:.7rem;font-family:'Zen Kaku Gothic New',sans-serif;
  font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);
  border:1px solid rgba(201,163,92,.4);padding:.18rem .55rem;vertical-align:middle;white-space:nowrap;
}
.mi-desc{font-size:.9rem;color:var(--cream-dim);margin-top:.35rem;max-width:26rem}
.mi-price{font-family:'Shippori Mincho',serif;font-size:1.1rem;color:var(--gold);white-space:nowrap}
.menu-note{margin-top:2.6rem;display:flex;align-items:center;justify-content:space-between;gap:1.6rem;flex-wrap:wrap}
.menu-note p{color:var(--cream-dim);font-size:.95rem}

/* ---------- full menu page ---------- */
.menu-cat-nav{
  position:sticky;top:0;z-index:40;background:rgba(20,18,14,.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.menu-cat-nav .inner{
  max-width:var(--maxw);margin:0 auto;padding:.9rem 6vw;
  display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;
}
.menu-cat-nav .inner::-webkit-scrollbar{display:none}
.menu-cat-nav a{
  white-space:nowrap;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--cream-dim);padding:.5rem .95rem;border:1px solid var(--line);
  transition:color .3s,border-color .3s,background .3s;
}
.menu-cat-nav a:hover,.menu-cat-nav a.active{color:var(--cream);border-color:var(--vermillion)}
.menu-section{padding:5rem 0 1rem;scroll-margin-top:70px}
.menu-section:first-of-type{padding-top:3rem}
.menu-cat-head{display:flex;align-items:baseline;gap:1.2rem;margin-bottom:2rem;flex-wrap:wrap}
.menu-cat-head h2{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700}
.menu-cat-head .jp{font-family:'Shippori Mincho',serif;color:var(--cream-dim);opacity:.6;letter-spacing:.2em;font-size:1rem}
.menu-cat-head .note{font-size:.85rem;color:var(--cream-dim);font-style:italic}
.menu-list{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--line)}
@media(max-width:760px){.menu-list{grid-template-columns:1fr}}
.menu-row{
  display:flex;justify-content:space-between;gap:1.4rem;align-items:baseline;
  padding:1.25rem 1.6rem;border:1px solid var(--line);margin:-.5px;transition:background .3s;
}
.menu-row:hover{background:var(--ink-2)}
.menu-row:hover .mr-name{color:var(--vermillion)}
.mr-name{font-family:'Shippori Mincho',serif;font-size:1.04rem;font-weight:600;transition:color .3s}
.mr-desc{font-size:.84rem;color:var(--cream-dim);margin-top:.25rem;max-width:28rem;line-height:1.5}
.mr-price{font-family:'Shippori Mincho',serif;font-size:1rem;color:var(--gold);white-space:nowrap}
.mr-badge{
  display:inline-block;margin-left:.6rem;font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);border:1px solid rgba(201,163,92,.4);padding:.14rem .5rem;vertical-align:middle;white-space:nowrap;
}

/* ---------- reviews ---------- */
#reviews{background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden}
.rev-head{display:grid;grid-template-columns:auto 1fr;gap:4rem;align-items:center;margin-bottom:4rem}
@media(max-width:760px){.rev-head{grid-template-columns:1fr;gap:1.6rem}}
.rev-score{font-family:'Shippori Mincho',serif;font-size:clamp(5rem,10vw,8rem);font-weight:800;line-height:1;color:var(--cream)}
.rev-score small{font-size:.35em;color:var(--cream-dim);font-weight:500}
.rev-stars{color:var(--gold);font-size:1.5rem;letter-spacing:.2em;margin:.4rem 0}
.rev-head p{color:var(--cream-dim);max-width:30rem;font-size:1.02rem}
.rev-head p b{color:var(--cream);font-weight:500}
.rev-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.6rem}
@media(max-width:760px){.rev-grid{grid-template-columns:1fr}}
.rev-card{
  background:var(--ink-3);border:1px solid var(--line);padding:2.4rem 2.3rem;
  display:flex;flex-direction:column;gap:1.3rem;transition:transform .35s,border-color .35s;
}
.rev-card:hover{transform:translateY(-4px);border-color:rgba(201,163,92,.4)}
.rev-card .q{font-family:'Shippori Mincho',serif;font-size:1.08rem;line-height:1.65;color:var(--cream)}
.rev-card .q::before{content:"\201C";color:var(--vermillion);font-size:1.6em;line-height:0;vertical-align:-.25em;margin-right:.1em}
.rev-card .who{display:flex;align-items:center;gap:.8rem;margin-top:auto}
.rev-card .who .av{
  width:38px;height:38px;border-radius:50%;background:var(--vermillion-deep);
  display:flex;align-items:center;justify-content:center;font-family:'Shippori Mincho',serif;
  font-weight:700;color:#fff;font-size:.95rem;flex-shrink:0;
}
.rev-card .who b{display:block;font-weight:500;font-size:.92rem}
.rev-card .who span{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cream-dim)}
.rev-card .stars{color:var(--gold);font-size:.85rem;letter-spacing:.15em}

/* ---------- visit ---------- */
.visit-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:4.5rem;align-items:start}
@media(max-width:900px){.visit-grid{grid-template-columns:1fr;gap:3rem}}
.hours-table{width:100%;border-collapse:collapse;margin:2rem 0 2.4rem}
.hours-table td{padding:.85rem 0;border-bottom:1px solid var(--line);font-size:.98rem;color:var(--cream-dim)}
.hours-table td:last-child{text-align:right;color:var(--cream)}
.hours-table tr.today td{color:var(--gold)}
.hours-table tr.closed td:last-child{color:var(--vermillion);letter-spacing:.1em;text-transform:uppercase;font-size:.85rem}
.visit-meta{display:flex;flex-direction:column;gap:1.1rem}
.visit-meta a{transition:color .3s}
.visit-meta a:hover{color:var(--vermillion)}
.visit-meta .row{display:flex;gap:1rem;align-items:flex-start;font-size:1rem;color:var(--cream-dim)}
.visit-meta .row svg{width:19px;height:19px;flex-shrink:0;margin-top:.25rem;color:var(--vermillion)}
.visit-meta .row b{color:var(--cream);font-weight:500}
.amenities{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2rem}
.amenities span{
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-dim);
  border:1px solid var(--line);padding:.45rem .9rem;
}
.map-frame{border:1px solid var(--line);position:relative;background:var(--ink-2);aspect-ratio:4/3.4}
.map-frame::before{
  content:"";position:absolute;top:-1px;right:-1px;width:56px;height:56px;
  border-top:2px solid var(--gold);border-right:2px solid var(--gold);z-index:2;pointer-events:none;
}
.map-frame iframe{width:100%;height:100%;border:0;filter:grayscale(1) invert(.92) contrast(.9) sepia(.18)}
.map-fallback{
  position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1.1rem;text-align:center;padding:2rem;background:var(--ink-2);
  opacity:0;pointer-events:none;transition:opacity .5s;
}
.map-fallback.show{opacity:1;pointer-events:auto}
.map-fallback::before{
  content:"";position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='40' viewBox='0 0 80 40'%3E%3Cg fill='none' stroke='%23ece3d0' stroke-width='1.4'%3E%3Cpath d='M0 40a40 40 0 0 1 80 0M10 40a30 30 0 0 1 60 0M20 40a20 20 0 0 1 40 0M30 40a10 10 0 0 1 20 0'/%3E%3C/g%3E%3C/svg%3E");
  background-size:80px 40px;
}
.map-fallback svg{width:44px;height:44px;color:var(--vermillion);position:relative}
.map-fallback b{font-family:'Shippori Mincho',serif;font-size:1.25rem;font-weight:600;position:relative}
.map-fallback p{color:var(--cream-dim);font-size:.95rem;position:relative}

/* ---------- order ---------- */
#order{background:var(--ink-2);border-top:1px solid var(--line);text-align:center}
#order .sec-label{justify-content:center}
#order .sec-label::after{content:"";width:34px;height:1px;background:var(--vermillion)}
#order>.wrap>p{max-width:32rem;margin:0 auto 3.2rem;color:var(--cream-dim)}
.order-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;max-width:54rem;margin:0 auto}
@media(max-width:760px){.order-grid{grid-template-columns:1fr}}
.order-card{
  border:1px solid var(--line);padding:2.6rem 1.6rem;background:var(--ink-3);
  display:flex;flex-direction:column;align-items:center;gap:.9rem;
  transition:transform .35s,border-color .35s;
}
.order-card:hover{transform:translateY(-5px);border-color:var(--vermillion)}
.order-card .glyph{font-family:'Shippori Mincho',serif;font-size:2rem;color:var(--vermillion);font-weight:700;line-height:1}
.order-card b{font-family:'Shippori Mincho',serif;font-size:1.25rem;font-weight:600}
.order-card span{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cream-dim)}
.order-phone{margin-top:3rem;color:var(--cream-dim);font-size:.95rem}
.order-phone a{color:var(--gold);font-family:'Shippori Mincho',serif;font-size:1.2rem;letter-spacing:.06em}
.order-phone a:hover{color:var(--vermillion)}

/* ---------- about page ---------- */
.about-lead{font-family:'Shippori Mincho',serif;font-size:clamp(1.4rem,3vw,2rem);line-height:1.5;color:var(--cream);max-width:42rem;margin-bottom:2.2rem}
.about-lead em{font-style:normal;color:var(--vermillion)}
.about-body{max-width:42rem}
.about-body p{margin-bottom:1.5rem;color:var(--cream-dim);font-size:1.06rem}
.about-body p strong{color:var(--cream);font-weight:500}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);margin-top:1rem}
@media(max-width:760px){.values-grid{grid-template-columns:1fr}}
.value{padding:2.4rem 2rem;border:1px solid var(--line);margin:-.5px}
.value .glyph{font-family:'Shippori Mincho',serif;color:var(--vermillion);font-size:1.8rem;margin-bottom:1rem;display:block}
.value h3{font-size:1.3rem;margin-bottom:.6rem}
.value p{color:var(--cream-dim);font-size:.96rem}
.pullquote{
  border-left:2px solid var(--gold);padding:.4rem 0 .4rem 1.8rem;margin:1rem 0;
  font-family:'Shippori Mincho',serif;font-style:italic;font-size:1.2rem;color:var(--cream);line-height:1.6;
}
.pullquote small{display:block;margin-top:.7rem;font-family:'Zen Kaku Gothic New',sans-serif;font-style:normal;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cream-dim)}

/* ---------- photo slots / gallery ---------- */
.photo-slot{
  position:relative;background:var(--ink-3);border:1px solid var(--line);overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.photo-slot img{width:100%;height:100%;object-fit:cover;display:block}
.photo-slot .ph{
  display:flex;flex-direction:column;align-items:center;gap:.7rem;text-align:center;padding:1.5rem;
  color:var(--cream-dim);
}
.photo-slot .ph svg{width:34px;height:34px;color:var(--vermillion);opacity:.6}
.photo-slot .ph span{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase}
.photo-slot::after{
  content:"";position:absolute;top:-1px;left:-1px;width:42px;height:42px;
  border-top:2px solid var(--vermillion);border-left:2px solid var(--vermillion);pointer-events:none;opacity:.5;
}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;grid-auto-rows:240px}
@media(max-width:760px){.gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}}
@media(max-width:480px){.gallery-grid{grid-template-columns:1fr;grid-auto-rows:220px}}
.gallery-grid .photo-slot{transition:transform .4s}
.gallery-grid .photo-slot:hover{transform:scale(.99)}
.gallery-grid .tall{grid-row:span 2}
.gallery-grid .wide{grid-column:span 2}
@media(max-width:480px){.gallery-grid .wide{grid-column:span 1}.gallery-grid .tall{grid-row:span 1}}

/* ---------- contact page ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:4.5rem;align-items:start}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:3rem}}
.cform{display:flex;flex-direction:column;gap:1.3rem}
.cform label{display:block;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-dim);margin-bottom:.5rem}
.cform input,.cform textarea,.cform select{
  width:100%;background:var(--ink-3);border:1px solid var(--line);color:var(--cream);
  font-family:'Zen Kaku Gothic New',sans-serif;font-size:1rem;padding:.95rem 1.1rem;
  transition:border-color .3s;
}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--vermillion)}
.cform textarea{resize:vertical;min-height:130px}
.cform .row2{display:grid;grid-template-columns:1fr 1fr;gap:1.3rem}
@media(max-width:520px){.cform .row2{grid-template-columns:1fr}}
.cform .note{font-size:.82rem;color:var(--cream-dim)}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:4.5rem 0 2.5rem;position:relative;overflow:hidden}
.foot-grid{display:flex;justify-content:space-between;gap:3rem;flex-wrap:wrap;margin-bottom:3.5rem}
.foot-logo{font-family:'Shippori Mincho',serif;font-size:2rem;font-weight:700;letter-spacing:.12em}
.foot-logo em{color:var(--vermillion);font-style:normal}
.foot-col{font-size:.92rem;color:var(--cream-dim);line-height:2}
.foot-col b{display:block;color:var(--cream);font-weight:500;letter-spacing:.16em;text-transform:uppercase;font-size:.76rem;margin-bottom:.6rem}
.foot-col a:hover{color:var(--vermillion)}
.foot-jp{text-align:center;font-family:'Shippori Mincho',serif;color:var(--cream-dim);letter-spacing:.5em;font-size:.9rem;margin-bottom:2rem;opacity:.6}
.foot-base{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  border-top:1px solid var(--line);padding-top:1.8rem;
  font-size:.76rem;letter-spacing:.1em;color:var(--cream-dim);text-transform:uppercase;
}
.foot-credit{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.28rem .85rem;border-radius:999px;
  background:rgba(63,181,173,.07);border:1px solid rgba(63,181,173,.28);
  font-family:'Zen Kaku Gothic New',sans-serif;font-size:.72rem;
  letter-spacing:.12em;color:#3fb5ad;text-transform:uppercase;
  text-decoration:none;transition:background .25s,border-color .25s;
}
.foot-credit:hover{background:rgba(63,181,173,.14);border-color:rgba(63,181,173,.55)}
.foot-credit svg{width:12px;height:12px;opacity:.7;flex-shrink:0}
