/* ─── PROJECT PAGE STYLES ─── */

.proj-hero{position:relative;min-height:560px;color:#fff;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;width:100%}
.proj-hero__img{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.proj-hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0.35) 40%, rgba(0,0,0,0.85) 100%);z-index:1}
.proj-hero__inner{position:relative;z-index:2;padding-top:96px;padding-bottom:64px}
.proj-hero__inner .sheet-marks{margin-bottom:48px}
.proj-back{display:inline-flex;align-items:center;gap:10px;color:rgba(255,255,255,.7);font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;text-decoration:none;margin-bottom:32px;transition:color .25s}
.proj-back:hover{color:var(--red)}
.proj-back .arr{font-size:14px}
.proj-hero__meta{max-width:820px;display:flex;flex-direction:column;gap:16px}
.proj-hero__meta .eyebrow{color:var(--red)}
.proj-hero__meta .h1{font-family:var(--font-display);font-weight:800;font-size:clamp(40px,6vw,80px);letter-spacing:-0.025em;line-height:1;margin:8px 0;color:#fff;text-wrap:balance}
.proj-hero__meta .lede{color:rgba(255,255,255,.88);max-width:48ch;margin:0;font-size:clamp(16px,1.4vw,18px);line-height:1.6}

/* specs strip */
.proj-specs{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:24px 0;margin:0 0 0}
.proj-spec{display:flex;flex-direction:column;gap:6px;padding:8px 16px;border-right:1px solid var(--line-soft)}
.proj-spec:last-child{border-right:0}
.proj-spec .k{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted)}
.proj-spec .v{font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:-0.01em;color:var(--fg)}
@media (max-width:880px){
  .proj-specs{grid-template-columns:repeat(2,1fr);gap:16px 0}
  .proj-spec{border-right:0;border-bottom:1px solid var(--line-soft);padding:12px 16px}
}

/* works grid */
.works-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:24px}
.work{padding:32px 28px;background:var(--bg-2);border:1px solid var(--line);border-radius:10px;display:flex;flex-direction:column;gap:14px;position:relative}
.work::before{content:"";position:absolute;top:-1px;left:-1px;width:14px;height:14px;border-top:1.5px solid var(--red);border-left:1.5px solid var(--red)}
.work-num{font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;color:var(--red);text-transform:uppercase}
.work h3{font-family:var(--font-display);font-weight:600;font-size:22px;letter-spacing:-0.01em;line-height:1.2;margin:0;color:var(--fg)}
.work ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.work ul li{position:relative;padding-left:22px;font-family:var(--font-mono);font-size:12.5px;letter-spacing:0.04em;color:var(--fg-soft);line-height:1.45}
.work ul li::before{content:"";position:absolute;left:0;top:7px;width:12px;height:1.5px;background:var(--red)}
@media (max-width:880px){.works-grid{grid-template-columns:1fr}}

/* gallery inner reuse (in case style-dark css doesn't load this rule on this page) */
.gallery-inner{padding-top:24px !important;padding-bottom:96px !important}

/* lead modal */
.lead-modal{position:fixed;inset:0;background:rgba(8,8,10,0.85);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}
.lead-modal[hidden]{display:none}
.lead-modal__card{background:#1a1c1f;color:#fafafa;border:1px solid #3a3d41;border-radius:12px;max-width:520px;width:100%;padding:40px;position:relative;max-height:90vh;overflow-y:auto}
.lead-modal__close{position:absolute;top:16px;right:16px;background:transparent;border:none;color:#9aa0a6;font-size:28px;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%}
.lead-modal__close:hover{background:rgba(255,255,255,0.05);color:#fff}
.lead-modal .form-group{margin-bottom:16px}
.lead-modal label{display:block;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:#9aa0a6;margin-bottom:8px;font-family:'JetBrains Mono',monospace}
.lead-modal input,.lead-modal textarea{width:100%;background:#212427;border:1px solid #3a3d41;color:#fafafa;padding:14px 16px;font-size:15px;font-family:'Inter',sans-serif;border-radius:8px;outline:none;box-sizing:border-box}
.lead-modal input:focus,.lead-modal textarea:focus{border-color:#E53935}
.lead-modal .btn-primary{display:inline-flex;align-items:center;gap:8px;background:#E53935;color:#fff;border:none;padding:18px 32px;border-radius:8px;font-family:'Onest',sans-serif;font-size:16px;font-weight:600;cursor:pointer;width:100%;justify-content:center}
.lead-modal .btn-primary:hover{background:#c92e23}
.lead-modal .btn-primary[disabled]{opacity:.7;cursor:wait}
.lead-modal input.invalid,.lead-modal textarea.invalid{border-color:#ff5b4d;background:rgba(255,91,77,.06)}
.lead-modal .req{color:#E53935;margin-left:4px;font-weight:700}
.lead-modal .form-error{color:#ff8a7a;font-size:12px;margin:6px 0 0;font-family:'JetBrains Mono',monospace;letter-spacing:0.04em}
body.modal-open{overflow:hidden}
.lead-success{display:none;text-align:center;padding:8px 0 4px;animation:successIn .35s ease}
.lead-success.is-on{display:block}
.lead-modal.is-success .lead-form{display:none}
@keyframes successIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.lead-success__check{width:72px;height:72px;border-radius:50%;background:rgba(76,217,123,.12);border:1px solid rgba(76,217,123,.4);margin:0 auto 20px;display:flex;align-items:center;justify-content:center}
.lead-success__check svg{width:36px;height:36px;stroke:#4cd97b;fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.lead-success__check svg path{stroke-dasharray:48;stroke-dashoffset:48;animation:drawCheck .5s ease .15s forwards}
@keyframes drawCheck{to{stroke-dashoffset:0}}
.lead-success__title{font-family:Onest,sans-serif;font-size:24px;font-weight:700;letter-spacing:-0.01em;margin:0 0 10px;color:#fafafa}
.lead-success__body{color:#9aa0a6;font-size:14px;line-height:1.6;margin:0 0 24px}
.lead-success__body b{color:#fafafa;font-weight:600}
.lead-success__meta{display:flex;justify-content:center;gap:16px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:#666;margin:0 0 24px}
.lead-success__meta span{display:flex;align-items:center;gap:6px}
.lead-success__meta i{width:6px;height:6px;background:#4cd97b;border-radius:50%;font-style:normal}
.lead-success__close{background:transparent;color:#9aa0a6;border:1px solid #3a3d41;padding:14px 28px;border-radius:8px;font-family:Onest,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}
.lead-success__close:hover{border-color:#9aa0a6;color:#fafafa}

/* ─── PROJECT ABOUT — text + photos ─── */
.proj-about{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:start}
.proj-about__txt{display:flex;flex-direction:column;gap:16px}
.proj-about__txt h2{margin-top:8px}
.proj-about__detail{margin:0;color:var(--fg-soft);font-size:15px;line-height:1.6}
.proj-about__photos{display:grid;grid-template-columns:1fr;gap:14px}
.proj-about__photos img{width:100%;display:block;border-radius:10px;aspect-ratio:4/3;object-fit:cover;border:1px solid var(--line)}
@media (max-width:880px){.proj-about{grid-template-columns:1fr;gap:32px}}

/* ─── PROJECT GALLERY — categorized sections ─── */
.gallery-group{margin:0 0 48px}
.gallery-group:last-child{margin-bottom:0}
.gallery-group__head{display:flex;justify-content:space-between;align-items:baseline;margin:0 0 16px;border-top:1px solid rgba(255,255,255,.12);padding-top:18px}
.gallery-group__title{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--red)}
.gallery-group__count{font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,.5)}

.proj-about__img{width:100%}
.proj-about__img img{width:100%;display:block;border-radius:10px;aspect-ratio:4/3;object-fit:cover;border:1px solid var(--line)}
