
:root{
  --card-bg: rgba(18,32,66,.55);
  --card-bg-soft: rgba(25,40,78,.42);
  --card-border: rgba(215,228,255,.18);
  --card-shadow: 0 16px 40px rgba(0,0,0,.40);

  --accent:#d8e6ff;
  --accent-hover:#f3f8ff;

  --text:#f7fbff;
  --text-soft:#c7d4ef;
}

*{margin:0;padding:0;box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  font-family:Inter,Arial,sans-serif;
  color:var(--text);
  padding:32px;
  min-height:100vh;
  position:relative;
  background:#091120;
}

/* Faded site-wide banner */
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:url("images/banner.png") center/cover no-repeat;
  opacity:.12;
  z-index:-2;
}

body::after{
  content:"";
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at top,#4969b3 0%,#233b72 35%,#122345 70%,#091120 100%);
  opacity:.90;
  z-index:-1;
}

.hero,.glass{
  position:relative;
  overflow:hidden;
  border-radius:26px;
  backdrop-filter:blur(22px);
  background:var(--card-bg);
  border:1px solid var(--card-border);
  box-shadow:var(--card-shadow);
}

.hero{
  padding:90px 40px;
  text-align:center;
  margin-bottom:48px;
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(rgba(9,17,32,.30),rgba(9,17,32,.70)),
    url("images/banner.png") center/cover no-repeat;
  z-index:0;
}

.hero>*{
  position:relative;
  z-index:1;
}

.hero h1{
  font-size:3rem;
  margin-bottom:12px;
}

.hero p{
  color:var(--text-soft);
}

.section{
  margin-bottom:48px;
}

.section h2{
  margin-bottom:18px;
  color:#eef4ff;
}

.grid{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:24px;
}

.card{
  width:270px;
  height:360px;
  display:flex;
  flex-direction:column;
  padding:18px;
  background:var(--card-bg-soft);
  border:1px solid var(--card-border);
  border-radius:22px;
  backdrop-filter:blur(20px);
  transition:.25s ease;
}

.card:hover{
  transform:translateY(-6px);
  border-color:rgba(235,242,255,.45);
  box-shadow:
    0 20px 45px rgba(0,0,0,.45),
    0 0 20px rgba(160,190,255,.15);
}

.card-image{
  width:100%;
  height:120px;
  overflow:hidden;
  border-radius:16px;
  margin-bottom:16px;
  background:rgba(255,255,255,.05);
}

.card-image img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
  transition:transform .3s ease;
}

.card:hover .card-image img{
  transform:scale(1.05);
}

.icon{
  font-size:1.5rem;
  margin-bottom:8px;
}

.card h3{
  margin-bottom:10px;
}

.desc{
  flex:1;
  color:var(--text-soft);
  line-height:1.45;
}

.badge{
  display:inline-block;
  width:fit-content;
  padding:6px 14px;
  margin:12px 0;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.10);
  color:#dce8ff;
  font-size:.78rem;
}

.open{
  display:block;
  margin-top:auto;
  text-align:center;
  text-decoration:none;
  color:#183052;
  background:linear-gradient(#f4f8ff,#d7e6ff);
  padding:12px;
  border-radius:999px;
  font-weight:700;
  transition:.2s;
}

.open:hover{
  background:linear-gradient(#fff,#edf5ff);
}

.footer{
  margin-top:56px;
  padding:24px;
  text-align:center;
}

code{color:#d8e6ff}

@media (max-width:768px){
  body{padding:18px;}
  .hero{padding:70px 24px;}
  .hero h1{font-size:2.4rem;}
  .card{
    width:100%;
    max-width:320px;
  }
}


body{

    position:relative;

    background:#081123;

}

body::before{

    content:"";

    position:fixed;

    inset:0;

    background:

        url("images/banner.png")
        center / cover
        no-repeat;

    opacity:.12;

    pointer-events:none;

    z-index:-2;

}

body::after{

    content:"";

    position:fixed;

    inset:0;

    background:

        linear-gradient(
            #0a1327,
            #12234a,
            #09111f
        );

    opacity:.75;

    pointer-events:none;

    z-index:-1;

}
