html, body { margin: 0; padding: 0; scroll-behavior: smooth; scroll-snap-type: y mandatory; scroll-snap-type: mandatory }
body { font-family: "Piazzolla", serif; font-optical-sizing: auto; font-weight: 400; font-style: normal; font-size: 16px; color: #4C4A4B; line-height: 1.5; margin: 15px; padding: 0; -ms-overflow-style: none; scrollbar-width: none }
::-webkit-scrollbar { display: none }
.site-border { border: solid 15px #256D97; position: fixed; top: 0; right: 0; bottom: 0; left: 0; pointer-events: none }
body.home {margin: 0px}
body.home main { margin: 0 auto; }
main { margin: 40px auto; }
.sm-logo { top: 60px; position: absolute; left: 50%; transform: translateX(-50%); }
.sm-logo img { width: 120px; }
header { display: flex; align-items: center; padding: 10px 20px; background: #ededed; }
header img { height: 50px; position: relative; top: 5px }
section { display: flex; justify-content: center; align-items: center; scroll-snap-align: start }
section#logo { background: #4C4A4B; height: 100vh; }
section#logo .contact { font-size: 16px; color: #fff; position: absolute; bottom: 40px; right: 30px; left: 30px; text-align: center; }
section#logo .contact a { color: #fff; }
section#content { background: url(../_img/golf-course-bg.jpg) no-repeat bottom center scroll; -webkit-background-size: cover; -moz-background-size: cover; background-size: cover; -o-background-size: cover; }
section#content .inner { text-align: left; background: rgba(255, 255, 255, .85); padding: 30px; }
section .inner { width: 100%; max-width: 600px; padding: 0px 20px }
.logo { margin: 0px; }
.main-logo { max-width: 100%; display: block; width: 300px; height: auto }
.dot-nav { position: fixed; top: 30px; right: 32px; display: flex; flex-direction: column; gap: 10px; z-index: 1000 }
.dot-nav a { width: 6px; height: 6px; border-radius: 50%; background: #EDEDED; opacity: .3; -webkit-transition: -webkit-transform .3s ease, background-color .3s ease; transition: transform .3s ease, background-color .3s ease; pointer-events: none; cursor: default }
.dot-nav a.active { opacity: 1; -webkit-transform: scale(1.1); transform: scale(1.1) }
.back-top { text-align: center; margin-top: 20px }
.back-top a { color: #aaa; text-decoration: none; border-bottom: 1px dotted #ccc; text-transform: uppercase; font-size: 11px }
.back-top a:hover { border-bottom: 1px solid #ccc }
a:link { color: #256D97 }
a:hover { text-decoration: none }
h1 { font-family: "Piazzolla", serif; font-optical-sizing: auto; font-weight: 700; font-style: normal; font-size: 1.5rem; margin: 0 }
p { font-size: 16px }
ul { padding-left: 20px; margin: 0px }
ul li { line-height: .9rem; margin-bottom: 5px }
ul.links { list-style: none; padding: 0px; border-top: solid 1px #ededed; margin-top:1em }
ul.links li { border-bottom: solid 1px #ededed; line-height: normal; margin: 0px; }
ul.links li a { display: block; padding: 10px; text-align: center; text-decoration: none; }
ul.links li a:hover { text-decoration: underline; }
.text-center { text-align: center }
hr { border: 0; border-top: 1px solid #EAEDEF }
.container { margin-left: auto; margin-right: auto; width: 100% }
.row { position: relative; width: 100% }
.row::after { content: ""; display: table; clear: both }
.row [class^=col] { float: left; margin: .5rem 2% }
.col-4 { width: 29.333334% }
.scroll-down { position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%); font-size: 2rem; animation: bounce 2s infinite; color: #FFF; opacity: .7; width: 16px }
.scroll-down svg { fill: #FFF }
.text-center { text-align: center }
.btn { font-family: "Piazzolla", serif; padding: 10px 15px; border-radius: 4px; background: #256D97; color: #fff; text-decoration: none; border: 0px; cursor:pointer; }
.btn:hover, .btn:focus { background: #29698f }
.mb-2 { margin-bottom: 2rem }

.menu-btn { margin-left: auto; font-size: 24px; cursor: pointer; }
/* Overlay to detect outside clicks */
.overlay { position: fixed; top: 0; right: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.3); display: none; z-index: 998; }
.side-menu { position: fixed; top: 0; right: -250px; width: 250px; height: 100%; background: #256D97; color: white; transition: right 0.3s ease; z-index: 999; padding-top: 20px; }
.side-menu.active { right: 0; }
.side-menu .close-btn { font-size: 40px; padding: 0px 36px; cursor: pointer; display: block; text-align: right; color: white; }
.side-menu a { display: block; padding: 15px 20px; color: white; text-decoration: none; text-align: center; }
.side-menu a:hover { background: rgba(255, 255, 255, .1); }
input[type="text"], button { font-family: "Piazzolla", serif; padding: 10px; margin: 5px; font-size: 16px; }
@keyframes bounce {
    0%, 20%, 50%, 80%, 100% { transform: translateX(-50%) translateY(0) }
    40% { transform: translateX(-50%) translateY(-10px) }
    60% { transform: translateX(-50%) translateY(-5px) }
}
@media (max-width:768px) {
    .main-logo { margin: 0 auto !important; width: 200px; }
    section#content .inner { padding: 30px 60px; }
    .row [class^=col] { float: left; margin: 0 2% }
    .col-4 { width: 100% }
}
