﻿@import url('https://fonts.googleapis.com/css2?family=Alexandria:wght@100..900&family=Kalam:wght@300;400;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Graduate&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Kalam:wght@300..700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Aldrich&display=swap');



:root {
	--co1: #25353F;
	--co1t: hsla(204, 25%, 19%, 0.5);
	--colink: #1091CA;
	--cohover:#DF6F46;
	--colight: snow;
	--codark:#25353F;
	--conorm:#E4E6E7;
}

* {
   box-sizing: border-box;
   user-select: none222;
}

/* MAIN BODY >>> */

body {
	color: var(--codark);
    background-color: var(--conorm);
    font-family: 'Open Sans', sans-serif;
    font-size: medium;
    text-align:left;
    margin:0;
    min-height: 100%;
}

.home {
	background-image:url('../../images/core/bgnd_main.png');
	background-size: cover;
	background-repeat:no-repeat;
}

.dnd {
/* DO NOT DISPLAY */
	display:none;
	visibility:hidden;
}

.eng {
	lang: en;
	font-style:italic;
}

.blogtxt {
	display:none;
	text-align:justify;
}

.lang-eng {
	font-style:italic;
	lang: en-en; 
}

.logo {
	font-family:'Alexandria', sans serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-weight:600;
}

.logo2 {
	font-family:'Alexandria', sans serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-weight:200;
}

.acadomo {
  font-family: "Graduate", serif;
  font-style: normal;
 }
 
a:link, a:visited {
	color: var(--colink);
	text-decoration:none;
}

a:hover {
	color: var(--cohover);
	text-decoration:none;
}

#title-reminder {
	font-family:'Alexandria', display;
	font-optical-sizing: auto;
	font-style: normal;
	color: var(--conorm);
	text-align:right;
	font-size: 0.8em;
	position: fixed;
	right:4px; top: 4px;
	padding: 2px;
	width: auto; height: 100%;
	opacity: 0.8;
}

h1, h2, h3, h4, h5, h6 {
	font-family:'Alexandria', sans serif;
	color: var(--co1);
	/* text-shadow: 1px 1px 2px var(--codark); */
	font-optical-sizing: auto;
	font-style: normal;
	font-weight:600;
	text-align:center;
	-webkit-hyphens: none;
	-ms-hyphens: none;
	hyphens: none;
}

h4, h5, h6 {
 	opacity:0.8;
}

h1::after, h2::after, h3::after, h4::after, h5::after, h6::after {
	content:'';
}

.norm h1, .norm h2, .norm h3, .norm h4 {
	color: var(--codark);
}


.light h1, .light h2, .light h3, .light h4 {
	color: var(--codark);
	text-shadow: 2px 2px 4px rgba(255, 255, 255, 0.9);
}

.dark h1, .dark h2, .dark h3, .dark h4 {
	color: var(--colight);
	text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.9);
}

h1 {
    font-size: 3.0em;
}

h2 {
    font-size:2.5em;
}

h3 {
    font-size: 2.0em;
}

h4 {
    font-size: 1.5em;
}

img {
	height:auto;
	width:auto;
}

table {
	width: 100%;
	font-size:medium;
	margin-top: 20px;
	margin-bottom: 32px;
	border: thin var(--codark) solid;
	border-bottom: medium black solid;
	border-collapse: collapse;
	caption-side: top;
}

.caption-style {
    width:50%;
	margin:auto;
	padding: 4px;
	font-size:large;
	background-color:var(--codark);
	color:snow;
	opacity:0.8;
}

tr {
	font-size: small;
	vertical-align: top;
}

th {
	border-right: thin var(--conorm) solid;
	color:snow; 
	background-color:var(--codark);
	font-size:large;
	text-align: center;
	width:auto;
	padding: 4px;
}

th:last-child {
	
}

th:first-child {
}

td {
	width:auto;
	border-right: thin black solid; 
	text-align: left;
	padding: 10px;
}

td:last-child, th:last-child  {
	border-right: none;
	text-align:center;
}

tr:nth-child(odd) {
	background-color: rgba(0,0,0,0.1);
}

td scrollable-cell {
	max-height: 128px;
	overflow: auto;
}

ul {
	text-align:left;
	list-style-type:square;
	margin-left:-1em;
}

nav {
	text-align:center;
}

img#mainlogo {
	width: auto; height: auto;
	margin:8px;
	animation-name: imgFadeIn;
  	animation-duration: 2.5s;
}

@keyframes imgFadeIn {
	from { opacity: 0.0;}
  	to { opacity: 1.0; }
 }
 
.float-right {
	margin-left: 4px;
	float:right;
}

.float-left {
	margin-right: 4px;
	float:left;
}

img.logo {
	border-radius: 0px;
}

img.float-right, img.float-left {
	max-width:320px;
	height:auto;
}

.centered {
	text-align:center;
}

.scrollable {
	overflow:auto;
	width:auto;
	height:auto;
}

hr {
	width:20%;
	opacity:60%;
	border: 1px var(--conorm) solid;
	margin-top: 12px;
	margin-bottom: 12px;
}

.wide50 {
	width:50%;
	margin:auto;
}

blockquote, aside {
    display: block;
    background: linear-gradient(to bottom, white 95%, transparent 100%);
    color:var(--codark);
    width: 80%;
    padding: 12px;
    margin: 12px auto 12px auto;
    font-size: small;
    border-radius: 16px;
    box-shadow: 0 -4px 8px rgba(0, 0, 0, 0.1);
}

aside {
    border: none;
    color: var(--conorm);
    background:none;
}

cite {
	font-size:medium;
	color: var(--codark);
	font-style:italic;
}

summary {
	font-size:medium;
}

details {
	font-size:small;
	opacity:0.8;
}

.welcome-box {
	background-color: var(-co1);
	padding:10%;
	width:100%; height:100%;
	text-align:center;
	font-size:0.8em;
	animation-name: fading;
	animation-duration: 3s;
}

.welcome-box h1 {
	border:none;
	color:var(--conorm);
	text-align:center;
}

header {
	width:100%; top:0;
	margin:auto;
	text-align:center;
	background-color:var(--co1);
	z-index:100;
}

.header-menu {
	color: snow;
	background-color: var(--co1);
	font-size:large;
	width: auto;
	margin: auto;
	position:sticky; top:0;
	text-align:center;
	z-index:100;
}

.header-menu > div {
	position: relative;
	margin:auto;
	width:80%;
	margin: auto;
	max-width:1200px;
	padding:8px 12px 8px 12px;
	animation-name: fading;
	animation-duration: 2s;
	top: 0px;
	left: 0px;
}

#menu-normal {
	display: inline-block;
}

#menu-ham {
	display: none;
}

.menu-header {
    display: inline;
    cursor:progress;
}

.menu-content {
    display: none;
    background-color:var(--co1);
    transition: all 0.5s ease-in-out;
    position: absolute;
    width:600px;
    left: 50%;
    transform: translateX(-50%);
    border-radius: 0 0 16px 16px;
    padding-bottom:16px;
    padding-top:16px;
    box-shadow: 0 8px 8px rgba(0, 0, 0, 0.1);
}

.menu-container {
    position: relative;
    display: inline-block;
}

.menu-container:hover .menu-content {
    display: block;
}

.menu-content a {
	color: var(--conorm);
    display: block;
    opacity:1.0;
    display: inline-block;
    padding: 12px;
    text-align: center;
    border-radius: 16px;
    transition: all 0.5s ease-in-out;
    text-shadow: none;
}

.menu-content a:hover {
    color: var(--codark);
    background-color: snow;
}

footer {
	width:100%; 
	margin:auto; height:auto;
	margin:0;
	background-color: var(--codark);
	color:var(--conorm);
	text-align:center;
	font-size:medium;
	padding:18px;
	z-index:100;
}

.footer-box {
	text-align:left;
	font-size: medium;
	padding:4px;
	margin:4px;
	color:var(--conorm);
}

#up {
	display:none;
	opacity:0.8;
	padding:6px; cursor: pointer;
	position: fixed;
	right:0; bottom: 20%;
	background-color: var(--conorm);
	z-index: 999;
}

#bti-container {
	width:100%;
	display:none;
	font-weight:bold;
	position: fixed;
	bottom:0;
	background-color: transparent;
	z-index:200;
}

#bottom-info  {
	max-width:300px;
	margin:auto;
	padding:6px;
	background-color: var(--codark);
	font-size:large;
	text-align:center;
	border: thin var(--conorm) solid;
	border-bottom:none;
	border-radius: 10em 10em 0 0;
}

.error-msg, .topinfo-msg {
	margin:0;
	left:0; top:0;
	z-index: 100;
	padding: 20%;
	width: 100%;
	min-height: 60px;
	background-color: red;
	color: snow;
	text-align:center;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.error-msg {
	position:fixed;
	font-size: small;
	height:100%;
}

.topinfo-msg, vacationMessage {
	position:relative;
	font-size:large;
	padding: 6px;
	background-color: var(--co1);
	opacity: 1.0;
	display: none;
}

.error-msg h1 {
	font-size:1.5em;
	color: inherit;
	border-color:inherit;
}

#footer-rgpd, .alert-container {
	display: none;
	opacity: 1.0;
	position:fixed;
	bottom:0;
	margin: auto;
    z-index: 110;
    width:100%;
    left:0;
    font-size:small;
    color: var(--codark);
    background-color: var(--colight);
    box-shadow: 0 -2px 16px rgba(0, 0, 0, 0.1);
	padding: 20px 15% 20px 15%;
    border-top: medium var(--co1t) solid;
	animation-name: fading;
	animation-duration: 2s;
	border-radius: 0;
}

.alert-container {
    border-top-color: var(--co1);
}

.alert-container.narrow {
	width:30%;
	left:35%;
	padding: 8px 6px;
}

.alert-title {
    display: block;
    padding: 6px;
    background-color: transparent;
    color: var(--conorm);
    text-align: center;
    font-weight: bold;
}

.alert-message {
    display: block;
    padding: 8px;
    color: var(--codark);
    text-align: center;
}

.alert-note {
    display: block;
    padding: 0px;
    color: var(--co1);
    font-size:x-small;
    font-style:italic;
    text-align: center;
}

.mainbox, .mainflex {
	background-color: var(--conorm);
	width:100%;
	margin:auto;
	padding:20px;
	padding-left: 15%;
	padding-right:15%;
	
}

.mainbox {
	animation-name: fading;
	animation-timing-function: ease-in-out;
	animation-duration: 2s;
}

.mainflex {
	margin:auto;
	display: flex;
	flex-wrap: wrap;
	flex-direction: row;
	justify-content: space-between;
	align-items: legacy;
	align-content: stretch;
	animation-name: fading;
	animation-timing-function: ease-in-out;
	animation-duration: 2s;
}

.mainbox .mainflex {
	padding-left: 0;
	padding-right:0;
	color: var(--co1)
}

.mainflex.menu {
	justify-content: center;
}

.flexbox {
	border-style: none;
	background-color: transparent;
	border-color: none;
	border-width: medium;
	position: relative;
	width:300px; height: auto;
	padding:16px; margin-bottom: 8px;
	margin:20px;
	border-radius: 16px;
	box-shadow: 0 8px 8px rgba(0, 0, 0, 0.1);
	text-align:center;
}

.flexbox.grow2 {
	flex-grow:2;
}

.flexbox.grow3 {
	flex-grow:3;
}

.flexbox.grow4 {
	flex-grow:4;
}

.flexbox.grow5 {
	flex-grow:5;
}

.maingrid {
	display:grid;
	grid-auto-flow: column;
	grid-template-columns: auto auto auto;
  	grid-template-rows: auto auto auto;
	gap: 8px;
 	background-color: transparent;
 	padding: 10px;
}

.maingrid > a {
  background-color: transparent;
  text-align: left;
  padding:4px 0;
}

.-round {
	border-radius:50%;
	width:200px;
	height:200px;
}

img.img100 {
	display: block;
	margin:auto;
	width:100%;
	height:auto;
	box-shadow: 0 0 8px rgba(0,0,0,0.2);
	transition: all 2s;
}

.flexbox hr {
	width:100%;
}

.box-title {
	width: 100%;
	height: 160px;
	background-position:center;
	background-repeat:no-repeat;
	background-size:cover;
	padding: 12px;
}

.grid-container {
  display: inline-grid;
  width: 100%;
  grid-template-columns: auto auto;
  padding: 0;
}

.grid-item {
  padding: 2px;
  text-align: left;
  font-size:small;
}

.grid-item img {
	padding-right: 8px; 
	vertical-align:middle; 
}

.light {
	background-color: var(--colight);
	color: var(--codark);
}

p.light, p.dark {
	padding: 8px;
}

.dark, .darkoblique, .darkhalo {
	background-color: var(--codark);
	color:var(--conorm);
}

.darkoblique {
	background-color:var(--conorm);
	background: linear-gradient(135deg, var(--co1) 50%, var(--codark) 50%);
}

.darkhalo {
	background-color:var(--conorm);
 	background-image: radial-gradient(var(--codark) 0%, var(--co1) 33%);
 }

.lightoblique {
	background-color:var(--codark);
	background: linear-gradient(135deg, var(--codark) 8%, var(--conorm) 8%);
}

.title-content {
	background-color:var(--co1);
	width:100%;
	margin:auto;
    padding:20px;
    padding-left: min(10%, 50%-600px);
    padding-right: min(10%, 50%-600px);
    min-height:200px;
    text-align:center;
    background-position-x: center;
    background-position-y: center;
	background-repeat:no-repeat;
	background-size: auto;
}

.title-content.empty {
	background-image:url('../../images/core/fortheo_monogram.png');
	background-position:center;
	background-repeat:repeat;
	background-size: auto;
}

.title-content h1 {
	font-family:"Alexandria", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	color: var(--conorm);
	font-weight:bold;
	/* border-left: 1.0em var(--conorm) dotted; */
	text-shadow: 2px 2px 8px rgba(0,0,0, 0.2);
}

img#vcard {
	width:100%;
	height:auto;
	border-shadow: 2px 2px 8px rgba(0,0,0, 0.2);
}

img.tit {
	width:100%;
	height: auto;
	border-shadow: 2px 2px 8px rgba(0,0,0, 0.2);
}


img.notanad {
	max-height:300px;
}

img.ohpc {
	width:100%;
	height:auto;
}

img.shimmer {
	position: relative;
	animation-name: shimmering;
	transition-timing-function: ease;
	animation-duration: 1s;
	animation-iteration-count: infinite;
	animation-direction: alternate;
}

img.shimmer:hover {
	animation-name: pulsemove;
	transition-timing-function: ease;
	animation-duration: 0.5s;
	animation-iteration-count: infinite;
}


input[type=number] {
	text-align:right; font-size:large;
	width:100%; max-width:160px;
	height:24px;
	padding: 8px;
	background-color: var(--conorm);
	color: var(--codark);
	box-shadow: 0 0 6px 3px rgba(0,0,0,0.2) inset;
	border: none;
}

input[type=number]:disabled {
	color: snow;
	background-color: var(--conorm);
}

.handwritten {
	font-family: "Kalam", cursive;
	font-style: normal;
	font-weight: 400;
	font-size:2.5em;
	text-shadow: 0 0 8px rgba(0,0,0,0.2);
}


.handwritten.small {
	font-size: 1em;
	text-shadow: none;
}

.bottom-info {
	font-size:small;
	padding-bottom: 12px;
	opacity:0.8;
}

.btn {
	display:inline-block;
	min-width: 120px;
	color: var(--codark);
	font-family: 'Open Sans', sans-serif;
	border-radius: 24px;
	background-color: var(--conorm);
	border: thin var(--co2) solid;
	padding: 8px; margin: 2px;
	box-shadow: 0 0 8px rgba(0, 0, 0, 0.5);
	cursor:pointer;
}

.btn:hover:not(:disabled) {
    box-shadow: 0 0 16px rgba(0, 0, 0, 0.5) inset;
}

.btn.light {
	background-color: var(--conorm);
	color: var(--codark);
}

.btn.dark {
	background-color: var(--codark);
	color: var(--conorm);
}

.btn:disabled {
    cursor: not-allowed;
    filter: grayscale(75%);
    padding:3px;
    margin:0 2px;
}

.btn.closeCross {
	position:absolute;
	min-width: 0;
	color: var(--codark);
	top: 4px; right:4px;
	font-size:small;
	font-weight:bold;
	width: auto;
	padding: 4px;
	margin:4px;
	border: none;
	box-shadow: none;
}

#cntdwn-container {
	width:33%; height: 20px;
	max-width: 180px;
	margin: auto;
	border:thin var(--co1) solid;
	padding:2px;
}

#cntdwn {
	left:0; position: relative;
	height:100%;
	background-color: var(--co1);
}

@keyframes shimmering {
    0%	{ opacity: 1.0;}
    100% { opacity: 0.5;}
}

@keyframes pulsemove {
    0%	{ top: 0px;}
    50%	{ top: -8px;}
    100% { top: 8px;}

}

@media screen and (max-width: 1200px) {
	.mainflex {
	    justify-content: space-around;
	    -webkit-hyphens: auto;
		-ms-hyphens: auto;
		hyphens: auto;

    }
}

@media screen and (max-width: 768px) {
    body, p {
        font-size:large;
    }
    
    h1 {
        font-size: 2.0em;
    }
    
    h2 {
        font-size: 1.5em;
    }
    
    h3 {
        font-size: 1.2em;
    }
    
    h4 {
        font-size: 1.0em;
    }
    
    td, th {
		font-size: small;
	}
	
	.flexbox {
		min-width:auto;
		padding:10px;
		margin-bottom: 8px;
		margin:20px;
	}
    
	aside {
	    width: 100%;
	    float:none;
	    margin:auto;
	}
		
	.title-content {
	    background-position:center;
		background-repeat:no-repeat;
		background-size:cover;
	}
	
    img.main-logo {
		max-width: 320px;
		width: auto;
	}
	
	.header-menu {
		text-align:left;
	}
		
	.header-menu > div {
		width: 100%;
		padding:8px;
	}
	
	#mainlogo {
		width:auto;
		max-width:90%;
	}
	
	#menu-normal {
		display: none;
	}
	
	#menu-ham {
		display: inline-block;
		z-index:900;
		text-align:center;
	}
	
	@keyframes AutoSlide {
		0%	{ left:-100%;}
	  100% 	{ left:0; }
	}
	
	#ham-content {
		display:none;
		position: fixed;
		text-align:left;
		font-size:x-large;
	    height:100%;
	    left:0; top:0; margin:0;
	    min-width: 100%;
	    overflow:auto;
	    padding: 12px;
	    border-right: thin var(--codark) solid;
	  	box-shadow: 40% 0 16px rgba(0, 0, 0, 0.1);
	  	opacity: 0.97;
	}

	#ham-content:target {
		display: block;
		animation-name: AutoSlide ;
		animation-duration: 1s;
		animation-timing-function: cubic-bezier(0.7, 1.0, 0.5);
	}

	.mainflex {
		flex-flow: column nowrap;
		width:100%; height:auto;
		padding: 4px;
		margin:0;
	}
	
	.flexbox, .mainbox {
		width:100%;
		margin: auto;
		padding:8px;
		margin-bottom: 8px;
	}

	#footer-rgpd, .alert-container, .alert-container.narrow {
	    width:100%;
	    left:0;
		margin:auto;
		padding:16px;
		padding-right:20%;

	}
	
	#up {
		bottom: 20%;
	}

	img.notanad {
		width:100%;
		height:auto;
		max-height:none;
	}
	
	.footer-box {
	text-align:center;
	}
	
	table {
		width: 200%;
	}

}
/* <<< END responsive */









