@charset "utf-8";

/* =========================================================
   event.css - PC/SP unified
   対象HTML: #itemlist.eventPage
========================================================= */
#itemlist.eventPage,
#itemlist.eventPage * {
  box-sizing: border-box;
}

#itemlist.eventPage {
  --ev-brown: #745536;
  --ev-gold: #c5a437;
  --ev-orange: #f5823a;
  --ev-cream: #fff8ea;
  --ev-light: #fffdf8;
  --ev-text: #333;
  --ev-muted: #666;
  --ev-border: #eadfca;
  --ev-shadow: 0 12px 30px rgba(74, 52, 31, 0.12);
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px 70px;
  color: var(--ev-text);
  font-size: 16px;
  line-height: 1.8;
}

#itemlist.eventPage img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

#itemlist.eventPage a {
  color: inherit;
  transition: opacity 0.2s ease, transform 0.2s ease, background 0.2s ease;
}

#itemlist.eventPage a:hover {
  opacity: 0.86;
}

#itemlist.eventPage .breadcrumb ul {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 22px;
  padding: 0;
  list-style: none;
  font-size: 13px;
}

/* hero */
#itemlist.eventPage .ev-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 34px;
  align-items: stretch;
  margin: 0 0 24px;
  padding: 46px;
  border-radius: 24px;
  background:
    radial-gradient(circle at 10% 0%, rgba(197,164,55,0.22), transparent 32%),
    linear-gradient(135deg, #fffaf0 0%, #fff 48%, #f7efe3 100%);
  box-shadow: var(--ev-shadow);
  border: 1px solid var(--ev-border);
}

#itemlist.eventPage .ev-label,
#itemlist.eventPage .ev-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 10px;
  color: var(--ev-orange);
  font-weight: 700;
  letter-spacing: 0.08em;
  font-size: 13px;
}

#itemlist.eventPage .ev-label::before,
#itemlist.eventPage .ev-kicker::before {
  content: "";
  width: 28px;
  height: 2px;
  background: var(--ev-orange);
}

#itemlist.eventPage h1,
#itemlist.eventPage h2,
#itemlist.eventPage h3,
#itemlist.eventPage p {
  margin-top: 0;
}

#itemlist.eventPage h1 {
  margin: 0 0 18px;
  color: var(--ev-brown);
  font-size: 38px;
  line-height: 1.35;
  letter-spacing: 0.02em;
}

#itemlist.eventPage .ev-hero__lead,
#itemlist.eventPage .ev-section__lead {
  color: var(--ev-muted);
  line-height: 1.9;
}

#itemlist.eventPage .ev-hero__lead {
  margin: 0 0 24px;
  font-size: 17px;
}

#itemlist.eventPage .ev-hero__cta,
#itemlist.eventPage .ev-ctaBlock div,
#itemlist.eventPage .ev-contact__btns {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

#itemlist.eventPage .ev-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 12px 24px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 700;
  line-height: 1.4;
}

#itemlist.eventPage .ev-btn--primary {
  color: #fff !important;
  background: var(--ev-orange);
  box-shadow: 0 8px 18px rgba(245,130,58,0.25);
}

#itemlist.eventPage .ev-btn--line {
  color: var(--ev-brown) !important;
  background: #fff;
  border: 1px solid var(--ev-gold);
}

#itemlist.eventPage .ev-hero__points {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 22px 0 0;
  padding: 0;
  list-style: none;
}

#itemlist.eventPage .ev-hero__points li {
  padding: 6px 12px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--ev-border);
  color: var(--ev-brown);
  font-weight: 700;
  font-size: 13px;
}

#itemlist.eventPage .ev-hero__side {
  padding: 26px;
  border-radius: 20px;
  background: var(--ev-brown);
  color: #fff;
}

#itemlist.eventPage .ev-hero__sideTitle {
  margin: 0 0 14px;
  color: #fff;
  font-weight: 700;
  font-size: 18px;
}

#itemlist.eventPage .ev-hero__side ol {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

#itemlist.eventPage .ev-hero__side li {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px;
  border-radius: 12px;
  background: rgba(255,255,255,0.12);
  font-weight: 700;
}

#itemlist.eventPage .ev-hero__side span {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--ev-gold);
  color: #fff;
  flex: 0 0 auto;
}

/* anchor */
#itemlist.eventPage .ev-anchor {
  position: sticky;
  top: 0;
  z-index: 5;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin: 0 0 46px;
  padding: 14px;
  border: 1px solid var(--ev-border);
  border-radius: 18px;
  background: rgba(255,255,255,0.94);
  backdrop-filter: blur(6px);
}

#itemlist.eventPage .ev-anchor a {
  min-width: 118px;
  padding: 9px 12px;
  border-radius: 999px;
  text-align: center;
  text-decoration: none;
  color: var(--ev-brown) !important;
  background: var(--ev-cream);
  border: 1px solid var(--ev-border);
  font-weight: 700;
  font-size: 14px;
}

/* sections */
#itemlist.eventPage .ev-section {
  margin: 0 0 58px;
  padding: 42px;
  border-radius: 22px;
  background: #fff;
  border: 1px solid var(--ev-border);
}

#itemlist.eventPage .ev-section--cream,
#itemlist.eventPage .ev-speed {
  background: var(--ev-cream);
}

#itemlist.eventPage .ev-section h2 {
  margin: 0 0 16px;
  padding: 0 0 0 18px;
  border-left: 6px solid var(--ev-orange);
  color: var(--ev-brown);
  font-size: 30px;
  line-height: 1.45;
}

#itemlist.eventPage .ev-section__lead {
  margin: 0 0 26px;
}

#itemlist.eventPage .ev-sceneGrid,
#itemlist.eventPage .ev-choiceGrid,
#itemlist.eventPage .ev-serviceGrid,
#itemlist.eventPage .ev-reviewGrid {
  display: grid;
  gap: 18px;
}

#itemlist.eventPage .ev-sceneGrid,
#itemlist.eventPage .ev-choiceGrid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

#itemlist.eventPage .ev-sceneCard,
#itemlist.eventPage .ev-choiceCard,
#itemlist.eventPage .ev-reviewGrid article {
  display: block;
  padding: 24px;
  border-radius: 18px;
  background: var(--ev-light);
  border: 1px solid var(--ev-border);
  text-decoration: none;
}

#itemlist.eventPage .ev-sceneCard span,
#itemlist.eventPage .ev-choiceCard b,
#itemlist.eventPage .ev-reviewGrid h3 {
  display: block;
  margin: 0 0 10px;
  color: var(--ev-brown);
  font-size: 19px;
  font-weight: 700;
}

#itemlist.eventPage .ev-sceneCard p,
#itemlist.eventPage .ev-choiceCard p,
#itemlist.eventPage .ev-reviewGrid p {
  margin: 0;
  color: var(--ev-muted);
}

#itemlist.eventPage .ev-choiceCard a,
#itemlist.eventPage .ev-serviceCard a {
  display: inline-block;
  margin-top: 14px;
  color: var(--ev-orange) !important;
  font-weight: 700;
}

/* category */
#itemlist.eventPage .ev-categoryGrid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

#itemlist.eventPage .ev-categoryGrid a {
  overflow: hidden;
  display: block;
  border-radius: 18px;
  background: #fff;
  border: 1px solid var(--ev-border);
  text-decoration: none;
  box-shadow: 0 8px 18px rgba(74,52,31,0.08);
}

#itemlist.eventPage .ev-categoryGrid img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}

#itemlist.eventPage .ev-categoryGrid span {
  display: block;
  padding: 12px 14px;
  color: var(--ev-brown);
  font-weight: 700;
  text-align: center;
}

#itemlist.eventPage .ev-center {
  margin-top: 28px;
  text-align: center;
}

/* chips */
#itemlist.eventPage .ev-chipGrid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

#itemlist.eventPage .ev-chipGrid a {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 10px 12px;
  border-radius: 14px;
  text-decoration: none;
  color: var(--ev-brown) !important;
  background: #fff;
  border: 1px solid var(--ev-gold);
  font-weight: 700;
}

#itemlist.eventPage .ev-chipGrid a::after {
  content: "›";
  margin-left: 8px;
  color: var(--ev-orange);
  font-size: 20px;
  line-height: 1;
}

#itemlist.eventPage .ev-speed {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  gap: 30px;
  align-items: center;
}

#itemlist.eventPage .ev-chipGrid--compact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* service */
#itemlist.eventPage .ev-serviceGrid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

#itemlist.eventPage .ev-serviceCard {
  display: grid;
  grid-template-columns: 170px minmax(0, 1fr);
  gap: 18px;
  padding: 18px;
  border-radius: 18px;
  background: var(--ev-light);
  border: 1px solid var(--ev-border);
}

#itemlist.eventPage .ev-serviceCard img {
  width: 100%;
  height: 130px;
  object-fit: cover;
  border-radius: 14px;
}

#itemlist.eventPage .ev-serviceCard h3 {
  margin: 0 0 8px;
  color: var(--ev-brown);
  font-size: 20px;
}

#itemlist.eventPage .ev-serviceCard p {
  margin: 0;
  color: var(--ev-muted);
}

/* cta/review/contact */
#itemlist.eventPage .ev-ctaBlock,
#itemlist.eventPage .ev-contact {
  margin: 0 0 58px;
  padding: 34px;
  border-radius: 22px;
  color: #fff;
  background: linear-gradient(135deg, var(--ev-brown), #4b3321);
}

#itemlist.eventPage .ev-ctaBlock {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

#itemlist.eventPage .ev-ctaBlock p,
#itemlist.eventPage .ev-contact p {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
}

#itemlist.eventPage .ev-reviewGrid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

#itemlist.eventPage .ev-contact {
  text-align: center;
}

#itemlist.eventPage .ev-contact p {
  margin-bottom: 18px;
}

#itemlist.eventPage .ev-contact__btns {
  justify-content: center;
}

#itemlist.eventPage .ev-contact__btns a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 220px;
  min-height: 50px;
  padding: 12px 20px;
  border-radius: 999px;
  background: #fff;
  color: var(--ev-brown) !important;
  text-decoration: none;
  font-weight: 700;
}

@media screen and (max-width: 767px) {
  #itemlist.eventPage {
    width: 100%;
    padding: 0 4vw 12vw;
    font-size: 3.8vw;
  }

  #itemlist.eventPage .breadcrumb ul {
    margin-bottom: 4vw;
    font-size: 3vw;
  }

  #itemlist.eventPage .ev-hero {
    display: block;
    margin-bottom: 5vw;
    padding: 7vw 5vw;
    border-radius: 5vw;
  }

  #itemlist.eventPage h1 {
    font-size: 7.2vw;
  }

  #itemlist.eventPage .ev-hero__lead {
    font-size: 4vw;
  }

  #itemlist.eventPage .ev-hero__cta,
  #itemlist.eventPage .ev-ctaBlock div,
  #itemlist.eventPage .ev-contact__btns {
    display: grid;
    gap: 3vw;
  }

  #itemlist.eventPage .ev-btn,
  #itemlist.eventPage .ev-contact__btns a {
    width: 100%;
    min-height: 12vw;
    padding: 3vw 4vw;
  }

  #itemlist.eventPage .ev-hero__points {
    gap: 2vw;
  }

  #itemlist.eventPage .ev-hero__points li {
    font-size: 3.2vw;
    padding: 1.5vw 2.5vw;
  }

  #itemlist.eventPage .ev-hero__side {
    margin-top: 6vw;
    padding: 5vw;
    border-radius: 4vw;
  }

  #itemlist.eventPage .ev-anchor {
    position: static;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 2.2vw;
    margin-bottom: 8vw;
    padding: 3vw;
    border-radius: 4vw;
  }

  #itemlist.eventPage .ev-anchor a {
    min-width: 0;
    padding: 2.5vw 1vw;
    font-size: 3.4vw;
  }

  #itemlist.eventPage .ev-section,
  #itemlist.eventPage .ev-ctaBlock,
  #itemlist.eventPage .ev-contact {
    margin-bottom: 8vw;
    padding: 6vw 4vw;
    border-radius: 5vw;
  }

  #itemlist.eventPage .ev-section h2 {
    padding-left: 3vw;
    border-left-width: 1.2vw;
    font-size: 6vw;
  }

  #itemlist.eventPage .ev-sceneGrid,
  #itemlist.eventPage .ev-choiceGrid,
  #itemlist.eventPage .ev-categoryGrid,
  #itemlist.eventPage .ev-chipGrid,
  #itemlist.eventPage .ev-speed,
  #itemlist.eventPage .ev-serviceGrid,
  #itemlist.eventPage .ev-reviewGrid,
  #itemlist.eventPage .ev-chipGrid--compact {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3vw;
  }

  #itemlist.eventPage .ev-categoryGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #itemlist.eventPage .ev-categoryGrid span {
    padding: 2.5vw 1.5vw;
    font-size: 3.4vw;
  }

  #itemlist.eventPage .ev-chipGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #itemlist.eventPage .ev-chipGrid a {
    min-height: 12vw;
    padding: 2vw;
    font-size: 3.6vw;
  }

  #itemlist.eventPage .ev-serviceCard {
    grid-template-columns: 30vw minmax(0, 1fr);
    gap: 3vw;
    padding: 3vw;
  }

  #itemlist.eventPage .ev-serviceCard img {
    height: 24vw;
    border-radius: 3vw;
  }

  #itemlist.eventPage .ev-serviceCard h3 {
    font-size: 4.4vw;
  }

  #itemlist.eventPage .ev-ctaBlock {
    display: block;
  }

  #itemlist.eventPage .ev-ctaBlock p,
  #itemlist.eventPage .ev-contact p {
    margin-bottom: 4vw;
    font-size: 4.5vw;
  }
}
