/* PROJECT DETAILS CSS */
.page-hero-xl { min-height: 60vh; }
.pd-grid { display: grid; grid-template-columns: 1fr 340px; gap: 4rem; align-items: start; }
.pd-main p { color: var(--clr-muted); font-size: .95rem; }
.pd-info-card { background: var(--clr-card); border: 1px solid var(--clr-border); border-radius: var(--radius-lg); padding: 2rem; position: sticky; top: 100px; }
.pd-info-card h4 { font-size: 1rem; margin-bottom: 1.5rem; padding-bottom: 1rem; border-bottom: 1px solid var(--clr-border); }
.pd-info-item { display: flex; justify-content: space-between; align-items: center; padding: .6rem 0; border-bottom: 1px solid rgba(255,255,255,.04); }
.pd-info-item span { font-size: .78rem; color: var(--clr-muted); }
.pd-info-item strong { font-size: .85rem; color: var(--clr-cream); text-align: right; }
@media(max-width:900px){ .pd-grid{grid-template-columns:1fr;} .pd-info-card{position:static;} }

/* Gallery */
.gallery-grid { display: grid; grid-template-columns: repeat(3,1fr); grid-template-rows: auto auto; gap: 1rem; margin-top: 2.5rem; }
.gallery-item { border-radius: var(--radius); overflow: hidden; cursor: pointer; }
.gallery-item.big { grid-column: 1/3; grid-row: 1/2; }
.gi-img { height: 280px; background-size: cover; background-position: center; transition: transform .5s ease; }
.gallery-item.big .gi-img { height: 400px; }
.gallery-item:hover .gi-img { transform: scale(1.05); }
@media(max-width:768px){ .gallery-grid{grid-template-columns:1fr 1fr;} .gallery-item.big{grid-column:1/3;} }
@media(max-width:480px){ .gallery-grid{grid-template-columns:1fr;} .gallery-item.big{grid-column:1;} }

/* Lightbox */
.lightbox { display: none; position: fixed; inset: 0; z-index: 9999; align-items: center; justify-content: center; }
.lightbox.open { display: flex; }
.lb-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.92); }
.lb-img { position: relative; z-index: 1; max-width: 90vw; max-height: 85vh; background-size: contain; background-repeat: no-repeat; background-position: center; width: 900px; height: 600px; border-radius: var(--radius-lg); }
.lb-close { position: absolute; top: 20px; right: 20px; z-index: 2; width: 44px; height: 44px; border-radius: 50%; background: rgba(255,255,255,.1); color: #fff; font-size: 1.2rem; display: flex; align-items: center; justify-content: center; cursor: pointer; border: none; transition: var(--transition); }
.lb-close:hover { background: rgba(255,255,255,.2); }
.lb-prev, .lb-next { position: absolute; top: 50%; transform: translateY(-50%); z-index: 2; width: 50px; height: 50px; border-radius: 50%; background: rgba(255,255,255,.1); color: #fff; font-size: 1.8rem; display: flex; align-items: center; justify-content: center; cursor: pointer; border: none; transition: var(--transition); }
.lb-prev { left: 20px; }
.lb-next { right: 20px; }
.lb-prev:hover, .lb-next:hover { background: rgba(201,149,58,.4); }

/* Timeline */
.timeline { max-width: 800px; margin: 3rem auto 0; position: relative; }
.timeline::before { content: ''; position: absolute; left: 120px; top: 0; bottom: 0; width: 2px; background: linear-gradient(to bottom, var(--clr-gold), transparent); }
.tl-item { display: grid; grid-template-columns: 120px 1fr; gap: 2rem; margin-bottom: 2.5rem; position: relative; }
.tl-date { font-size: .78rem; font-weight: 600; color: var(--clr-gold); text-align: right; padding-top: .3rem; }
.tl-content { background: var(--clr-card); border: 1px solid var(--clr-border); border-radius: var(--radius-lg); padding: 1.5rem; position: relative; }
.tl-content::before { content: ''; position: absolute; left: -9px; top: 14px; width: 16px; height: 16px; border-radius: 50%; background: var(--clr-gold); border: 3px solid var(--clr-bg); }
.tl-content h4 { font-size: 1rem; margin-bottom: .4rem; }
.tl-content p { font-size: .85rem; color: var(--clr-muted); }
@media(max-width:640px){ .timeline::before{left:0;} .tl-item{grid-template-columns:1fr;} .tl-date{text-align:left;} .tl-content::before{display:none;} }

/* Results */
.results-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1.5rem; margin-top: 3rem; }
.result-card { background: var(--clr-card); border: 1px solid var(--clr-border); border-radius: var(--radius-lg); padding: 2.5rem; text-align: center; transition: var(--transition); }
.result-card:hover { border-color: rgba(201,149,58,.4); transform: translateY(-4px); }
.res-num { font-family: var(--font-display); font-size: 3rem; font-weight: 900; line-height: 1; margin-bottom: .5rem; }
.res-label { font-size: .82rem; color: var(--clr-muted); }
@media(max-width:768px){ .results-grid{grid-template-columns:1fr 1fr;} }

.testimonial-card.big { max-width: 800px; margin: 0 auto; }
