/* メニュー内寿司画像を小さく */
.menu-sushi-img {
            width: 200px;
    height: auto;
    margin-left: 8px;
    vertical-align: middle;
    border-radius: 4px;
    box-shadow: 0 1.5px 5px #0002;
}
/* 寿司職人写真ラッパー: グラデーション枠・中央寄せ・アニメ */
.chef-photo-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 10px;
    border-radius: 18px;
    background: linear-gradient(135deg, #fff 60%, #ffbfa3 100%, #ff5c39 120%);
    box-shadow: 0 8px 32px 0 rgba(40,40,60,0.18), 0 1.5px 8px 0 #ff5c3933;
    max-width: 260px;
    margin: 0 auto;
    position: relative;
    opacity: 0;
    transform: translateY(40px);
    transition: opacity 0.9s cubic-bezier(.4,0,.2,1), transform 0.9s cubic-bezier(.4,0,.2,1);
}
.fadein-active {
    opacity: 1 !important;
    transform: none !important;
}
.chef-photo {
    width: 100%;
    max-width: 220px;
    border-radius: 12px;
    box-shadow: 0 4px 32px #ff5c3933, 0 1.5px 8px #fff8;
    background: #fff;
    display: block;
}
/* メインビジュアル横並び用 */
.mainvisual-row {
    position: relative;
    width: fit-content;
    margin: 32px auto 24px auto;
}
.mainvisual-logo {
    position: absolute;
    left: 0;
    top: 0;
    width: 80px;
    height: 56px;
    border-radius: 12px;
    box-shadow: 0 4px 24px #0002;
    display: block;
    z-index: 2;
}
@media (max-width: 700px) {
    .mainvisual-row {
        flex-direction: column;
        gap: 12px;
    }
    .mainvisual-logo {
        max-width: 38vw;
        max-height: 80px;
    }
}
/* トップページ メインビジュアル画像用 */
.sushi-mainvisual {
    width: 100%;
    max-width: 900px;
    display: block;
    border-radius: 16px;
    box-shadow: 0 4px 24px #0002;
}
/* sushiホーム用スタイル（home.htmlから移設） */
:root{
    --bg:#181c23;
    --card:#232834;
    --accent:#b78020ed;
    --muted:#b0b6c3;
    --glass: rgba(40,48,60,0.18);
    --radius:14px;
    font-family: 'Yu Mincho', 'Hiragino Mincho ProN', 'MS PMincho', 'MS Mincho', serif;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
    margin:0;
    background:
        radial-gradient(600px 300px at 10% 20%, rgba(255,92,57,0.08), transparent 12%),
        radial-gradient(500px 250px at 90% 80%, rgba(14,164,233,0.10), transparent 18%),
        var(--bg);
    color:#e6e8ef;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    line-height:1.4;
}

header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:24px;
    padding:20px clamp(18px,4vw,48px);
    position:sticky;
    top:0;
    backdrop-filter: blur(6px);
    background: linear-gradient(180deg, rgba(11,15,18,0.6), rgba(11,15,18,0.3));
    z-index:40;
    flex-direction: column;
}
.brand{
    display:flex;
    gap:12px;
    align-items:center;
}
.logo{
    width:200px;height: 70px;
    border-radius:10px;
    background:linear-gradient(135deg,var(--accent),#ff8e6b);
    display:grid;place-items:center;
    box-shadow:0 6px 22px rgba(255,92,57,0.12), inset 0 -6px 18px rgba(0,0,0,0.25);
    font-weight:700;
    color:#111;
    font-size:18px;
}
nav{
    display:flex;
    gap:18px;
    align-items:center;
    justify-content:center;
}
nav a{
    color:var(--muted);
    text-decoration:none;
    font-weight:600;
    padding:8px 12px;
    border-radius:10px;
    transition:all .18s ease;
}
nav a:hover{color:#fff;background:rgba(255,255,255,0.03)}
.cta{
    background: var(--accent);
    color:#fff;
    padding:10px 14px;
    border-radius:10px;
    font-weight:700;
    text-decoration:none;
    box-shadow:0 8px 30px rgba(255,92,57,0.12);
}

main{padding:48px clamp(18px,4vw,48px) 96px}
.hero{
    display:grid;
    grid-template-columns:1fr 420px;
    gap:32px;
    align-items:center;
    margin-bottom:48px;
}
.hero-card{
    background:linear-gradient(180deg, rgba(40,48,60,0.92), rgba(30,34,44,0.88));
    border-radius:var(--radius);
    padding:36px;
    box-shadow: 0 8px 40px rgba(2,6,23,0.7);
    position:relative;
    overflow:hidden;
}
.eyebrow{color:var(--accent);font-weight:700;letter-spacing:0.04em}
h1{
    margin:12px 0 8px;
    font-size:clamp(28px,4.4vw,44px);
    line-height:1.02;
    letter-spacing:-0.02em;
    color:linear-gradient(#fff,#f0f0f0);
}
p.lead{color:var(--muted);margin:0 0 18px}
.actions{display:flex;gap:12px}
.btn{
    padding:12px 16px;border-radius:10px;text-decoration:none;font-weight:700;
    transition:transform .14s ease,opacity .14s ease;
}
.btn:hover{transform:translateY(-3px)}
.btn-ghost{background:transparent;border:1px solid rgba(255,255,255,0.06);color:#fff}
.media{
    background:linear-gradient(180deg,rgba(255, 255, 255, 0.6) 45%, rgba(255, 255, 255, 0.6));
    border-radius:12px;
    padding:10px;
}
/* sushi preview */
.sushi{
    height:320px;
    border-radius:12px;
    background:
        radial-gradient(600px 200px at 20% 10%, rgba(255,92,57,0.06), transparent 8%),
        linear-gradient(135deg,#0f1725 0%, #071018 100%);
    display:grid;
    place-items:center;
    position:relative;
    overflow:hidden;
}
.sushi::after{
    content:'';
    position:absolute;inset:auto 10% 10% 10%;
    height:3px;background:linear-gradient(90deg,rgba(255,255,255,0.03), rgba(255,92,57,0.08));
    border-radius:999px;transform:translateY(70px);
}
.sushi-plate{
    width:82%;height:56%;
    background:linear-gradient(180deg,#ffece2,#fff3ea);
    border-radius:100px 100px 24px 24px;
    box-shadow: 0 14px 40px rgba(0,0,0,0.45);
    display:flex;align-items:center;justify-content:center;
    transform:translateY(8px);
}
.nigiri{
    width:150px;height:70px;border-radius:24px;
    background:linear-gradient(180deg,#ffefe8,#ffdcd0);
    position:relative;overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,0.35);
}
.nigiri::before{
    content:'';position:absolute;left:12px;top:6px;width:126px;height:44px;border-radius:16px;
    background:linear-gradient(180deg,#ea3b25,#ff6d4d);
    transform:rotate(-6deg);
    box-shadow: inset 0 -6px 18px rgba(0,0,0,0.12);
}

/* menu */
.grid{
    display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:28px;
}
.card{
    background:linear-gradient(135deg,rgba(40,48,60,0.98),rgba(30,34,44,0.92));
    border-radius:12px;
    padding:16px;
    border:1px solid rgba(255,255,255,0.04);
}
.card h3{margin:6px 0 4px}
.price{color:var(--accent);font-weight:800}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:32px}
.tile{
    border-radius:10px;
    height:70px;
    background:linear-gradient(180deg,rgba(40,48,60,0.98),rgba(30,34,44,0.92));
    overflow:hidden;
    position:relative;
    box-shadow:0 2px 12px #0005;
}
.tile::after{
    content:'';
    position:absolute;inset:0;
    background-image:linear-gradient(180deg,rgba(0,0,0,0.0),rgba(0,0,0,0.18));
}
.tile.small{height:50px}
footer{
    margin-top:48px;
    padding:28px;
    border-radius:12px;
    background:linear-gradient(180deg,rgba(40,48,60,0.98),rgba(30,34,44,0.92));
    display:flex;
    justify-content:space-between;
    align-items:center;
    color:var(--muted);
}
.muted{color:var(--muted);font-size:14px}
@media (max-width:980px){
    .hero{grid-template-columns:1fr}
    .grid{grid-template-columns:repeat(2,1fr)}
    .gallery{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:560px){
    header{padding:12px}
    .brand .logo{width:40px;height:40px;font-size:16px}
    .grid{grid-template-columns:1fr}
    .gallery{grid-template-columns:repeat(2,1fr)}
    .hero-card{padding:20px}
}

/* ロゴ画像の左上固定配置用CSS */
.sushi-logo-fixed {
  position: fixed;
  top: 16px;
  left: 16px;
  z-index: 1000;
  width: 180px;
  max-width: 40vw;
  height: auto;
  pointer-events: none;
}
@media (max-width: 600px) {
  .sushi-logo-fixed {
    top: 8px;
    left: 8px;
    width: 38vw;
    max-width: 180px;
  }
}