:root{
  /* === TLS BRAND COLORS (from the school building) === */
  --teal:#0097A7;        /* the blue-green building walls */
  --teal-dark:#00788A;   /* darker teal for hovers */
  --teal-light:#E0F7FA;  /* pale teal for backgrounds */
  --green:#7CB518;       /* lime green trim on building */
  --green-dark:#5E8C0F;
  --green-light:#F1F8E9;
  --orange:#E85D04;      /* orange gate accents */
  --orange-light:#FFF3E0;

  /* === NEUTRALS === */
  --cream:#FAFDF7;       /* slight green tint to cream */
  --offwhite:#F0F7F4;
  --ink:#0D2B1E;         /* deep green-black */
  --ink2:#1F4A35;
  --muted:#6B8F7A;
  --white:#FFFFFF;
  --border:#C8E6D4;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Manrope',sans-serif;background:var(--cream);color:var(--ink);overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* NAV */
nav{
  position:sticky;top:0;z-index:100;
  background:var(--teal);
  border-bottom:3px solid var(--green);
  padding:0 2.5rem;
  display:flex;align-items:center;justify-content:space-between;
  height:64px;
}
.nav-logo{display:flex;align-items:center;gap:.7rem;text-decoration:none}
.nav-badge{
  width:38px;height:38px;background:var(--white);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:800;color:var(--teal);
}
.nav-title strong{display:block;font-size:.88rem;font-weight:800;color:var(--white);}
.nav-title span{font-size:.62rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7)}
nav ul{list-style:none;display:flex;gap:2rem;align-items:center}
nav ul a{font-size:.8rem;font-weight:600;color:rgba(255,255,255,.85);text-decoration:none;transition:color .2s}
nav ul a:hover{color:var(--green)}
nav ul a.active{color:var(--white);font-weight:800}
.btn-apply{
  background:var(--orange);color:var(--white);
  padding:.55rem 1.3rem;border-radius:50px;
  font-size:.8rem;font-weight:700;text-decoration:none;
  transition:background .2s,transform .2s;
  box-shadow:0 3px 12px rgba(232,93,4,.4);
}
.btn-apply:hover{background:#C44D02;transform:translateY(-1px)}

/* BUTTONS */
.btn-primary{background:var(--teal);color:var(--white);padding:.75rem 1.8rem;border-radius:50px;font-size:.85rem;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;transition:all .25s;box-shadow:0 4px 18px rgba(0,151,167,.35);}
.btn-primary:hover{background:var(--teal-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,151,167,.4)}
.btn-green{background:var(--green);color:var(--white);padding:.75rem 1.8rem;border-radius:50px;font-size:.85rem;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;transition:all .25s;box-shadow:0 4px 18px rgba(124,181,24,.35);}
.btn-green:hover{background:var(--green-dark);transform:translateY(-2px)}
.btn-orange{background:var(--orange);color:var(--white);padding:.75rem 1.8rem;border-radius:50px;font-size:.85rem;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;transition:all .25s;box-shadow:0 4px 18px rgba(232,93,4,.35);}
.btn-orange:hover{background:#C44D02;transform:translateY(-2px)}
.btn-outline{border:2px solid var(--teal);color:var(--teal);padding:.75rem 1.8rem;border-radius:50px;font-size:.85rem;font-weight:700;text-decoration:none;transition:all .25s;}
.btn-outline:hover{background:var(--teal);color:var(--white)}
.btn-white{background:var(--white);color:var(--teal);padding:.8rem 2rem;border-radius:50px;font-size:.85rem;font-weight:700;text-decoration:none;transition:all .25s;box-shadow:0 4px 20px rgba(0,0,0,.15);}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,.2)}
.btn-outline-white{border:2px solid rgba(255,255,255,.5);color:var(--white);padding:.8rem 2rem;border-radius:50px;font-size:.85rem;font-weight:700;text-decoration:none;transition:all .25s;}
.btn-outline-white:hover{border-color:var(--white);background:rgba(255,255,255,.12)}
.btn-submit{width:100%;background:var(--teal);color:var(--white);border:none;padding:.9rem;border-radius:50px;font-family:'Manrope',sans-serif;font-size:.88rem;font-weight:700;cursor:pointer;transition:all .25s;}
.btn-submit:hover{background:var(--teal-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,151,167,.35)}

/* SHARED SECTION */
section{padding:5rem 2.5rem}
.sec-label{font-size:.65rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);margin-bottom:1rem}
.sec-title{font-family:'Instrument Serif',serif;font-size:clamp(2rem,5vw,3rem);font-weight:400;line-height:1.1;color:var(--ink);letter-spacing:-.02em;margin-bottom:1rem;}
.sec-title em{font-style:italic;color:var(--teal)}
.sec-sub{font-size:.9rem;color:var(--ink2);line-height:1.75;max-width:520px}

/* FORM */
.fg{margin-bottom:1rem}
.fg label{display:block;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.45rem}
.fg input,.fg textarea,.fg select{
  width:100%;padding:.78rem 1rem;
  background:var(--white);border:1.5px solid var(--border);
  border-radius:10px;color:var(--ink);font-family:'Manrope',sans-serif;
  font-size:.88rem;outline:none;transition:border-color .2s;-webkit-appearance:none;
}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--teal)}
.fg input::placeholder,.fg textarea::placeholder{color:#A8C4B0}
.fg textarea{height:90px;resize:none}

/* DECREE BAND */
.decree-band{background:var(--teal);padding:3.5rem 2.5rem;text-align:center;}
.decree-label{font-size:.65rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:1.4rem;}
.decree-band blockquote{font-family:'Instrument Serif',serif;font-size:clamp(1.5rem,4vw,2.4rem);font-style:italic;color:var(--white);line-height:1.4;max-width:700px;margin:0 auto;}

/* FOOTER */
footer{
  background:var(--ink);padding:3rem 2.5rem;
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;
  border-top:4px solid var(--teal);
}
.footer-logo-wrap{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem}
.footer-badge{width:36px;height:36px;background:var(--teal);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:var(--white)}
.footer-name{font-size:.9rem;font-weight:800;color:var(--white);line-height:1.2}
.footer-name small{display:block;font-size:.6rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.4)}
.footer-desc{font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.7;margin-bottom:1.5rem}
.footer-socials{display:flex;gap:.6rem}
.footer-socials a{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:.8rem;text-decoration:none;transition:all .25s;}
.footer-socials a:hover{background:var(--teal);border-color:var(--teal)}
.footer-col h4{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:1.2rem}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:.6rem}
.footer-col ul a{font-size:.82rem;color:rgba(255,255,255,.6);text-decoration:none;transition:color .2s}
.footer-col ul a:hover{color:var(--white)}
.footer-bottom{background:var(--ink);border-top:1px solid rgba(255,255,255,.08);padding:1.2rem 2.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.footer-bottom p{font-size:.75rem;color:rgba(255,255,255,.3)}

/* REVEAL */
.r{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.r.v{opacity:1;transform:none}
.r.d1{transition-delay:.08s}.r.d2{transition-delay:.16s}.r.d3{transition-delay:.24s}.r.d4{transition-delay:.32s}

/* HAMBURGER MENU */
.hamburger{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:.4rem;
}
.hamburger span{
  display:block;
  width:24px;height:2.5px;
  background:var(--white);
  border-radius:4px;
  transition:all .3s;
}
.hamburger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

.mobile-menu{
  display:none;
  position:fixed;
  top:64px;left:0;right:0;bottom:0;
  background:var(--ink);
  z-index:499;
  flex-direction:column;
  padding:2rem 2.5rem;
  gap:0;
  overflow-y:auto;
}
.mobile-menu.open{display:flex}
.mobile-menu a{
  font-size:1.2rem;font-weight:700;
  color:rgba(255,255,255,.85);
  text-decoration:none;
  padding:1.1rem 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  transition:color .2s;
}
.mobile-menu a:hover{color:var(--teal)}
.mobile-menu .mobile-apply{
  margin-top:1.5rem;
  background:var(--orange);
  color:var(--white)!important;
  text-align:center;
  border-radius:50px;
  padding:1rem!important;
  border-bottom:none!important;
  font-size:1rem!important;
}
.mobile-menu .mobile-divider{
  font-size:.65rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.3);
  padding:.8rem 0 .4rem;
  border-bottom:none!important;
}
.mobile-socials{
  display:flex;gap:1rem;
  margin-top:2rem;
  padding-top:1.5rem;
  border-top:1px solid rgba(255,255,255,.08);
}
.mobile-socials a{
  width:44px;height:44px;
  background:rgba(255,255,255,.08);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;
  border-bottom:none!important;
  padding:0!important;
}

@media(max-width:768px){
  nav ul{display:none}
  .hamburger{display:flex}
}


/* RESPONSIVE */
@media(max-width:768px){
  nav ul{display:none}
  section{padding:4rem 1.5rem}
  footer{grid-template-columns:1fr;padding:2.5rem 1.5rem}
  .footer-bottom{padding:1rem 1.5rem;flex-direction:column;text-align:center}
}