@font-face {
font-family: 'Della Respira';
src: url('../f/dellarespira-regular.woff2') format('woff2'),
     url('../f/dellarespira-regular.woff') format('woff');
font-weight: normal;
font-style: normal;
font-display: swap;
unicode-range: U+000-5FF;
}

:root {
--base:#fff;
--accent:#583B9B; /* purple */
--accent-2:#8C1682; /* pink */
}

body {
background: var(--base);
font-family: -apple-system,BlinkMacSystemFont,segoe ui,Roboto,Helvetica,Arial,sans-serif,apple color emoji,segoe ui emoji,segoe ui symbol;
font-size: 130%;
margin: 0;
padding: 0;
line-height: 1.2;
}

:focus-visible {
outline: 3px solid black;
box-shadow: 0 0 0 6px white;
}

a { 
text-decoration: underline;
color: var(--accent);
}

a:visited, a:hover, a:focus { 
color: var(--accent-2);
text-decoration: underline;
}

a:active { 
color: #000;
text-decoration: underline;
}

footer, .content {
max-width: 840px;
margin-left: auto;
margin-right: auto;
}

.banner {
background: var(--accent) url(../images/candles01.jpg) no-repeat 50% 50%;
background-size: cover;
box-shadow: 0 0 20px rgb(0 0 0 / 80%) inset;
min-height: 6em;
padding: 4em 0;
}

header {
text-align: center;
margin-bottom: 2em;
background: rgba(0,0,0,.4);
}

.banner header {
padding: 2em;
}

footer {
text-align: center;
margin-top: 6em;
margin-bottom: 6em;
font-size: 70%;
}

h1, h2, h3 {
font-family: 'Della Respira', cursive;
font-weight: normal;
text-align: center;
}

h1 {
font-size: 300%;
color: var(--accent);
margin-top: 0;
margin-bottom: -.2em;
}

h2 {
margin-top: 2em;
font-size: 200%;
color: var(--accent);
}

h3 {
margin-top: 1.5em;
font-size: 150%;
color: var(--accent);
}

p {
margin: 1.2em 0;
}

.lead {
font-family: 'Della Respira', cursive;
font-weight: normal;
font-size: 110%;
}

/* header in banner */

.banner header h1, .banner header h1 span, .banner header p {
color: var(--base);
}

.banner header h1 {
text-shadow: 0.05em 0.05em 0 rgba(0,0,0,.5);
}

.banner header .lead {
text-shadow: 0.1em 0.1em 0 rgba(0,0,0,.5);
}

ul {
padding-left: 0;
}

li {
margin-bottom: 1em; 
list-style: none;
background: url(../images/icon.svg) no-repeat 0 0;
background-size: 2em auto;
background-position: 0 .3em;
padding: .5em 0 .5em 2.5em;
}

p strong, li strong {
color: var(--accent-2);
}

p.center {
text-align: center;
}

main img {
max-width: 100%;
height: auto;
border-radius: 20px;
box-shadow: rgba(100, 100, 111, 0.4) 0px 7px 29px 0px;
}


/* Features */

.features {
display: flex;
flex-wrap: wrap;
justify-content: center;
width: calc(100% + 2em);
margin: 3em 0 3em -2em;
padding: 0;
list-style: none;
}

.features li {
width: calc(50% - 2em);
margin-left: 2em;
margin-top: 3em;
padding: 0;
background: none;
text-align: center;
}

.features li:nth-child(1), .features li:nth-child(2), .features li:nth-child(3) {
margin-top: 0;
}

.features li > :last-child {
margin-bottom: 0;
}

.features li img {
width: 65%;
border-radius: 0;
box-shadow: none;
}

.features li h3 {
margin: 0.5em 0 -.5em 0;
}

.features li p {
font-size: 90%;
}

.gallery {
display: flex;
flex-wrap: wrap;
margin: 2em 0 0 -1.25rem;
width: calc(100% + 1.25rem);
}

.gallery img {
display: block;
margin: 1.25rem 0 0 1.25rem;
width: calc(50% - 1.25rem);
}

.infobox {
display: flex;
flex-flow: row wrap;
margin-bottom: 2em;
}

.imgarea {
flex: 3;
}

.infoarea {
flex: 4;
margin-left: 2em;
}

.infoarea h3 {
text-align: left;
margin-top: 0;
}

hr {
border-top: .1em solid var(--accent-2);
margin-bottom: 3em;
}

a.button {
background: var(--accent);
color: #fff;
padding: 12px 18px;
border: none;
font-size: inherit;
text-decoration: none;
}
a.button:hover, a.button:focus {
background: var(--accent-2);
}


/* sharing */

#sharing {
width:100%;
/*height: 50px;*/
position: fixed;
bottom: 0;
left: 0;
right: 0;
z-index: 10000;
}

ul.share-buttons {
text-align: left;
list-style: none;
padding: 0;
margin: 0;
background: rgba(0,0,0,.7);
width: 100%;
}

ul.share-buttons img {
height: 24px;
}

ul.share-buttons li {
display: inline;
text-align: center;
margin: 0;
background: none;
padding-left: 0;
}

ul.share-buttons li a {
display: inline-block;
width: 12%;
padding: 5px 0 2px 0;
background: #000;
border-radius: 0px;
}

ul.share-buttons li.share {
padding: 0 5px;
}

ul.share-buttons li.share-fb a {
background: #3B5998;
}

ul.share-buttons li.share-tw a {
background: #000;
}

ul.share-buttons li.share-pn a {
background: #DB081c;
}

ul.share-buttons li.share-em a {
background: #444;
}

ul.share-buttons li.share-wa a {
background: #25d366;
}

ul.share-buttons li.share-pr a {
background: #3B5998;
}

ul.share-buttons li a:hover {
filter: brightness(70%);
}

ul.share-buttons .sr-only{
position: absolute;
clip: rect(1px 1px 1px 1px);
clip: rect(1px, 1px, 1px, 1px);
padding: 0;
border: 0;
height: 1px;
width: 1px;
overflow: hidden;
}

@media (min-width: 601px) {

ul.share-buttons li.share-wa {
display: none;
}

}



/* media queries */

@media only screen and (max-width: 900px) {

footer, .content {
max-width: 85%;
}

}

@media only screen and (max-width: 800px) {

.banner {
min-height: 3em;
}

header {
margin-top: 3em;
margin-bottom: 1.5em;
}

.banner header {
margin-top: 0;
padding-top: 2.5em;
padding-bottom: 2.5em;
}

body.page header {
display: block;
}

body.page h1 {
text-align: center;
}

footer {
margin-top: 4em;
margin-bottom: 4em;
line-height: 2;
}

h1 {
font-size: 250%;
}

h2 {
font-size: 150%;
}

h3 {
font-size: 120%;
}

.features {
width: 100%;
margin: 0 0 2em 0;
}

.features li {
width: 100%;
margin-left: 0;
margin-top: 2em;
}

.features li:nth-child(2), .features li:nth-child(3) {
margin-top: 2em;
}

.gallery img {
display: block;
margin: 1.25rem 0 0 1.25rem;
width: 100%;
margin-left: 0;
margin-top: 2em;
}

.imgarea {
flex: 1 100%;
}

.infoarea {
flex: 1 100%;
margin-left: 0;
}

.infoarea h3 {
text-align: center;
margin-top: 1em;
}

.button {
display: inline-block;
line-height: 1.5;
}

}


@media only screen and (max-width: 450px) {

.banner {
min-height: 2.5em;
}

header {
margin-top: 2.5em;
margin-bottom: 1.25em;
}

.banner header {
margin-top: 0;
padding-top: 2em;
padding-bottom: 1em;
}

h1 {
font-size: 180%;
}

h2 {
text-align: left;
font-size: 120%;
}

h3 {
text-align: left;
font-size: 110%;
}

.lead {
font-size: 90%;
}

}