/* =========================
   GLOBAL STYLES
========================= */

:root{
  --bg:#0b0b0b;
  --panel:#121212;
  --text:#ffffff;
  --muted:#b5b5b5;
  --accent:#5b5cff;
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

body{
  font-family:'Inter',sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
}

.container{
  width:90%;
  max-width:1100px;
  margin:auto;
}

/* =========================
   HEADER
========================= */

header{
  position:relative;
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:20px 0;
}

/* LOGO */
.logo{
  display:flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  color:#fff;
}

.logo-img{
  height:32px;
  width:auto;
  object-fit:contain;
}

.logo-text{
  font-weight:700;
  font-size:16px;
}

/* NAV */
nav{
  display:flex;
  align-items:center;
}

nav a{
  color:var(--muted);
  margin-left:20px;
  text-decoration:none;
  font-size:14px;
}

nav a:hover{
  color:#fff;
}

/* HAMBURGER */
.menu-toggle{
  display:none;
  font-size:24px;
  cursor:pointer;
  color:#fff;
}

/* =========================
   HERO
========================= */

.hero{
  text-align:center;
  padding:80px 0 60px;
}

.hero h1{
  font-size:38px;
  margin-bottom:15px;
}

.hero p{
  color:var(--muted);
  max-width:600px;
  margin:0 auto 30px;
}

.site-header{
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 0;
}

.logo{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #fff;
}

.logo-img{
  height: 36px;
  width: auto;
  display: block;
  object-fit: contain;
}

.logo-text{
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
}

.site-nav{
  display: flex;
  align-items: center;
  gap: 20px;
}

.site-nav a{
  color: var(--muted);
  text-decoration: none;
  font-size: 14px;
  margin-left: 0;
}

.site-nav a:hover{
  color: #fff;
}

.menu-toggle{
  display: none;
  appearance: none;
  border: 0;
  background: transparent;
  color: #fff;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
}

@media (max-width: 768px){
  .menu-toggle{
    display: block;
  }

  .site-nav{
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    width: 220px;
    display: none;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    padding: 14px;
    background: #111;
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    box-shadow: 0 12px 30px rgba(0,0,0,0.35);
    z-index: 1000;
  }

  .site-nav.show{
    display: flex;
  }

  .site-nav a{
    width: 100%;
    padding: 10px 0;
  }

  .hero h1{
    font-size: 28px;
  }

  .page-hero h1,
  .article-page h1{
    font-size: 2rem;
  }

  .article-lead{
    font-size: 1rem;
  }
}

/* =========================
   BUTTONS
========================= */

.btn{
  display:inline-block;
  padding:12px 20px;
  border-radius:6px;
  background:var(--accent);
  color:#fff;
  text-decoration:none;
  margin:5px;
  font-size:14px;
}

.btn-outline{
  background:transparent;
  border:1px solid var(--accent);
}

/* =========================
   SECTIONS
========================= */

section{
  padding:60px 0;
}

h2{
  margin-bottom:20px;
}

/* =========================
   GRID + CARDS
========================= */

.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:20px;
}

.card{
  background:var(--panel);
  padding:20px;
  border-radius:10px;
}

.card h3{
  margin-bottom:10px;
}

.muted{
  color:var(--muted);
}

/* =========================
   CTA
========================= */

.cta{
  text-align:center;
  padding:60px 0;
  background:linear-gradient(135deg,#1a1a1a,#101020);
}

/* =========================
   PAGE HERO
========================= */

.page-hero{
  padding:56px 0 30px;
}

.page-hero h1{
  font-size:2.4rem;
  margin:12px 0;
}

.eyebrow{
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
}

/* =========================
   TAG
========================= */

.tag{
  display:inline-block;
  margin-bottom:12px;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  background:rgba(91,92,255,.1);
  color:#c9caff;
}

/* =========================
   ARTICLE PAGE
========================= */

.article-page{
  max-width:800px;
  margin:0 auto;
}

.article-page h1{
  font-size:2.6rem;
}

.article-lead{
  font-size:1.1rem;
  color:#ccc;
}

/* =========================
   MODAL
========================= */

.modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.7);
  display:none;
  justify-content:center;
  align-items:center;
}

.modal.show{
  display:flex;
}

.modal-box{
  background:#111;
  padding:20px;
  border-radius:12px;
}

/* =========================
   CONTACT FORM
========================= */

.contact-form{
  max-width:600px;
  margin:auto;
  display:grid;
  gap:12px;
}

.contact-form input,
.contact-form textarea,
.contact-form select{
  padding:12px;
  border-radius:8px;
  border:1px solid #222;
  background:#0b0b0b;
  color:#fff;
}

/* =========================
   FOOTER
========================= */

footer{
  text-align:center;
  padding:30px 0;
  font-size:13px;
  color:var(--muted);
}

/* =========================
   MOBILE RESPONSIVE
========================= */

@media(max-width:768px){

  /* NAV */
  nav{
    position:absolute;
    top:60px;
    right:10px;
    background:#111;
    width:220px;
    flex-direction:column;
    padding:20px;
    display:none;
    border-radius:10px;
    box-shadow:0 10px 30px rgba(0,0,0,0.4);
  }

  nav.show{
    display:flex;
  }

  nav a{
    margin:10px 0;
  }

  .menu-toggle{
    display:block;
  }

  /* TEXT */
  .hero h1{
    font-size:28px;
  }

  .page-hero h1{
    font-size:2rem;
  }

  .article-lead{
    font-size:1rem;
  }
}