/* ════════════════════════════════════════════════════════════════
 *  TITAN — pages.css
 *  Section + page specific styles.
 * ════════════════════════════════════════════════════════════════ */

/* ════════ HOME — HERO ════════ */
.tcg-hero {
  position: relative;
  min-height: clamp(620px, 92vh, 920px);
  display: flex;
  align-items: center;
  overflow: hidden;
  isolation: isolate;
  margin-top: -1px;
}
.tcg-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(115deg, rgba(212,175,55,.18) 0 1px, transparent 1px 38%),
    linear-gradient(90deg, rgba(212,175,55,.08), transparent 24%, transparent 76%, rgba(212,175,55,.08));
  opacity: .55;
}
.tcg-hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
}
.tcg-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: contrast(1.1) saturate(.85);
}
.tcg-hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(10,10,10,.95) 0%, rgba(10,10,10,.72) 42%, rgba(10,10,10,.45) 68%, rgba(10,10,10,.86) 100%),
    linear-gradient(180deg, rgba(10,10,10,.62) 0%, rgba(10,10,10,.38) 35%, rgba(10,10,10,1) 100%);
  z-index: 1;
}
.tcg-hero__container {
  position: relative;
  z-index: 2;
  padding-block: var(--space-20);
}
.tcg-hero__eyebrow {
  margin-bottom: var(--space-5);
}
.tcg-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.75rem, 1.5rem + 6.5vw, 6.5rem);
  line-height: 0.95;
  font-weight: 700;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  margin-bottom: var(--space-4);
  max-width: 18ch;
}
.tcg-hero__title span { display: inline-block; }
.tcg-hero__title .tcg-hero__accent {
  position: relative;
  background: var(--grad-gold-text);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.tcg-hero__title .tcg-hero__accent::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0.08em;
  height: 4px;
  background: var(--titan-gold);
  transform: scaleX(0);
  transform-origin: left;
  animation: tcg-underline 1.2s cubic-bezier(0.19, 1, 0.22, 1) 0.8s forwards;
}
@keyframes tcg-underline { to { transform: scaleX(1); } }
@media (max-width: 640px) {
  .tcg-hero {
    min-height: 820px;
    align-items: flex-start;
  }
  .tcg-hero__container {
    padding-top: var(--space-16);
    padding-bottom: var(--space-24);
  }
  .tcg-hero__title {
    font-size: clamp(2.35rem, 10.5vw, 3.2rem);
    max-width: 100%;
    line-height: 1.02;
  }
  .tcg-hero__title .tcg-hero__accent {
    font-size: .95em;
  }
}

.tcg-hero__sub {
  font-size: var(--text-xl);
  color: var(--titan-bone);
  margin-bottom: var(--space-5);
  max-width: 56ch;
  line-height: var(--lh-snug);
}
.tcg-hero__sub strong { color: var(--titan-ivory); font-weight: 600; }
.tcg-hero__proof {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
}
.tcg-hero__proof span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 12px;
  border: 1px solid var(--titan-gold-25);
  border-radius: var(--radius-md);
  background: rgba(10,10,10,.48);
  color: var(--titan-ivory);
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}
.tcg-hero__proof svg { color: var(--titan-gold); }

.tcg-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-12);
}

.tcg-hero__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  padding-top: var(--space-8);
  border-top: 1px solid var(--titan-gold-25);
  max-width: 600px;
}
.tcg-hero__stat-num {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: 700;
  line-height: 1;
  color: var(--titan-gold);
  display: block;
}
.tcg-hero__stat-label {
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--titan-bone);
  margin-top: 4px;
  display: block;
}

.tcg-hero__scroll {
  position: absolute;
  bottom: var(--space-6);
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  color: var(--titan-bone);
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  animation: tcg-bounce 2s ease-in-out infinite;
}
.tcg-hero__scroll svg { color: var(--titan-gold); }
@keyframes tcg-bounce {
  0%,100% { transform: translate(-50%, 0); }
  50%     { transform: translate(-50%, 8px); }
}

/* ════════ HOME — SERVICES TRIO ════════ */
.tcg-section--services { background: var(--titan-black); }
.tcg-services-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}
@media (min-width: 900px) {
  .tcg-services-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ════════ HOME — WHY TITAN ════════ */
.tcg-why {
  background: var(--titan-obsidian);
  position: relative;
  overflow: hidden;
}
.tcg-why::before {
  content: '';
  position: absolute;
  top: 50%;
  right: -10%;
  transform: translateY(-50%);
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(212,175,55,.06) 0%, transparent 60%);
  pointer-events: none;
}
.tcg-why__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6) var(--space-8);
}
@media (min-width: 700px)  { .tcg-why__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .tcg-why__grid { grid-template-columns: repeat(3, 1fr); } }

.tcg-why__item {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-4);
  border-left: 2px solid var(--titan-gold-25);
  transition: border-color var(--dur-base), background var(--dur-base);
}
.tcg-why__item:hover {
  border-color: var(--titan-gold);
  background: var(--titan-gold-05);
}
.tcg-why__chevron {
  flex-shrink: 0;
  margin-top: 6px;
  color: var(--titan-gold);
}
.tcg-why__title {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  margin-bottom: 4px;
  color: var(--titan-ivory);
}
.tcg-why__desc {
  font-size: var(--text-sm);
  color: var(--titan-bone);
  line-height: var(--lh-base);
}

/* ════════ HOME — STATS ════════ */
.tcg-stats-section {
  position: relative;
  padding-block: var(--space-20);
  overflow: hidden;
}
.tcg-stats-section__bg {
  position: absolute; inset: 0; z-index: -2;
}
.tcg-stats-section__bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: grayscale(.8) sepia(.4) contrast(1.1);
}
.tcg-stats-section__bg::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(10,10,10,.95) 0%, rgba(20,20,20,.85) 100%);
}
.tcg-stats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-8);
}
@media (min-width: 700px) { .tcg-stats-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1100px){ .tcg-stats-grid { grid-template-columns: repeat(6, 1fr); } }

/* ════════ HOME — RECENT PROJECTS ════════ */
.tcg-projects-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 700px)  { .tcg-projects-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .tcg-projects-grid { grid-template-columns: repeat(4, 1fr); } }

.tcg-project-card {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: var(--radius-md);
  border: var(--border-gold-thin);
  cursor: pointer;
  display: block;
}
.tcg-project-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slower) var(--ease-out-quart);
}
.tcg-project-card:hover img { transform: scale(1.08); }
.tcg-project-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(10,10,10,0) 40%, rgba(10,10,10,.95) 100%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--space-5);
}
.tcg-project-card__tag {
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--titan-gold);
  margin-bottom: var(--space-2);
}
.tcg-project-card__title {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--titan-ivory);
  line-height: var(--lh-snug);
}

/* ════════ HOME — AREAS MAP ════════ */
.tcg-areas {
  display: grid;
  gap: var(--space-8);
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 900px) { .tcg-areas { grid-template-columns: 1.2fr 1fr; } }
.tcg-areas__map {
  background: var(--titan-graphite);
  border: var(--border-gold-thin);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 5 / 4;
  position: relative;
}
.tcg-areas__map svg { width: 100%; height: 100%; }
.tcg-areas__list { display: flex; flex-direction: column; gap: var(--space-3); }
.tcg-areas__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  background: var(--titan-graphite);
  border: 1px solid var(--titan-steel);
  border-radius: var(--radius-md);
  transition: all var(--dur-base);
}
.tcg-areas__item:hover {
  background: var(--titan-gold-05);
  border-color: var(--titan-gold);
  transform: translateX(6px);
}
.tcg-areas__item-name {
  font-family: var(--font-heading);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}
.tcg-areas__item-pop { font-size: var(--text-xs); color: var(--titan-bone); }

.tcg-area-index-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 700px) { .tcg-area-index-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .tcg-area-index-grid { grid-template-columns: repeat(3, 1fr); } }
.tcg-area-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  min-height: 100%;
  padding: var(--space-6);
  background: linear-gradient(180deg, rgba(31,31,31,.98), rgba(20,20,20,.98));
  border: var(--border-gold-thin);
  border-radius: var(--radius-md);
  transition: transform var(--dur-base) var(--ease-out-quart), border-color var(--dur-base), box-shadow var(--dur-base);
}
.tcg-area-card:hover {
  transform: translateY(-5px);
  border-color: var(--titan-gold-50);
  box-shadow: var(--shadow-lg);
}
.tcg-area-card__kicker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--titan-gold);
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}
.tcg-area-card__title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  text-transform: uppercase;
}
.tcg-area-card__desc {
  color: var(--titan-bone);
  font-size: var(--text-sm);
  line-height: var(--lh-relaxed);
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.tcg-area-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: auto;
  color: var(--titan-gold);
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

/* ════════ HOME — PROCESS ════════ */
.tcg-process {
  position: relative;
}
.tcg-process__steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  position: relative;
}
@media (min-width: 900px) {
  .tcg-process__steps { grid-template-columns: repeat(5, 1fr); gap: var(--space-4); }
}
.tcg-process__step {
  text-align: center;
  padding: var(--space-5);
  position: relative;
}
.tcg-process__numeral {
  font-family: var(--font-display);
  font-size: var(--text-5xl);
  font-weight: 700;
  color: var(--titan-gold);
  line-height: 1;
  display: block;
  margin-bottom: var(--space-4);
}
.tcg-process__title {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  margin-bottom: var(--space-2);
}
.tcg-process__desc {
  font-size: var(--text-sm);
  color: var(--titan-bone);
}

/* ════════ HOME — TESTIMONIALS ════════ */
.tcg-testimonials {
  background: var(--titan-obsidian);
}
.tcg-tslider {
  max-width: 800px;
  margin: 0 auto;
  text-align: center;
  position: relative;
  min-height: 300px;
}
.tcg-tslide {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  inset: 0;
  transition: opacity var(--dur-slow) var(--ease-out-quart), visibility 0s linear var(--dur-slow);
}
.tcg-tslide.is-active {
  opacity: 1;
  visibility: visible;
  position: relative;
  transition: opacity var(--dur-slow) var(--ease-out-quart), visibility 0s;
}
.tcg-tslide__stars {
  display: inline-flex;
  gap: 2px;
  color: var(--titan-gold);
  margin-bottom: var(--space-5);
}
.tcg-tslide__quote {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1rem + 1.5vw, 2rem);
  line-height: var(--lh-snug);
  color: var(--titan-ivory);
  margin-bottom: var(--space-6);
}
.tcg-tslide__quote::before { content: '"'; color: var(--titan-gold); }
.tcg-tslide__quote::after  { content: '"'; color: var(--titan-gold); }
.tcg-tslide__author {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: var(--text-sm);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--titan-gold);
}
.tcg-tslide__meta {
  font-size: var(--text-xs);
  color: var(--titan-bone);
  margin-top: 4px;
}
.tcg-tslider__dots {
  display: flex;
  justify-content: center;
  gap: var(--space-2);
  margin-top: var(--space-8);
}
.tcg-tslider__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--titan-steel);
  border: 1px solid var(--titan-iron);
  cursor: pointer;
  transition: all var(--dur-base);
}
.tcg-tslider__dot.is-active {
  background: var(--titan-gold);
  border-color: var(--titan-gold);
  width: 24px;
  border-radius: var(--radius-pill);
}

/* ════════ HOME — FINAL CTA ════════ */
.tcg-final-cta {
  position: relative;
  padding-block: var(--space-32);
  text-align: center;
  overflow: hidden;
}
.tcg-final-cta__bg {
  position: absolute; inset: 0; z-index: -2;
}
.tcg-final-cta__bg img {
  width: 100%; height: 100%; object-fit: cover;
  filter: contrast(1.2) saturate(.7);
}
.tcg-final-cta__bg::after {
  content: '';
  position: absolute; inset: 0;
  background: var(--grad-overlay-radial);
}
.tcg-final-cta h2 {
  margin-bottom: var(--space-5);
  font-size: clamp(2.5rem, 1.5rem + 4vw, 4.5rem);
}
.tcg-final-cta__sub {
  color: var(--titan-bone);
  font-size: var(--text-lg);
  max-width: 50ch;
  margin: 0 auto var(--space-10);
}
.tcg-final-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: center;
  align-items: center;
}

/* ════════ PAGE HERO (sub-pages) ════════ */
.tcg-page-hero {
  position: relative;
  padding-block: clamp(6rem, 12vw, 10rem);
  min-height: 420px;
  display: flex;
  align-items: center;
  overflow: hidden;
}
.tcg-page-hero__bg {
  position: absolute; inset: 0; z-index: -2;
}
.tcg-page-hero__bg img {
  width: 100%; height: 100%; object-fit: cover;
  filter: contrast(1.1) saturate(.85);
}
.tcg-page-hero__bg::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(10,10,10,.92) 0%, rgba(10,10,10,.65) 100%);
}
.tcg-page-hero__inner { max-width: 900px; }
.tcg-page-hero__title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 1.5rem + 4vw, 5rem);
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: -0.025em;
  margin-bottom: var(--space-5);
}
.tcg-page-hero__sub {
  font-size: var(--text-xl);
  color: var(--titan-bone);
  max-width: 60ch;
  line-height: var(--lh-snug);
}

/* ════════ SERVICE DETAIL PAGE ════════ */
.tcg-service-features {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  margin: var(--space-8) 0;
}
@media (min-width: 700px)  { .tcg-service-features { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .tcg-service-features { grid-template-columns: repeat(4, 1fr); } }
.tcg-service-features li {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: var(--titan-graphite);
  border: var(--border-gold-thin);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: 500;
}
.tcg-service-features li svg { color: var(--titan-gold); flex-shrink: 0; }

/* ════════ ABOUT page ════════ */
.tcg-about-timeline {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  position: relative;
  padding-left: var(--space-8);
  border-left: 2px solid var(--titan-gold-25);
}
.tcg-about-timeline__year {
  display: inline-block;
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--titan-gold);
  font-weight: 700;
  margin-bottom: var(--space-2);
  position: relative;
}
.tcg-about-timeline__year::before {
  content: '';
  position: absolute;
  left: calc(var(--space-8) * -1 - 7px);
  top: 50%;
  width: 12px;
  height: 12px;
  background: var(--titan-gold);
  border-radius: 50%;
  transform: translateY(-50%);
  box-shadow: 0 0 0 4px var(--titan-black), 0 0 12px var(--titan-gold-50);
}

.tcg-values-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 700px)  { .tcg-values-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .tcg-values-grid { grid-template-columns: repeat(4, 1fr); } }
.tcg-value-card {
  padding: var(--space-6);
  background: var(--titan-graphite);
  border: var(--border-gold-thin);
  border-radius: var(--radius-lg);
  text-align: center;
  transition: all var(--dur-base);
}
.tcg-value-card:hover { transform: translateY(-4px); border-color: var(--titan-gold-50); }
.tcg-value-card__icon {
  width: 56px;
  height: 56px;
  margin: 0 auto var(--space-4);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-pill);
  background: var(--titan-gold-10);
  color: var(--titan-gold);
}
.tcg-value-card__title {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-weight: 600;
  margin-bottom: var(--space-2);
}
.tcg-value-card__desc { font-size: var(--text-sm); color: var(--titan-bone); }

.tcg-equipment-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 700px)  { .tcg-equipment-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .tcg-equipment-grid { grid-template-columns: repeat(3, 1fr); } }
.tcg-equipment-card {
  padding: var(--space-5);
  background: var(--titan-obsidian);
  border-left: 3px solid var(--titan-gold);
}
.tcg-equipment-card__name {
  font-family: var(--font-heading);
  font-weight: 600;
  color: var(--titan-ivory);
  margin-bottom: 4px;
}
.tcg-equipment-card__desc { font-size: var(--text-sm); color: var(--titan-bone); }

.tcg-certs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: center;
  margin-top: var(--space-8);
}
.tcg-cert {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  border: var(--border-gold-thin);
  border-radius: var(--radius-pill);
  font-size: var(--text-sm);
  color: var(--titan-bone);
}
.tcg-cert svg { color: var(--titan-gold); }

/* ════════ GALLERY page ════════ */
.tcg-gallery-filter {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
  justify-content: center;
}
.tcg-gallery-chip {
  padding: 8px 18px;
  border: 1px solid var(--titan-steel);
  border-radius: var(--radius-pill);
  background: transparent;
  color: var(--titan-bone);
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  cursor: pointer;
  transition: all var(--dur-fast);
}
.tcg-gallery-chip:hover { color: var(--titan-gold); border-color: var(--titan-gold-50); }
.tcg-gallery-chip.is-active {
  background: var(--titan-gold);
  color: var(--titan-black);
  border-color: var(--titan-gold);
}
.tcg-gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4);
}
.tcg-gallery-item {
  aspect-ratio: 4 / 5;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-md);
  cursor: pointer;
  border: 1px solid var(--titan-steel);
}
.tcg-gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slower); }
.tcg-gallery-item:hover img { transform: scale(1.08); }
.tcg-gallery-item__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(10,10,10,.95));
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--space-4);
  opacity: .9;
  transition: opacity var(--dur-base);
}
.tcg-gallery-item:hover .tcg-gallery-item__overlay { opacity: 1; }

/* Lightbox */
.tcg-lightbox {
  position: fixed;
  inset: 0;
  background: rgba(10,10,10,.97);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--dur-base), visibility 0s linear var(--dur-base);
  padding: var(--space-6);
}
.tcg-lightbox.is-open { opacity: 1; visibility: visible; transition-delay: 0s; }
.tcg-lightbox__img {
  max-width: 90vw;
  max-height: 85vh;
  width: auto; height: auto;
  border: 1px solid var(--titan-gold-25);
  border-radius: var(--radius-md);
}
.tcg-lightbox__close {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  width: 48px;
  height: 48px;
  border: var(--border-gold-thin);
  border-radius: 50%;
  color: var(--titan-gold);
  font-size: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* ════════ TESTIMONIALS page ════════ */
.tcg-testimonials-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 700px)  { .tcg-testimonials-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .tcg-testimonials-grid { grid-template-columns: repeat(3, 1fr); } }
.tcg-testimonial-card {
  padding: var(--space-6);
  background: var(--titan-graphite);
  border: var(--border-gold-thin);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.tcg-testimonial-card__stars { color: var(--titan-gold); display: inline-flex; gap: 2px; }
.tcg-testimonial-card__quote {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  line-height: var(--lh-relaxed);
  color: var(--titan-ivory);
}
.tcg-testimonial-card__author {
  font-family: var(--font-heading);
  font-weight: 600;
  color: var(--titan-gold);
  margin-top: auto;
}
.tcg-testimonial-card__meta { font-size: var(--text-xs); color: var(--titan-bone); }

.tcg-rating-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  border: var(--border-gold);
  border-radius: var(--radius-pill);
  background: var(--titan-gold-05);
  margin-bottom: var(--space-8);
}
.tcg-rating-badge__num {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--titan-gold);
}

/* ════════ CONTACT page ════════ */
.tcg-contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}
@media (min-width: 900px) {
  .tcg-contact-grid { grid-template-columns: 7fr 5fr; }
}
.tcg-contact-info {
  background: var(--titan-graphite);
  border: var(--border-gold-thin);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.tcg-contact-info__item {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
}
.tcg-contact-info__item-icon {
  flex-shrink: 0;
  width: 44px; height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--titan-gold-10);
  border-radius: var(--radius-pill);
  color: var(--titan-gold);
}
.tcg-contact-info__label {
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--titan-bone);
  margin-bottom: 4px;
  display: block;
}
.tcg-contact-info__value {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  color: var(--titan-ivory);
}
.tcg-contact-info__value:hover { color: var(--titan-gold); }

.tcg-contact-map {
  margin-top: var(--space-12);
  border: var(--border-gold-thin);
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 21 / 9;
}
.tcg-contact-map iframe { width: 100%; height: 100%; border: 0; filter: grayscale(.6) contrast(1.1); }

/* ════════ QUOTE page ════════ */
.tcg-quote-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}
@media (min-width: 1000px) { .tcg-quote-grid { grid-template-columns: 8fr 4fr; } }
.tcg-quote-side {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.tcg-quote-trust {
  background: var(--titan-graphite);
  border: var(--border-gold-thin);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.tcg-quote-trust__item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  color: var(--titan-ivory);
}
.tcg-quote-trust__item svg { color: var(--titan-gold); flex-shrink: 0; }

/* Legal pages */
.tcg-legal {
  max-width: 880px;
  padding: var(--space-8);
  background: var(--titan-graphite);
  border: var(--border-gold-thin);
  border-radius: var(--radius-md);
}
.tcg-legal__updated {
  color: var(--titan-gold);
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  margin-bottom: var(--space-6);
}
.tcg-legal h2 {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  margin-top: var(--space-6);
  margin-bottom: var(--space-2);
}
.tcg-legal h2:first-of-type { margin-top: 0; }
.tcg-legal p {
  color: var(--titan-bone);
  line-height: var(--lh-relaxed);
}
.tcg-legal a {
  color: var(--titan-gold);
  font-weight: 600;
}

/* ════════ 404 page ════════ */
.tcg-404 {
  position: relative;
  min-height: 80vh;
  display: flex;
  align-items: center;
  text-align: center;
}
.tcg-404__title {
  font-family: var(--font-display);
  font-size: clamp(3rem, 2rem + 6vw, 7rem);
  line-height: 1;
  margin-bottom: var(--space-5);
  text-transform: uppercase;
}
.tcg-404__big {
  font-family: var(--font-display);
  font-size: clamp(8rem, 4rem + 16vw, 16rem);
  line-height: 1;
  background: var(--grad-gold-text);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -0.05em;
  margin-bottom: var(--space-6);
}
