@charset "UTF-8";
/* =========================================================
   Marin Festa in Otaru 2026 — Marine Wave design system
   Aesthetic: fresh, airy, aquatic. Sky gradients, white
   organic waves, rounded type, circular photos.
   Built on Bootstrap 5.3.
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  --sky-top:#6ec1e8;
  --sky-mid:#a4d9f4;
  --sky-soft:#dff2fc;
  --sky-pale:#eef9fe;
  --marine:#0e86c9;
  --marine-deep:#0a5f93;
  --navy:#123a5e;
  --ink:#163b52;
  --ink-soft:#4d6f84;
  --accent:#ffd23f;       /* poster date-band yellow */
  --accent-deep:#f5a623;
  --teal:#16a3b6;
  --line:#d7ebf6;
  --white-warm:#f8fcfe;

  --ff-jp:"Zen Maru Gothic","Noto Sans JP",system-ui,sans-serif;
  --ff-body:"Noto Sans JP",system-ui,sans-serif;
  --ff-en:"Poppins",sans-serif;
  --ff-script:"Yellowtail",cursive;

  --radius:22px;
  --shadow-soft:0 18px 40px -18px rgba(14,110,170,.35);
  --shadow-card:0 10px 30px -12px rgba(16,80,130,.28);
}

*{ -webkit-font-smoothing:antialiased; }

body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--white-warm);
  line-height:1.85;
  letter-spacing:.01em;
  overflow-x:hidden;
}

h1,h2,h3,h4,.heading{ font-family:var(--ff-jp); font-weight:700; line-height:1.4; }

a{ color:var(--marine-deep); text-decoration:none; transition:.2s; }
a:hover{ color:var(--marine); }

.en{ font-family:var(--ff-en); letter-spacing:.02em; }
.script{ font-family:var(--ff-script); }

/* ---------- Decorative helpers ---------- */
.dotgrid{
  background-image:radial-gradient(var(--sky-mid) 1.6px, transparent 1.7px);
  background-size:16px 16px;
}
.text-marine{ color:var(--marine)!important; }
.text-navy{ color:var(--navy)!important; }
.text-accent{ color:var(--accent-deep)!important; }
.bg-sky-pale{ background:var(--sky-pale)!important; }

/* section eyebrow: script EN over JP heading */
.eyebrow{
  font-family:var(--ff-script);
  font-size:clamp(1.6rem,3.4vw,2.5rem);
  color:var(--sky-top);
  line-height:1;
  margin-bottom:.1em;
}
.sec-title{
  font-size:clamp(1.6rem,4.2vw,2.6rem);
  font-weight:700;
  color:var(--navy);
  letter-spacing:.04em;
}
.sec-title .accent-bar{ color:var(--marine); }

/* wave divider (organic) */
.wave-top,.wave-bottom{ display:block; width:100%; line-height:0; }
.wave-bottom svg,.wave-top svg{ display:block; width:100%; height:auto; }

/* ===================================================== */
/* Header / Nav                                          */
/* ===================================================== */
.site-header{
  position:sticky; top:0; z-index:1030;
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header .navbar-brand img{ height:38px; width:auto; }
.site-nav .nav-link{
  font-family:var(--ff-jp);
  font-weight:700;
  color:var(--navy);
  font-size:.95rem;
  padding:.4rem .9rem!important;
  position:relative;
}
.site-nav .nav-link .en-sub{
  display:block; font-family:var(--ff-en); font-weight:600;
  font-size:.6rem; letter-spacing:.12em; color:var(--sky-top);
  text-transform:uppercase; line-height:1;
}
.site-nav .nav-link:hover,.site-nav .nav-link.active{ color:var(--marine); }
.site-nav .nav-link.active::after{
  content:""; position:absolute; left:.9rem; right:.9rem; bottom:0;
  height:3px; border-radius:3px; background:var(--accent);
}
.header-cta{
  background:var(--marine); color:#fff!important; border-radius:999px;
  font-family:var(--ff-jp); font-weight:700; padding:.5rem 1.3rem!important;
  box-shadow:0 8px 18px -8px rgba(14,134,201,.8);
}
.header-cta:hover{ background:var(--marine-deep); color:#fff!important; }
.navbar-toggler{ border-color:var(--line); }

/* ===================================================== */
/* Hero                                                  */
/* ===================================================== */
.kojibox {
font-family:var(--ff-jp);
font-weight:700;
font-size:1.15rem;
margin-bottom:1.5rem;
background:#fff; border-radius:20px; padding:2rem; box-shadow:var(--shadow-card); border:2px solid #fff;
}
.hero{
  position:relative;
  background:url("assets/main.webp") center center/cover no-repeat, var(--sky-soft);
  min-height:clamp(560px,86vh,860px);
  display:flex; align-items:center; justify-content:center;
  padding:2rem 0;
  overflow:hidden;
}
.hero-inner{ position:relative; z-index:2; width:100%; }
.hero .wave-bottom{
  position:absolute; left:0; right:0; bottom:-1px; z-index:3;
  pointer-events:none;
}

.hero-logo-img{
    background: url("assets/hero-logo.png") center/contain no-repeat;
    margin-top: -100px;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 0rem;
    width: 80vw;
    max-width: 1600px;
    height: clamp(280px,80vw,560px);
    animation: fadeInScale .8s ease-out;
}
@keyframes fadeInScale{
  from{ opacity:0; transform:scale(.85); }
  to{ opacity:1; transform:scale(1); }
}

/* centered info card */
.hero-card-center{
  max-width:520px;
  background:rgba(255,255,255,.86);
  -webkit-backdrop-filter:blur(10px); backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.95);
  border-radius:24px;
  box-shadow:0 28px 60px -28px rgba(11,70,110,.6);
  padding:1.5rem 1.8rem;
}
.hero-date{
  display:inline-block; background:var(--marine);
  color:#fff; font-family:var(--ff-jp); font-weight:700;
  font-size:clamp(1.15rem,3.4vw,1.9rem);
  padding:.35rem 1.2rem; border-radius:14px;
  box-shadow:0 10px 22px -10px rgba(11,95,147,.7);
}
.hero-date b{ color:var(--accent); }
.hero-meta{
    align-items: center;
    font-family: var(--ff-jp);
    font-weight: 700;
    color: var(--navy);
    font-size: 2.1em;
}
.hero-chip{
  background:rgba(255,255,255,.9); border-radius:999px;
  padding:.3rem 1rem; box-shadow:var(--shadow-card); white-space:nowrap; text-align: center;
}
.hero-chip .lbl{ color:var(--marine); font-size:1.2rem; margin-right:.35rem; text-align: center;}
.hero-free{
  background:var(--accent); color:var(--navy);
  border-radius:999px; padding:.3rem 1.1rem;
  box-shadow:0 8px 18px -8px rgba(245,166,35,.7);
}

/* poster card floating in hero */
.hero-poster{
  border-radius:20px; overflow:hidden;
  box-shadow:0 30px 60px -20px rgba(11,70,110,.6);
  transform:rotate(2.5deg);
  border:6px solid #fff;
  max-width:330px; width:100%;
}
.hero-poster img{ display:block; width:100%; height:auto; }

/* bunting */
.bunting{ display:flex; height:26px; overflow:hidden; }
.bunting i{ flex:1; height:0; border-left:14px solid transparent;
  border-right:14px solid transparent; border-top:22px solid; }
.bunting i:nth-child(5n+1){ border-top-color:#ff8fa3; }
.bunting i:nth-child(5n+2){ border-top-color:var(--accent); }
.bunting i:nth-child(5n+3){ border-top-color:var(--sky-top); }
.bunting i:nth-child(5n+4){ border-top-color:#8fd6b3; }
.bunting i:nth-child(5n+5){ border-top-color:#c6a8e6; }

/* ===================================================== */
/* News                                                  */
/* ===================================================== */
.news-list{ list-style:none; margin:0; padding:0; }
.news-list li{
  display:flex; flex-wrap:wrap; align-items:center; gap:.4rem 1rem;
  padding:1rem .4rem; border-bottom:1px dashed var(--line);
}
.news-date{ font-family:var(--ff-en); font-weight:600; color:var(--ink-soft); min-width:7.5em; }
.news-tag{
  font-family:var(--ff-jp); font-weight:700; font-size:.72rem;
  color:#fff; background:var(--marine); border-radius:999px;
  padding:.12rem .8rem;
}
.news-tag.info{ background:var(--teal); }
.news-tag.event{ background:var(--accent-deep); }
.news-body{ flex:1 1 240px; font-weight:500; }

/* ===================================================== */
/* Pillars (circular photos)                             */
/* ===================================================== */
.pillar{ text-align:center; }
.pillar-photo{
  position:relative; width:170px; height:170px; margin:0 auto 1rem;
  border-radius:50%; overflow:hidden;
  border:5px solid #fff; box-shadow:var(--shadow-card);
}
.pillar-num{
  position:absolute; top:-6px; left:-6px;
  width:42px; height:42px; border-radius:50%;
  background:var(--accent); color:var(--navy);
  font-family:var(--ff-en); font-weight:700;
  display:grid; place-items:center; z-index:2;
  box-shadow:0 6px 12px -4px rgba(245,166,35,.7);
}
.pillar h4{ color:var(--navy); font-size:1.12rem; }
.pillar p{ font-size:.92rem; color:var(--ink-soft); }

/* ===================================================== */
/* Image placeholder (striped)                           */
/* ===================================================== */
.ph{
  background:
    repeating-linear-gradient(135deg,#e7f3fb 0 12px,#daeefa 12px 24px);
  color:var(--marine-deep);
  display:grid; place-items:center; text-align:center;
  font-family:"Poppins",monospace; font-size:.72rem; letter-spacing:.08em;
  text-transform:uppercase; font-weight:600;
}
.ph span{ background:rgba(255,255,255,.7); padding:.2rem .6rem; border-radius:6px; }

/* ===================================================== */
/* Cards / overview                                      */
/* ===================================================== */
.soft-card{
  background:#fff; border-radius:var(--radius);
  box-shadow:var(--shadow-card); border:1px solid var(--line);
}
.exh-table{ margin:0 0 2rem; }
.info-table{ width:100%; border-collapse:separate; border-spacing:0; }
.info-table thead th{
  font-family:var(--ff-jp); color:#fff; font-weight:700;
  white-space:nowrap; vertical-align:top; padding:1rem 1.2rem;
  background:linear-gradient(90deg,var(--marine) 0%,var(--marine-deep) 100%);
  border-top:1px solid var(--line);
}
.info-table thead th:first-child{ border-radius:12px 0 0 0; }
.info-table thead th:last-child{ border-radius:0 12px 0 0; }
.info-table tbody td{
  padding:1rem 1.2rem; border-bottom:1px solid var(--line);
  font-weight:500; vertical-align:top;
}
.info-table tbody tr{
  background:#fff; transition:.2s;
}
.info-table tbody tr:hover{
  background:var(--sky-pale); box-shadow:0 4px 12px -6px rgba(14,110,170,.25);
}
.info-table tbody tr:last-child td{ border-bottom:0; }
.info-table tbody tr:last-child td:first-child{ border-radius:0 0 0 12px; }
.info-table tbody tr:last-child td:last-child{ border-radius:0 0 12px 0; }
.info-table td:first-child{
  color:var(--navy); font-weight:700; font-family:var(--ff-jp); width:26%;
}
.info-table td:last-child{
  color:var(--ink-soft); font-size:.92rem; line-height:1.6;
}

/* ===================================================== */
/* Section / tag chips                                   */
/* ===================================================== */
.chip{
  display:inline-block; background:var(--sky-pale); color:var(--marine-deep);
  border:1px solid var(--line); border-radius:999px;
  padding:.4rem 1rem; font-weight:600; font-size:.92rem; margin:.2rem;
}

/* ===================================================== */
/* Event guide table                                     */
/* ===================================================== */
.guide-table{ width:100%; border-collapse:separate; border-spacing:0 12px; }
.guide-table thead th{
  font-family:var(--ff-jp); font-weight:700; color:#fff;
  background:var(--marine); padding:.9rem 1.1rem; font-size:.92rem;
  text-align:left;
}
.guide-table thead th:first-child{ border-radius:12px 0 0 12px; }
.guide-table thead th:last-child{ border-radius:0 12px 12px 0; }
.guide-table tbody tr{ box-shadow:var(--shadow-card); }
.guide-table tbody td{
  background:#fff; padding:1rem 1.1rem; vertical-align:top;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.guide-table tbody td:first-child{ border-left:1px solid var(--line); border-radius:14px 0 0 14px; }
.guide-table tbody td:last-child{ border-right:1px solid var(--line); border-radius:0 14px 14px 0; }

/* Event schedule table */
.event-table{
  width:100%; border-collapse:collapse; font-size:.9rem;
  border:1px solid var(--line); border-radius:16px; overflow:hidden;
  box-shadow:var(--shadow-card);
}
.event-table thead{
  background:var(--marine); color:#fff; font-family:var(--ff-jp); font-weight:700;
}
.event-table thead th{
  padding:.85rem 1rem; text-align:left; font-size:.9rem; font-weight:700;
  border-right:1px solid rgba(255,255,255,.2);
}
.event-table thead th:last-child{ border-right:0; }
.event-table tbody td{
  padding:.9rem 1rem; border-bottom:1px solid var(--line);
  border-right:1px solid var(--line); vertical-align:top;
}
.event-table tbody td:last-child{ border-right:0; }
.event-table tbody tr:last-child td{ border-bottom:0; }
.event-table tbody tr.event-row-both td:first-child{ background:var(--marine); color:#fff; font-weight:700; }
.event-table tbody tr.event-row-11 td:first-child{ background:var(--accent-deep); color:#fff; font-weight:700; }
.event-table tbody tr.event-row-12 td:first-child{ background:var(--teal); color:#fff; font-weight:700; }
.event-table tbody td:nth-child(2){ background:var(--sky-pale); font-weight:600; color:var(--navy); }
.event-table tbody b{ color:var(--navy); }
.venue-pill{
  display:inline-block; background:var(--navy); color:#fff;
  font-family:var(--ff-jp); font-weight:700; font-size:.85rem;
  border-radius:999px; padding:.25rem .9rem;
}
.date-pill{
  display:inline-block; background:var(--accent); color:var(--navy);
  font-family:var(--ff-jp); font-weight:700; font-size:.85rem;
  border-radius:999px; padding:.25rem .9rem; white-space:nowrap;
}
.ev-org{margin:.35rem 0 0;font-size:.72rem;line-height:1.5;color:#6b7a86;}
.note-strip .ev-org,.show-body .ev-org,.finale-text .ev-org{color:rgba(255,255,255,.85);}
.note-strip .ev-org::before,.show-body .ev-org::before,.finale-text .ev-org::before{color:rgba(255,255,255,.65);}
/* ===================================================== */
/* Exhibitor grid                                        */
/* ===================================================== */
.exh-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:14px; }
.exh-item{
  display:flex; align-items:center; gap:.7rem;
  background:#fff; border:1px solid var(--line); border-radius:16px;
  padding:.95rem 1.1rem; box-shadow:var(--shadow-card);
  font-family:var(--ff-jp); font-weight:700; color:var(--navy);
  transition:.2s; min-height:64px;
}
.exh-item:hover{ transform:translateY(-3px); border-color:var(--sky-top); }
.exh-item .anchor{
  width:34px; height:34px; flex:none; border-radius:9px;
  background:var(--sky-pale); color:var(--marine);
  display:grid; place-items:center; font-family:var(--ff-en); font-weight:700;
}

/* ===================================================== */
/* Prep / coming soon                                    */
/* ===================================================== */
.prep{
  text-align:center; padding:4rem 1.5rem;
  background:#fff; border-radius:var(--radius);
  border:2px dashed var(--sky-mid); box-shadow:var(--shadow-card);
}
.prep .badge-prep{
  display:inline-block; background:var(--accent); color:var(--navy);
  font-family:var(--ff-jp); font-weight:700; border-radius:999px;
  padding:.4rem 1.4rem; margin-bottom:1.2rem;
}
.prep-icon{ font-size:3.4rem; line-height:1; }

/* ===================================================== */
/* CTA band                                              */
/* ===================================================== */
.cta-band{
  background:linear-gradient(120deg,var(--marine),var(--marine-deep));
  color:#fff; border-radius:28px; position:relative; overflow:hidden;
}
.cta-band::after{
  content:""; position:absolute; right:-60px; bottom:-80px;
  width:280px; height:280px; border-radius:50%;
  background:rgba(255,255,255,.08);
}
.btn-festa{
  background:var(--accent); color:var(--navy)!important;
  font-family:var(--ff-jp); font-weight:700;
  border-radius:999px; padding:.8rem 2.1rem; border:0;
  box-shadow:0 12px 24px -10px rgba(0,0,0,.4);
}
.btn-festa:hover{ filter:brightness(1.05); transform:translateY(-2px); }
.btn-outline-festa{
  background:transparent; color:#fff!important; border:2px solid rgba(255,255,255,.7);
  font-family:var(--ff-jp); font-weight:700; border-radius:999px; padding:.75rem 2rem;
}
.btn-outline-festa:hover{ background:#fff; color:var(--marine-deep)!important; }

/* ===================================================== */
/* Footer                                                */
/* ===================================================== */
.site-footer{ background:var(--navy); color:#cfe3f0; }
.site-footer a{ color:#cfe3f0; }
.site-footer a:hover{ color:#fff; }
.footer-logo{ background:#fff; border-radius:14px; padding:.7rem 1rem; display:inline-block; }
.footer-logo img{ height:40px; width:auto; }
.footer-hours{ font-size:.92rem; color:#9fc1d6; }
.sns-row{ display:flex; gap:.6rem; }
.sns-row a{
  width:42px; height:42px; border-radius:50%;
  background:rgba(255,255,255,.12); display:grid; place-items:center;
  color:#fff; font-size:1.1rem; transition:.2s;
}
.sns-row a:hover{ background:var(--marine); transform:translateY(-2px); }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.12); font-size:.85rem; color:#8fb2c8; }

/* page hero (sub pages) */
.page-hero{
  background:linear-gradient(180deg,var(--sky-top),var(--sky-soft));
  position:relative; padding:3rem 0 0; overflow:hidden; text-align:center;
}
.page-hero h1{ color:#fff; font-size:clamp(2rem,6vw,3.2rem); text-shadow:0 4px 0 rgba(11,95,147,.25); }
.page-hero .eyebrow{ color:#fff; opacity:.95; }
.breadcrumb-festa{ font-size:.85rem; color:var(--ink-soft); }
.breadcrumb-festa a{ color:var(--marine-deep); }

/* utilities */
.section{ padding:4.5rem 0; }
.section-tight{ padding:3rem 0; }
.maxw-narrow{ max-width:820px; }

/* ---------- Responsive ---------- */
@media (max-width:991.98px){
  .hero{ align-items:flex-end; }
  .hero-card{ max-width:100%; margin:0 auto; }
  .hero-meta{ justify-content:flex-start; }
}
@media (max-width:575.98px){
  .section{ padding:3.2rem 0; }
  .pillar-photo{ width:140px; height:140px; }
  .info-table th{ width:6.5em; padding:.7rem .8rem; }
  .info-table td{ padding:.7rem .8rem; }
}


/* =====================================================
   top page (index.html) — flyer layout
   ===================================================== */
.info-kaijo {
    background-color: #d98c2e;
    width: 100%;
    text-align: left;
    padding-left: 10px;
    color: #FFFFFF;
	margin-bottom: 10px;
}
.info-kaijo2 {
    background-color: #65A4DC;
    width: 100%;
    text-align: left;
	padding-left: 10px;
    color: #FFFFFF;
	margin-bottom: 10px;
}
.info-kaijo3 {
    background-color: #7e6daa;
    width: 100%;
    text-align: left;
	padding-left: 10px;
    color: #FFFFFF;
	margin-bottom: 10px;
}
.info-kaijo4 {
    background-color: #cf6d8b;
    width: 100%;
    text-align: left;
	padding-left: 10px;
    color: #FFFFFF;
	margin-bottom: 10px;
}
.info-kaijo-t {
    background-color: #9bb837;
    width: 100%;
    text-align: left;
    padding-left: 10px;
    color: #FFFFFF;
    margin-bottom: 10px;
}
/* =========================================================
   Event guide — flyer-style layout (matches printed PDF)
   ========================================================= */

.flyer{ display:flex; flex-direction:column; gap:1.8rem; }

/* ---- one day group : navy date tab + body ---- */
.flyer-day{
  display:grid; grid-template-columns:68px 1fr;
  border-radius:14px; overflow:hidden;
  background:#fff;
  box-shadow:0 14px 36px -20px rgba(16,80,130,.45);
  border:1px solid #e7eef4;
}

/* navy vertical date tab */
.day-tab{
  background:linear-gradient(180deg,#15598a 0%,#0b3b5d 100%);
  color:#fff; font-family:var(--ff-jp);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:.05rem; padding:1.4rem .25rem; text-align:center;
}
.day-tab b{
  font-family:var(--ff-en); font-weight:800; font-size:1.7rem;
  line-height:.95; display:block;
}
.day-tab em{ font-style:normal; font-size:.62rem; font-weight:700; display:block; margin-bottom:.35rem; }
.day-tab .day-dot{ font-size:1rem; line-height:.5; margin:.1rem 0 .25rem; }
.day-tab .day-chip{
  margin-top:.55rem; background:rgba(255,255,255,.22);
  border-radius:6px; padding:.45rem .25rem; font-size:.72rem; font-weight:700;
  writing-mode:vertical-rl; letter-spacing:.18em;
}
.day-tab2{
  background:linear-gradient(180deg,#62aca8 0%,#62aca8 100%);
  color:#fff; font-family:var(--ff-jp);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:.05rem; padding:1.4rem .25rem; text-align:center;
}
.day-tab2 b{
  font-family:var(--ff-en); font-weight:800; font-size:1.7rem;
  line-height:.95; display:block;
}
.day-tab2 em{ font-style:normal; font-size:.62rem; font-weight:700; display:block; margin-bottom:.35rem; }
.day-tab2 .day-dot{ font-size:1rem; line-height:.5; margin:.1rem 0 .25rem; }
.day-tab2 .day-chip{
  margin-top:.55rem; background:rgba(255,255,255,.22);
  border-radius:6px; padding:.45rem .25rem; font-size:.72rem; font-weight:700;
  writing-mode:vertical-rl; letter-spacing:.18em;
}

/* body holds the venue blocks */
.flyer-body{ padding:1rem 1.1rem 1.2rem; display:flex; flex-direction:column; gap:1rem; }

/* ---- venue block ---- */
.venue{ border-radius:10px; overflow:hidden; border:1px solid #eaf0f5; }
.venue-bar{
  display:flex; align-items:center; gap:.55rem;
  color:#fff;
  font-family:var(--ff-jp); font-weight:700; font-size:1.2rem;
  background:#9d9e9e;
}
.kaijo {
    background-color: #d98c2e;
    width: 20%;
    text-align: center;
}
.kaijo2 {
    background-color: #65A4DC;
    width: 20%;
    text-align: center;
}
.kaijo3 {
    background-color: #7e6daa;
    width: 20%;
    text-align: center;
}
.kaijo4 {
    background-color: #cf6d8b;
    width: 20%;

    text-align: center;
}
.kaijo-t {
    background-color: #9bb837;
    width: 20%;
    text-align: center;
}
.venue-no{
    flex: none;
    background: #fff;
    color: #d98c2e;
    place-items: center;
    font-family: var(--ff-en);
    font-weight: 600;
    font-size: 1.3rem;
    padding-top: 0px;
    padding-right: 5px;
    padding-bottom: 0px;
    padding-left: 5px;
    margin-top: 3px;
    margin-right: 3px;
    margin-bottom: 3px;
    margin-left: 3px;
	border-radius: 4px;
}
.venue-no2{
    flex: none;
    background: #fff;
    color: #65A4DC;
    place-items: center;
    font-family: var(--ff-en);
    font-weight: 600;
    font-size: 1.3rem;
    padding-top: 0px;
    padding-right: 5px;
    padding-bottom: 0px;
    padding-left: 5px;
    margin-top: 3px;
    margin-right: 3px;
    margin-bottom: 3px;
    margin-left: 3px;
	border-radius: 4px;
}
.venue-no3{
    flex: none;
    background: #fff;
    color: #7e6daa;
    place-items: center;
    font-family: var(--ff-en);
    font-weight: 600;
    font-size: 1.3rem;
    padding-top: 0px;
    padding-right: 5px;
    padding-bottom: 0px;
    padding-left: 5px;
    margin-top: 3px;
    margin-right: 3px;
    margin-bottom: 3px;
    margin-left: 3px;
	border-radius: 4px;
}
.venue-no4{
    flex: none;
    background: #fff;
    color: #cf6d8b;
    place-items: center;
    font-family: var(--ff-en);
    font-weight: 600;
    font-size: 1.3rem;
    padding-top: 0px;
    padding-right: 5px;
    padding-bottom: 0px;
    padding-left: 5px;
    margin-top: 3px;
    margin-right: 3px;
    margin-bottom: 3px;
    margin-left: 3px;
	border-radius: 4px;
}
.venue-name small{ font-weight:500; font-size:.82em; opacity:.92; }
/* venue colour themes (from the PDF) */
.venue--v1{ --vc:linear-gradient(90deg,#ea972f,#d97c1c); }
.venue--v2{ --vc:linear-gradient(90deg,#2f86bf,#226d9d); }
.venue--v3{ --vc:linear-gradient(90deg,#74748f,#565574); }
.venue--v4{ --vc:linear-gradient(90deg,#6f95a4,#557684); }
.venue--sp{ --vc:linear-gradient(90deg,#4fa46d,#3c8a58); }

.venue-body{ background:#fff; padding:.3rem .95rem .7rem; }
.venue-2col{ display:grid; grid-template-columns:1fr 1fr; gap:0 1.8rem; }

/* ---- single event ---- */
.ev{ padding:.6rem 0; border-bottom:1px dashed #e6eef3; }
.ev:last-child{ border-bottom:0; }
.ev-title{
  display:flex; align-items:flex-start; gap:.4rem;
  color:#65a4dc; font-family:var(--ff-jp); font-weight:600;
  font-size:1.3rem; line-height:1.3; margin:0 0 .25rem;
}
.ev-title1{
  display:flex; align-items:flex-start; gap:.4rem;
  color:#d98c2e; font-family:var(--ff-jp); font-weight:600;
  font-size:1.3rem; line-height:1.3; margin:0 0 .25rem;
}
.ev-title3{
  display:flex; align-items:flex-start; gap:.4rem;
  color:#d98c2e; font-family:var(--ff-jp); font-weight:600;
  font-size:1.3rem; line-height:1.3; margin:0 0 .25rem;
}
.ev-title4{
  display:flex; align-items:flex-start; gap:.4rem;
  color:#cf6d8b; font-family:var(--ff-jp); font-weight:600;
  font-size:1.3rem; line-height:1.3; margin:0 0 .25rem;
}
.ev-title-t{
  display:flex; align-items:flex-start; gap:.4rem;
  color:#9bb837; font-family:var(--ff-jp); font-weight:600;
  font-size:1.3rem; line-height:1.3; margin:0 0 .25rem;
}
.ev-title .ev-ic{ color:#ea972f; font-size:1em; margin-top:.12em; flex:none; }
.ev-tags{ display:flex; flex-wrap:wrap; gap:.3rem; margin:.05rem 0 .3rem; }
.tag{
  font-family:var(--ff-jp); font-weight:700; font-size:.62rem;
  color:#fff; border-radius:4px; padding:.13rem .55rem; line-height:1.5;
}
.tag--orange{ background:#717070; }
.tag--red{ background:#4e7fc0; }
.tag--blue{ background:#3a8dc4; }
.ev-desc{ font-size:.74rem; color:#000; margin:.1rem 0 .28rem; line-height:1.45; font-weight:600; }
.ev-time{ font-size:.7rem; color:#000; margin:.18rem 0 0; line-height:1.45; }
.ev-org{ display:block; font-size:.64rem; color:#000; margin-top:.1rem; }

/* QR note (見学会) */
.qr-note{ display:flex; align-items:center; gap:.7rem; margin-top:.2rem; }
.qr-box{
  flex:none; width:56px; height:56px; border-radius:8px;
  background:#fff; border:1px solid #d7e3ec; display:grid; place-items:center;
  color:#5e87a0; font-size:1.7rem;
}
.qr-note small{ font-size:.66rem; color:#6a8294; line-height:1.4; }

/* plain note strip (会場③ クーポン等) */
.note-strip{
  padding:.6rem .9rem;
  font-size:.74rem; color:#000; line-height:1.55;
}

/* ---- band stage card (浅草橋オールディーズナイト) ---- */
.show-card{ margin-top:.8rem; border-radius:10px; overflow:hidden; border:1px solid #f2d6ac; }
.show-head{
  background:linear-gradient(90deg,#ea972f,#df5a4c); color:#fff;
  padding:.5rem .95rem; font-family:var(--ff-jp); font-weight:800; font-size:.92rem;
  display:flex; align-items:center; gap:.45rem;
}
.show-head small{ font-weight:500; font-size:.72em; opacity:.95; margin-left:auto; }
.show-body{ background:#fffaf2; padding:.7rem .95rem; }
.show-body > p{ font-size:.74rem; color:#000; margin:0 0 .5rem; line-height:1.5; }
.band-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:.18rem 1rem;
  font-size:.7rem; color:#000;
}
.band-grid span{ white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.band-grid b{ color:#d97c1c; font-family:var(--ff-en); font-weight:700; margin-right:.35rem; }

/* ---- finale : fireworks ---- */
.finale{ margin-top:.8rem; display:grid; grid-template-columns:1fr 150px; gap:.8rem; }
.finale-text{
  color:#000;
  display:flex; flex-direction:column; justify-content:center;
}
.finale-text h4{ color:#d97c1c; font-family:var(--ff-jp); font-size:1.05rem; margin:0 0 .3rem; }
.finale-text p{ font-size:.74rem; color:#000; margin:0; line-height:1.55; }
.finale-text .meta{ font-family:var(--ff-en); font-weight:400; font-size:.72rem; color:#000; margin-top:.4rem; }
/* night-sky placeholder — replace background-image with your own photo */
.finale-photo{
    border-radius: 10px;
    position: relative;
    background-position: 50% 50%;
    background-image: url(assets/photo/031.JPG);
    background-repeat: no-repeat;
    background-size: cover;
    width: 100%;
}

/* ---- ferry interior nested timeline (第4会場) ---- */
.ferry-sub{ margin-top:.55rem; display:flex; gap:.55rem; }
.ferry-label{
    flex: none;
    writing-mode: vertical-rl;
    text-orientation: upright;
    color: #cf6d8b;
    border-radius: 7px;
    font-family: var(--ff-jp);
    font-weight: 700;
    font-size: .66rem;
    letter-spacing: .12em;
    padding: .5rem .2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border: thin solid #CF6D8B;
}
.ferry-list{ flex:1; padding-left:.75rem; }
.ferry-list .ev{ padding:.45rem 0; }
.ferry-list .ev-title{ font-size:.86rem; }

/* small caption under a venue */
.venue-foot{ font-size:.66rem; color:#8b9eac; padding:.1rem .95rem .55rem; background:#fff; }

/* ---- responsive ---- */
@media (max-width:768px){
  .flyer-day{ grid-template-columns:1fr; }
  .day-tab{ flex-direction:row; flex-wrap:wrap; gap:.4rem; padding:.7rem 1rem; justify-content:center; }
  .day-tab b{ font-size:1.35rem; }
  .day-tab em{ margin-bottom:0; }
  .day-tab .day-dot{ margin:0 .2rem; }
  .day-tab .day-chip{ writing-mode:horizontal-tb; letter-spacing:.1em; padding:.2rem .6rem; margin-top:0; }
  .venue-2col{ grid-template-columns:1fr; gap:0; }
  .finale{ grid-template-columns:1fr; }
  .finale-photo{ min-height:110px; }
  .band-grid{ grid-template-columns:1fr; }
}