/* projects page-specific styles */
/* ============================================================
   SERVICE PAGE TEMPLATE STYLES
   ============================================================ */
/* breadcrumb */
.breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:0.8125rem;color:var(--concrete-400);margin-bottom:var(--sp-6)}
.breadcrumb a{color:var(--concrete-200);transition:color var(--dur-fast) var(--ease-standard)}
.breadcrumb a:hover{color:var(--epoxy-blue)}
.breadcrumb svg{width:13px;height:13px;opacity:0.6}
.breadcrumb [aria-current]{color:var(--mist)}

/* service hero: split text + image */
.svc-hero{position:relative;background:var(--cha-black);overflow:hidden;isolation:isolate;
  padding-top:calc(var(--header-h) + var(--sp-12));padding-bottom:var(--sp-16);
  border-bottom:var(--bw) solid var(--slate-800)}
.svc-hero__glow{position:absolute;z-index:-1;pointer-events:none;width:58vw;height:58vw;max-width:740px;max-height:740px;top:-16%;right:-12%;
  background:radial-gradient(circle, rgba(105,217,255,0.13) 0%, rgba(111,142,216,0.06) 40%, transparent 68%);filter:blur(10px)}
.svc-hero__texture{position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:0.045;mix-blend-mode:screen;
  background-image:repeating-linear-gradient(116deg,transparent 0 40px,rgba(168,221,228,0.5) 40px 41px),repeating-linear-gradient(60deg,transparent 0 70px,rgba(168,221,228,0.3) 70px 71px);
  -webkit-mask-image:radial-gradient(ellipse at 85% 25%,black 0%,transparent 72%);mask-image:radial-gradient(ellipse at 85% 25%,black 0%,transparent 72%)}
.svc-hero__inner{max-width:var(--container);margin:0 auto;padding:0 var(--gutter);
  display:grid;grid-template-columns:1fr;gap:var(--sp-12);align-items:center}
@media (min-width:960px){.svc-hero__inner{grid-template-columns:1.05fr 0.95fr;gap:var(--sp-16)}}
.svc-hero__eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:var(--fs-overline);font-weight:600;letter-spacing:var(--ls-overline);text-transform:uppercase;color:var(--epoxy-blue);margin-bottom:var(--sp-4)}
.svc-hero__eyebrow::before{content:"";width:28px;height:1.5px;background:var(--epoxy-blue);display:inline-block}
.svc-hero__title{font-family:var(--font-heading);font-weight:800;font-size:var(--fs-display);line-height:1.06;letter-spacing:var(--ls-tight);color:var(--ice-white);margin-bottom:var(--sp-6);text-wrap:balance}
.svc-hero__title .accent{color:var(--epoxy-blue)}
.svc-hero__lead{font-size:var(--fs-body-l);line-height:1.6;color:var(--concrete-200);max-width:54ch;margin-bottom:var(--sp-8)}
.svc-hero__cta{display:flex;flex-wrap:wrap;gap:var(--sp-4);align-items:center}
.svc-hero__media{position:relative;border-radius:var(--r-lg);overflow:hidden;border:var(--bw) solid var(--slate-800);
  aspect-ratio:4/3;background:var(--graphite)}
.svc-hero__media img{width:100%;height:100%;object-fit:cover;display:block}
.svc-hero__media-tag{position:absolute;left:var(--sp-4);bottom:var(--sp-4);z-index:2;
  font-size:0.6875rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--cha-black);background:var(--epoxy-blue);padding:6px 12px;border-radius:var(--r-full)}
.svc-hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(5,5,5,0.5) 100%)}
.placeholder-img{display:grid;place-items:center;width:100%;height:100%;color:var(--slate-600);
  background:repeating-linear-gradient(135deg,var(--graphite) 0 18px,var(--carbon) 18px 36px)}
.placeholder-img svg{width:56px;height:56px;opacity:0.5}

@media (max-width:520px){.svc-hero__cta{flex-direction:column;align-items:stretch}.svc-hero__cta .btn{width:100%}}

/* generic section wrapper */
.svc-section{position:relative;padding:var(--section-y) 0;overflow:hidden;isolation:isolate}
.svc-section--alt{background:var(--graphite);border-top:var(--bw) solid var(--slate-800)}
.svc-section--black{background:var(--cha-black);border-top:var(--bw) solid var(--slate-800)}
.svc-section__inner{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.svc-glow{position:absolute;z-index:-1;pointer-events:none;width:50vw;height:50vw;max-width:640px;max-height:640px;
  background:radial-gradient(circle,rgba(105,217,255,0.08) 0%,rgba(111,142,216,0.05) 42%,transparent 70%);filter:blur(10px)}
.svc-glow--tr{top:-12%;right:-12%}.svc-glow--bl{bottom:-14%;left:-12%}

/* overview: text + highlights */
.overview{display:grid;grid-template-columns:1fr;gap:var(--sp-12)}
@media (min-width:960px){.overview{grid-template-columns:1.3fr 0.7fr;gap:var(--sp-16);align-items:start}}
.overview__body p{font-size:var(--fs-body-l);line-height:1.7;color:var(--concrete-200);margin-bottom:var(--sp-4)}
.overview__body p:last-child{margin-bottom:0}
.overview__aside{background:var(--carbon);border:var(--bw) solid var(--slate-800);border-radius:var(--r-md);padding:var(--sp-8)}
.overview__aside-title{font-family:var(--font-heading);font-weight:700;font-size:var(--fs-h4);color:var(--ice-white);letter-spacing:var(--ls-tight);margin-bottom:var(--sp-6)}
.overview__list{display:flex;flex-direction:column;gap:var(--sp-4)}
.overview__list-item{display:flex;align-items:flex-start;gap:12px;font-size:0.9375rem;color:var(--concrete-200);line-height:1.5}
.overview__list-item svg{width:20px;height:20px;color:var(--epoxy-blue);flex:0 0 auto;margin-top:1px}

/* benefits grid (reuse service-card style) */
.benefits-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-6)}
@media (min-width:640px){.benefits-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1024px){.benefits-grid{grid-template-columns:repeat(3,1fr)}}
.benefit-card{background:var(--carbon);border:var(--bw) solid var(--slate-800);border-radius:var(--r-md);padding:var(--sp-8);
  transition:transform var(--dur-mid) var(--ease-standard),border-color var(--dur-mid) var(--ease-standard),box-shadow var(--dur-mid) var(--ease-standard)}
.benefit-card:hover{transform:translateY(-4px);border-color:rgba(105,217,255,0.4);box-shadow:var(--shadow-card)}
.benefit-card__icon{width:48px;height:48px;border-radius:var(--r-sm);display:grid;place-items:center;margin-bottom:var(--sp-6);
  background:rgba(105,217,255,0.07);border:var(--bw) solid rgba(105,217,255,0.18);color:var(--epoxy-blue)}
.benefit-card__icon svg{width:24px;height:24px}
.benefit-card__title{font-family:var(--font-heading);font-weight:700;font-size:var(--fs-h4);color:var(--ice-white);letter-spacing:var(--ls-tight);margin-bottom:var(--sp-3)}
.benefit-card__desc{font-size:0.9375rem;line-height:1.6;color:var(--concrete-200)}

/* ideal applications */
.applications{display:grid;grid-template-columns:1fr;gap:var(--sp-6)}
@media (min-width:768px){.applications{grid-template-columns:repeat(3,1fr)}}
.app-card{position:relative;border-radius:var(--r-md);overflow:hidden;border:var(--bw) solid var(--slate-800);min-height:280px;background:var(--graphite);display:flex;flex-direction:column;justify-content:flex-end}
.app-card__img{position:absolute;inset:0;z-index:0}
.app-card__img img{width:100%;height:100%;object-fit:cover}
.app-card__img .placeholder-img{position:absolute;inset:0}
.app-card__shade{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(5,5,5,0.2) 0%,rgba(5,5,5,0.5) 45%,rgba(5,5,5,0.9) 100%)}
.app-card__body{position:relative;z-index:2;padding:var(--sp-8)}
.app-card__tag{display:inline-flex;font-size:0.6875rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--epoxy-blue);margin-bottom:var(--sp-3)}
.app-card__title{font-family:var(--font-heading);font-weight:700;font-size:var(--fs-h3);color:var(--ice-white);letter-spacing:var(--ls-tight);margin-bottom:var(--sp-3)}
.app-card__desc{font-size:0.9375rem;line-height:1.55;color:var(--concrete-200)}

/* FAQ accordion */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:var(--sp-3)}
.faq-item{background:var(--carbon);border:var(--bw) solid var(--slate-800);border-radius:var(--r-md);overflow:hidden;
  transition:border-color var(--dur-fast) var(--ease-standard)}
.faq-item.is-open{border-color:rgba(105,217,255,0.35)}
.faq-item__trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);
  padding:var(--sp-6);text-align:left;cursor:pointer}
.faq-item__q{font-family:var(--font-heading);font-weight:700;font-size:1.0625rem;color:var(--ice-white);letter-spacing:var(--ls-tight);line-height:1.35}
.faq-item__icon{width:32px;height:32px;flex:0 0 auto;border-radius:var(--r-full);display:grid;place-items:center;
  background:rgba(105,217,255,0.08);border:var(--bw) solid rgba(105,217,255,0.2);color:var(--epoxy-blue);
  transition:transform var(--dur-mid) var(--ease-standard),background var(--dur-fast) var(--ease-standard)}
.faq-item__icon svg{width:16px;height:16px;transition:transform var(--dur-mid) var(--ease-standard)}
.faq-item.is-open .faq-item__icon{background:var(--epoxy-blue);color:var(--cha-black)}
.faq-item.is-open .faq-item__icon svg{transform:rotate(45deg)}
.faq-item__panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--dur-mid) var(--ease-standard)}
.faq-item.is-open .faq-item__panel{grid-template-rows:1fr}
.faq-item__inner{overflow:hidden}
.faq-item__a{padding:0 var(--sp-6) var(--sp-6);font-size:0.9375rem;line-height:1.65;color:var(--concrete-200)}

/* related services */
.related-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-6)}
@media (min-width:640px){.related-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1024px){.related-grid{grid-template-columns:repeat(3,1fr)}}
.related-card{position:relative;display:flex;align-items:center;gap:14px;background:var(--carbon);border:var(--bw) solid var(--slate-800);
  border-radius:var(--r-md);padding:var(--sp-6);transition:transform var(--dur-mid) var(--ease-standard),border-color var(--dur-mid) var(--ease-standard),box-shadow var(--dur-mid) var(--ease-standard)}
.related-card:hover{transform:translateY(-3px);border-color:rgba(105,217,255,0.4);box-shadow:var(--shadow-card)}
.related-card__icon{width:46px;height:46px;flex:0 0 auto;border-radius:var(--r-sm);display:grid;place-items:center;background:rgba(105,217,255,0.07);border:var(--bw) solid rgba(105,217,255,0.18);color:var(--epoxy-blue)}
.related-card__icon svg{width:24px;height:24px}
.related-card__text{flex:1}
.related-card__title{font-family:var(--font-heading);font-weight:700;font-size:1.0625rem;color:var(--ice-white);letter-spacing:var(--ls-tight);margin-bottom:2px}
.related-card__arrow{color:var(--concrete-400);transition:transform var(--dur-fast) var(--ease-standard),color var(--dur-fast) var(--ease-standard)}
.related-card__arrow svg{width:18px;height:18px}
.related-card:hover .related-card__arrow{color:var(--epoxy-blue);transform:translateX(3px)}
.related-card__link::after{content:"";position:absolute;inset:0}

/* section head shared (left aligned default) */
.svc-head{max-width:680px;margin-bottom:var(--sp-16)}
.svc-head--center{margin-left:auto;margin-right:auto;text-align:center}
.svc-head--center .section-head__eyebrow{justify-content:center}
.svc-head--center .section-head__lead{margin-left:auto;margin-right:auto}

/* placeholder note banner (template-only, remove on real pages) */
.tpl-note{background:rgba(105,217,255,0.06);border:1px dashed rgba(105,217,255,0.35);border-radius:var(--r-sm);
  color:var(--concrete-200);font-size:0.8125rem;padding:10px 14px;margin-bottom:var(--sp-8);line-height:1.5}
.tpl-note strong{color:var(--epoxy-blue)}


/* ===== PROJECTS PAGE ===== */
.proj-hero{position:relative;padding:calc(var(--header-h) + var(--sp-20)) 0 var(--sp-16);overflow:hidden;background:var(--cha-black)}
.proj-hero__glow{position:absolute;top:-20%;right:-10%;width:55%;height:120%;
  background:radial-gradient(circle,rgba(105,217,255,0.10) 0%,transparent 65%);pointer-events:none}
.proj-hero__texture{position:absolute;inset:0;opacity:0.5;pointer-events:none;
  background-image:linear-gradient(135deg,rgba(255,255,255,0.015) 1px,transparent 1px);background-size:34px 34px}
.proj-hero__inner{position:relative;max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.proj-hero__eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:var(--fs-overline);font-weight:600;
  letter-spacing:0.18em;text-transform:uppercase;color:var(--epoxy-blue);margin-bottom:var(--sp-5)}
.proj-hero__eyebrow::before{content:"";width:34px;height:2px;background:var(--epoxy-blue)}
.proj-hero__title{font-family:var(--font-heading);font-weight:800;font-size:var(--fs-display);line-height:1.05;
  letter-spacing:var(--ls-tight);color:var(--ice-white);margin-bottom:var(--sp-6);max-width:16ch}
.proj-hero__title .accent{color:var(--epoxy-blue)}
.proj-hero__lead{font-size:var(--fs-lead);line-height:1.6;color:var(--concrete-200);max-width:60ch}

/* filters */
.proj-filters{position:relative;background:var(--cha-black);padding:0 0 var(--sp-10)}
.proj-filters__inner{max-width:var(--container);margin:0 auto;padding:0 var(--gutter);
  display:flex;flex-wrap:wrap;gap:10px}
.filter-btn{appearance:none;cursor:pointer;font-family:var(--font-body);font-size:0.9375rem;font-weight:600;
  color:var(--concrete-200);background:var(--carbon);border:var(--bw) solid var(--slate-800);
  border-radius:var(--r-full);padding:11px 22px;transition:all var(--t-fast)}
.filter-btn:hover{color:var(--ice-white);border-color:var(--slate-600);transform:translateY(-1px)}
.filter-btn.is-active{color:var(--cha-black);background:var(--epoxy-blue);border-color:var(--epoxy-blue)}
.filter-btn__count{opacity:0.6;font-weight:500;margin-left:4px}
.filter-btn.is-active .filter-btn__count{opacity:0.7}

/* gallery grid */
.proj-gallery{position:relative;background:var(--cha-black);padding:0 0 var(--sp-24)}
.proj-gallery__inner{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-5)}
.proj-card{position:relative;display:block;width:100%;margin:0;padding:0;text-align:left;font:inherit;color:inherit;cursor:pointer;-webkit-appearance:none;appearance:none;border-radius:var(--r-md);overflow:hidden;
  border:var(--bw) solid var(--slate-800);background:var(--carbon);aspect-ratio:4/3;
  transition:transform var(--t-med),border-color var(--t-med),box-shadow var(--t-med)}
.proj-card.is-hidden{display:none}
.proj-card__media{position:absolute;inset:0}
.proj-card__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.proj-card__overlay{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(5,5,5,0.05) 0%,rgba(5,5,5,0.15) 45%,rgba(5,5,5,0.82) 100%);
  transition:opacity var(--t-med)}
.proj-card__view{position:absolute;top:var(--sp-4);right:var(--sp-4);width:40px;height:40px;display:grid;place-items:center;
  border-radius:var(--r-full);background:rgba(105,217,255,0.92);color:var(--cha-black);
  opacity:0;transform:translateY(-6px) scale(0.9);transition:all var(--t-med);z-index:3}
.proj-card__view svg{width:18px;height:18px}
.proj-card__body{position:absolute;left:0;bottom:0;width:100%;padding:var(--sp-6);z-index:2;
  display:flex;flex-direction:column;gap:7px}
.proj-card__cat{display:inline-flex;align-self:flex-start;font-size:0.6875rem;font-weight:700;letter-spacing:0.08em;
  text-transform:uppercase;color:var(--cha-black);background:var(--epoxy-blue);
  border-radius:var(--r-full);padding:4px 11px}
.proj-card__title{font-family:var(--font-heading);font-weight:700;font-size:1.1875rem;line-height:1.2;
  letter-spacing:-0.01em;color:var(--ice-white)}
.proj-card__desc{font-size:0.8125rem;line-height:1.45;color:var(--concrete-200);max-width:36ch}
.proj-card__count{font-size:0.6875rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--epoxy-blue);margin-top:2px}
.proj-card:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px}
.proj-card:hover{transform:translateY(-5px);border-color:rgba(105,217,255,0.45);
  box-shadow:0 18px 44px -18px rgba(0,0,0,0.85),0 0 0 1px rgba(105,217,255,0.12)}
.proj-card:hover .proj-card__media img{transform:scale(1.07)}
.proj-card:hover .proj-card__view{opacity:1;transform:translateY(0) scale(1)}
.proj-empty{display:none;text-align:center;padding:var(--sp-16) 0;color:var(--concrete-400);font-size:var(--fs-lead)}
.proj-empty.is-shown{display:block}

/* featured */
.proj-featured{position:relative;background:var(--graphite);padding:var(--sp-20) 0;border-top:1px solid var(--slate-800)}
.proj-featured__inner{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.proj-featured__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-5);margin-top:var(--sp-10)}
.feat-card{position:relative;display:block;border-radius:var(--r-md);overflow:hidden;
  border:var(--bw) solid var(--slate-800);aspect-ratio:3/4;transition:transform var(--t-med),border-color var(--t-med),box-shadow var(--t-med)}
.feat-card__media{position:absolute;inset:0}
.feat-card__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.feat-card__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,0.05) 0%,rgba(5,5,5,0.2) 40%,rgba(5,5,5,0.85) 100%)}
.feat-card__body{position:absolute;left:0;bottom:0;width:100%;padding:var(--sp-6);display:flex;flex-direction:column;gap:8px;z-index:2}
.feat-card__cat{align-self:flex-start;font-size:0.6875rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--epoxy-blue)}
.feat-card__title{font-family:var(--font-heading);font-weight:700;font-size:1.375rem;line-height:1.18;color:var(--ice-white)}
.feat-card:hover{transform:translateY(-5px);border-color:rgba(105,217,255,0.45);box-shadow:0 18px 44px -18px rgba(0,0,0,0.85)}
.feat-card:hover .feat-card__media img{transform:scale(1.06)}

@media(max-width:1024px){
  .proj-grid{grid-template-columns:repeat(2,1fr)}
  .proj-featured__grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .proj-grid{grid-template-columns:1fr;gap:var(--sp-4)}
  .proj-featured__grid{grid-template-columns:1fr}
  .proj-card{aspect-ratio:16/10}
  .feat-card{aspect-ratio:4/3}
  .proj-filters__inner{gap:8px}
  .filter-btn{padding:9px 16px;font-size:0.875rem}
}

/* ============================================================
   PROJECT LIGHTBOX (vanilla-JS, no third-party scripts)
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:var(--z-overlay,200);display:flex;align-items:center;justify-content:center;padding:clamp(16px,4vw,48px)}
.lightbox[hidden]{display:none}
.lightbox__backdrop{position:absolute;inset:0;background:rgba(5,5,5,0.92);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.lightbox__figure{position:relative;z-index:1;margin:0;max-width:1000px;width:100%;display:flex;flex-direction:column;align-items:center;gap:var(--sp-4)}
.lightbox__img{max-width:100%;max-height:72vh;object-fit:contain;border-radius:var(--r-md);border:var(--bw) solid var(--slate-800);background:var(--graphite);box-shadow:0 24px 60px -20px rgba(0,0,0,0.9)}
.lightbox__caption{text-align:center;display:flex;flex-direction:column;gap:4px;max-width:62ch}
.lightbox__title{font-family:var(--font-heading);font-weight:700;font-size:1.125rem;color:var(--ice-white)}
.lightbox__desc{font-size:0.875rem;line-height:1.5;color:var(--concrete-200)}
.lightbox__count{font-size:0.8125rem;font-weight:700;letter-spacing:0.08em;color:var(--epoxy-blue);margin-top:2px}
.lightbox__close,.lightbox__nav{position:absolute;z-index:2;display:grid;place-items:center;border-radius:var(--r-full);
  background:rgba(13,15,17,0.82);border:var(--bw) solid var(--slate-600);color:var(--ice-white);cursor:pointer;
  transition:background var(--dur-fast,150ms) var(--ease-standard),border-color var(--dur-fast,150ms) var(--ease-standard),transform var(--dur-fast,150ms) var(--ease-standard)}
.lightbox__close{top:clamp(12px,3vw,24px);right:clamp(12px,3vw,24px);width:46px;height:46px}
.lightbox__nav{top:50%;transform:translateY(-50%);width:48px;height:48px}
.lightbox__nav--prev{left:clamp(8px,2vw,24px)}
.lightbox__nav--next{right:clamp(8px,2vw,24px)}
.lightbox__close:hover,.lightbox__nav:hover{background:var(--epoxy-blue);border-color:var(--epoxy-blue);color:var(--cha-black)}
.lightbox__close svg,.lightbox__nav svg{width:22px;height:22px}
.lightbox__nav[disabled]{opacity:0;pointer-events:none}
.lightbox__close:focus-visible,.lightbox__nav:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}
@media(max-width:768px){
  .lightbox__img{max-height:60vh}
  .lightbox__nav{width:42px;height:42px;background:rgba(13,15,17,0.6)}
  .lightbox__nav--prev{left:6px}
  .lightbox__nav--next{right:6px}
}
