:root {
  --bglv0: #eeeeee;
  --bglv1: #e0e9e2;
  --fglv0: #171717;
  --fglv1: #303030;
  --fglv2: #454748;
  --fglv3: #746f6f;
  --fglv4: #a49e9e;
  --fglink: #143cb5;
  --fgaccent: #f26960;
  --borderColor: #b3b5b9;
  --radii: 4px;
}

/* Support iOS dynamic type */
@supports (-webkit-touch-callout: none) {
  :root {
    font: -apple-system-body;
  }
}

html {
  font-size: 13px;
}

body,
button,
textarea,
input {
  font-family: system-ui, sans-serif;
  color: var(--fglv1);
}

div, summary, a {
  box-sizing: border-box;
}

select,
button {
  box-sizing: border-box;
}

body {
  word-wrap: break-word;
  font-size: 1.2rem;
  margin: 0;
  padding: 0;
  background-color: var(--bglv0);
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: bold;
}

a { 
  text-underline-offset: 0.2em;
  color: var(--fglink);
}

footer,
main,
header {
  padding: 2.4em;
  max-width: 50em;
  margin: auto;
}

header { margin-top: 1.2em }

footer {
  margin-top: 12em;
  margin-bottom: 12em;
}

label {
  display: block;
}

textarea,
select,
input,
button {
  font-size: inherit;
  border-radius: var(--radii);
  padding: 16px; 
  border-radius: 0;
  background: var(--bglv0);
  border: 0.5px solid var(--borderColor);
  box-shadow: 1px 1px 0 0px var(--bglv0);
  transform: scale(1, 0.97);
  color: var(--fglv1);
  letter-spacing: 1px;
}

*::placeholder {
  color: var(--fglv3);
}

fieldset {
  border: 0;
  padding: 0;
  margin: 1em 0;
}

button, .button {
  padding: 1em 1.5em;
  line-height: 1;
  font-size: inherit;
  background: var(--bglv1);
  font-weight: bold;
  cursor: pointer;
  box-shadow: 1px 1px 0 0px var(--bglv0);
}

button:focus, .button:focus, select:focus, input:focus {
  box-shadow: none;
}

select:disabled {
  opacity: 0.7;
}

a.button {
  display: inline-block;
  text-decoration: none;
  color: inherit;
}

button[type="submit"], .button\:type-submit {
  background: var(--bglv2);
}

code, pre, .code {
  font-family: ui-monospace, "SFMono-Regular", "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;  
  font-size: 0.95em;
}

em, i {
  color: var(--fglv2);
  font-style: normal;
}

mark {
  position: relative;
  background-color: #3eff8fb0;
  z-index: -1;
  border-radius: 5em 1.2em 6em 1em;
  border-right: 5px solid rgba(0, 0, 0, 0.06);
}

.site-title {
  text-decoration: none;
}

.site-title .party {
  color: var(--fgaccent);
  font-size: 1em;
}

.site-title .name {
  margin-top: 10px;
  width: 120px;
}

.main-nav {
  font-size: 1.2em;
  display: flex;
  flex-direction: column;
  gap: 1em;
  list-style: none;
}

.main-nav details {
  position: relative;
}

.main-nav summary.target:after {
  position: absolute;
  color: currentColor;
  top: 0;
  right: 0;
  padding: 0.8em 1.2em;
  pointer-events: none;
  content: '+';
}

.main-nav details[open] summary.target:after {
  content: '–';
}

summary.target {
  list-style: none;
  cursor: pointer;
}

summary.target::-webkit-details-marker {
  display: none;
}

.main-nav .indent {
  padding-left: 1.3em;
}
@media (min-width: 400px) {
  .main-nav .indent {
    padding-left: 3.3em;
  }
}

.main-nav details,
.main-nav a.target {
  border-bottom: 1px solid var(--fgaccent);
}

.main-nav .target {
  width: 100%;
  text-decoration: none;
  color: var(--fglv1);
  padding: 0.8em 1.2em;
  box-shadow: inset 0 0 0 var(--fglv0);
  transition: color 0.2s, box-shadow ease-out 0.4s;
}

@media (any-hover: hover) {
  .main-nav .target:hover {
    background-image: linear-gradient(to bottom, var(--bglv0) 0,  var(--bglv0) 100px, transparent 100px, transparent 100px);
    box-shadow: inset 0 -5em 0 var(--fglv0);
    color: var(--bglv0);
    background-position: 0 -100px;
    background-repeat: repeat-x;
  }

  .main-nav .target:focus:hover {
    transition: color 0.2s, background-position ease-out 0.4s;
    box-shadow: none;
    background-position: 0 0;
    background-color: var(--fglv0);
    color: var(--fglv0);
  }
}

.main-nav .target:before {
  content: '→';
  margin-right: 1.2em;
  font-size: 1em;
  color: var(--fglv4);
}

.main-nav [open] .target:before {
  color: var(--fgaccent);
}

.text-link svg {
  width: 30px;
  height: 30px;
}

.link {
  padding: 0.4em 0.8em;
  box-shadow: inset 0 0 0 var(--fglv0);
  transition: color 0.2s, box-shadow ease-out 0.4s;
  border: 1px solid;
  text-decoration: none;
  color: currentColor;
  font-size: 0.86em;
}

.link:hover {
  box-shadow: inset 0 -5em 0 var(--fglv0);
  border: 1px solid var(--fglv0);
  color: var(--bglv0);
}

.text-link {
  display: inline-flex;
  gap: 0.8em;
  align-items: center;
  color: var(--fglv1);
  font-weight: 600;
}

.text-link:hover {
  color: var(--fglink);
}

.social-nav {
  display: flex;
  align-items: end;
  gap: 2em;
  flex-wrap: wrap;
}

.intro {
  font-size: 1.4em;
  font-family: Georgia, 'Times New Roman', Times, serif;
  margin-bottom: 2em;
}

.list {
  padding: 0 1em;
}

.list li {
  margin: 1.2em 0;
  list-style-type: square; 
}

.link-list .date {
  font-size: 0.8em;
  color: var(--fglv3);
}

.schedule-list .event {
  font-variant-numeric: tabular-nums;
  display: flex;
  gap: 0.4em;
  align-items: center;
}

.schedule-list .date {
  flex-shrink: 0;
}

.schedule-list .details {
  flex: 1 1 auto;
  display: flex;
  gap: 0.4em;
}

.schedule-list .action {
  flex-shrink: 0;
  white-space: nowrap;
}

@media (max-width: 800px) {
  .schedule-list .event {
    flex-wrap: wrap;
  }
  .schedule-list .details {
    flex-wrap: wrap;
  }
}

.schedule-list .event-type {
  display: inline-block;
  white-space: nowrap;
  padding: 0.1em 0.6em;
  background-color: var(--bglv1);
  font-size: 0.7em;
  font-weight: bold;
  border-radius: 3em;
}

.cta-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 2em;
  margin-bottom: 4em;
}
