/* ============================================================
   Jocan Contracting — modern editorial-luxury
   Palette: navy + cream + brass
   ============================================================ */
:root{
  --navy: #0d2a47;
  --navy-deep: #081a2d;
  --navy-ink: #0b223a;
  --cream: #f5f0e6;
  --cream-soft: #faf6ee;
  --bone: #ece4d3;
  --charcoal: #161616;
  --ink: #1c1c1c;
  --muted: #6c6258;
  --brass: #b89253;
  --brass-light: #d5b27a;
  --line: rgba(13,42,71,.12);
  --line-on-dark: rgba(245,240,230,.16);
  --shadow-lg: 0 30px 80px -30px rgba(8,26,45,.45);
  --shadow-md: 0 14px 40px -20px rgba(8,26,45,.35);
  --maxw: 1240px;
  --gutter: clamp(20px, 4vw, 56px);
  --radius: 2px;
  --font-display: "Playfair Display", "Times New Roman", serif;
  --font-body: "Inter", system-ui, sans-serif;
}

/* reset */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  font-size:17px;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .25s ease}
button{font-family:inherit;cursor:pointer}
ul{margin:0;padding:0;list-style:none}

.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}

/* ----- typography ----- */
.display{
  font-family:var(--font-display);
  font-weight:600;
  letter-spacing:-0.015em;
  line-height:1.05;
  font-size:clamp(40px, 6.4vw, 96px);
  margin:.2em 0 .35em;
}
.display em{font-style:italic;color:var(--brass);font-weight:500}
.display--md{font-size:clamp(32px,4.2vw,60px);line-height:1.08}

.eyebrow{
  display:inline-block;
  font-family:var(--font-body);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:12px;
  font-weight:600;
  color:var(--muted);
  margin:0 0 18px;
  padding-left:34px;
  position:relative;
}
.eyebrow::before{
  content:"";
  position:absolute;left:0;top:50%;
  width:22px;height:1px;
  background:currentColor;opacity:.6;
}
.eyebrow--gold{color:var(--brass)}

/* ----- buttons ----- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.5em;
  padding:16px 28px;
  font-size:14px;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  border:1px solid transparent;
  border-radius:var(--radius);
  transition:transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
  cursor:pointer;
}
.btn--gold{background:var(--brass);color:#fff;border-color:var(--brass)}
.btn--gold:hover{background:var(--brass-light);border-color:var(--brass-light);transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--cream);border-color:rgba(245,240,230,.4)}
.btn--ghost:hover{background:rgba(245,240,230,.08);border-color:var(--cream)}
.btn--dark{background:var(--navy);color:var(--cream);border-color:var(--navy)}
.btn--dark:hover{background:var(--navy-deep)}
.btn--full{width:100%}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;
  z-index:50;
  padding:18px 0;
  transition:background .35s ease, padding .35s ease, box-shadow .35s ease;
  background:linear-gradient(to bottom, rgba(8,26,45,.55), rgba(8,26,45,0));
}
.nav.is-scrolled{
  background:rgba(13,42,71,.96);
  padding:12px 0;
  box-shadow:0 1px 0 rgba(245,240,230,.06);
  backdrop-filter:saturate(1.1) blur(8px);
}
.nav__inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);
}
.nav__brand{
  display:flex;align-items:center;gap:14px;
  color:var(--cream);
  font-family:var(--font-display);
  font-size:22px;font-weight:600;letter-spacing:.01em;
}
.nav__brand img{
  width:42px;height:42px;border-radius:50%;
  background:var(--cream);
  object-fit:cover;
  box-shadow:0 0 0 1px rgba(245,240,230,.2);
}
.nav__brand em{font-style:italic;font-weight:500;color:var(--brass-light);font-size:16px;margin-left:2px}
.nav__links{display:flex;align-items:center;gap:36px}
.nav__links a{
  color:var(--cream);
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:500;
  opacity:.85;
}
.nav__links a:hover{opacity:1;color:var(--brass-light)}
.nav__cta{
  border:1px solid rgba(245,240,230,.35) !important;
  padding:11px 20px;
  border-radius:var(--radius);
  opacity:1 !important;
}
.nav__cta:hover{background:var(--brass);border-color:var(--brass) !important;color:#fff !important}
.nav__burger{
  display:none;
  background:transparent;border:0;
  width:38px;height:38px;
  flex-direction:column;justify-content:center;gap:5px;padding:0;
}
.nav__burger span{
  display:block;height:1.5px;width:24px;margin:0 auto;
  background:var(--cream);
  transition:transform .3s ease, opacity .3s ease;
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;
  color:var(--cream);
  isolation:isolate;
  padding:140px 0 80px;
  overflow:hidden;
}
.hero__bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transform:scale(1.05);
  z-index:-2;
}
.hero__veil{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(8,26,45,.55) 0%, rgba(8,26,45,.85) 100%),
    radial-gradient(80% 60% at 30% 30%, rgba(184,146,83,.18) 0%, transparent 60%);
  z-index:-1;
}
.hero__content{position:relative}
.hero__lede{
  font-size:clamp(17px,1.35vw,20px);
  max-width:640px;
  color:rgba(245,240,230,.85);
  margin:0 0 38px;
  line-height:1.65;
}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:80px}
.hero__stats{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  gap:32px;
  max-width:600px;
  border-top:1px solid rgba(245,240,230,.18);
  padding-top:32px;
}
.hero__stats strong{
  display:block;
  font-family:var(--font-display);
  font-size:clamp(32px,3vw,44px);
  font-weight:600;
  color:var(--brass-light);
  line-height:1;
  margin-bottom:8px;
}
.hero__stats span{
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:rgba(245,240,230,.7);
}
.hero__scroll{
  position:absolute;left:50%;bottom:32px;
  transform:translateX(-50%);
  color:var(--brass-light);
  font-size:22px;
  opacity:.8;
  animation:bob 2.4s ease-in-out infinite;
}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.strip{background:var(--navy);color:var(--cream);padding:28px 0;border-top:1px solid rgba(245,240,230,.06)}
.strip__row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
  font-size:13px;letter-spacing:.16em;text-transform:uppercase;
}
.strip__row > div{display:flex;align-items:center;gap:14px}
.strip__num{
  font-family:var(--font-display);font-size:22px;color:var(--brass-light);font-weight:600;
}

/* ============================================================
   SECTIONS
   ============================================================ */
.section-head{max-width:760px;margin:0 0 70px}
.section-head--center{margin:0 auto 70px;text-align:center}
.section-head--center .eyebrow{padding-left:34px}
.section-head__lede{font-size:18px;color:var(--muted);line-height:1.7;margin:0}

/* services */
.services{padding:130px 0;background:var(--cream)}
.services__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
}
.service{
  background:#fff;
  border:1px solid var(--line);
  display:flex;flex-direction:column;
  transition:transform .35s ease, box-shadow .35s ease;
}
.service:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.service__media{
  height:280px;
  background-size:cover;background-position:center;
  border-bottom:3px solid var(--brass);
}
.service__body{padding:34px 32px 36px;display:flex;flex-direction:column;flex:1}
.service__num{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass);font-weight:600;margin:0 0 16px;
}
.service h3{
  font-family:var(--font-display);
  font-size:26px;font-weight:600;
  margin:0 0 16px;color:var(--navy-ink);line-height:1.2;
}
.service p{color:var(--muted);margin:0 0 22px}
.service ul{margin-top:auto;border-top:1px solid var(--line);padding-top:22px}
.service li{
  font-size:14px;color:var(--ink);
  padding:6px 0 6px 22px;position:relative;
}
.service li::before{
  content:"";position:absolute;left:0;top:14px;
  width:10px;height:1px;background:var(--brass);
}
.service--featured{
  background:var(--navy);color:var(--cream);
}
.service--featured h3{color:var(--cream)}
.service--featured p{color:rgba(245,240,230,.75)}
.service--featured li{color:rgba(245,240,230,.92)}
.service--featured ul{border-top-color:var(--line-on-dark)}
.service--featured .service__num{color:var(--brass-light)}

/* why */
.why{background:var(--navy);color:var(--cream);padding:130px 0;position:relative;overflow:hidden}
.why::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 60% at 80% 20%, rgba(184,146,83,.12) 0%, transparent 60%);
  pointer-events:none;
}
.why__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start;position:relative}
.why__left h2{margin-top:.15em}
.why__left p{color:rgba(245,240,230,.78);margin:0 0 32px;max-width:480px}
.why__list{display:flex;flex-direction:column;gap:24px}
.why__list li{
  display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;
  padding:24px 0;border-top:1px solid var(--line-on-dark);
}
.why__list li:first-child{border-top:0;padding-top:0}
.why__num{
  font-family:var(--font-display);font-size:32px;color:var(--brass-light);
  font-weight:600;line-height:1;width:48px;
}
.why__list h4{
  font-family:var(--font-display);
  font-size:22px;margin:0 0 8px;color:var(--cream);font-weight:600;
}
.why__list p{color:rgba(245,240,230,.72);margin:0;font-size:15.5px}

/* portfolio */
.portfolio{padding:130px 0;background:var(--cream-soft)}
.gallery{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  grid-auto-rows:220px;
  gap:14px;
}
.gallery a{
  display:block;position:relative;
  overflow:hidden;
  background:#000;
  cursor:zoom-in;
}
.gallery a::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(8,26,45,.45) 100%);
  opacity:0;transition:opacity .35s ease;
}
.gallery a:hover::after{opacity:1}
.gallery img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .9s cubic-bezier(.2,.7,.2,1);
}
.gallery a:hover img{transform:scale(1.06)}
.gallery a.tall{grid-row:span 2}
.gallery a.wide{grid-column:span 2}

/* lightbox */
.lightbox{
  position:fixed;inset:0;z-index:100;
  background:rgba(8,26,45,.94);
  display:none;align-items:center;justify-content:center;
  padding:40px;
}
.lightbox.is-open{display:flex}
.lightbox img{
  max-width:90vw;max-height:88vh;object-fit:contain;
  box-shadow:var(--shadow-lg);
}
.lightbox button{
  position:absolute;top:24px;right:30px;
  background:transparent;border:0;color:var(--cream);
  font-size:32px;line-height:1;
}

/* about */
.about{padding:130px 0;background:var(--cream)}
.about__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:80px;align-items:center}
.about__media{position:relative}
.about__media::before{
  content:"";position:absolute;
  left:-20px;top:-20px;right:40px;bottom:40px;
  border:1px solid var(--brass);
  z-index:0;
}
.about__media img{position:relative;z-index:1;width:100%;height:auto;box-shadow:var(--shadow-lg)}
.about__copy p{color:var(--muted);font-size:17px;margin:0 0 18px}
.about__chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.about__chips span{
  display:inline-block;padding:8px 16px;
  background:#fff;border:1px solid var(--line);
  font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--navy-ink);
}

/* contact */
.contact{padding:130px 0;background:var(--navy);color:var(--cream);position:relative;overflow:hidden}
.contact::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(70% 70% at 10% 100%, rgba(184,146,83,.15) 0%, transparent 60%);
}
.contact__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start;position:relative}
.contact__left p{color:rgba(245,240,230,.78);margin:0 0 36px;max-width:440px}
.contact__info{display:flex;flex-direction:column;gap:20px;border-top:1px solid var(--line-on-dark);padding-top:28px}
.contact__info li{
  display:grid;grid-template-columns:120px 1fr;gap:16px;
  font-size:15px;
}
.contact__info span{
  text-transform:uppercase;letter-spacing:.18em;font-size:12px;color:var(--brass-light);
  font-weight:600;
}
.contact__info a{color:var(--cream);border-bottom:1px solid rgba(245,240,230,.25);padding-bottom:1px}
.contact__info a:hover{color:var(--brass-light);border-color:var(--brass-light)}

.contact__form{
  background:rgba(245,240,230,.05);
  border:1px solid var(--line-on-dark);
  padding:44px 40px 40px;
  display:flex;flex-direction:column;gap:20px;
  backdrop-filter:blur(6px);
}
.contact__form label{display:flex;flex-direction:column;gap:8px}
.contact__form span{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--brass-light);font-weight:600;
}
.contact__form input,
.contact__form select,
.contact__form textarea{
  background:transparent;
  border:0;border-bottom:1px solid rgba(245,240,230,.25);
  color:var(--cream);
  font-family:inherit;font-size:16px;
  padding:12px 0;
  transition:border-color .25s ease;
}
.contact__form input::placeholder,
.contact__form textarea::placeholder{color:rgba(245,240,230,.4)}
.contact__form input:focus,
.contact__form select:focus,
.contact__form textarea:focus{outline:none;border-bottom-color:var(--brass-light)}
.contact__form select option{background:var(--navy);color:var(--cream)}
.contact__form textarea{resize:vertical;min-height:120px}
.contact__row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.contact__small{font-size:12px;color:rgba(245,240,230,.5);margin:6px 0 0;text-align:center;letter-spacing:.08em}

/* footer */
.footer{background:var(--navy-deep);color:rgba(245,240,230,.7);padding:80px 0 0}
.footer__inner{display:grid;grid-template-columns:1fr 2fr;gap:70px;padding-bottom:60px}
.footer__brand{display:flex;flex-direction:column;gap:18px}
.footer__brand img{width:54px;height:54px;border-radius:50%;background:var(--cream)}
.footer__brand p{margin:0;color:var(--cream);font-family:var(--font-display);font-size:18px;line-height:1.4}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.footer__cols h5{
  font-family:var(--font-body);font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brass-light);margin:0 0 18px;font-weight:600;
}
.footer__cols a,
.footer__cols span{display:block;padding:5px 0;font-size:15px;color:rgba(245,240,230,.7)}
.footer__cols a:hover{color:var(--brass-light)}
.footer__base{border-top:1px solid rgba(245,240,230,.08);padding:24px 0}
.footer__base-inner{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:13px;color:rgba(245,240,230,.55);letter-spacing:.04em;
}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease, transform .9s ease}
.reveal.is-in{opacity:1;transform:translateY(0)}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .services__grid{grid-template-columns:1fr 1fr}
  .service--featured{grid-column:1 / -1}
  .why__grid,.about__grid,.contact__grid{grid-template-columns:1fr;gap:50px}
  .footer__inner{grid-template-columns:1fr;gap:40px}
  .gallery{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:760px){
  body{font-size:16px}
  .nav__links{
    position:fixed;top:0;right:0;bottom:0;
    width:min(82vw,360px);
    background:var(--navy-deep);
    flex-direction:column;align-items:flex-start;justify-content:flex-start;
    padding:100px 36px 40px;gap:8px;
    transform:translateX(100%);
    transition:transform .4s cubic-bezier(.2,.7,.2,1);
    box-shadow:-30px 0 60px rgba(0,0,0,.4);
  }
  .nav__links.is-open{transform:translateX(0)}
  .nav__links a{width:100%;padding:14px 0;border-bottom:1px solid var(--line-on-dark);font-size:15px}
  .nav__cta{border:0 !important;padding:14px 0 !important}
  .nav__burger{display:flex}
  .nav__burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav__burger.is-open span:nth-child(2){opacity:0}
  .nav__burger.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

  .hero{padding:120px 0 60px;min-height:auto}
  .hero__stats{grid-template-columns:1fr 1fr;gap:18px}
  .strip__row{grid-template-columns:1fr 1fr;gap:18px}
  .services,.why,.portfolio,.about,.contact{padding:80px 0}
  .services__grid{grid-template-columns:1fr}
  .service--featured{grid-column:auto}
  .gallery{grid-template-columns:1fr 1fr;grid-auto-rows:160px}
  .gallery a.wide{grid-column:span 2}
  .gallery a.tall{grid-row:span 1}
  .about__media::before{display:none}
  .contact__row{grid-template-columns:1fr}
  .contact__form{padding:32px 24px}
  .footer__cols{grid-template-columns:1fr 1fr}
  .footer__base-inner{flex-direction:column;align-items:flex-start}
}
