:root{
  --paper:#eef5fb;
  --paper-light:#f8fcff;
  --white:#ffffff;
  --ink:#243142;
  --muted:#6f8096;
  --blue:#5d7fab;
  --blue-deep:#41699a;
  --blue-mid:#6e91bd;
  --blue-soft:#eaf4fb;
  --line:#c9d8e8;
  --site-width:1086px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:#edf5fb}
body{
  margin:0;
  color:var(--ink);
  background:#edf5fb;
  font-family:"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.skip-link{position:absolute;left:12px;top:-48px;z-index:1000;background:#fff;color:var(--blue-deep);padding:10px 14px;border:1px solid var(--line);border-radius:8px}
.skip-link:focus{top:12px}

.site-shell{
  width:100%;
  max-width:var(--site-width);
  margin:0 auto;
  overflow:hidden;
  background-color:#f4f9fd;
  background-image:
    linear-gradient(rgba(255,255,255,.78),rgba(255,255,255,.52)),
    url("../assets/images/paper-texture.png");
  background-size:auto,220px 220px;
  box-shadow:0 0 0 1px rgba(65,105,154,.06);
}

/* HEADER */
.site-header{
  height:108px;
  background:rgba(255,255,255,.92);
  position:relative;
  z-index:5;
}
.header-inner{
  width:1030px;
  height:100%;
  display:flex;
  align-items:flex-start;
  margin:0 auto;
  padding:18px 0 0;
}
.brand{display:block;width:324px;flex:0 0 324px;color:var(--blue-deep)}
.brand-name{
  display:block;
  font-family:Georgia,"Times New Roman",serif;
  font-size:44px;
  font-weight:900;
  line-height:.98;
  letter-spacing:.065em;
  color:var(--blue-deep);
  text-shadow:0 1px 0 rgba(255,255,255,.75);
  white-space:nowrap;
}
.brand-sub{
  display:block;
  margin:8px 0 0 1px;
  font-size:15px;
  font-weight:700;
  letter-spacing:.20em;
  color:#2f3742;
  white-space:nowrap;
}
.global-nav{
  display:flex;
  align-items:flex-start;
  gap:42px;
  margin:45px 0 0 18px;
  white-space:nowrap;
}
.global-nav a{
  position:relative;
  font-size:15px;
  font-weight:700;
  letter-spacing:.07em;
  color:#182536;
  padding-bottom:9px;
  transition:color .2s ease;
}
.global-nav a::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:0;
  width:0;
  height:2px;
  background:var(--blue);
  transform:translateX(-50%);
  transition:width .2s ease;
}
.global-nav a:hover,.global-nav a.is-current{color:var(--blue-deep)}
.global-nav a:hover::after,.global-nav a.is-current::after{width:42px}
.header-tel{
  margin-left:auto;
  margin-top:0;
  width:218px;
  height:74px;
  border-radius:12px;
  background:linear-gradient(180deg,#7697c2 0%,#5d7fab 100%);
  color:#fff;
  border:2px solid rgba(235,245,255,.88);
  outline:1px dashed rgba(255,255,255,.72);
  outline-offset:-7px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:11px;
  padding:0 14px;
  box-shadow:0 5px 13px rgba(65,105,154,.22);
  overflow:hidden;
  transition:transform .2s ease,box-shadow .2s ease;
}
.header-tel:hover{transform:translateY(-1px);box-shadow:0 7px 16px rgba(65,105,154,.28)}
.header-phone{
  width:34px;
  height:34px;
  flex:0 0 34px;
  background:url("../assets/icons/reservation-phone-transparent.png") center/contain no-repeat;
}
.header-tel-copy{
  flex:1 1 auto;
  min-width:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  transform:translateY(-2px);
}
.header-tel-label{
  display:block;
  margin:0 0 3px;
  white-space:nowrap;
  text-align:center;
  font-size:12px;
  line-height:1;
  letter-spacing:.05em;
  font-weight:700;
}
.header-tel strong{
  display:block;
  margin:0;
  white-space:nowrap;
  text-align:center;
  font-size:20.5px;
  line-height:1;
  letter-spacing:.015em;
  font-weight:800;
  font-variant-numeric:tabular-nums;
}

/* HERO */
.hero{
  position:relative;
  height:482px;
  overflow:hidden;
  background:#ddeaf3;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:url("../assets/images/storefront-hero-warm.png") center top/cover no-repeat;
  filter:saturate(.92) brightness(1.04) contrast(.98);
}
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,rgba(245,250,253,.92) 0%,rgba(245,250,253,.78) 28%,rgba(245,250,253,.35) 45%,rgba(245,250,253,.08) 65%,rgba(245,250,253,0) 78%),
    linear-gradient(180deg,rgba(255,255,255,.05) 0%,rgba(232,242,249,.16) 100%);
}
.hero-copy{position:relative;z-index:2;width:430px;padding-left:62px;padding-top:108px}
.hero h1{
  margin:0;
  color:var(--blue-deep);
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
  font-size:40px;
  font-weight:700;
  line-height:1.47;
  letter-spacing:.10em;
  text-shadow:0 1px 0 rgba(255,255,255,.8);
}
.hero-branch{display:none!important}
.hero p{
  margin:0;
  color:#243142;
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
  font-size:18px;
  font-weight:600;
  line-height:1.8;
  letter-spacing:.08em;
  text-shadow:0 1px 0 rgba(255,255,255,.72);
}

/* CONCEPT */
.concept{height:238px;padding-top:10px;background:linear-gradient(180deg,#f5fafe 0%,#eef6fb 100%)}
.concept-card{
  width:1030px;
  height:217px;
  margin:0 auto;
  border-radius:19px;
  background:rgba(255,255,255,.86);
  display:grid;
  grid-template-columns:140px 1fr 390px;
  align-items:center;
  gap:15px;
  padding:16px 28px 16px 45px;
  box-shadow:0 7px 22px rgba(84,124,161,.10);
  border:1px solid rgba(200,216,232,.65);
}
.concept-illustration{width:112px;height:112px;display:grid;place-items:center;margin-left:4px;opacity:.88}
.concept-illustration img{
  width:112px;
  height:112px;
  object-fit:contain;
  filter:sepia(.12) hue-rotate(165deg) saturate(.62) brightness(1.02);
}
.concept-copy{padding-top:3px}
.concept-copy h2{
  margin:0 0 16px;
  color:var(--blue-deep);
  font-family:Georgia,"Times New Roman",serif;
  font-size:24px;
  font-weight:800;
  letter-spacing:.16em;
  line-height:1;
}
.concept-lead{
  margin:0 0 14px;
  color:#243a58;
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
  font-size:20px;
  font-weight:700;
  line-height:1.56;
  letter-spacing:.03em;
  white-space:nowrap;
}
.concept-text{margin:0;color:#2d3744;font-size:12.5px;font-weight:600;line-height:1.85;letter-spacing:.07em}
.concept-photo{
  position:relative;
  width:392px;
  height:168px;
  border-radius:8px;
  overflow:hidden;
  justify-self:end;
  box-shadow:inset 0 0 30px rgba(65,105,154,.12),0 3px 12px rgba(84,124,161,.10);
}
.concept-photo::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 28px 14px rgba(246,251,255,.36);pointer-events:none}
.concept-photo img{width:100%;height:100%;object-fit:cover;filter:saturate(.86) contrast(1.02) brightness(1.03)}

/* SECTION TITLES */
.section-title{display:flex;align-items:center;justify-content:center;gap:0;height:22px}
.section-title h2{
  margin:0;
  color:#2c3d52;
  font-family:Georgia,"Times New Roman",serif;
  font-size:24px;
  font-weight:800;
  letter-spacing:.17em;
  line-height:1;
}
.section-title span{display:none!important}
.section-title .leaf-left{display:none!important}

/* MENU */
.menu{height:214px;position:relative;padding-top:13px;background:#fff}
.menu-panel{
  position:relative;
  width:1030px;
  height:182px;
  margin:4px auto 0;
  border-radius:14px;
  background:rgba(246,251,255,.92);
  box-shadow:0 4px 16px rgba(84,124,161,.08);
  border:1px solid rgba(201,216,232,.65);
  padding-top:20px;
}
.menu-items{height:98px;display:grid;grid-template-columns:repeat(3,1fr)}
.menu-item{position:relative;display:flex;align-items:center;padding-left:42px}
.menu-item:not(:last-child)::after{
  content:"";
  position:absolute;
  right:0;
  top:5px;
  width:2px;
  height:87px;
  background:repeating-linear-gradient(to bottom,rgba(93,127,171,.40) 0 7px,transparent 7px 14px);
}
.menu-icon{
  width:78px;
  height:78px;
  flex:0 0 78px;
  border-radius:50%;
  display:grid;
  place-items:center;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.30),0 3px 8px rgba(65,105,154,.13);
  margin-right:31px;
}
.menu-icon img{width:56px;height:56px;object-fit:contain;object-position:center center}
.icon-brown{background:#7897bd}
.icon-rust{background:#9aa9d4}
.menu-text h3{margin:0 0 7px;color:#1f2935;font-size:19px;font-weight:700;letter-spacing:.12em;line-height:1}
.menu-text .price{margin:0 0 5px;color:#17202b;font-size:34px;font-family:"Trebuchet MS","Yu Gothic",sans-serif;font-weight:700;letter-spacing:.07em;line-height:.95;white-space:nowrap}
.menu-text .caption{margin:0;color:#2f3b48;font-size:12px;font-weight:700;letter-spacing:.06em;white-space:nowrap}
.menu-note{position:absolute;left:72px;bottom:20px;margin:0;color:#2c3c4d;font-size:13px;font-weight:700;letter-spacing:.08em;white-space:nowrap}

/* RESERVATION */
.reservation{height:158px;padding-top:10px;background:#fff}
.reservation-box{
  width:1030px;
  height:147px;
  margin:0 auto;
  border:1.6px solid #8aa6c8;
  border-radius:10px;
  overflow:hidden;
  display:grid;
  grid-template-columns:405px 275px 1fr;
  background:rgba(246,251,255,.92);
  box-shadow:0 4px 16px rgba(84,124,161,.08);
}
.reservation-left,.reservation-middle{background:linear-gradient(180deg,#6e91bd 0%,#557fab 100%);color:#fff}
.reservation-left{display:flex;align-items:center;padding:0 0 0 34px}
.vintage-phone{width:100px;height:80px;margin-right:21px;display:grid;place-items:center;opacity:.96}
.vintage-phone img{width:92px;height:92px;object-fit:contain}
.reservation-main-text p{margin:0 0 6px;color:#fff;font-size:18px;font-weight:700;letter-spacing:.08em;line-height:1}
.reservation-main-text h2{margin:0 0 8px;color:#fff;font-size:25px;font-weight:700;letter-spacing:.09em;line-height:1}
.reservation-main-text a{display:block;color:#fff;font-size:31px;font-weight:800;letter-spacing:.04em;line-height:1;font-family:"Trebuchet MS","Yu Gothic",sans-serif;white-space:nowrap}
.reservation-middle{display:flex;flex-direction:column;justify-content:center;padding-left:29px;position:relative}
.reservation-middle::before{content:"";position:absolute;left:0;top:19px;width:2px;height:107px;background:repeating-linear-gradient(to bottom,rgba(255,255,255,.60) 0 8px,transparent 8px 16px)}
.reservation-middle p{margin:0 0 15px;font-size:15px;font-weight:700;letter-spacing:.08em;white-space:nowrap}.reservation-middle p:last-child{margin-bottom:0}
.reservation-right{position:relative;padding:25px 30px 0 42px;color:#253446;background:#f7fbfe}
.reservation-right p{margin:0;font-size:15px;font-weight:700;line-height:1.78;letter-spacing:.07em;white-space:normal}
.reservation-right img{display:none!important}

/* ACCESS */
.access{height:252px;padding-top:16px;background:#fff}
.access-card{
  position:relative;
  width:1030px;
  height:226px;
  margin:0 auto;
  border:1.6px solid #a8bdd5;
  border-radius:10px;
  background:rgba(248,252,255,.80);
  display:grid;
  grid-template-columns:415px 1fr;
  gap:15px;
  padding:38px 5px 18px 38px;
  box-shadow:0 2px 10px rgba(84,124,161,.06);
}
.access-heading{position:absolute;left:190px;top:-11px;display:flex;align-items:center;gap:0;color:var(--blue-deep)}
.access-heading span{display:none!important}
.access-heading span:first-child::before,.access-heading span:last-child::after{display:none!important}
.access-heading span:first-child::before{display:none!important}
.access-heading span:last-child::after{left:5px;transform:rotate(-14deg)}
.access-heading h2{
  margin:0;
  color:var(--blue-deep);
  font-family:Georgia,"Times New Roman",serif;
  font-size:24px;
  font-weight:800;
  letter-spacing:.16em;
  line-height:1;
  background:#f4f9fd;
  padding:0 6px;
}
.access-info{padding-left:20px;color:#243142}
.address-row{display:flex;align-items:center;margin-bottom:22px}
.address-row img{width:37px;height:37px;margin-right:19px;filter:hue-rotate(170deg) saturate(.58) brightness(1.05)}
.address-row p{margin:0;font-family:"Yu Mincho","Hiragino Mincho ProN",serif;font-size:21px;font-weight:700;letter-spacing:.07em;white-space:nowrap;color:#243142}
.info-grid{width:360px;display:grid;grid-template-columns:1fr 1fr;gap:18px 22px}
.info-item{display:flex;align-items:flex-start}
.info-item img{width:31px;height:31px;margin-right:15px;object-fit:contain;filter:hue-rotate(170deg) saturate(.58) brightness(1.05)}
.info-item p{margin:0;font-size:14px;font-weight:700;line-height:1.45;letter-spacing:.04em;color:#243142}
.map-card{align-self:start;width:550px;height:180px;border:1.5px solid #a8bdd5;border-radius:8px;overflow:hidden;background:#e7eff5;margin-top:0}
.map-card img{width:100%;height:100%;object-fit:cover;object-position:center}
.map-card-embed{position:relative}
.map-card-embed iframe{width:100%;height:100%;border:0;display:block;filter:saturate(.72) brightness(1.05)}
.map-open-link{position:absolute;right:16px;bottom:14px;display:inline-flex;align-items:center;justify-content:center;height:34px;padding:0 16px;border-radius:17px;background:rgba(255,255,255,.92);border:1px solid rgba(92,127,171,.40);color:#41699a;font-size:13px;font-weight:700;letter-spacing:.06em;box-shadow:0 4px 10px rgba(84,124,161,.12)}

/* RESPONSIVE */
@media (max-width:900px){
  .site-shell{max-width:none;overflow-x:hidden}
  .site-header{height:auto}
  .header-inner{
    width:100%;
    max-width:none;
    margin:0;
    display:grid;
    grid-template-columns:minmax(0,1fr) 178px;
    grid-template-rows:auto auto;
    align-items:center;
    gap:10px;
    padding:16px 12px 14px;
  }
  .brand{width:auto;min-width:0;flex:1 1 auto}
  .brand-name{font-size:clamp(25px,8vw,38px);letter-spacing:.04em;line-height:1}
  .brand-sub{margin:6px 0 0 1px;font-size:clamp(9px,2.4vw,12px);letter-spacing:.06em;white-space:nowrap}
  .header-tel{grid-column:2;grid-row:1;width:178px;height:56px;margin:0;border-radius:12px;gap:6px;padding:0 8px;outline-offset:-5px}
  .header-phone{width:24px;height:24px;flex:0 0 24px}
  .header-tel-copy{transform:none}
  .header-tel-label{font-size:9px;margin:0 0 2px;letter-spacing:.01em}
  .header-tel strong{font-size:15px;letter-spacing:0}
  .global-nav{grid-column:1/-1;grid-row:2;width:100%;margin:8px 0 0;padding:0;display:flex;flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:0}
  .global-nav a[href="#reservation"]{display:none}
  .global-nav a{font-size:clamp(12px,3.1vw,15px);letter-spacing:.02em;padding:8px 0 9px;white-space:nowrap}
  .global-nav a.is-current::after,.global-nav a:hover::after{width:30px;height:2px}
  .hero{height:600px;min-height:600px;display:flex;align-items:flex-end;background:#e9f3fa}
  .hero::before{background-size:cover;background-position:67% 0}
  .hero::after{background:linear-gradient(180deg,rgba(245,250,253,.05) 0%,rgba(245,250,253,.12) 18%,rgba(245,250,253,.32) 40%,rgba(245,250,253,.78) 66%,rgba(245,250,253,.98) 100%)}
  .hero-copy{width:100%;max-width:none;margin-top:auto;padding:0 22px 24px}
  .hero h1{font-size:26px;line-height:1.5;letter-spacing:.06em;margin-bottom:6px}
  .hero-branch{width:min(56vw,220px);margin:8px 0 10px 2px}
  .hero p{font-size:12.5px;line-height:1.9;letter-spacing:.03em;max-width:86%}
  .concept{height:auto;padding:30px 16px 22px}
  .concept-card{width:100%;height:auto;grid-template-columns:104px 1fr;gap:16px;padding:22px 20px;border-radius:16px}
  .concept-illustration{width:96px;height:96px;margin:0;align-self:start}
  .concept-illustration img{width:96px;height:96px}
  .concept-copy{padding-top:0;text-align:left}
  .concept-copy h2{text-align:left;font-size:clamp(22px,6vw,28px);margin-bottom:12px}
  .concept-lead{font-size:clamp(16px,4.3vw,19px);line-height:1.55;white-space:normal}
  .concept-text{font-size:clamp(12px,3.2vw,14px);line-height:1.75}
  .concept-photo{grid-column:1/-1;width:100%;height:190px;margin-top:10px}
  .menu{height:auto;padding:22px 18px 38px}
  .menu-panel{width:100%;height:auto;padding:26px 18px 28px}
  .menu-items{height:auto;grid-template-columns:1fr;gap:28px}
  .menu-item{flex-direction:column;text-align:center;padding-left:0;margin:0 auto;max-width:360px}
  .menu-item:not(:last-child)::after{display:none}
  .menu-icon{width:92px;height:92px;flex:0 0 92px;margin:0 auto 14px}
  .menu-icon img{width:60px;height:60px}
  .menu-text h3{font-size:22px}.menu-text .price{font-size:34px}.menu-note{position:static;text-align:center;margin:26px auto 0;white-space:normal;line-height:1.6;font-size:13px}
  .reservation{height:auto;padding:26px 18px 34px}
  .reservation-box{width:100%;height:auto;grid-template-columns:1fr;border-radius:10px}
  .reservation-left{flex-direction:column;justify-content:center;text-align:center;padding:28px 18px}
  .vintage-phone{margin:0 0 12px;width:104px;height:86px}.vintage-phone img{width:94px;height:94px}
  .reservation-main-text a{font-size:clamp(30px,8.8vw,44px);letter-spacing:.03em}
  .reservation-middle{padding:22px 18px;text-align:center}.reservation-middle::before{display:none}
  .reservation-right{padding:24px 20px 56px;text-align:center}.reservation-right p{font-size:13px;line-height:1.75;letter-spacing:.03em}
  .access{height:auto;padding:30px 18px 42px}
  .access-card{width:100%;height:auto;grid-template-columns:1fr;padding:42px 24px 24px}
  .access-heading{left:50%;transform:translateX(-50%);white-space:nowrap}
  .access-info{padding-left:0}
  .address-row{align-items:flex-start}.address-row p{white-space:normal;font-size:20px;line-height:1.55}
  .info-grid{width:100%;grid-template-columns:1fr 1fr}
  .map-card{width:100%;height:210px}
}
@media (max-width:420px){
  .header-inner{grid-template-columns:minmax(0,1fr) 166px;padding-left:12px;padding-right:10px}
  .brand-name{font-size:26px}.brand-sub{font-size:8.8px}
  .header-tel{width:166px;height:54px}.header-phone{width:22px;height:22px;flex-basis:22px}
  .header-tel-label{font-size:8.4px}.header-tel strong{font-size:14px}
  .hero{height:600px;min-height:600px}
  .hero::before{background-position:67% 0}
}

/* ==== MOBILE DECORATION CLEANUP 2026-05-27 ==== */
@media (max-width:900px){
  /* Hero: keep image framing, but remove the small leaf ornament that was drifting over text */
  .hero{
    height:540px;
    min-height:540px;
  }
  .hero::before{
    background-size:cover;
    background-position:61% 0;
  }
  .hero::after{
    background:
      linear-gradient(180deg,
        rgba(245,250,253,.02) 0%,
        rgba(245,250,253,.08) 16%,
        rgba(245,250,253,.22) 34%,
        rgba(245,250,253,.62) 58%,
        rgba(245,250,253,.94) 82%,
        rgba(245,250,253,.985) 100%);
  }
  .hero-copy{
    padding:0 22px 18px;
  }
  .hero h1{
    font-size:clamp(29px,7.8vw,37px);
    line-height:1.42;
    letter-spacing:.055em;
    margin-bottom:20px;
  }
  .hero-branch{
    display:none !important;
  }
  .hero p{
    max-width:78%;
    font-size:12.8px;
    line-height:1.85;
  }

  /* Section title ornaments: hide on mobile to avoid uneven/tilted marks */
  .section-title{
    gap:0;
    height:auto;
    min-height:28px;
    margin-bottom:16px;
  }
  .section-title span,
  .section-title span::before,
  .section-title span::after,
  .section-title .leaf-left,
  .section-title .leaf-right{
    display:none !important;
  }
  .section-title h2{
    font-size:22px;
    letter-spacing:.14em;
    line-height:1.15;
  }

  .menu{
    padding-top:20px;
  }
  .menu-panel{
    padding-top:24px;
  }

  /* Reservation decorative leaf: remove on mobile so it never overlaps text/card edges */
  .reservation-right{
    padding:24px 18px 34px;
    text-align:center;
  }
  .reservation-right img{
    display:none !important;
  }

  /* Access heading ornaments: hide side lines/leaves on mobile and center title */
  .access-heading{
    left:50%;
    top:-12px;
    transform:translateX(-50%);
    gap:0;
    justify-content:center;
    white-space:nowrap;
  }
  .access-heading span,
  .access-heading span::before,
  .access-heading span::after{
    display:none !important;
  }
  .access-heading h2{
    font-size:22px;
    letter-spacing:.14em;
    padding:0 8px;
  }
}
@media (max-width:420px){
  .hero{
    height:500px;
    min-height:500px;
  }
  .hero::before{
    background-position:60% 0;
  }
  .hero-copy{
    padding:0 20px 16px;
  }
  .hero h1{
    font-size:27px;
    line-height:1.42;
    margin-bottom:18px;
  }
  .hero p{
    max-width:80%;
    font-size:12.4px;
    line-height:1.8;
  }

  .section-title h2,
  .access-heading h2{
    font-size:20px;
  }
}



/* ==== ALL VIEWPORT DECORATION CLEANUP 2026-05-27 ====
   PC and mobile: remove unstable small leaf/line ornaments so titles, cards, and text stay aligned. */
.hero-branch,
.section-title span,
.section-title span::before,
.section-title span::after,
.section-title .leaf-left,
.section-title .leaf-right,
.reservation-right img,
.access-heading span,
.access-heading span::before,
.access-heading span::after{
  display:none!important;
}
.section-title{
  gap:0!important;
}
.access-heading{
  gap:0!important;
}
.section-title h2,
.access-heading h2{
  position:relative;
  z-index:1;
}


/* ==== PC reservation/access text fit fix 2026-05-28 ==== */
@media (min-width:901px){
  .reservation{
    height:154px !important;
    padding-top:8px !important;
  }
  .reservation-box{
    height:144px !important;
    align-items:stretch !important;
    overflow:hidden !important;
  }
  .reservation-left{
    align-items:center !important;
    padding-left:32px !important;
  }
  .vintage-phone{
    width:92px !important;
    height:74px !important;
    margin-right:18px !important;
  }
  .vintage-phone img{
    width:78px !important;
    height:78px !important;
    object-fit:contain !important;
  }
  .reservation-main-text{
    transform:translateY(-2px) !important;
  }
  .reservation-main-text p{
    margin-bottom:5px !important;
    font-size:16px !important;
    line-height:1.05 !important;
  }
  .reservation-main-text h2{
    margin-bottom:7px !important;
    font-size:23px !important;
    line-height:1.05 !important;
  }
  .reservation-main-text a{
    font-size:30px !important;
    line-height:1 !important;
    letter-spacing:.035em !important;
  }
  .reservation-middle{
    justify-content:center !important;
    padding-left:22px !important;
  }
  .reservation-middle::before{
    top:18px !important;
    height:104px !important;
  }
  .reservation-middle p{
    margin-bottom:11px !important;
    font-size:14px !important;
    line-height:1.35 !important;
    letter-spacing:.045em !important;
  }
  .reservation-right{
    display:flex !important;
    align-items:center !important;
    padding:0 22px 0 28px !important;
    overflow:hidden !important;
  }
  .reservation-right p{
    margin:0 !important;
    font-size:13px !important;
    line-height:1.55 !important;
    letter-spacing:.035em !important;
  }

  .access{
    height:266px !important;
    padding-top:16px !important;
  }
  .access-card{
    height:240px !important;
    padding-top:36px !important;
    padding-bottom:20px !important;
  }
  .address-row{
    margin-bottom:17px !important;
  }
  .address-row img{
    width:34px !important;
    height:34px !important;
    margin-right:17px !important;
  }
  .address-row p{
    font-size:20px !important;
    line-height:1.35 !important;
    letter-spacing:.055em !important;
  }
  .info-grid{
    width:368px !important;
    gap:14px 20px !important;
  }
  .info-item img{
    width:28px !important;
    height:28px !important;
    margin-right:12px !important;
  }
  .info-item p{
    font-size:13px !important;
    line-height:1.35 !important;
    letter-spacing:.02em !important;
  }
  .map-card{
    height:184px !important;
  }
}


/* ==== PC ACCESS holiday one-line fit 2026-05-28 ==== */
@media (min-width:901px){
  .access-card{
    grid-template-columns:430px 1fr !important;
  }
  .access-info{
    padding-left:16px !important;
  }
  .info-grid{
    width:398px !important;
    grid-template-columns:1fr 1fr !important;
    gap:14px 12px !important;
  }
  .info-item{
    min-width:0 !important;
  }
  .info-item img{
    margin-right:10px !important;
  }
  .info-item p{
    min-width:0 !important;
  }
  .info-item:nth-child(3) p{
    font-size:12.6px !important;
    letter-spacing:0 !important;
    line-height:1.35 !important;
  }
  .info-item:nth-child(3) .access-date-nowrap{
    white-space:nowrap !important;
    display:inline-block !important;
  }
}
