/* Homepage-only styles. Shared tokens, base typography, nav, and footer
   primitives live in site.css. */

/* HERO */
.hero{padding:72px 0 56px;position:relative;overflow:hidden}
.hero-inner{display:grid;grid-template-columns:1.4fr 1fr;gap:56px;align-items:center}
.hero h1{
  font-size:clamp(40px, 6.4vw, 76px);
  line-height:1.02;
  font-weight:700;
  font-variation-settings:"opsz" 120;
  margin:18px 0 22px;
}
.hero h1 em{font-style:italic;color:var(--brick);font-weight:600}
.hero .lead{
  font-size:18px;color:var(--ink-soft);max-width:560px;margin-bottom:30px;
}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;border-radius:999px;font-weight:600;font-size:15px;
  letter-spacing:.02em;border:1.5px solid transparent;cursor:pointer;
  transition:transform .18s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--brick);color:#fff7e6}
.btn-primary:hover{background:var(--brick-dark);color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.btn .arr{transition:transform .2s ease}
.btn:hover .arr{transform:translateX(3px)}

/* Hero side card / decorative */
.hero-side{position:relative}
.ticket{
  background:var(--card);
  border:1px solid var(--paper-line);
  border-radius:var(--radius);
  padding:24px 26px;
  box-shadow:var(--shadow);
  transform:rotate(-1.5deg);
  position:relative;
}
.ticket::before,.ticket::after{
  content:"";position:absolute;left:-9px;width:18px;height:18px;border-radius:50%;
  background:var(--cream);border:1px solid var(--paper-line);
}
.ticket::before{top:30%}
.ticket::after{bottom:30%}
.ticket .label{
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-mute);
}
.ticket h3{font-size:24px;margin:8px 0 14px;line-height:1.15}
.ticket .meta{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:14px;border-top:1px dashed var(--paper-line);
  font-size:13px;color:var(--ink-soft);
}
.ticket .stars{color:var(--mustard-dark);letter-spacing:2px}
.stamp{
  position:absolute;top:-18px;right:-12px;
  background:var(--mustard);color:#3a2a10;
  font-family:"Fraunces",serif;font-weight:700;font-style:italic;
  padding:8px 14px;border-radius:6px;font-size:13px;letter-spacing:.04em;
  box-shadow:0 4px 14px rgba(168,112,20,.4);
  transform:rotate(6deg);
}
.scribble{
  position:absolute;left:-30px;bottom:-30px;
  font-family:"Caveat",cursive;color:var(--brick);font-size:22px;
  transform:rotate(-7deg);max-width:200px;line-height:1.2;
}

/* SECTION HEADER */
.section-head{text-align:center;padding:24px 0 36px}
.section-head h2{
  font-size:clamp(34px,4.6vw,52px);
  font-weight:700;
  font-variation-settings:"opsz" 96;
  margin:14px 0 10px;
}
.section-head p{color:var(--ink-soft);max-width:560px;margin:0 auto}

.divider{
  display:flex;align-items:center;justify-content:center;gap:14px;
  color:var(--mustard-dark);margin:36px auto;
}
.divider::before,.divider::after{
  content:"";height:1px;background:var(--paper-line);flex:1;max-width:200px;
}
.divider span{font-family:"Fraunces",serif;font-style:italic}

/* GRID */
.lists{padding:8px 0 56px}
.grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:28px 24px;
}
.card{
  position:relative;background:var(--card);
  border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--paper-line);
  box-shadow:var(--shadow);
  transition:transform .25s ease, box-shadow .25s ease;
  text-decoration:none;color:inherit;display:block;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card-img{position:relative;aspect-ratio:1/1;overflow:hidden;background:#e9dcc1}
.card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .55s cubic-bezier(.2,.7,.2,1), filter .3s ease;
}
.card:hover .card-img img{transform:scale(1.06)}
.card-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(43,29,18,0) 50%, rgba(43,29,18,.55) 100%);
  opacity:0;transition:opacity .3s ease;
}
.card:hover .card-img::after{opacity:1}
.card-badge{
  position:absolute;top:12px;left:12px;
  background:rgba(245,236,217,.92);color:var(--ink);
  backdrop-filter:blur(4px);
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  padding:6px 10px;border-radius:999px;font-weight:700;
	z-index: 1;
}
.card-badge.hot{background:var(--brick);color:#ffe9c8}
.card-badge.new{background:var(--mustard);color:#3a2a10}
.card-body{padding:18px 20px 22px}
.card-kicker{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-mute);font-weight:600;margin-bottom:6px;
}
.card-title{
  font-family:"Fraunces",serif;font-size:21px;line-height:1.18;
  font-weight:600;margin:0 0 12px;color:var(--ink);
  font-variation-settings:"opsz" 36;
}
.card-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--brick);
}
.card:hover .card-link .arr{transform:translateX(4px)}

/* MAP CTA */
.map-cta{
  margin:24px 0 80px;
  background:linear-gradient(135deg, #1f1611 0%, #3a2418 50%, var(--brick-dark) 100%);
  color:var(--cream-2);
  border-radius:20px;
  padding:48px 44px;
  display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;
  position:relative;overflow:hidden;
}
.map-cta::before{
  content:"";position:absolute;inset:0;opacity:.18;
  background-image:
    radial-gradient(circle at 10% 20%, var(--mustard) 0, transparent 18%),
    radial-gradient(circle at 90% 80%, var(--brick) 0, transparent 22%),
    radial-gradient(circle at 60% 30%, #fff2d0 0, transparent 14%);
}
.map-cta > *{position:relative}
.map-cta h2{
  color:var(--cream-2);font-size:clamp(28px,3.4vw,40px);
  font-weight:600;font-style:italic;line-height:1.1;margin-bottom:10px;
}
.map-cta p{color:rgba(245,236,217,.75);max-width:520px;margin:0}
.map-cta .btn{background:var(--mustard);color:#2a1c0a;border-color:transparent}
.map-cta .btn:hover{background:#e0a542}

/* ABOUT */
.about{padding:24px 0 80px}
.about-inner{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center;
}
.about-photo{
  position:relative;
}
.about-photo img{
  width:100%;aspect-ratio:1/1;object-fit:cover;
  border-radius:18px;box-shadow:var(--shadow-lg);
}
.about-photo::before{
  content:"";position:absolute;inset:14px -14px -14px 14px;
  border:1.5px solid var(--brick);border-radius:18px;z-index:-1;
}
.about h2{font-size:clamp(34px,4.4vw,48px);margin-bottom:18px}
.about h2 em{color:var(--brick);font-style:italic}
.about p{color:var(--ink-soft);font-size:17px;margin-bottom:16px}
.about .signature{
  font-family:"Caveat",cursive;font-size:28px;color:var(--brick);margin-top:6px;
}

/* FOOTER */
footer{
  background:var(--ink);color:var(--cream-2);
  padding:72px 0 32px;margin-top:40px;
}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;
  padding-bottom:48px;border-bottom:1px solid rgba(245,236,217,.12);
}
footer h4{
  color:var(--cream);font-family:"Fraunces",serif;font-weight:600;
  font-size:14px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:18px;
}
footer h3{
  font-family:"Fraunces",serif;font-size:28px;color:var(--cream);
  font-weight:600;margin-bottom:14px;font-style:italic;
}
footer p{color:rgba(245,236,217,.7);font-size:15px}
footer a{color:var(--mustard)}
footer a:hover{color:#e7b85b}
.recent-list{list-style:none;padding:0;margin:0}
.recent-list li{margin-bottom:14px}
.recent-list a{
  display:flex;align-items:center;gap:14px;color:var(--cream-2);
  text-decoration:none;transition:transform .2s ease;
}
.recent-list a:hover{transform:translateX(4px);color:var(--mustard)}
.recent-list img{
  width:54px;height:54px;border-radius:10px;object-fit:cover;flex-shrink:0;
}
.recent-list .meta{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mustard);margin-bottom:2px}
.recent-list .name{font-family:"Fraunces",serif;font-size:17px;line-height:1.2}
.social{display:flex;gap:10px;margin-top:18px}
.social a{
  width:40px;height:40px;border-radius:50%;
  background:rgba(245,236,217,.08);display:inline-flex;align-items:center;justify-content:center;
  color:var(--cream-2);transition:background .2s ease;font-size:18px;
}
.social a:hover{background:var(--mustard);color:#2a1c0a}
.colophon{
  padding-top:28px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  font-size:13px;color:rgba(245,236,217,.5);
}
.colophon .heart{color:var(--brick)}

/* RESPONSIVE */
@media (max-width: 1000px){
  .grid{grid-template-columns:repeat(3,1fr)}
  .hero-inner{grid-template-columns:1fr;gap:48px}
  .hero-side{max-width:380px;margin:0 auto}
  .about-inner{grid-template-columns:1fr;gap:40px}
  .about-photo{max-width:380px;margin:0 auto}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}
@media (max-width: 720px){
  /* Nav-specific mobile rules now live in site.css. */
  .hero{padding:48px 0 32px}
  .grid{grid-template-columns:repeat(2,1fr);gap:20px 16px}
  .card-title{font-size:18px}
  .map-cta{padding:36px 28px}
  .footer-grid{grid-template-columns:1fr}
	.scribble { left: 0; }
}
@media (max-width: 440px){
  .grid{grid-template-columns:1fr}
}
