/*------------------------------------------------------------------
Project:  ComingSoon
Version:  
Last change:  
Assigned to:  Bach Le
Primary use:  
-------------------------------------------------------------------*/



@font-face {
    font-family: 'Montserrat-Regular';
    src: url('../fonts/PixleFont/PressStart.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Montserrat-SemiBold';
    src: url('../fonts/PixleFont/PressStart.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
}

@font-face {
  font-family: 'Playlist Script';
  src: url('../fonts/Playlist/Playlist Script.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'PressStart';
  src: url('../fonts/PixleFont/PressStart.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* Pixel font - local file */
@font-face {
  font-family: 'PressStartLocal';
  src: url('../fonts/PixleFont/PressStart.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/*---------------------------------------------*/
.container {max-width: 1200px;}



.contact100-form {
  max-width: 100%;
}


.wrap-input100 {
  width: min(280px, 100%);
  position: relative;
  background-color: transparent;
  height: 50px;
}

/*---------------------------------------------*/
.input100 {
  display: block;
  width: 100%;
  height: 100%;
  padding: 0 40px 0 3px;
  border-bottom: 1px solid rgba(255,255,255,0.1);
  background-color: rgba(255,255,255, 0.0);
}

.input100:focus {
  background-color: rgba(255,255,255, 0.05);
}


/*------------------------------------------------------------------
[ Alert validate ]*/

.validate-input {
  position: relative;
}

.alert-validate::before {
  content: attr(data-validate);
  position: absolute;
  max-width: 70%;
  background-color: #fff;
  border: 1px solid #c80000;
  border-radius: 0px;
  padding: 4px 25px 4px 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 32px;
  pointer-events: none;

  font-family: Montserrat-Regular;
  color: #c80000;
  font-size: 14px;
  line-height: 1.4;
  text-align: left;

  visibility: hidden;
  opacity: 0;

  -webkit-transition: opacity 0.4s;
  -o-transition: opacity 0.4s;
  -moz-transition: opacity 0.4s;
  transition: opacity 0.4s;
}

.alert-validate::after {
  content: "\f071";
  font-family: FontAwesome;
  display: block;
  position: absolute;
  color: #c80000;
  font-size: 14px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 38px;
}

.alert-validate:hover:before {
  visibility: visible;
  opacity: 1;
}

@media (max-width: 992px) {
  .alert-validate::before {
    visibility: visible;
    opacity: 1;
  }
}



.simpleslide100 {
  display: block;
  position: fixed;
  z-index: 0;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-color: #000;
}

.simpleslide100-item {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}



/*==================================================================
    TEXT TEXT TEXT TEXT TEXT TEXT TEXT TEXT TEXT TEXT TEXT TEXT TEXT
==================================================================*/

/*==================================================================
[ Color ]*/
.cl0 {color: #fff;}
.cl1 {color: #999;}





.s1-txt1 {
  font-family: Montserrat-SemiBold;
  font-size: 14px;
  color: #fff;
  line-height: 1.2;
  text-transform: uppercase;
}



.m1-txt1 {
  font-family: Montserrat-Regular;
  font-size: 14px;
  color: #fff;
  line-height: 1;
}




.l1-txt1 {
  font-family: Montserrat-Regular;
  font-size: clamp(16px, 2.5vw, 20px);
  color: #fff;
  line-height: 1;
}

.l1-txt2 {
  font-family: Montserrat-Regular;
  font-size: clamp(32px, 6vw, 60px); /* min, fluid, max */
  line-height: 1.05;
  color: #fff;
  max-width: 100%;
  word-break: break-word;
  margin: 0 auto;
  text-align: center;
  padding-left: 10px;
  padding-right: 10px;
}


/*==================================================================
   SHAPE SHAPE SHAPE SHAPE SHAPE SHAPE SHAPE SHAPE SHAPE SHAPE SHAPE
==================================================================*/

.size1 {
  width: 100%;
  min-height: 100vh;
  padding-left: 15px;
  padding-right: 15px;
  box-sizing: border-box;
}

.size2 {
  min-width: 140px;
  height: 50px;
}

.size3 {
  width: 36px;
  height: 36px;
}

.size4 {
  width: 35px;
  height: 100%;
}



.wsize1 {
  min-width: 46px;
}






.bg0 {background-color: #fff;}

.bg-img1 {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}







/*==================================================================
   WHERE WHERE WHERE WHERE WHERE WHERE WHERE WHERE WHERE WHERE WHERE  
==================================================================*/
.where1 {
  align-self: flex-start;
}



/*==================================================================
 HOW HOW HOW HOW HOW HOW HOW HOW HOW HOW HOW HOW HOW HOW HOW HOW HOW 
==================================================================*/
.placeholder0::-webkit-input-placeholder { color: #999999;}
.placeholder0:-moz-placeholder { color: #999999;}
.placeholder0::-moz-placeholder { color: #999999;}
.placeholder0:-ms-input-placeholder { color: #999999;}


/*---------------------------------------------*/
.overlay1 {
  position: relative;
  z-index: 1;
}
.overlay1::after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: rgba(0,0,0,0.5);
}

/*---------------------------------------------*/
.wrappic1 {
  display: block;
  flex-grow: 1;
}

.wrappic1 img {
  max-width: 100%;
}

/*---------------------------------------------*/
.how-btn1 {
  padding: 0 15px;
  background-color: transparent;
  border: 1px solid #fff;
  border-radius: 0px;
}

.how-btn1:hover {
  background-color: #fff;
  color: #555;
}

/*---------------------------------------------*/
.how-social {
  color: #999;
  font-size: 18px;
  border: 1px solid rgba(255,255,255,0.1);
  background-color: transparent;
  border-radius: 50%;
}

.how-social:hover {
  background-color: #fff;
  color: #555;
}

/*---------------------------------------------*/
.how-btn-play1 {
  width: 60px;
  height: 60px;
  background-color: transparent;
  border-radius: 50%;
  font-size: 20px;
  color: #333;
  position: relative;
  z-index: 1;
}

.how-btn-play1::after {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-color: #fff;
  border-radius: 50%;

  -webkit-transition: all 0.4s;
  -o-transition: all 0.4s;
  -moz-transition: all 0.4s;
  transition: all 0.4s;
}

.how-btn-play1:hover:after {
  opacity: 0.6;
  -webkit-transform: scale(1.2);
  -moz-transform: scale(1.2);
  -ms-transform: scale(1.2);
  -o-transform: scale(1.2);
  transform: scale(1.2);
}


/*------------------------------------------------------------------
[ Focus ]*/
.focus-in0:focus::-webkit-input-placeholder { color:transparent; }
.focus-in0:focus:-moz-placeholder { color:transparent; }
.focus-in0:focus::-moz-placeholder { color:transparent; }
.focus-in0:focus:-ms-input-placeholder { color:transparent; }


/*------------------------------------------------------------------
[ Hover ]*/
.hov-cl0:hover {color: #fff;}
.hov-bg0:hover {background-color: #fff;}

/*---------------------------------------------*/
.hov1:hover i {
  color: #fff;
}






/*==================================================================
  RESPONSIVE RESPONSIVE RESPONSIVE RESPONSIVE RESPONSIVE RESPONSIVE
==================================================================*/



@media (max-width: 1200px) {
  .m-0-xl {margin: 0;}
  .m-lr-0-xl {margin-left: 0; margin-right: 0;}
  .m-lr-15-xl {margin-left: 15px; margin-right: 15px;}
  .m-l-0-xl {margin-left: 0;}
  .m-r-0-xl {margin-right: 0;}
  .m-l-15-xl {margin-left: 15px;}
  .m-r-15-xl {margin-right: 15px;}

  .p-0-xl {padding: 0;}
  .p-lr-0-xl {padding-left: 0; padding-right: 0;}
  .p-lr-15-xl {padding-left: 15px; padding-right: 15px;}
  .p-l-0-xl {padding-left: 0;}
  .p-r-0-xl {padding-right: 0;}
  .p-l-15-xl {padding-left: 15px;}
  .p-r-15-xl {padding-right: 15px;}

  .w-full-xl {width: 100%;}

  /*---------------------------------------------*/

}



@media (max-width: 992px) {
  .dis-none-lg {display: none;}
  .m-0-lg {margin: 0;}
  .m-lr-0-lg {margin-left: 0; margin-right: 0;}
  .m-lr-15-lg {margin-left: 15px; margin-right: 15px;}
  .m-l-0-lg {margin-left: 0;}
  .m-r-0-lg {margin-right: 0;}
  .m-l-15-lg {margin-left: 15px;}
  .m-r-15-lg {margin-right: 15px;}

  .p-0-lg {padding: 0;}
  .p-lr-0-lg {padding-left: 0; padding-right: 0;}
  .p-lr-15-lg {padding-left: 15px; padding-right: 15px;}
  .p-l-0-lg {padding-left: 0;}
  .p-r-0-lg{padding-right: 0;}
  .p-l-15-lg {padding-left: 15px;}
  .p-r-15-lg {padding-right: 15px;}

  .w-full-lg {width: 100%;}

  /*---------------------------------------------*/
   .respon1 {
    font-size: clamp(28px, 7.5vw, 48px);
  }

  /* Center logo and timer on tablet and smaller */
  .w-full.flex-w.flex-sb-m {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px; /* space between logo and timer */
  }

  .w-full.flex-w.flex-sb-m > .wrappic1 {
    margin: 0; /* remove right margin used on desktop */
    text-align: center;
  }

  .w-full.flex-w.flex-sb-m > .cd100 {
    padding-right: 0;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }

  /* reduce spacing between countdown blocks on small screens */
  .w-full.flex-w.flex-sb-m .cd100 .m-r-22 {
    margin-right: 10px;
  }
}



@media (max-width: 768px) {
  .m-0-md {margin: 0;}
  .m-lr-0-md {margin-left: 0; margin-right: 0;}
  .m-lr-15-md {margin-left: 15px; margin-right: 15px;}
  .m-l-0-md {margin-left: 0;}
  .m-r-0-md {margin-right: 0;}
  .m-l-15-md {margin-left: 15px;}
  .m-r-15-md {margin-right: 15px;}

  .p-0-md {padding: 0;}
  .p-lr-0-md {padding-left: 0; padding-right: 0;}
  .p-lr-15-md {padding-left: 15px; padding-right: 15px;}
  .p-l-0-md {padding-left: 0;}
  .p-r-0-md{padding-right: 0;}
  .p-l-15-md {padding-left: 15px;}
  .p-r-15-md {padding-right: 15px;}

  .w-full-md {width: 100%;}

  /*---------------------------------------------*/
  .respon1 {
    font-size: clamp(28px, 7.5vw, 48px);
  }

}



@media (max-width: 576px) {
  .dis-none-sm {display: none;}
  .m-0-sm {margin: 0;}
  .m-lr-0-sm {margin-left: 0; margin-right: 0;}
  .m-lr-15-sm {margin-left: 15px; margin-right: 15px;}
  .m-l-0-sm {margin-left: 0;}
  .m-r-0-sm {margin-right: 0;}
  .m-l-15-sm {margin-left: 15px;}
  .m-r-15-sm {margin-right: 15px;}

  .p-0-sm {padding: 0;}
  .p-lr-0-sm {padding-left: 0; padding-right: 0;}
  .p-lr-15-sm {padding-left: 15px; padding-right: 15px;}
  .p-l-0-sm {padding-left: 0;}
  .p-r-0-sm{padding-right: 0;}
  .p-l-15-sm {padding-left: 15px;}
  .p-r-15-sm {padding-right: 15px;}

  .w-full-sm {width: 100%;}

  /*---------------------------------------------*/
   .respon1 {
    font-size: clamp(20px, 10vw, 36px);
  }
  
}



@media (max-width: 480px) {
  .m-0-ssm {margin: 0;}
  .m-lr-0-ssm {margin-left: 0; margin-right: 0;}
  .m-lr-15-ssm {margin-left: 15px; margin-right: 15px;}
  .m-l-0-ssm {margin-left: 0;}
  .m-r-0-ssm {margin-right: 0;}
  .m-l-15-ssm {margin-left: 15px;}
  .m-r-15-ssm {margin-right: 15px;}

  .p-0-ssm {padding: 0;}
  .p-lr-0-ssm {padding-left: 0; padding-right: 0;}
  .p-lr-15-ssm {padding-left: 15px; padding-right: 15px;}
  .p-l-0-ssm {padding-left: 0;}
  .p-r-0-ssm{padding-right: 0;}
  .p-l-15-ssm {padding-left: 15px;}
  .p-r-15-ssm {padding-right: 15px;}

  .w-full-ssm {width: 100%;}
}

/* Purple floating pixels */
.pixels {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2; /* above overlay */
  overflow: visible;
}

.pixel {
  position: absolute;
  width: 6px;
  height: 6px;
  background: #9b59b6;
  opacity: 0.8;
  border-radius: 1px;
  will-change: transform, opacity;
  animation-name: floatMove;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
}

@keyframes floatMove {
  0% {
    transform: translateY(0) translateX(0) rotate(0deg) scale(1);
    opacity: 1;
  }
  50% {
    opacity: 0.7;
  }
  100% {
    transform: translateY(-120vh) translateX(30vw) rotate(360deg) scale(0.9);
    opacity: 0;
  }
}

/* smaller pixels on small screens */
@media (max-width: 576px) {
  .pixel { width: 4px; height: 4px; }
}

/* Minimal, professional styles for DOS DEV landing page */
:root{
  --bg-1:#0b0f14;
  --bg-2:#08101a;
  --panel:#0f1724;
  --muted:#8f98a6;
  --accent:#7c3aed;
  --accent-2:#5b21b6;
  --text:#e6eef8;
  --max-width:1100px;
  --gap:18px;
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial;
}

/* page background: subtle pixel grid */
html,body{height:100%;margin:0;background:
  linear-gradient(180deg,var(--bg-1) 0%, var(--bg-2) 100%);
  color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden}

/* repeating pixel grid using small squares */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;
  background-image:
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 12px 12px, 12px 12px;
  opacity:0.03;mix-blend-mode:overlay;z-index:0;
}

/* container */
.container{max-width:var(--max-width);margin:0 auto;padding:0 20px;position:relative;z-index:1}

/* header */
.site-header{padding:18px 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;flex-direction:column;gap:6px}
.logo{display:block}
.site-logo{display:block;max-width:150px;height:auto;image-rendering:pixelated}
.tagline{font-size:12px;color:var(--muted)}

/* nav */
.nav{display:flex;gap:12px}
.nav a{color:var(--muted);text-decoration:none;font-size:13px;padding:8px 10px;border-radius:6px;display:inline-block}
.nav a:hover{background:rgba(255,255,255,0.02);color:var(--text)}

/* hero */
.hero{padding:64px 0 40px}
.hero-inner{text-align:center;max-width:920px;margin:0 auto}
.hero-title{font-family: 'Press Start 2P', cursive; font-size:20px; letter-spacing:1px; margin:0 0 12px; color:var(--accent)}
.hero-desc{color:var(--muted);margin:0 0 20px;line-height:1.45;max-width:780px;margin-left:auto;margin-right:auto}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* pixel-style buttons */
.btn{display:inline-block;padding:10px 16px;border-radius:3px;text-decoration:none;font-weight:700;border:3px solid rgba(0,0,0,0.35);cursor:pointer;box-shadow: 0 6px 0 rgba(0,0,0,0.45);transform:translateY(0);transition:transform .08s}
.btn:active{transform:translateY(3px);box-shadow:0 3px 0 rgba(0,0,0,0.45)}
.btn.primary{background:linear-gradient(180deg,var(--accent) 0%, var(--accent-2) 100%);color:#fff}
.btn.ghost{background:transparent;color:var(--text);border-color:rgba(255,255,255,0.06)}

/* sections */
.section{padding:42px 0}
.section-title{font-family:'Press Start 2P', cursive;font-size:14px;margin:0 0 10px;color:var(--accent)}
.section-sub{color:var(--muted);margin:0 0 18px}

/* Make every section fill the viewport and center its content */
.section,
.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 40px;
  padding-bottom: 40px;
  box-sizing: border-box;
}

/* Ensure the immediate container inside a section centers its inner content */
.section > .container,
.hero > .container {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 20px;
}

/* Keep grid and forms working while vertically centered */
.grid { align-self: stretch; }
.contact-grid { align-self: stretch; }

/* Reduce vertical padding on small screens */
@media (max-width: 600px) {
  .section,
  .hero {
    padding-top: 24px;
    padding-bottom: 24px;
  }
}

/* grid */
.grid{display:grid;gap:var(--gap)}
.grid-3{grid-template-columns:repeat(3,1fr)}
@media (max-width:900px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.grid-3{grid-template-columns:1fr}}

/* card: pixel/retro aesthetic */
.card{
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border: 3px solid rgba(0,0,0,0.35);
  padding:16px;border-radius:4px;min-height:110px;
  box-shadow: 0 6px 0 rgba(0,0,0,0.45);
}
.card h3{margin:0 0 8px;font-size:13px;font-weight:700}
.card p{margin:0;color:var(--muted);font-size:13px;line-height:1.4}

/* why */
.why-list{list-style:none;padding:0;margin:12px 0 0;display:grid;gap:10px}
.why-list li{background:rgba(255,255,255,0.02);padding:10px 12px;border-radius:4px;border:2px solid rgba(0,0,0,0.25);font-size:13px;color:var(--text)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 420px;gap:26px;align-items:start}
@media (max-width:960px){.contact-grid{grid-template-columns:1fr}}
.contact-line{color:var(--muted);margin:8px 0}
.contact-form{background:linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.02));padding:16px;border-radius:4px;border:2px solid rgba(0,0,0,0.25)}
.contact-form input,.contact-form textarea{width:96%;padding:10px;border-radius:4px;border:2px solid rgba(0,0,0,0.18);background:transparent;color:var(--text);margin-bottom:10px;font-size:13px}
.contact-form textarea{resize:vertical}
.form-actions{text-align:right}

/* footer */
.site-footer{border-top:2px solid rgba(255,255,255,0.02);padding:18px 0;margin-top:30px}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.footer-nav{display:flex;gap:10px}
.footer-nav a{color:var(--muted);text-decoration:none;font-size:13px}

/* accessibility helpers */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* pixels layer & animations */
.pixels{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:visible}
.pixel{
  position:absolute;will-change:transform,opacity;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.22) inset;
  animation-name:floatUp;animation-timing-function:linear;animation-iteration-count:infinite;
}
@keyframes floatUp{
  0%{transform:translateY(0) translateX(0) rotate(0);opacity:1}
  50%{opacity:0.8}
  100%{transform:translateY(-120vh) translateX(30vw) rotate(180deg);opacity:0}
}

/* small screens */
@media (max-width:600px){
  .header-inner{flex-direction:column;align-items:flex-start}
  .nav{width:100%;justify-content:flex-start;overflow:auto}
  .hero{padding:28px 0}
  .hero-title{font-size:12px}
  .btn{padding:12px 10px;width:100%}
  .site-logo{max-width:130px}
}

/* Apply pixel font to headings */
.hero-title,
.section-title {
  font-family: 'PressStart', 'Press Start 2P', monospace;
  /* preserve existing sizing/spacing — override only the family */
}

/* Apply the pixel font across the site */
html, body {
  font-family: 'PressStartLocal', 'Press Start 2P', monospace;
}

/* If you want headings slightly larger but using same font */
h1,h2,h3,h4,h5,h6 {
  font-family: 'PressStartLocal', 'Press Start 2P', monospace;
}

/* Full-page scroll snap */
html, body {
  height: 100%;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}

main {
  height: 100%;
  overflow-y: auto;
  scroll-snap-type: y mandatory;
  scroll-snap-stop: always;
  scroll-behavior: smooth;
  /* ensure one-page sections are direct children of main */
}

section {
  scroll-snap-align: start;
  scroll-snap-stop: always;
  /* keep existing full-screen behaviour */
  min-height: 100vh;
  box-sizing: border-box;
}

/* touch pan only vertical so snap works well on mobile */
@media (pointer: coarse) {
  main { touch-action: pan-y; }
}

/* prevent double scroll: disable body scrolling and let main handle it */
html, body {
  height: 100%;
  margin: 0;
  overflow: hidden; /* important: stop body from scrolling */
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}

/* main becomes the single scroll container */
main {
  height: 100vh;          /* fill viewport */
  overflow-y: auto;       /* only main scrolls */
  scroll-snap-type: y mandatory;
  scroll-snap-stop: always;
}

/* Header fixed so it's always visible */
:root { --header-h: 68px; }

/* keep previous styles, then add/override: */
.site-header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: var(--header-h);
  display: flex;
  align-items: center;
  background: rgba(6,8,12,0.55);
  backdrop-filter: blur(6px);
  z-index: 20;
  box-shadow: 0 2px 8px rgba(0,0,0,0.45);
}

/* ensure header inner fits */
.site-header .container { height: 100%; display:flex; align-items:center; }

/* push main content below header */
main { padding-top: var(--header-h); }

/* Footer fixed slim bar */
.site-footer{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 20;
  background: rgba(6,8,12,0.6);
  backdrop-filter: blur(6px);
  padding: 8px 0;
  border-top: 1px solid rgba(255,255,255,0.03);
}

/* keep footer content centered and readable */
.site-footer .container { display:flex; align-items:center; justify-content:space-between; gap:12px; }

/* make sure full-page sections account for footer when centering */
.section, .hero {
  /* reduce min-height by header+footer so centered content isn't covered */
  min-height: calc(100vh - var(--header-h) - 44px); /* 44px is footer approx */
}

/* on small screens reduce header/footer sizes */
@media (max-width:600px){
  :root { --header-h: 64px; }
  .site-logo{max-width:120px}
  .site-footer .container{flex-direction:column;gap:6px}
}

/* Hide scrollbar but keep scrolling functional */
main {
  /* keep existing overflow settings */
  overflow-y: auto;
  -ms-overflow-style: none; /* IE/Edge */
  scrollbar-width: none; /* Firefox */
}

/* WebKit browsers */
main::-webkit-scrollbar {
  display: none;
  width: 0;
  height: 0;
}

/* Optional utility to hide scrollbars on any element */
.hide-scrollbar {
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.hide-scrollbar::-webkit-scrollbar { display: none; }