/* FMGE Residential Campus - Fast launch landing page
   You can tweak colors, spacing, and typography here.
*/
:root{
  --bg:#0b1220;
  --panel:#0f1a33;
  --card:#111c3a;
  --muted:#a9b4d0;
  --text:#eaf0ff;
  --brand:#7c5cff;
  --brand2:#44e4c9;
  --line:rgba(255,255,255,.09);
  --shadow: 0 18px 60px rgba(0,0,0,.45);
  --radius:16px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color:var(--text);
}

a{color:inherit; text-decoration:none}
a:hover{opacity:.92}
code{background: rgba(255,255,255,.06); padding:.1rem .35rem; border-radius:8px; border:1px solid var(--line)}
.container{width:min(1120px, 92vw); margin:0 auto}
.sr-only{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}
.skip{position:absolute; left:-9999px; top:auto}
.skip:focus{left:1rem; top:1rem; background:#fff; color:#000; padding:.6rem .8rem; border-radius:10px; z-index:9999}

.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(12px);
  background: rgba(11,18,32,.65);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: .9rem 0;
  gap: 1rem;
}
.brand{display:flex; align-items:center; gap:.8rem}
.logo{
  width:40px; height:40px; display:grid; place-items:center;
  border-radius:12px;
  background: linear-gradient(135deg, rgba(124,92,255,1), rgba(68,228,201,1));
  color:#071024; font-weight:900;
}
.brand-text{display:flex; flex-direction:column; line-height:1.1}
.brand-sub{font-size:.82rem; color:var(--muted); font-weight:500}

.site-nav{display:flex; gap:1rem; align-items:center}
.site-nav a{color:var(--muted); font-weight:600; font-size:.95rem}
.site-nav a:hover{color:var(--text)}
.nav-toggle{display:none}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:.5rem;
  border-radius: 14px;
  padding: .8rem 1rem;
  font-weight:800;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
  color: var(--text);
  cursor:pointer;
}
.btn:hover{transform: translateY(-1px)}
.btn:active{transform: translateY(0)}
.btn-primary{
  background: linear-gradient(135deg, rgba(124,92,255,1), rgba(68,228,201,1));
  border: 0;
  color: #071024;
  box-shadow: 0 18px 55px rgba(124,92,255,.15);
}
.btn-ghost{
  background: rgba(255,255,255,.03);
}
.btn-lg{padding: .95rem 1.15rem; border-radius:16px}

.hero{padding: 3.2rem 0 1.6rem}
.hero-inner{display:grid; grid-template-columns: 1.25fr .85fr; gap:2rem; align-items:start}
.pill{
  display:inline-flex; align-items:center;
  border:1px solid var(--line);
  background: rgba(255,255,255,.03);
  padding:.45rem .75rem;
  border-radius:999px;
  color:var(--muted);
  font-weight:700;
  font-size:.86rem;
}
h1{font-size: clamp(2rem, 4vw, 3.1rem); line-height:1.05; margin:.9rem 0 .8rem}
.grad{background: linear-gradient(135deg, var(--brand), var(--brand2));
  -webkit-background-clip:text; background-clip:text; color:transparent}
.lead{color: var(--muted); font-size:1.05rem; line-height:1.6; max-width:60ch}

.hero-cta{display:flex; gap:.8rem; flex-wrap:wrap; margin: 1.1rem 0 1.1rem}
.chips{display:flex; flex-wrap:wrap; gap:.55rem; margin-top: .9rem}
.chip{
  border:1px solid var(--line);
  background: rgba(255,255,255,.03);
  padding:.45rem .65rem;
  border-radius:999px;
  font-weight:700;
  color:var(--muted);
  font-size:.86rem;
}

.trust{display:grid; grid-template-columns: repeat(3, 1fr); gap:.8rem; margin-top:1.2rem}
.trust-card{
  border:1px solid var(--line);
  background: rgba(255,255,255,.03);
  border-radius: var(--radius);
  padding: .9rem;
}
.trust-kpi{font-weight:900}
.trust-sub{color:var(--muted); font-weight:600; font-size:.9rem; margin-top:.25rem}

.hero-panel .panel-card{
  border:1px solid var(--line);
  background: var(--card);
  border-radius: 22px;
  padding: 1.2rem;
  box-shadow: var(--shadow);
}
.panel-title{margin:0}
.panel-sub{color:var(--muted); margin:.35rem 0 1rem}
.mini-form{display:grid; gap:.85rem}
label{display:grid; gap:.35rem; font-weight:700}
input, select, textarea{
  background: rgba(6,10,20,.55);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: .75rem .85rem;
  color: var(--text);
  outline: none;
  font: inherit;
}
textarea{resize: vertical}
input:focus, select:focus, textarea:focus{border-color: rgba(124,92,255,.75)}
.fineprint{color: var(--muted); font-size:.85rem; line-height:1.5; margin:.2rem 0 0}
.quick-links{display:flex; gap:.8rem; margin-top:1rem; flex-wrap:wrap}
.ql{
  color: var(--muted);
  font-weight:800;
  border-bottom: 1px dashed rgba(255,255,255,.2);
  padding-bottom:2px;
}

.panel-note{
  margin-top: .9rem;
  color: var(--muted);
  font-weight:800;
  padding:.85rem 1rem;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.02);
}

.section{padding: 3rem 0}
.section.alt{background: rgba(255,255,255,.02); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.section-head{display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; margin-bottom:1.2rem; flex-wrap:wrap}
.section-head h2{margin:0; font-size: clamp(1.45rem, 2.6vw, 2.1rem)}
.section-head p{margin:0; color:var(--muted); max-width:70ch; line-height:1.6}

.grid{display:grid; gap:1rem}
.grid.features{grid-template-columns: repeat(3, 1fr)}
.grid.steps{grid-template-columns: repeat(4, 1fr)}
.grid.two{grid-template-columns: repeat(2, 1fr)}
.card{
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  border-radius: var(--radius);
  padding: 1.1rem;
}
.card h3{margin:.1rem 0 .45rem}
.card p{margin:0; color:var(--muted); line-height:1.55}
.list{margin:.65rem 0 0; padding-left:1.1rem; color:var(--muted); line-height:1.7; font-weight:600}
.muted{color:var(--muted)}
.stack{display:grid; gap:.7rem; margin-top: 1rem}

.callout{
  margin-top: 1.4rem;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: rgba(124,92,255,.08);
  padding: 1.2rem;
}
.callout-inner{display:flex; justify-content:space-between; align-items:center; gap:1rem; flex-wrap:wrap}
.callout h3{margin:0}
.callout p{margin:.35rem 0 0; color:var(--muted); max-width:70ch}

.step-num{
  width:38px; height:38px;
  display:grid; place-items:center;
  border-radius: 14px;
  background: rgba(124,92,255,.2);
  border:1px solid rgba(124,92,255,.35);
  font-weight:900;
  margin-bottom:.7rem;
}

.gallery{display:grid; grid-template-columns: repeat(3, 1fr); gap:1rem; margin-top:1rem}
.ph{
  min-height: 140px;
  border: 1px dashed rgba(255,255,255,.18);
  background: rgba(255,255,255,.02);
  border-radius: var(--radius);
  display:grid; place-items:center;
  color: var(--muted);
  font-weight:800;
  text-align:center;
  padding: 1rem;
}

.founders .founder{display:flex; gap:1rem; align-items:flex-start}
.avatar{
  width:54px; height:54px;
  border-radius: 18px;
  display:grid; place-items:center;
  background: rgba(68,228,201,.14);
  border: 1px solid rgba(68,228,201,.28);
  font-weight:900;
}

.faq{display:grid; gap:.85rem}
.faq-item{
  border:1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,.03);
  padding: .8rem 1rem;
}
summary{cursor:pointer; font-weight:900}
details p{color:var(--muted); line-height:1.6}

.footer{
  border-top: 1px solid var(--line);
  padding: 2rem 0 1.2rem;
  background: rgba(0,0,0,.08);
}
.footer-inner{
  display:grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 1.2rem;
  align-items:start;
}
.footer-brand{display:flex; align-items:center; gap:.6rem}
.footer-links{display:grid; gap:.55rem}
.footer-links a{color:var(--muted); font-weight:700}
.footer-links a:hover{color:var(--text)}
.footer-bottom{
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap;
  border-top:1px solid var(--line);
  padding-top:1rem;
  margin-top:1.2rem;
}
.small{font-size:.9rem}

/* Modal */
.modal{position:fixed; inset:0; display:none; z-index:100}
.modal[aria-hidden="false"]{display:block}
.modal-backdrop{position:absolute; inset:0; background: rgba(0,0,0,.6)}
.modal-card{
  position: relative;
  width: min(760px, 92vw);
  margin: 6vh auto;
  border-radius: 24px;
  border:1px solid var(--line);
  background: rgba(11,18,32,.92);
  backdrop-filter: blur(14px);
  box-shadow: var(--shadow);
  padding: 1.2rem 1.2rem 1.1rem;
}
.modal-head{display:flex; align-items:center; justify-content:space-between; gap:1rem}
.icon-btn{
  width:40px; height:40px; border-radius: 14px;
  border:1px solid var(--line); background: rgba(255,255,255,.03);
  color: var(--text); cursor:pointer; font-weight:900;
}
.apply-form{margin-top: .9rem; display:grid; gap:.85rem}
.form-actions{display:flex; gap:.8rem; flex-wrap:wrap; margin-top:.3rem}
.map{
  min-height: 220px;
  border-radius: var(--radius);
  overflow: hidden;
}
.map iframe{display:block; width:100%; min-height:220px}

/* Responsive */
@media (max-width: 980px){
  .hero-inner{grid-template-columns: 1fr; }
  .trust{grid-template-columns: 1fr; }
  .grid.features{grid-template-columns: 1fr; }
  .grid.steps{grid-template-columns: 1fr; }
  .grid.two{grid-template-columns: 1fr; }
  .gallery{grid-template-columns: 1fr; }
  .footer-inner{grid-template-columns: 1fr; }
  .site-nav{
    position: fixed;
    left: 4vw;
    right: 4vw;
    top: 70px;
    display:none;
    flex-direction: column;
    gap: .7rem;
    padding: 1rem;
    border-radius: 18px;
    border:1px solid var(--line);
    background: rgba(11,18,32,.95);
    backdrop-filter: blur(12px);
  }
  .site-nav.open{display:flex}
  .nav-toggle{display:inline-flex; align-items:center; justify-content:center;
    width:44px; height:44px; border-radius: 14px;
    border:1px solid var(--line); background: rgba(255,255,255,.03);
    color: var(--text); cursor:pointer; font-weight:900;
  }
}
