/* ===================== OCCASION PAGE STYLES ===================== */

/* ---- hero ---- */
.oh{background:var(--ink);color:var(--cream);border-bottom:5px solid var(--red);position:relative;overflow:hidden;padding:clamp(60px,8vw,116px) 0}
.oh .dots{position:absolute;inset:0;color:oklch(1 0 0 / .07)}
.oh .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.12fr .88fr;gap:50px;align-items:center}
.oh-copy{min-width:0}
.oh .kicker-line{color:var(--peach-deep)}
.oh .kicker-line::before{background:var(--peach-deep)}
.oh h1{font-family:"Poppins";font-weight:900;font-size:clamp(38px,5.2vw,70px);line-height:.95;letter-spacing:-0.03em;margin:16px 0 18px}
.oh h1 em{font-style:normal;color:var(--peach-deep)}
.oh p.lead{font-size:18px;color:oklch(0.88 0.055 58 / .85);max-width:48ch;margin-bottom:26px}
.oh-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:30px}
.oh-stats{display:flex;gap:30px;flex-wrap:wrap;padding-top:24px;border-top:2px solid oklch(1 0 0 / .14)}
.oh-stats .ostat .v{font-family:"Poppins";font-weight:900;font-size:clamp(22px,2.4vw,28px);color:var(--peach-deep);line-height:1}
.oh-stats .ostat .l{font-size:12.5px;color:oklch(0.88 0.055 58 / .72);font-weight:600;margin-top:4px}
.oh-photo{position:relative;height:430px}
.oh-photo img{position:absolute;border-radius:var(--r-lg);border:4px solid var(--peach-deep);object-fit:cover;box-shadow:6px 6px 0 var(--peach-deep)}
.oh-photo img:nth-child(1){width:66%;aspect-ratio:1.15;top:0;right:2%;transform:rotate(3deg);z-index:2}
.oh-photo img:nth-child(2){width:50%;aspect-ratio:1;bottom:4%;left:0;transform:rotate(-5deg);z-index:1}

/* ---- intro split ---- */
.ointro{display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:center}
.oi-photo{border-radius:var(--r-lg);overflow:hidden;border:3px solid var(--ink);box-shadow:var(--pop-lg);aspect-ratio:1.1}
.oi-photo img{width:100%;height:100%;object-fit:cover}
.oi-copy h2{margin:10px 0 14px}
.oi-copy p{color:var(--navy-soft);font-size:16.5px;line-height:1.7;margin-bottom:14px}
.oi-copy .pills{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}
.oi-copy .pill{display:inline-flex;align-items:center;gap:7px;font-family:"Poppins";font-weight:800;font-size:12.5px;background:var(--peach);border:2px solid var(--ink);border-radius:var(--r-pill);padding:7px 13px}
.oi-copy .pill svg{width:14px;height:14px;color:var(--red)}

/* ---- sample menu ---- */
.omenu{background:var(--ink);color:var(--cream);position:relative;overflow:hidden}
.omenu .doodle-bg img{opacity:.07}
.omenu .wrap{position:relative;z-index:1}
.omenu .head{text-align:center;max-width:620px;margin:0 auto var(--s-1)}
.omenu .head h2{color:var(--cream)}
.omenu .head .kicker-line{color:var(--peach-deep);justify-content:center;display:inline-flex}
.omenu .head .kicker-line::before{background:var(--peach-deep)}
.ocourses{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ocourse{background:oklch(1 0 0 / .04);border:2px solid oklch(1 0 0 / .14);border-radius:var(--r-lg);padding:28px 24px}
.ocourse .oc-tag{display:inline-block;font-family:"Poppins";font-weight:800;font-size:12px;letter-spacing:.1em;text-transform:uppercase;background:var(--peach-deep);color:var(--ink);padding:6px 13px;border-radius:var(--r-pill);border:2px solid var(--cream);margin-bottom:16px}
.ocourse p{font-size:15px;color:oklch(0.88 0.055 58 / .82);line-height:1.65}
.omenu-note{text-align:center;font-size:13.5px;color:oklch(0.88 0.055 58 / .6);font-weight:600;margin-top:26px}

/* ---- gallery ---- */
.ogallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gtile{border-radius:var(--r-lg);overflow:hidden;border:3px solid var(--ink);box-shadow:var(--pop);aspect-ratio:.82}
.gtile:nth-child(1){aspect-ratio:.82;grid-row:span 2}
.gtile img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gtile:hover img{transform:scale(1.05)}

/* ---- faq ---- */
.ofaq-wrap{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
.ofaq-intro{position:sticky;top:96px}
.ofaq-intro h2{margin:10px 0 12px}
.ofaq-intro p{color:var(--navy-soft);font-size:15.5px;line-height:1.65;margin-bottom:22px;max-width:38ch}
.ofaq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{border:3px solid var(--ink);border-radius:var(--r-md);background:var(--paper);overflow:hidden;box-shadow:3px 3px 0 var(--ink)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 22px;font-family:"Poppins";font-weight:800;font-size:16px;text-align:left;color:var(--ink);background:var(--paper);transition:background .15s}
.faq-q:hover{background:var(--cream-deep)}
.faq-q svg{width:20px;height:20px;flex:0 0 auto;transition:transform .25s var(--ease);color:var(--red)}
.faq-item.open .faq-q svg{transform:rotate(180deg)}
.faq-item.open .faq-q{background:var(--cream-deep)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.faq-item.open .faq-a{max-height:240px}
.faq-a p{padding:0 22px 20px;font-size:14.5px;color:var(--navy-soft);line-height:1.65}

/* ---- cta ---- */
.octa{background:var(--red);color:var(--cream);border-top:5px solid var(--ink);position:relative;overflow:hidden}
.octa .doodle-bg img{opacity:.10}
.octa .wrap{position:relative;z-index:1;text-align:center;max-width:680px}
.octa .kicker-line{color:var(--cream);justify-content:center;display:inline-flex;opacity:.9}
.octa .kicker-line::before{background:var(--cream)}
.octa h2{color:var(--cream);font-size:clamp(28px,3.8vw,48px);margin:12px 0 14px}
.octa p{font-size:17px;color:oklch(1 0 0 / .9);margin-bottom:28px;max-width:50ch;margin-left:auto;margin-right:auto}
.octa-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---- responsive ---- */
@media(max-width:900px){
  .ocourses{grid-template-columns:1fr;gap:14px}
  .ogallery{grid-template-columns:repeat(2,1fr)}
  .gtile:nth-child(1){grid-row:span 1}
  .ofaq-wrap{grid-template-columns:1fr;gap:28px}
  .ofaq-intro{position:static}
}
@media(max-width:820px){
  .oh .wrap{grid-template-columns:1fr;gap:30px}
  .oh-photo{height:300px}
  .ointro{grid-template-columns:1fr;gap:26px}
  .oi-photo{order:-1;aspect-ratio:1.5}
}
@media(max-width:560px){
  .oh-stats{gap:20px}
  .ogallery{grid-template-columns:1fr}
  .gtile{aspect-ratio:1.4}
}
