@import url('https://fonts.googleapis.com/css2?family=Anton&family=Inter:wght@400;500;600;700;800;900&display=swap');
:root {
  --black:#000000;
  --white:#ffffff;
  --gray-950:#090909;
  --gray-900:#111111;
  --gray-800:#1f1f1f;
  --gray-700:#333333;
  --gray-600:#555555;
  --gray-500:#777777;
  --gray-300:#d8d8d8;
  --gray-200:#eeeeee;
  --gray-100:#f7f7f7;
  --line:rgba(0,0,0,.14);
  --line-dark:rgba(255,255,255,.22);
  --muted:rgba(0,0,0,.66);
  --muted-invert:rgba(255,255,255,.74);
  --shadow:0 22px 70px rgba(0,0,0,.12);
  --radius-xl:34px;
  --radius-lg:24px;
  --radius-sm:14px;
  --container:min(1120px, calc(100% - 40px));
}

* {
  box-sizing:border-box;
  caret-color:var(--black)
}

html {
  scroll-behavior:smooth;
  accent-color:var(--black)
}

body {
  margin:0;
  min-height:100vh;
  overflow-x:hidden;
  color:var(--black);
  background:var(--white);
  font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  line-height:1.62;
}

body::before {
  content:'';
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background: linear-gradient(120deg, transparent 0 72%, rgba(0,0,0,.035) 72% 73%, transparent 73%), linear-gradient(30deg, transparent 0 82%, rgba(0,0,0,.025) 82% 83%, transparent 83%);
  background-size:120px 120px,180px 180px;
}

::selection {
  background:var(--black);
  color:var(--white)
}

a {
  color:inherit;
  text-decoration:none
}

img {
  display:block;
  max-width:100%
}

p,
h1,
h2,
h3 {
  margin-top:0
}

p,
li,
input,
textarea {
  font-size:clamp(15px,1.1vw,17px);
  font-weight:500;
  line-height:1.65;
  color:var(--muted)
}

.header {
  position:sticky;
  top:14px;
  z-index:50;
  width:var(--container);
  margin:14px auto 0;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:14px;
  padding:10px 12px 10px 18px;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(20px) saturate(140%);
  box-shadow:0 16px 44px rgba(0,0,0,.10);
}

.brand {
  display:flex;
  align-items:center;
  gap:10px;
  min-width:max-content
}

.brand-text {
  display:block;
  font-family:'Anton',Impact,sans-serif;
  font-size:clamp(26px,3.2vw,42px);
  line-height:1;
  letter-spacing:.015em;
  text-transform:uppercase;
  color:var(--black);
}

.header nav {
  display:flex;
  justify-content:center;
  align-items:center;
  gap:4px
}

.header nav a {
  position:relative;
  padding:9px 11px;
  font-family:'Anton',Impact,sans-serif;
  font-size:13px;
  letter-spacing:.075em;
  text-transform:uppercase;
  color:var(--black);
}

.header nav a::after {
  content:'';
  position:absolute;
  left:12px;
  right:12px;
  bottom:4px;
  height:2px;
  border-radius:999px;
  background:currentColor;
  transform:scaleX(0);
  transform-origin:center;
  transition:transform .22s ease;
}

.header nav a:hover::after,
.header nav a[aria-current='page']::after {
  transform:scaleX(1)
}

.menu-toggle {
  display:none;
  background:none;
  border:0;
  color:var(--black);
  padding:10px;
  cursor:pointer
}

.menu-toggle span {
  display:block;
  width:28px;
  height:2px;
  background:currentColor;
  margin:6px 0;
  border-radius:4px;
  transition:transform .22s ease,opacity .22s ease
}

.button,
.btn,
button.button {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  width:fit-content;
  min-height:42px;
  padding:12px 18px;
  border:2px solid var(--black);
  border-radius:999px;
  background:var(--black);
  color:var(--white);
  font-family:'Inter',system-ui,sans-serif;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.09em;
  cursor:pointer;
  transition:transform .22s ease, box-shadow .22s ease, background .22s ease, color .22s ease;
}

.button:hover,
.btn:hover {
  transform:translateY(-3px);
  box-shadow:0 16px 36px rgba(0,0,0,.18)
}

.button.light,
.button.dark,
.button-sun {
  background:var(--black);
  color:var(--white)
}

.button.outline {
  background:var(--white);
  color:var(--black);
  border-color:var(--black);
  box-shadow:none
}

.button.outline:hover {
  background:var(--black);
  color:var(--white)
}

.hero {
  position:relative;
  min-height:760px;
  margin-top:-76px;
  display:grid;
  align-items:center;
  overflow:hidden;
  background: linear-gradient(90deg, rgba(255,255,255,.94), rgba(255,255,255,.64) 48%, rgba(255,255,255,.86)), url('../img/bg-hero.jpg') center/cover no-repeat;
  background-color:var(--white);
}

.hero::after {
  content:'JAZZ · SAPORI · TERRITORIO';
  position:absolute;
  left:-4vw;
  right:-4vw;
  bottom:24px;
  white-space:nowrap;
  font-family:'Anton',Impact,sans-serif;
  font-size:clamp(38px,6.5vw,92px);
  line-height:.98;
  letter-spacing:.02em;
  color:rgba(0,0,0,.07);
  text-transform:uppercase;
  pointer-events:none;
}

.hero-overlay {
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 72% 28%, rgba(0,0,0,.08), transparent 18rem)
}

.hero-content {
  position:relative;
  z-index:2;
  max-width:1120px;
  width:100%;
  margin:0 auto;
  padding:170px 40px 112px;
  display:grid;
  grid-template-columns:1fr;
  gap:26px;
  align-items:start;
}

h1 {
  max-width:980px;
  margin:0;
  font-family:'Anton',Impact,sans-serif;
  font-size:clamp(58px,10vw,132px);
  line-height:.94;
  letter-spacing:-.025em;
  text-transform:uppercase;
  color:var(--black);
}

.lead {
  margin:0 0 12px;
  padding:22px;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:rgba(255,255,255,.82);
  color:var(--black);
  box-shadow:var(--shadow);
}

.eyebrow,
.sapori-eyebrow {
  display:inline-flex;
  width:fit-content;
  margin:0 0 18px;
  padding:8px 12px;
  border:1px solid var(--black);
  border-radius:999px;
  background:var(--white);
  color:var(--black);
  font-family:'Inter',system-ui,sans-serif;
  font-size:12px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.section,
.calendar-section,
.contact-section,
.territory-content,
.sapori-clean-grid,
.sapori-clean-feature,
.footer,
.cta,
.internal-hero {
  width:var(--container);
}

.section,
.calendar-section,
.contact-section,
.territory-content,
.sapori-clean-grid,
.sapori-clean-feature {
  margin:0 auto;
  padding:74px 0;
}

.section h2,
.territory h2,
.contact-info h2,
.sapori-clean-feature h2,
.section-head h2,
.calendar-info h2,
.sapori-clean-card h2,
.territory-content h2 {
  font-family:'Anton',Impact,sans-serif;
  text-transform:uppercase;
  letter-spacing:-.02em;
  color:var(--black);
}

.section h2,
.territory h2,
.contact-info h2,
.sapori-clean-feature h2,
.section-head h2 {
  font-size:clamp(38px,6vw,76px);
  line-height:1.04;
}

.intro>p,
.section-head p,
.territory-text p,
.sapori-clean-feature p,
.territory-content p,
.contact-info p {
  max-width:760px;
  color:var(--muted)
}

.cards {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
  margin-top:42px;
  align-items:stretch
}

.card {
  position:relative;
  min-height:430px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  overflow:hidden;
  border-radius:var(--radius-xl);
  border:1px solid var(--line);
  background:var(--gray-100);
  box-shadow:var(--shadow);
  isolation:isolate;
}

.card img {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .5s ease
}

.card::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 18%,rgba(255,255,255,.25),rgba(255,255,255,.94));
  z-index:0
}

.card div {
  position:relative;
  z-index:1;
  padding:24px;
  text-align:left
}

.card h3 {
  font-family:'Anton',Impact,sans-serif;
  font-size:clamp(36px,4.2vw,56px);
  line-height:.98;
  text-transform:uppercase;
  margin-bottom:12px;
  color:var(--black)
}

.card p {
  font-size:18px;
  color:var(--black);
  font-weight:600
}

.card:hover img {
  transform:scale(1.06)
}

.text-sun {
  color:var(--black)
}

/* Homepage image cards: color photos + black overlay for readable black/white UI */
.home-hover-card-cultura::after,
.home-hover-card-sapori::after,
.home-hover-card-territorio::after {
  background:linear-gradient(180deg, rgba(0,0,0,.06) 0%, rgba(0,0,0,.34) 45%, rgba(0,0,0,.82) 100%);
}

.home-hover-card-cultura h3,
.home-hover-card-cultura p,
.home-hover-card-cultura .text-sun,
.home-hover-card-sapori h3,
.home-hover-card-sapori p,
.home-hover-card-sapori .text-sun,
.home-hover-card-territorio h3,
.home-hover-card-territorio p,
.home-hover-card-territorio .text-sun {
  color:var(--white);
  text-shadow:0 2px 18px rgba(0,0,0,.34);
}

.territory {
  width:var(--container);
  margin:32px auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  align-items:stretch;
  padding:22px;
  border-radius:34px;
  background:var(--gray-100);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}

.territory-text {
  padding:34px 24px;
  display:flex;
  flex-direction:column;
  justify-content:center
}

.map-card {
  min-height:360px;
  border-radius:28px;
  background:var(--white);
  display:grid;
  place-items:center;
  overflow:hidden;
  color:var(--black);
  border:1px solid var(--line)
}

.photo-card {
  overflow:hidden;
  padding:0
}

.valle-photo {
  display:block;
  width:100%;
  height:100%;
  min-height:320px;
  object-fit:cover;
  border-radius:inherit
}

.map-card svg {
  width:100%;
  height:100%;
  min-height:320px;
  padding:18px
}

.map-route {
  fill:none;
  stroke:var(--black);
  stroke-width:10;
  stroke-linecap:round;
  stroke-dasharray:10 18
}

.map-point circle {
  fill:var(--white);
  stroke:var(--black);
  stroke-width:4
}

.map-point rect {
  fill:var(--black)
}

.map-point text {
  fill:var(--white);
  font-weight:900;
  font-size:20px
}

.muted {
  fill:rgba(0,0,0,.55);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em
}

.section-head {
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:24px;
  margin-bottom:28px
}

.event-grid {
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
  align-items:stretch
}

.event-card,
.calendar-item {
  position:relative;
  overflow:hidden;
  border-radius:26px;
  border:1px solid var(--line);
  background:var(--white);
  color:var(--black);
  box-shadow:var(--shadow);
  transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;
}

.event-card:hover,
.calendar-item:hover {
  transform:translateY(-6px);
  border-color:var(--black);
  box-shadow:0 26px 76px rgba(0,0,0,.16)
}

.event-card {
  min-height:300px;
  padding:16px;
  display:flex;
  flex-direction:column;
  gap:16px;
  justify-content:flex-start;
  min-width:0
}

.event-tba {
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:112px;
  border-radius:20px;
  background:repeating-linear-gradient(-18deg,var(--white) 0 12px,var(--gray-200) 12px 24px);
  color:var(--black);
  font-family:'Anton',Impact,sans-serif;
  font-size:clamp(42px,5vw,68px);
  line-height:1;
  box-shadow:inset 0 0 0 6px rgba(0,0,0,.10);
  border:1px solid var(--line)
}

.event-card span,
.calendar-info span {
  font-family:'Inter',system-ui,sans-serif;
  font-size:12px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--gray-600)
}

.event-card h3 {
  font-family:'Anton',Impact,sans-serif;
  font-size:clamp(30px,3.1vw,46px);
  line-height:1.02;
  text-transform:uppercase;
  margin:0;
  color:var(--black);
  overflow-wrap:anywhere
}

.event-card p {
  margin-top:auto;
  color:var(--muted)
}

.calendar-list {
  display:grid;
  gap:14px
}

.calendar-item {
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:28px;
  padding:18px;
  overflow:hidden
}

.calendar-date {
  display:grid;
  place-items:center;
  width:130px;
  aspect-ratio:1;
  border-radius:22px;
  background:var(--black);
  color:var(--white);
  font-family:'Anton',Impact,sans-serif;
  font-size:30px;
  line-height:1.08;
  text-align:center;
  text-transform:uppercase
}

.calendar-info {
  min-width:0
}

.calendar-info h2 {
  font-size:clamp(32px,4vw,56px);
  line-height:1.02;
  margin:10px 0;
  color:var(--black)
}

.calendar-info p {
  margin:0;
  color:var(--muted)
}

.calendar-item .button {
  flex-shrink:0;
  white-space:nowrap;
  justify-self:end
}

.cta {
  margin:32px auto 76px;
  min-height:360px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:32px;
  border-radius:34px;
  color:var(--white);
  background:linear-gradient(135deg,rgba(0,0,0,.70),rgba(0,0,0,.42)),url('../img/vibrante.jpg') center/cover no-repeat;
  box-shadow:var(--shadow);
  overflow:hidden;
}

.cta .brand-text,
.cta h2 {
  color:var(--white)
}

.cta h2 {
  max-width:860px;
  margin:36px 0;
  font-family:'Anton',Impact,sans-serif;
  font-size:clamp(42px,6.5vw,82px);
  line-height:.98;
  text-transform:uppercase;
  letter-spacing:-.03em
}

.cta .button {
  background:var(--white);
  color:var(--black);
  border-color:var(--white)
}

.internal-hero {
  position:relative;
  min-height:420px;
  margin:28px auto 0;
  display:flex;
  flex-direction:column;
  justify-content:end;
  padding:42px;
  overflow:hidden;
  border-radius:34px;
  border:1px solid var(--line);
  background-color:var(--gray-100);
  background-size:cover;
  background-position:center;
  box-shadow:var(--shadow);
}

.internal-hero::before {
  content:'';
  position:absolute;
  inset:0;
  background:rgba(255,255,255,.74);
  z-index:0;
  pointer-events:none
}

.internal-hero>* {
  position:relative;
  z-index:1
}

.internal-hero h1 {
  font-size:clamp(50px,9vw,112px);
  color:var(--black)
}

.internal-hero p {
  color:var(--black)
}

.internal-hero-content {
  position:relative;
  z-index:1
}

.event-vertical-space {
  height:120px
}

.sapori-clean-grid {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
  align-items:stretch
}

.sapori-clean-card,
.territory-content article,
.contact-info,
.contact-form {
  padding:26px;
  border-radius:26px;
  background:var(--white);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}

.sapori-clean-card {
  position:relative;
  overflow:hidden;
  min-height:300px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  gap:24px
}

.sapori-icon {
  font-family:'Anton',Impact,sans-serif;
  font-size:64px;
  color:var(--black)
}

.sapori-clean-card h2 {
  font-size:clamp(34px,4vw,50px);
  line-height:.98;
  color:var(--black);
  margin:0
}

.sapori-clean-card p {
  color:var(--muted);
  font-size:18px;
  margin:0
}

.sapori-clean-feature {
  display:grid;
  grid-template-columns:minmax(0,.85fr) minmax(280px,1fr);
  align-items:end;
  gap:clamp(28px,5vw,72px);
  margin-top:32px;
  margin-bottom:96px;
  padding:clamp(30px,5vw,56px);
  border:1px solid var(--line);
  border-radius:32px;
  background:var(--gray-100);
  box-shadow:var(--shadow);
  overflow:hidden;
  color:var(--black)
}

.sapori-clean-feature h2 {
  margin:0;
  font-size:clamp(42px,6.4vw,88px);
  line-height:.95;
  max-width:650px;
  color:var(--black)
}

.sapori-clean-feature>p {
  margin:0;
  max-width:620px;
  padding:24px 0 0 28px;
  border-left:3px solid var(--black);
  color:var(--muted)
}

.territory-content {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px
}

.territory-content h2 {
  font-size:clamp(34px,4vw,50px);
  line-height:1.03;
  color:var(--black)
}

.territory-content article {
  position:relative;
  overflow:hidden;
  transition:transform .28s ease,border-color .28s ease,box-shadow .28s ease
}

.territory-content article:hover {
  transform:translateY(-8px);
  border-color:var(--black);
  box-shadow:0 22px 58px rgba(0,0,0,.16)
}

.contact-section {
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:18px
}

.contact-info a {
  color:var(--black);
  font-weight:900;
  text-decoration:underline;
  text-underline-offset:3px
}

.contact-form {
  display:grid;
  gap:16px
}

.contact-form label {
  display:grid;
  gap:8px;
  color:var(--black);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:12px
}

.contact-form input,
.contact-form textarea {
  width:100%;
  border:1px solid var(--line);
  border-radius:18px;
  padding:16px 18px;
  background:var(--white);
  color:var(--black);
  font:inherit;
  outline:none
}

.contact-form input:focus,
.contact-form textarea:focus {
  border-color:var(--black);
  box-shadow:0 0 0 4px rgba(0,0,0,.10)
}

.footer {
  margin:0 auto 20px;
  padding:28px 0;
  display:flex;
  justify-content:space-between;
  gap:20px;
  border-top:1px solid var(--line);
  color:rgba(0,0,0,.62);
  font-size:16px
}

.footer p {
  margin:0;
  color:rgba(0,0,0,.62)
}

@media (max-width:1080px) {
  .header {
    grid-template-columns:auto auto;
    justify-content:space-between;
  }

  .menu-toggle {
    display:block;
  }

  .header>.button {
    display:none;
  }

  body.menu-lock {
    overflow:hidden;
    height:100dvh;
    touch-action:none;
  }

  .header nav {
    display:none;
  }

  .header.menu-open {
    position:fixed;
    inset:0;
    z-index:9999;
    width:100vw;
    height:100dvh;
    max-width:none;
    margin:0;
    padding:24px 22px max(24px, env(safe-area-inset-bottom));
    border:0;
    border-radius:0;
    background:var(--white);
    box-shadow:none;
    display:grid;
    grid-template-columns:1fr auto;
    grid-template-rows:auto 1fr;
    align-items:center;
  }

  .header.menu-open .brand, .header.menu-open .menu-toggle {
    position:relative;
    z-index:2;
    align-self:start;
  }

  .header.menu-open nav {
    grid-column:1/-1;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:stretch;
    gap:14px;
    min-height:0;
    padding:28px 0 24px;
    overflow:auto;
    background:var(--white);
  }

  .header.menu-open nav a {
    width:min(560px,100%);
    margin:0 auto;
    padding:18px 20px;
    text-align:center;
    font-size:clamp(20px,6vw,34px);
    line-height:1;
    color:var(--black);
  }

  .header.menu-open nav a::after {
    left:20%;
    right:20%;
    bottom:8px;
  }

  .header.menu-open .menu-toggle span:nth-child(1) {
    transform:translateY(8px) rotate(45deg);
  }

  .header.menu-open .menu-toggle span:nth-child(2) {
    opacity:0;
  }

  .header.menu-open .menu-toggle span:nth-child(3) {
    transform:translateY(-8px) rotate(-45deg);
  }

  .event-grid {
    grid-template-columns:repeat(2,minmax(0,1fr));
  }

}

@media (max-width:980px) {
  :root {
    --container:min(100% - 28px,760px)
  }

  .hero {
    min-height:680px
  }

  .hero-content {
    padding:150px 28px 96px
  }

  .cards,.sapori-clean-grid,.territory-content,.territory,.contact-section {
    grid-template-columns:1fr
  }

  .card {
    min-height:360px
  }

  .map-card {
    min-height:320px
  }

  .calendar-item {
    grid-template-columns:1fr
  }

  .calendar-date {
    width:132px;
    aspect-ratio:auto;
    padding:18px
  }

  .calendar-item .button {
    justify-self:start
  }

  .sapori-clean-feature {
    grid-template-columns:1fr;
    align-items:start;
    gap:22px;
    margin-top:18px;
    margin-bottom:64px;
    padding:28px 22px
  }

  .sapori-clean-feature>p {
    padding:18px 0 0;
    border-left:0;
    border-top:3px solid var(--black)
  }

}

@media (max-width:620px) {
  :root {
    --container:calc(100% - 20px);
  }

  .header {
    top:10px;
    padding:9px 10px 9px 14px;
    grid-template-columns:1fr auto;
  }

  .header.menu-open {
    top:0;
    padding:19px 10px max(24px, env(safe-area-inset-bottom)) 14px;
  }

  .brand {
    min-width:0;
  }

  .brand-text {
    max-width:calc(100vw - 94px);
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
    font-size:30px;
  }

  .hero {
    min-height:620px;
    margin-top:-68px;
  }

  .hero-content {
    padding:140px 18px 90px;
    justify-items:center;
    text-align:center;
  }

  .hero::after {
    bottom:14px;
  }

  h1 {
    font-size:clamp(48px,17vw,78px);
  }

  .section, .calendar-section, .contact-section, .territory-content, .sapori-clean-grid, .sapori-clean-feature {
    padding:54px 0;
  }

  .section h2, .territory h2, .contact-info h2, .sapori-clean-feature h2, .section-head h2 {
    font-size:clamp(34px,12vw,52px);
  }

  .intro h2 {
    white-space:nowrap;
    font-size:clamp(29px,10.5vw,46px);
    letter-spacing:-.035em;
  }

  .section-head {
    align-items:center;
    flex-direction:column;
    text-align:center;
  }

  .section-head p, .intro>p, .territory-text p, .contact-info p, .calendar-info p {
    text-align:center;
    margin-left:auto;
    margin-right:auto;
  }

  .card {
    min-height:310px;
  }

  .card div, .event-card, .calendar-item, .sapori-clean-card, .territory-content article {
    text-align:center;
  }

  .territory, .cta, .internal-hero {
    border-radius:24px;
  }

  .territory {
    padding:12px;
  }

  .territory-text, .cta {
    padding:24px 18px;
    text-align:center;
    align-items:center;
  }

  .map-card {
    min-height:260px;
  }

  .event-grid {
    grid-template-columns:1fr;
  }

  .event-card {
    min-height:0;
    padding:18px;
  }

  .event-tba {
    min-height:96px;
    font-size:clamp(38px,16vw,54px);
  }

  .internal-hero {
    padding:28px;
    min-height:360px;
    text-align:center;
    align-items:center;
  }

  .calendar-date {
    margin-left:auto;
    margin-right:auto;
  }

  .calendar-item .button {
    justify-self:center;
    width:100%;
  }

  .footer {
    flex-direction:column;
    align-items:center;
    text-align:center;
    font-size:14px;
  }

}
