html, body { max-width: 1400px; margin: 0 auto; font-family: "montserrat", sans-serif; font-size: 0.9rem; font-size: clamp(0.85rem, 3.5vw, 1rem); color: #080808; }

video { width: 100%; height: 100%; }

@keyframes pulse { 0% { transform: scale(1); } 50% { transform: scale(1.1); } 100% { transform: scale(1); } }
.pulse { animation: pulse 0.9s infinite; z-index: 2; }

.pane { transform: translateY(100%); opacity: 0; transition: transform 1s ease-out, opacity 2s ease-out, filter 2s ease-out; }
.pane.visible { transform: translateY(0);  opacity: 1; }

@keyframes IncreaseStrong  { from { font-size: 6px; } to { font-size: clamp( 1.2rem, 3.5vw, 2rem); } }
strong { animation: IncreaseStrong 1.8s ease-out forwards; font-weight: 900; text-wrap: balance; color: #fffffe; }

h1, h2, h3, h4 { text-transform: capitalize; font-weight: 900; margin: 40px 0px; text-wrap: balance; }
h1 { margin: 20px 0px; font-size: clamp( 1.6rem, 3.5vw, 2rem) }
h2 { font-size: clamp( 1.6rem, 3.5vw, 1.8rem); }
h3 { font-size: clamp( 1.2rem, 3.5vw, 1.6rem); }
h4 { font-size: clamp( 1.1rem, 3.5vw, 1.4rem); }
h5 { font-size: clamp( 1.1rem, 3.5vw, 1.3rem); margin: 0px 0px; }

@media screen and (max-width: 700px) { h1, h2, h3, h4, h5, h6, strong { margin: 20px 0px; }}

#blueblackGlass, #blueGlass { background-image: linear-gradient(to bottom right, rgba(23,67,88,0.8), rgba(8,8,8,0.8)); color: #fff; border-radius: 6px; margin: 20px 0px; padding: 20px; z-index: 1; }
#blueGlass {  padding: 5px 20px; }
#blueblackGlass  h2 { animation: IncreaseH2 1.8s ease-out forwards; }
#page { margin: 0 auto; text-align: left; width: 90%; }

header { display: grid; grid-template-columns: 1fr 1fr ; padding: 5px 0px 0px; margin: 6px 0px 0px; place-items: center; gap: 30px; }
.column2 { display: grid; grid-template-columns: 1fr 1fr ; margin: 6px 0px; gap: 20px; }
.bottomWrapper { display: grid; grid-template-columns: 33% 67%; margin: 20px 0px; }
.overlay { margin: 40px 0px;  }
.overlay2 { margin: 15% 2% 0% 5%; }
@media screen and (max-width: 900px) { header, .column2 { grid-template-columns: 100%; } }
@media screen and (max-width: 900px) { .column2 { gap: 10px;} }
@media screen and (max-width: 700px) { .bottomWrapper { grid-template-columns: 100%; padding: 0px 40px; } }
@media screen and (max-width: 700px) { .overlay2 { margin-top: -20%; padding-bottom: 20px; z-index: 1; } }

aside { text-align:justify; line-height: 150%; }

details > summary { cursor: grab; padding: 8px 0px 8px 20px; margin: 4px 0px 4px 0px; font-weight: 900; color: white; text-wrap: balance; }
details > p { padding: 8px 0px 8px 0px; margin: 4px 0px 4px 0px; color: #FFF; text-align:justify; line-height: 150%; }
details > h2, h3, h4 { margin: 16px 0px; font-weight: 900;}
details > h2 { margin: 20px 0px; font-size: clamp(1.3rem, 3.5vw, 1.8rem);}
details > h3 { font-size: clamp(1.2rem, 3.5vw, 1.6rem);}
details > h4 { font-size: clamp(1.1rem, 3.5vw, 1.1rem);}

@keyframes slide { from { transform: translateX(100%); } to { transform: translateX(0); } }
div.sticky { position: -webkit-sticky; position: sticky; bottom: 0; z-index: 4; animation: slide 0.9s ease-out; }

#fadeout { height:100px; position:fixed; bottom:0; width:100%; background: linear-gradient(to bottom,  rgba(255,255,255,0) 0%,rgba(255,255,255,1) 90%); filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#ffffff',GradientType=0 ); z-index: 3; }

main { margin: 5px 0px 2px 0px; width: 100%; text-align: left; background: rgba(255, 255, 255, 0.9); }

p { text-align:justify; line-height: 150%; }
b { font-size: clamp( 0.9rem, 3.5vw, 1.1rem); font-weight: 900; }
.spacing { letter-spacing: .1rem; }

.br { display: block; margin-top: 8px; }
.br2020 { margin: 20px 0px; }
.br3030 { margin: 30px 0px; }
.br4040 { margin: 50px 0px 0px; }
large { font-size: clamp( 1.1rem, 3.5vw, 1.6rem); font-weight: 900; margin: 20px 0px 20px; }
small { font-family: "Playfair Display", serif; font-weight: 900; }

img { max-width: 100%; height: auto; }
.icon { width: 80px; height: 79px; }
.xp { width: 62px; height: 55px; margin: 0px 0px 10px 12px; }
.logo, .logo2 { width: 100%; height: auto; }
.logo2 { margin: 20px 0px; }
.signature { width: 110px; height: 55px; }
.imgBooklet { width: 194px; height: 288px; margin: 25px 0px 20px 20px; float: right; }

@media screen and (max-width: 700px) {
.imgBooklet { width: 108px; height: 162px; margin: 25px 0px 20px 20px; float: right; } }

fieldset { border-box: 4px solid; padding: 10px; margin: 40px 0px; line-height: 150%; border-image-source: radial-gradient( circle at bottom right, #4f4f4e, #ccc, transparent 120%); border-image-slice: 1; }
fieldset p { text-align:justify; }
legend {  font-size: clamp(1rem, 3.5vw, 1.2rem); font-weight: 900; text-wrap: balance; text-align: left; }
.red { padding: 10px; border-radius: 6px; margin: 40px 0px; border: 3px solid #ef4123; }
@media screen and (max-width: 700px) { fieldset, .red { margin: 20px 0px; } }

mark { background-color: #ccc; text-transform: capitalize; font-weight: 600; }

.q { position: relative; padding-left: 1.1em; font-style: italic; margin: 40px 0px; color: #505050; }
.q::before { content: "“"; position: absolute; left: 0; top: 0; font-size: 1.5em; line-height: 0.8; }
.q:not(:has(.attrib))::after { content: "”"; }
.attrib { display: inline-block; margin-left: 0.2em; font-style: normal; }
.attrib::before { content: "” — "; font-style: normal; }
.qReduce { margin: 0px 0px 40px; }
.reduceTopMargin { margin-top: -10px; }
.reduceTopMargin2 { margin-top: 10px; }
.increaseTopMargin { margin-top: 50px; font-weight: bold; }
.reduceTopMargin3 { margin-top: -30px; font-weight: bold; }

.indent { position: relative; padding-left: 1.1em; font-style: italic; color: #505050; margin-top: -40px; }

a { color: #fffffe; text-decoration: underline; font-weight: 900; }
a:hover { text-decoration: none; color: #32cd32; }
a:visited { text-decoration: none; }

#contact { font-size: 12px; margin: 10px 5px 10px 5px; text-align: center; }

.booklet { display: grid; grid-template-columns: 1fr 1fr; }
@media screen and (max-width: 1110px) { .booklet { grid-template-columns: 100%; }}

.dropBooklet { width: 194px; height: 288px; padding: 40px 20px; }
@media screen and (max-width: 700px) { .dropBooklet { width: 108px; height: 162px; margin: 20px 0px; float: left; padding: 20px; }}

#menu { list-style-type: none; margin: 2px 0px 2px 0px; padding: 2px 2px 2px 2px; overflow: hidden; border-radius: 6px; text-wrap: balance;	}
#menu li { float: left; }
#menu li a { display: inline-block; color: white; text-align: left; padding: 10px 10px; font-weight: 900; }
#menu li a:hover { color: black; background-color: white; border-radius: 6px; }