/* =========================================================
   J Curry LLC — site styles
   Palette: deep indigo #100028 / footer #0a0119 / accent cyan #00bfe7
   Fonts: Play (headings) + Josefin Sans (body)
   ========================================================= */

:root{
  --bg:#100028;
  --bg-alt:#170a35;
  --footer:#0a0119;
  --accent:#00bfe7;
  --accent-2:#19d0ff;
  --text:#e7e5ef;
  --muted:#a9a6bd;
  --line:rgba(255,255,255,.10);
  --card:#1a0b3d;
  --maxw:1170px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:"Josefin Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{
  font-family:"Play",sans-serif;
  color:#fff;
  margin:0 0 .5em;
  font-weight:700;
  line-height:1.2;
}
p{margin:0 0 1rem;color:var(--muted)}
a{color:var(--accent);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent-2)}
img{max-width:100%;display:block}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:90px 0}
.section--tight{padding:64px 0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  font-family:"Play",sans-serif;
  font-weight:700;
  font-size:14px;
  letter-spacing:2px;
  text-transform:uppercase;
  padding:15px 34px;
  border-radius:4px;
  cursor:pointer;
  transition:transform .2s, box-shadow .2s, background .2s;
}
.btn--primary{background:var(--accent);color:#03121a;border:2px solid var(--accent)}
.btn--primary:hover{background:var(--accent-2);color:#03121a;transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,191,231,.30)}
.btn--ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.35)}
.btn--ghost:hover{border-color:var(--accent);color:#fff;transform:translateY(-2px)}

/* ---------- Section heading ---------- */
.eyebrow{
  display:block;color:var(--accent);
  font-size:14px;letter-spacing:3px;text-transform:uppercase;margin-bottom:10px;
  font-family:"Play",sans-serif;
}
.section-title{font-size:38px;position:relative;padding-bottom:22px;margin-bottom:18px}
.section-title:after{content:"";position:absolute;left:0;bottom:0;height:4px;width:70px;background:var(--accent);border-radius:2px}
.center .section-title:after{left:50%;transform:translateX(-50%)}
.center{text-align:center}
.lead{max-width:760px;margin:0 auto;color:var(--muted)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:50;
  background:transparent;border-bottom:1px solid var(--line);
  transition:background .35s, padding .35s, box-shadow .35s;
  padding:14px 0;
}
.site-header.scrolled{background:#100028f2;padding:8px 0;box-shadow:0 8px 30px rgba(0,0,0,.35);backdrop-filter:blur(6px)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand img{height:54px;width:auto;border-radius:6px;transition:height .35s}
.scrolled .brand img{height:46px}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none;margin:0;padding:0}
.nav-links a{
  font-family:"Play",sans-serif;color:#fff;text-transform:uppercase;
  font-size:15px;letter-spacing:1px;position:relative;padding:4px 0;
}
.nav-links a:after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--accent);transition:width .25s}
.nav-links a:hover:after,.nav-links a.active:after{width:100%}
.nav-social{display:flex;gap:16px;align-items:center;padding-left:26px;border-left:1px solid var(--line)}
.nav-social a{color:#fff;font-size:16px}
.nav-social a:hover{color:var(--accent)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:26px;height:2px;background:#fff;transition:.3s}

/* ---------- Hero ---------- */
.hero{
  min-height:100vh;display:flex;align-items:center;
  background:linear-gradient(180deg, rgba(16,0,40,.78), rgba(16,0,40,.92)), url("../img/hero.jpg");
  background-size:cover;background-position:center;
  padding:140px 0 90px;position:relative;
}
.hero__inner{max-width:760px}
.hero .eyebrow{font-size:16px}
.hero h1{font-size:clamp(40px,7vw,72px);text-transform:uppercase;margin-bottom:24px;line-height:1.05}
.hero h1 .accent{color:var(--accent)}
.hero p{font-size:19px;margin-bottom:34px;max-width:640px}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap}

/* ---------- Services / Value props ---------- */
.services{background:var(--bg)}
.grid{display:grid;gap:26px}
.grid--4{grid-template-columns:repeat(4,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.svc-card{
  background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:38px 30px;transition:transform .25s, border-color .25s, box-shadow .25s;
}
.svc-card:hover{transform:translateY(-6px);border-color:var(--accent);box-shadow:0 18px 40px rgba(0,0,0,.35)}
.svc-card__icon{
  height:74px;width:74px;display:flex;align-items:center;justify-content:center;
  border:2px solid var(--accent);border-radius:10px;margin-bottom:22px;transition:transform .4s;
}
.svc-card:hover .svc-card__icon{transform:rotate(45deg)}
.svc-card:hover .svc-card__icon img{transform:rotate(-45deg)}
.svc-card__icon img{height:38px;width:38px;transition:transform .4s}
.svc-card h4{font-size:20px;margin-bottom:12px}
.svc-card p{font-size:15px;margin:0}

/* affiliations chips */
.affiliations{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:10px}
.chip{
  border:1px solid var(--line);border-radius:50px;padding:8px 22px;
  color:var(--text);font-size:14px;letter-spacing:1px;font-family:"Play",sans-serif;
}

/* ---------- CEO desk / split ---------- */
.ceo{background:var(--bg-alt)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split__media{position:relative}
.split__media img{border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.45)}
.split__media .badge{
  position:absolute;left:-18px;bottom:-18px;background:var(--accent);color:#03121a;
  font-family:"Play",sans-serif;font-weight:700;padding:18px 22px;border-radius:12px;line-height:1.1;
}
.split__media .badge b{display:block;font-size:34px}
.signature{font-family:"Play",sans-serif;color:#fff;font-size:18px;margin-top:18px}
.signature span{display:block;color:var(--muted);font-size:14px;font-family:"Josefin Sans",sans-serif}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center;margin-top:10px}
.stat b{font-family:"Play",sans-serif;color:#fff;font-size:46px;display:block}
.stat span{color:var(--muted);text-transform:uppercase;letter-spacing:2px;font-size:13px}

/* ---------- Call to action ---------- */
.cta{
  background:linear-gradient(180deg, rgba(10,1,25,.86), rgba(10,1,25,.92)), url("../img/callto-bg.jpg");
  background-size:cover;background-position:center;text-align:center;
}
.cta h2{font-size:clamp(30px,5vw,46px);margin-bottom:18px}
.cta p{text-transform:uppercase;letter-spacing:2px;color:#cfcde0;margin-bottom:32px}

/* ---------- Breadcrumb hero (sub pages) ---------- */
.page-hero{
  padding:180px 0 90px;
  background:linear-gradient(180deg, rgba(16,0,40,.80), rgba(16,0,40,.94)), url("../img/breadcrumb-bg.jpg");
  background-size:cover;background-position:center;
}
.page-hero h1{font-size:clamp(36px,6vw,54px);text-transform:uppercase;margin-bottom:10px}
.crumbs{color:var(--muted);font-size:15px}
.crumbs a{color:#fff}
.crumbs span{color:var(--accent)}

/* ---------- About bio ---------- */
.prose p{font-size:17px;margin-bottom:1.2rem;color:#c9c6dd}
.prose p:first-of-type:first-letter{color:var(--accent);font-weight:700}

/* ---------- Services list (detailed) ---------- */
.svc-list{display:grid;grid-template-columns:repeat(2,1fr);gap:26px}
.svc-list__item{
  background:var(--card);border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:10px;padding:30px 32px;transition:transform .2s, box-shadow .2s;
}
.svc-list__item:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(0,0,0,.35)}
.svc-list__item h4{font-size:20px;margin-bottom:12px;color:#fff}
.svc-list__item p{font-size:15px;margin-bottom:.6rem}
.svc-list__item p:last-child{margin-bottom:0}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start}
.contact-info .info-item{display:flex;gap:18px;align-items:flex-start;margin-bottom:26px}
.contact-info .info-item .ic{
  flex:0 0 54px;height:54px;width:54px;border:1px solid var(--line);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:20px;
}
.contact-info h4{margin:0 0 4px;font-size:18px}
.contact-info p{margin:0;font-size:15px}
form .field{margin-bottom:18px}
form label{display:block;font-size:14px;letter-spacing:1px;text-transform:uppercase;color:#cfcde0;margin-bottom:8px;font-family:"Play",sans-serif}
form input,form textarea{
  width:100%;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:8px;
  color:#fff;font-family:inherit;font-size:16px;padding:13px 16px;transition:border-color .2s, background .2s;
}
form input:focus,form textarea:focus{outline:none;border-color:var(--accent);background:rgba(0,191,231,.06)}
form textarea{min-height:140px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-note{font-size:13px;color:var(--muted);margin-top:14px}
.map-wrap{margin-top:50px;border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.map-wrap iframe{display:block;width:100%;height:380px;border:0;filter:grayscale(.3) contrast(1.05)}

/* ---------- Footer ---------- */
.site-footer{background:var(--footer);padding-top:64px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px}
.site-footer h5{color:#fff;font-size:17px;margin-bottom:20px;text-transform:uppercase;letter-spacing:1px}
.site-footer p{font-size:15px}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer ul li{margin-bottom:10px}
.site-footer ul li a{color:var(--muted)}
.site-footer ul li a:hover{color:var(--accent)}
.footer-social{display:flex;gap:10px;margin-top:6px}
.footer-social a{
  height:40px;width:40px;border-radius:50%;background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;
}
.footer-social a:hover{background:var(--accent);color:#03121a}
.footer-bottom{border-top:1px solid var(--line);padding:22px 0;text-align:center}
.footer-bottom p{margin:0;font-size:14px;color:var(--muted)}
.footer-bottom a{color:var(--accent)}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (max-width:992px){
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:36px}
  .contact-grid{grid-template-columns:1fr;gap:36px}
}
@media (max-width:760px){
  .section{padding:64px 0}
  .nav-social{display:none}
  .nav-toggle{display:flex}
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:78%;max-width:320px;height:100vh;
    flex-direction:column;align-items:flex-start;justify-content:center;gap:26px;
    background:#0c021f;padding:40px;transform:translateX(100%);transition:transform .35s;box-shadow:-20px 0 50px rgba(0,0,0,.5);
  }
  .nav-links.open{transform:none}
  .nav-links a{font-size:20px}
  body.nav-open{overflow:hidden}
  .nav-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.active span:nth-child(2){opacity:0}
  .nav-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .svc-list{grid-template-columns:1fr}
  .grid--4{grid-template-columns:1fr}
  .grid--2{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr;gap:30px}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .form-row{grid-template-columns:1fr}
  .hero p{font-size:17px}
}
