/* Type */

/* 
font-family: 'aktiv-grotesk', sans-serif;
font-weight: 400; font-style: normal;
font-weight: 400; font-style: italic;
font-weight: 500;
font-weight: 600;
font-weight: 700; font-style: normal;
font-weight: 700; font-style: italic;
font-weight: 800;

font-family: 'aktiv-grotesk-extended', sans-serif;
font-weight: 400; 
font-weight: 500;
font-weight: 600;
font-weight: 700; 
font-weight: 800;
*/

html {
  font-size: 16px; /* 16 is default for most browsers*/
}
@media screen and (min-width: 320px) {
  html { font-size: 110%; }
}
@media screen and (min-width: 992px) {
  html { font-size: 114%; }
}
@media screen and (min-width: 1200px) {
  html { font-size: 116%; }
}
@media screen and (min-width: 1400px) {
  html { font-size: 118%; }
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  line-height:1.5;
  font-family: 'aktiv-grotesk', sans-serif;
}

h2.on-detail { font-family: 'aktiv-grotesk-extended', sans-serif; font-weight:800; font-size:0.7rem; color:inherit; }

.text-condensed { font-family: 'aktiv-grotesk', sans-serif; }

/* global typography */

.text-serif { font-family:serif; }

h1,h2,h3,h4,h5,h6 { text-wrap:balance; color:inherit; }

h1 { font-size: 2.56rem; line-height:1.25; font-family: 'aktiv-grotesk-extended', sans-serif; font-weight:800; margin-top:0px; margin-bottom: 1rem; }
h2 { font-size: 1.618rem; line-height:1.36; font-family: 'aktiv-grotesk-extended', sans-serif; font-weight:700; margin-top:1rem; margin-bottom: 1rem; }
h3 { font-size: 1.1rem; line-height:1.5; font-weight:700; } 

h2.on-detail { font-size: 0.85rem; font-weight:700; margin-top:1.5rem; margin-bottom: 1rem; text-transform:uppercase; letter-spacing:0.050rem; }

p, li { font-size:1rem; }
li { margin-bottom:0.25rem; } /* I like to differentiate between line height and items */
p.intro,p.lead { font-family: 'aktiv-grotesk-extended', sans-serif; font-weight:inherit; font-size:1.2rem; text-wrap:balance; }

label { color:inherit; }

hr { margin-top: 1rem; margin-bottom: 1rem; border: 0; border-top-color: currentcolor; border-top-style: none; border-top-width: 0px; border-top: 1px solid rgba(0,0,0,.1); opacity:1; }

hr.clearing-spacer { clear:both; background-color:inherit; border:0px; opacity:1; }

a { color:var(--cty-alink); text-decoration:underline; }
a:hover { color:var(--cty-ahover); text-decoration:underline; }


/* buttons */

.btn-brand { 
  background-color:var(--cty-alink); 
  border:1px solid var(--cty-alink); 
  color:white; 
  font-size:18px; line-height:36px; font-weight:800; text-transform:none; letter-spacing:0.010rem; 
  margin: 4px 2px 4px 0px; 
  padding: 4px 20px 0 20px; 
  transition:var(--cty-transition-hover); 
  text-decoration:none; 
  border-radius:40px;
  font-family: 'aktiv-grotesk-extended', sans-serif;
}
.btn-brand:hover { 
  background-color:var(--cty-ahover); 
  border-color:var(--cty-ahover); 
  color:white; 
  text-decoration:none; 
}

.btn-outline-brand { 
  background-color:transparent; 
  border:2px solid var(--cty-alink); 
  color:var(--cty-alink); 
  font-size:18px; line-height:36px; font-weight:800; text-transform:none; letter-spacing:0.010rem; 
  margin: 4px 2px 4px 0px; 
  padding: 4px 20px 0 20px; 
  transition:var(--cty-transition-hover);  
  text-decoration:none; 
  border-radius:40px;
  font-family: 'aktiv-grotesk-extended', sans-serif;
}
.btn-outline-brand:hover { 
  background-color:var(--cty-ahover); 
  border-color:var(--cty-ahover); 
  color:white; 
  text-decoration:none; 
}

.btn-brand-map { 
  background-color:var(--cty-alink); 
  border:1px solid var(--cty-alink); 
  color:white; 
  font-size:16px; line-height:30px; font-weight:700; text-transform:none; letter-spacing:0.010rem; 
  margin: 4px 2px 4px 0px; 
  padding: 4px 20px 0 20px; 
  transition:var(--cty-transition-hover); 
  text-decoration:none; 
  border-radius:40px;
  font-family: 'aktiv-grotesk-extended', sans-serif;
}
.btn-brand-map:hover { 
  background-color:var(--cty-ahover); 
  border-color:var(--cty-ahover); 
  color:white; 
  text-decoration:none; 
}



.btn-brand-pill { 
  background-color:var(--cty-alink); 
  border:1px solid var(--cty-alink); 
  color:white; 
  font-size:18px; line-height:36px; font-weight:800; text-transform:none; letter-spacing:0.010rem; 
  margin: 4px 2px 4px 0px; 
  padding: 4px 20px 0 20px; 
  transition:var(--cty-transition-hover); 
  text-decoration:none; 
  border-radius:40px;
  font-family: 'aktiv-grotesk-extended', sans-serif;
}
.btn-brand-pill:hover { 
  background-color:var(--cty-ahover); 
  border-color:var(--cty-ahover); 
  color:white; 
  text-decoration:none; 
}

.btn-outline-brand-pill { 
  background-color:transparent; 
  border:2px solid var(--cty-alink); 
  color:var(--cty-alink); 
  font-size:18px; line-height:36px; font-weight:800; text-transform:none; letter-spacing:0.010rem; 
  margin: 4px 2px 4px 0px; 
  padding: 4px 20px 0 20px; 
  transition:var(--cty-transition-hover);  
  text-decoration:none; 
  border-radius:40px;
  font-family: 'aktiv-grotesk-extended', sans-serif;
}
.btn-outline-brand-pill:hover { 
  background-color:var(--cty-ahover); 
  border-color:var(--cty-ahover); 
  color:white; 
  text-decoration:none; 
}

.btn-naked { 
  color:var(--cty-alink); 
  text-transform:uppercase; 
  letter-spacing:0.050rem; 
  margin: 4px 2px 4px 0px; 
  padding: .375rem 0rem; 
  transition:var(--cty-transition-hover);  
}
.btn-naked:hover { 
  color:var(--cty-ahover); 
}

.add-arrow::after {
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  font-family: "Font Awesome 6 Pro";
  font-weight: 400;
  content: "\f178";
  padding-left:8px;
}
.add-angle::after {
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  font-family: "Font Awesome 6 Pro";
  font-weight: 400;
  content: "\203a";
  padding-left:8px;
}



/* link box */


.lk { display:table; width:100%; margin-bottom:0.75rem; background-color:var(--cty-bg-card); padding:1rem 1rem 0.75rem 1rem; }
.lk a { text-decoration:none; color:inherit; }
.lk a:hover { text-decoration:none; color:inherit; }
.lk-arrow { display:table-cell; width:36px; vertical-align:top; font-size:1rem; line-height:1.5; color:var(--cty-alink); }
.lk-content { display:table-cell; width:auto; vertical-align:top; }
.lk-content-primary { font-size:1rem; font-weight:700; margin-bottom:0.2rem; }
.lk-content-secondary { font-size:0.9rem; }


/* button group */

.cafe-button-group { margin:1rem 0; }
.cafe-button-group button { 
  background-color:white; 
  border:1px solid var(--cty-alink); 
  color:var(--cty-alink);
  font-size:0.8rem; font-weight:700; 
  margin: 4px 2px 4px 0px; 
  padding: .375rem .75rem; 
  transition:var(--cty-transition-hover); 
  text-decoration:none; 
}
.cafe-button-group button:hover { 
  background-color:var(--cty-ahover); 
  border-color:var(--cty-ahover); 
  color:white; 
  text-decoration:none; 
}
.cafe-button-group button.button-selected { 
  background-color:var(--cty-alink); 
  border-color:var(--cty-alink); 
  color:white; 
  text-decoration:none; 
}

