@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@600&display=swap');

/* ---------- CSS Custom Properties ---------- */
:root{
  --bg:#0b1726;
  --bg-2:#0e223b;
  --text:#eaf0f6;
  --muted:#c3cfdb;
  --accent:#1f6feb;
  --accent-2:#164ea6;
  --card:#14253b;
  --border:rgba(255,255,255,.12);
  --shadow:0 10px 30px rgba(0,0,0,.35);
}

/* ---------- Reset / Base ---------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:linear-gradient(180deg,var(--bg) 0%, #0a1320 100%);
  line-height:1.6;
}
a{color:var(--accent);text-decoration:none}
a:hover{color:#9cc1ff;text-decoration:underline}
.container{max-width:1100px;margin:0 auto;padding:0 1rem}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  -webkit-backdrop-filter:saturate(180%) blur(8px);
  backdrop-filter:saturate(180%) blur(8px);
  background:rgba(10,19,32,.75);
  border-bottom:1px solid var(--border);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:.75rem 0;position:relative;
}
.nav a.brand{
  font-family:'Poppins',system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:1.5rem;
  font-weight:600;
  letter-spacing:.03em;
  white-space:nowrap;
  line-height:1;
}

/* links container: gap only (NO default display) */
.nav .links{gap:1rem;flex-wrap:wrap}
.nav .btn{
  padding:.55rem .9rem;border:1px solid var(--border);
  border-radius:.5rem;background:transparent;color:var(--text);
}
.nav .btn:hover{background:rgba(255,255,255,.06)}

/* ---------- Universal Hamburger ---------- */
.menu-btn{
  display:inline-flex;align-items:center;justify-content:center;
  background:transparent;border:1px solid var(--border);color:var(--text);
  padding:.5rem .65rem;border-radius:.5rem;font-size:1.1rem;cursor:pointer;
  margin-left:auto;
}
.nav .links{
  display:none !important;                  /* hidden until .open added */
  position:absolute;right:1rem;top:calc(100% + .5rem);
  background:rgba(10,19,32,.98);
  border:1px solid var(--border);border-radius:.6rem;
  padding:.5rem;flex-direction:column;gap:.25rem;min-width:260px;z-index:60;
}
.nav .links a.btn{width:100%;text-align:left;padding:.7rem .8rem;}
.nav.open .links{display:flex !important;}  /* shown when JS toggles */

/* ---------- Hero ---------- */
.hero {
  position: relative;
  min-height: 56vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: url('hero.jpg') center/cover no-repeat,
              linear-gradient(180deg, #0d1b2a, #091323);
}
.hero .overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(0,0,0,.55), rgba(0,0,0,.55));
}

.hero .inner{position:relative;z-index:1;padding:5rem 0}
.eyebrow{letter-spacing:.12em;text-transform:uppercase;font-size:.8rem;color:#cde3ff;opacity:.95}
h1{font-size:clamp(2rem,4vw + 1rem,3.25rem);line-height:1.15;margin:.35rem 0 0 0}
.subhead{font-size:clamp(1.05rem,1.2vw + .8rem,1.5rem);color:var(--muted);margin-top:.75rem}
.cta-row{display:flex;gap:.75rem;margin-top:1.25rem;flex-wrap:wrap}

/* ---------- Buttons ---------- */
.btn-primary,.btn-secondary{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.8rem 1.1rem;border-radius:.6rem;font-weight:600;box-shadow:var(--shadow);
}
.btn-primary{background:var(--accent);color:#fff;border:1px solid transparent}
.btn-primary:hover{background:var(--accent-2)}
.btn-secondary{background:transparent;color:var(--text);border:1px solid var(--border)}
.btn-secondary:hover{background:rgba(255,255,255,.07)}

/* ---------- Sections / Cards ---------- */
.section{padding:3.25rem 0;border-top:1px solid var(--border)}
.section.alt{background:linear-gradient(180deg,#0a1320,#0c1a2e 120%)}
.cards{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1rem; grid-gap:1rem;      /* legacy alias for older browsers */
  margin-top:1rem;
}
.card{background:var(--card);border:1px solid var(--border);border-radius:.8rem;padding:1rem}
.card h3{margin:.25rem 0}
.badge{
  display:inline-block;font-size:.72rem;padding:.25rem .5rem;border-radius:.4rem;
  background:#133361;color:#b7d3ff;border:1px solid #1d3d6c;
}

/* ---------- Tables ---------- */
.table{width:100%;border-collapse:collapse;margin-top:.75rem;font-size:.95rem}
.table th,.table td{padding:.65rem .6rem;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
.table{min-width:600px;}

/* ---------- Misc ---------- */
.small{font-size:.9rem;color:var(--muted)}
.notice{padding:.75rem 1rem;border:1px dashed var(--border);border-radius:.6rem;background:rgba(255,255,255,.04)}
.footer{padding:2rem 0;border-top:1px solid var(--border);color:#a9b8c6}
.footer .cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
img{max-width:100%;height:auto;}

/* ---------- Responsive Tweaks ---------- */
@media (max-width:480px){
  .hero .inner{padding:3.25rem 0}
  .hero h1{font-size:clamp(1.7rem,7vw,2.2rem)}
  .hero .subhead{font-size:clamp(1rem,4.5vw,1.25rem)}
  .cta-row{gap:.5rem}
}
@media (max-width:390px){
  .hero h1{font-size:clamp(1.35rem,7.5vw,1.85rem);line-height:1.15}
  .hero .subhead{font-size:clamp(.95rem,4.2vw,1.15rem)}
}
@media (max-width:700px){
  .footer .cols{grid-template-columns: 1fr}
}A

/* ---------- A11y / UX ---------- */
a.btn,.btn-primary,.btn-secondary,.menu-btn{min-height:44px;min-width:44px}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
button,a.btn,.btn-primary,.btn-secondary{touch-action:manipulation}
input,select,textarea{font-size:16px}
@media (prefers-reduced-motion:reduce){
  *{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
}

/* ---------- Anchor offset for sticky header ---------- */
:root{scroll-padding-top:72px}

/* Experience helpers */
.checklist{list-style:none;padding:0;margin:0;font-size:1rem;line-height:1.55}
.checklist li{margin:0 0 .6rem 0;padding-left:1.6em;position:relative}
.checklist li::before{content:"✔";position:absolute;left:0;color:var(--accent);font-weight:600}
.cdscarousel img{width:100%;height:auto;border-radius:.6rem}
.cdscarousel .swiper-button-prev,
.cdscarousel .swiper-button-next{color:#fff}

/* --- Carousel sizing fix --- */
.cdscarousel{
  max-width:600px;
  max-height:360px;
  aspect-ratio:3/2;
  border-radius:.6rem;
  overflow:hidden;
}
.cdscarousel .swiper-slide img{
  width:100%;
  height:100%;
  object-fit:cover;
}

/* Center the carousel column when screen is super-wide */
@media(min-width:1200px){
  .cdscarousel{margin-left:auto;}
}

/* ---------- Logo grid (experience page) ---------- */
.logo-grid{
  display:flex;
  flex-wrap:wrap;
  gap:1.25rem;
  align-items:center;
}
.logo-grid img {
  width: 90px;
  height: 90px;       /* force square box */
  object-fit: contain; /* centers logo inside */
  background: #fff;
  padding: .5rem;
  border-radius: .4rem;
  box-shadow: 0 2px 6px rgba(0,0,0,.25);
}
@media(max-width:480px){
  .logo-grid{justify-content:center}
  .logo-grid img{width:90px;max-height:90px}
}

/* === Mobile fix: keep carousel fully on-screen === */
@media (max-width: 640px){
  .section .container > div[style*="grid-template-columns"]{
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
  }
  .cdscarousel{
    width: calc(100vw - 2rem);
    max-width: 100%;
    margin: 0 auto;
    aspect-ratio: 4 / 3;
    max-height: none;
    border-radius: .6rem;
    overflow: hidden;
  }
  .cdscarousel .swiper-slide img{
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

/* (Optional) prevent any stray horizontal scrollbars */
html, body { overflow-x: hidden; }

/* ---------- Logo ---------- */
.logo{
  display: flex;
  justify-content: flex-start;
  margin-bottom: clamp(1rem, 2.5vw, 2rem);
}
.logo img{
  width: clamp(500px, 32vw, 500px);
  max-height: clamp(500px, 12vw, 500px);
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 6px 16px rgba(0,0,0,.45));
}
@media (max-width: 480px){
  .logo{ justify-content: center; }
  .logo img{
    width: clamp(180px, 70vw, 280px);
  }
}

/* --- Subtle verse watermark --- */
body::after{
  content: "“Put on the whole armor of God” (Eph 6:11)";
  position: fixed;
  right: 1.25rem;
  bottom: 1.25rem;
  font-size: 1.0rem;
  font-style: italic;
  font-weight: 400;
  letter-spacing: 0.02em;
  color: var(--text);
  opacity: 0.40;
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
@media print{
  body::after{ display:none; }
}

/* Default table styles (keep yours) */
.table { width:100%; border-collapse: collapse; }
.table th, .table td { padding:.75rem 1rem; vertical-align: top; }

/* Accordion container (auto-built by JS) */
.table-accordion { display:none; }

/* Mobile: hide table, show accordion */
@media (max-width: 640px){
  .acc-body{
    /* keep grid, but a single column works too */
    grid-template-columns: 1fr;          /* was 44% 1fr */
    gap: .25rem 0;
  }

  /* each item spans the full width of the grid */
  .acc-row-label,
  .acc-row-value{
    grid-column: 1 / -1;
  }

  .acc-row-label{
    font-weight:700;
    opacity:.95;
    margin-top:.75rem;
    border-top:1px solid rgba(255,255,255,.08);
    padding-top:.75rem;
  }
  .acc-row-label:first-of-type{
    margin-top:0; border-top:0; padding-top:0;
  }

  .acc-row-label + .acc-row-value{
    margin-top:.25rem;    /* label → value */
    margin-bottom:.5rem;  /* space between pairs */
  }
}

@media (max-width: 640px){
  .table-wrap{ display:none !important; }
  .table-accordion{ display:block !important; }
}

/* MOBILE: show accordion, hide table */
@media (max-width: 640px){
  .table-wrap{ display:none !important; }
  .table-accordion{ display:block !important; }

  /* Boxed cards */
  .table-accordion details{
    margin:0 0 1rem;
    border:1px solid rgba(255,255,255,.12);
    border-radius:.8rem;
    background:rgba(20,35,59,.65);
    box-shadow:0 4px 14px rgba(0,0,0,.25);
    overflow:hidden;
  }

  /* Header row */
  .table-accordion summary{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:1rem;
    padding:1rem 1.125rem;
    font-weight:700;
    list-style:none;                 /* remove bullets */
  }
  .table-accordion summary::marker{ content:""; }           /* Firefox */
  .table-accordion summary::-webkit-details-marker{ display:none; } /* WebKit */

  /* Caret rotation (if you kept the SVG) */
  .table-accordion summary .caret{ flex:0 0 auto; transition:transform .2s; }
  .table-accordion details[open] summary .caret{ transform:rotate(180deg); }

  /* Body: stack label above value, full width */
  .acc-body{
    padding:.5rem 1.125rem 1rem;
    display:grid;
    grid-template-columns:1fr;       /* single column */
    gap:.25rem 0;
  }
  .acc-row-label,
  .acc-row-value{ grid-column:1 / -1; }

  .acc-row-label{
    font-weight:700; opacity:.95; margin-top:.75rem;
    border-top:1px solid rgba(255,255,255,.08); padding-top:.75rem;
  }
  .acc-row-label:first-child{ margin-top:0; border-top:0; padding-top:0; }
  .acc-row-label + .acc-row-value{ margin:.25rem 0 .5rem; }
}
