/* ============================================================
   FEKRA — All Sections, Page Content, Cards, Portfolio, Services
   ============================================================ */

/* ════════════════════════════════════════════════════════════
   SHARED SECTION LAYOUT
   ════════════════════════════════════════════════════════════ */
.section { padding: 120px 0; position: relative; }
.section-header { text-align: center; max-width: 680px; margin: 0 auto 80px; }
.section-tag {
  display: inline-block;
  font-family: var(--font-display);
  font-size: .7rem;
  font-weight: 400;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--green);
  padding: 6px 18px;
  border: 1px solid var(--border-green);
  border-radius: 50px;
  margin-bottom: 20px;
}
.section-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 400;
  line-height: 1.2;
  color: var(--text);
  margin-bottom: 20px;
  letter-spacing: -.01em;
}
.section-desc { color: var(--text-2); font-size: 1.05rem; line-height: 1.8; }

/* ════════════════════════════════════════════════════════════
   INDEX: ABOUT PREVIEW
   ════════════════════════════════════════════════════════════ */
.about-preview {
  background: var(--bg-2);
  overflow: hidden;
  position: relative;
  min-height: 680px;
  display: flex;
  align-items: center;
  padding: 100px 0;
}

/* Character background layer */
.about-preview-bg {
  position: absolute;
  inset: 0;
  background-image: url('../img/carctr.png');
  background-repeat: no-repeat;
  background-size: auto 108%;
  background-position: center center;
  pointer-events: none;
  opacity: 0.4;
}
.about-preview-bg::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 48% 72% at 20% 54%,
    rgba(18,60,230,0.16) 0%,
    rgba(10,30,120,0.08) 40%,
    transparent 70%
  );
}
.about-preview-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to left,   var(--bg-2) 0%, var(--bg-2) 36%, rgba(6,14,30,0.80) 54%, rgba(6,14,30,0.20) 68%, transparent 80%),
    linear-gradient(to bottom, var(--bg-2) 0%, transparent 16%),
    linear-gradient(to top,    var(--bg-2) 0%, transparent 16%);
}

.about-preview-content {
  position: relative;
  z-index: 2;
  max-width: 500px;
  margin-left: auto;
}
.about-preview-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.5vw, 2.6rem);
  font-weight: 400;
  line-height: 1.25;
  color: var(--text);
  margin-bottom: 28px;
  letter-spacing: -.01em;
}
.about-preview-text {
  color: var(--text-2);
  font-size: 1rem;
  line-height: 1.85;
  margin-bottom: 36px;
}

/* ════════════════════════════════════════════════════════════
   INDEX: SERVICES PREVIEW
   ════════════════════════════════════════════════════════════ */
.services-preview { background: var(--bg); }
.services-preview-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
  max-width: 1320px;
  margin-inline: auto;
}
.svc-card {
  background: var(--surface);
  border: 1px solid rgba(248,251,255,0.10);
  border-radius: var(--radius-lg);
  padding: 52px 28px 48px;
  min-height: 300px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: transform .35s ease, border-color .35s ease, box-shadow .35s ease;
}
.svc-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--green), transparent);
  opacity: 0;
  transition: opacity .35s ease;
}
.svc-card:hover {
  transform: translateY(-6px);
  border-color: rgba(1,166,81,0.40);
  box-shadow: 0 0 32px rgba(1,166,81,0.15), 0 8px 32px rgba(0,0,0,0.4);
}
.svc-card:hover::before { opacity: 1; }
.svc-icon {
  width: 52px; height: 52px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 24px;
  color: var(--green);
  transition: transform .35s ease;
}
.svc-icon svg { width: 100%; height: 100%; }
.svc-card:hover .svc-icon { transform: scale(1.12); }
.svc-title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 400;
  color: var(--text);
  letter-spacing: .04em;
  margin-bottom: 10px;
}
.svc-subtitle {
  font-family: var(--font-body);
  font-size: .78rem;
  color: var(--text-2);
  line-height: 1.6;
  letter-spacing: .02em;
}
.services-preview-action { text-align: center; margin-top: 56px; }

/* ════════════════════════════════════════════════════════════
   INDEX: WHY US
   ════════════════════════════════════════════════════════════ */
.why-us { background: var(--bg-2); }
.why-us-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 64px;
  max-width: 1320px;
  margin-inline: auto;
}
.why-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 36px 32px;
  position: relative;
  overflow: visible;
  transition: border-color .3s, transform .3s;
}
.why-card:hover { border-color: var(--border-green); transform: translateY(-3px); }
.why-card-num {
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 400;
  color: rgba(1,166,81,0.15);
  line-height: 1;
  margin-bottom: 16px;
  display: block;
}
.why-card-title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 400;
  color: var(--text);
  margin-bottom: 12px;
  letter-spacing: .02em;
  line-height: 1.35 !important;
  overflow: visible !important;
  padding-inline: 2px !important;
  padding-block: 4px !important;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}
.why-card-text { color: var(--text-2); font-size: .9rem; line-height: 1.75; }

/* ════════════════════════════════════════════════════════════
   INDEX: PORTFOLIO PREVIEW
   ════════════════════════════════════════════════════════════ */
.portfolio-preview {
  background: var(--bg);
  overflow: hidden;
  isolation: isolate;
}

/* ════════════════════════════════════════════════════════════
   SHARED: FINAL CTA
   ════════════════════════════════════════════════════════════ */
.final-cta {
  background: var(--bg-2);
  text-align: center;
}
.final-cta-title {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 400;
  color: var(--text);
  line-height: 1.35;
  margin-bottom: 20px;
  letter-spacing: -.01em;
}
.final-cta-sub {
  color: var(--text-2);
  font-size: 1rem;
  margin-bottom: 44px;
  line-height: 1.8;
}
.final-cta-line {
  width: 1px; height: 80px;
  background: linear-gradient(to bottom, transparent, var(--green), transparent);
  margin: 0 auto 44px;
}

/* ════════════════════════════════════════════════════════════
   SHARED: FOOTER
   ════════════════════════════════════════════════════════════ */
.footer {
  background: var(--bg-2);
  border-top: 1px solid var(--border);
  padding: 80px 0 40px;
  position: relative;
  overflow: hidden;
}
.footer::after {
  content: '';
  position: absolute;
  left: 0; top: 0;
  height: 100%; width: 100%;
  background-image: url('../img/footer.png');
  background-repeat: no-repeat;
  background-position: left top;
  background-size: auto 100%;
  opacity: 0.25;
  pointer-events: none;
  z-index: 0;
}
.footer > * { position: relative; z-index: 1; }
.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  gap: 56px;
  margin-bottom: 64px;
}
.footer-brand .footer-logo {
  display: inline-flex; align-items: center; gap: 12px;
  margin-bottom: 20px; text-decoration: none;
  color: var(--text);
  font-family: var(--font-display);
  font-size: 1.3rem; letter-spacing: .08em;
}
.footer-brand .footer-logo img { height: 48px; object-fit: contain; }
.footer-brand p { color: var(--text-2); font-size: .87rem; line-height: 1.8; max-width: 280px; }
.footer-brand .footer-address { color: var(--text-3); font-size: .82rem; margin-top: 12px; line-height: 1.7; }
.footer-social { display: flex; gap: 8px; margin-top: 24px; }
.footer-social-link {
  width: 36px; height: 36px;
  border: 1px solid var(--border);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-2); text-decoration: none;
  font-size: 1rem;
  transition: all .25s;
}
.footer-social-link:hover { border-color: var(--lime); color: var(--lime); background: rgba(1,251,29,0.05); }
.footer-col h4 {
  font-family: var(--font-display);
  font-size: .75rem; letter-spacing: .16em; text-transform: uppercase;
  color: var(--text); margin-bottom: 20px;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-col a { color: var(--text-2); text-decoration: none; font-size: .87rem; transition: color .25s; }
.footer-col a:hover { color: var(--lime); }
.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 28px;
  border-top: 1px solid var(--border);
  color: var(--text-3); font-size: .8rem;
}

/* ════════════════════════════════════════════════════════════
   ABOUT PAGE
   ════════════════════════════════════════════════════════════ */
.about-hero {
  padding: 160px 0 100px;
  position: relative;
  overflow: hidden;
}
.about-hero .glow-1 { opacity: .5; }

/* Character image (car-about.png) */
.abt-hero-char {
  position: absolute;
  left: 0; bottom: 0;
  height: 100%; width: 38%;
  pointer-events: none;
  z-index: 0;
}
.abt-hero-char::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 70% at 48% 58%, rgba(18,60,230,0.12) 0%, rgba(10,30,120,0.06) 40%, transparent 72%);
  pointer-events: none;
  z-index: 1;
}
.abt-hero-char::after {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(to left,   var(--bg) 0%, transparent 32%),
    linear-gradient(to bottom, var(--bg) 0%, transparent 18%),
    linear-gradient(to top,    var(--bg) 0%, transparent 18%);
  pointer-events: none;
  z-index: 2;
}
.abt-hero-char-img {
  width: 100%; height: 100%;
  object-fit: contain;
  object-position: left bottom;
  position: relative;
  z-index: 0;
  opacity: 0.08;
  left: 200px;
}

/* Philosophy cards */
.about-philosophy-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-top: 64px;
  align-items: stretch;
}
.phil-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 44px 40px;
  position: relative;
  overflow: visible;
  transition: border-color .3s, transform .3s;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 180px;
}
.phil-card:hover { border-color: var(--border-green); transform: translateY(-4px); }
.phil-card::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--green), var(--lime), transparent);
  opacity: 0;
  transition: opacity .3s;
}
.phil-card:hover::after { opacity: 1; }
.phil-card-label {
  font-family: var(--font-display);
  font-size: .7rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--green); margin-bottom: 20px; display: block;
}
.phil-card-title {
  font-family: 'NoorBold', sans-serif;
  font-size: 1.05rem;
  line-height: 1.5;
  white-space: nowrap;
  font-weight: 700;
  color: var(--text);
  letter-spacing: .01em;
  overflow: visible !important;
  padding-inline: 2px !important;
  padding-block: 4px !important;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

/* Values grid */
.values-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.value-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  transition: border-color .3s, transform .3s;
}
.value-card:hover { border-color: var(--border-green); transform: translateY(-3px); }
.value-card-title {
  font-family: var(--font-display);
  font-size: 1rem; font-weight: 400; color: var(--lime);
  margin-bottom: 12px; display: flex; align-items: center; gap: 10px;
}
.value-card-title::before {
  content: '';
  display: inline-block; width: 5px; height: 5px;
  background: var(--lime); border-radius: 50%; flex-shrink: 0;
}
.value-card-text { color: var(--text-2); font-size: .9rem; line-height: 1.75; }

.about-cta { background: var(--bg) !important; }

/* ════════════════════════════════════════════════════════════
   SERVICES PAGE — Hero
   ════════════════════════════════════════════════════════════ */
.svc-hero {
  padding: 160px 0 80px;
  position: relative;
  overflow: hidden;
}
.svc-hero .glow-1 { opacity: .5; }

.hero-character {
  position: absolute;
  left: 18%; bottom: 0;
  height: 98%;
  z-index: 0;
  object-fit: contain;
  pointer-events: none;
  opacity: 0.28;
}
.svc-char-fg {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 1;
  background:
    radial-gradient(ellipse 40% 60% at 26% 55%, rgba(18,60,230,0.10) 0%, rgba(10,30,120,0.05) 40%, transparent 65%),
    linear-gradient(to left,   var(--bg) 0%, var(--bg) 40%, rgba(6,13,26,0.70) 54%, rgba(6,13,26,0.10) 67%, transparent 78%),
    linear-gradient(to bottom, var(--bg) 0%, transparent 18%),
    linear-gradient(to top,    var(--bg) 0%, transparent 18%);
}
.svc-hero-container { padding-inline-end: 36%; }

/* ── Services cinematic showcase ──────────────────────────── */
.svc-showcase {
  padding: 130px 0;
  background: var(--bg);
  position: relative;
}
.svc-showcase::before {
  content: '';
  position: absolute;
  top: 0; left: 50%; transform: translateX(-50%);
  width: 1px; height: 100%;
  background: linear-gradient(to bottom, transparent 0%, rgba(1,166,81,0.12) 20%, rgba(1,166,81,0.08) 80%, transparent 100%);
  pointer-events: none;
}

.svc-block {
  position: relative;
  padding: 100px 0;
  overflow: hidden;
}
.svc-block + .svc-block::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.055) 30%, rgba(1,166,81,0.15) 50%, rgba(255,255,255,0.055) 70%, transparent 100%);
}
.svc-block::after {
  content: '';
  position: absolute; inset: 0;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.6s ease;
}
.svc-block:hover::after { opacity: 1; }
.svc-block:nth-child(1)::after { background: radial-gradient(ellipse 60% 50% at 75% 50%, rgba(1,166,81,0.04) 0%, transparent 70%); }
.svc-block:nth-child(2)::after { background: radial-gradient(ellipse 60% 50% at 25% 50%, rgba(1,251,29,0.03) 0%, transparent 70%); }
.svc-block:nth-child(3)::after { background: radial-gradient(ellipse 60% 50% at 75% 50%, rgba(1,166,81,0.04) 0%, transparent 70%); }
.svc-block:nth-child(4)::after { background: radial-gradient(ellipse 60% 50% at 25% 50%, rgba(1,251,29,0.03) 0%, transparent 70%); }
.svc-block:nth-child(5)::after { background: radial-gradient(ellipse 60% 50% at 75% 50%, rgba(1,166,81,0.05) 0%, transparent 70%); }

.svc-block-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 80px;
  align-items: center;
  position: relative;
  z-index: 1;
}
/* Alternating layout: flip direction on even blocks for visual variety */
.svc-block:nth-child(even) .svc-block-inner  { direction: ltr; }
.svc-block:nth-child(even) .svc-block-content { direction: rtl; }
.svc-block:nth-child(even) .svc-block-visual  { direction: rtl; }

.svc-block-content { position: relative; padding: 20px 0; }
.svc-ghost-num {
  position: absolute;
  top: -28px;
  inset-inline-end: -10px;
  font-family: var(--font-display);
  font-size: clamp(9rem, 16vw, 15rem);
  font-weight: 400;
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,0.04);
  line-height: 1;
  pointer-events: none;
  user-select: none;
  letter-spacing: -0.04em;
}
.svc-index { display: inline-flex; align-items: center; gap: 10px; margin-bottom: 28px; }
.svc-index-num {
  font-family: var(--font-display);
  font-size: 0.7rem;
  letter-spacing: 0.3em;
  color: var(--green);
  font-weight: 400;
}
.svc-index-line {
  width: 40px; height: 1px;
  background: linear-gradient(90deg, var(--green), transparent);
}
.svc-block:nth-child(even) .svc-index-line { background: linear-gradient(270deg, var(--green), transparent); }
.svc-block-title {
  font-family: 'NoorBold', sans-serif;
  font-size: clamp(1.6rem, 2.8vw, 2.6rem);
  font-weight: 700;
  color: var(--text);
  line-height: 1.25;
  letter-spacing: -0.01em;
  margin-bottom: 22px;
  position: relative;
  z-index: 1;
}
.svc-block-title em {
  font-style: normal;
  background: linear-gradient(135deg, var(--green) 0%, var(--lime) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.svc-block-text { color: var(--text-2); font-size: 0.97rem; line-height: 1.9; margin-bottom: 36px; max-width: 480px; }
.svc-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.svc-tag {
  font-family: var(--font-display);
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text-2);
  padding: 6px 14px;
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 50px;
  background: rgba(255,255,255,0.025);
  transition: border-color 0.3s, color 0.3s, background 0.3s;
}
.svc-tag:hover,
.svc-block:hover .svc-tag { border-color: rgba(1,166,81,0.3); color: var(--lime); background: rgba(1,166,81,0.06); }

.svc-block-visual { position: relative; height: 380px; display: flex; align-items: center; justify-content: center; }
.svc-visual-panel {
  position: relative;
  width: 100%; height: 100%;
  border-radius: 24px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.07);
  backdrop-filter: blur(12px);
  overflow: hidden;
  transition: transform 0.5s cubic-bezier(.25,.8,.25,1), border-color 0.4s, box-shadow 0.4s;
  box-shadow: 0 24px 80px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.06);
}
.svc-block:hover .svc-visual-panel {
  transform: translateY(-6px);
  border-color: rgba(1,166,81,0.2);
  box-shadow: 0 40px 100px rgba(0,0,0,0.45), 0 0 60px rgba(1,166,81,0.07), inset 0 1px 0 rgba(255,255,255,0.09);
}
.svc-visual-panel::before {
  content: '';
  position: absolute;
  top: 0; inset-inline-start: 0;
  width: 80px; height: 80px;
  background: linear-gradient(135deg, rgba(1,166,81,0.12) 0%, transparent 60%);
  border-radius: 24px 0 0 0;
}
.svc-visual-panel::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(1,251,29,0.18), transparent);
}
.svc-art { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; }

/* ── Service 1: Brand Identity art ─────────────────────────── */
.svc-art-identity { gap: 0; }
.svc-art-identity .rings-wrap { position: relative; width: 220px; height: 220px; }
.id-ring { position: absolute; border-radius: 50%; border: 1px solid rgba(1,166,81,0.18); animation: ringPulse 4s ease-in-out infinite; }
.id-ring:nth-child(1) { inset: 0;    border-color: rgba(1,166,81,0.22); animation-delay: 0s; }
.id-ring:nth-child(2) { inset: 18px; border-color: rgba(1,251,29,0.14); animation-delay: 0.5s; }
.id-ring:nth-child(3) { inset: 36px; border-color: rgba(1,166,81,0.1);  animation-delay: 1s; }
.id-ring:nth-child(4) { inset: 54px; border-color: rgba(1,251,29,0.18); animation-delay: 1.5s; }
.id-dot { position: absolute; border-radius: 50%; transform: translate(-50%,-50%); }
.id-dot:nth-child(5) { width:10px;height:10px; top:50%;left:50%; background:var(--lime); box-shadow:0 0 20px rgba(1,251,29,0.6); }
.id-dot:nth-child(6) { width:7px; height:7px;  top:22%;left:72%; background:var(--green); box-shadow:0 0 12px rgba(1,166,81,0.5); }
.id-dot:nth-child(7) { width:5px; height:5px;  top:75%;left:30%; background:rgba(1,251,29,0.5); }
.id-dot:nth-child(8) { width:4px; height:4px;  top:35%;left:18%; background:rgba(1,166,81,0.4); }
.id-cross-h { position:absolute; top:50%; left:10%; right:10%; height:1px; background:linear-gradient(90deg,transparent,rgba(1,251,29,0.15),transparent); }
.id-cross-v { position:absolute; left:50%; top:10%; bottom:10%; width:1px; background:linear-gradient(180deg,transparent,rgba(1,251,29,0.15),transparent); }
.id-swatches { position:absolute; inset-inline-end:24px; top:50%; transform:translateY(-50%); display:flex; flex-direction:column; gap:6px; }
.id-swatch { width:6px; border-radius:3px; }
.id-swatch:nth-child(1) { height:32px; background:var(--lime); opacity:0.85; }
.id-swatch:nth-child(2) { height:22px; background:var(--green); opacity:0.7; }
.id-swatch:nth-child(3) { height:16px; background:rgba(255,255,255,0.25); }
.id-swatch:nth-child(4) { height:12px; background:rgba(255,255,255,0.1); }
.id-typescale { position:absolute; inset-inline-start:22px; top:28px; display:flex; flex-direction:column; gap:4px; align-items:flex-start; }
.id-typescale span { display:block; background:rgba(255,255,255,0.12); border-radius:2px; }
.id-typescale span:nth-child(1) { width:54px; height:5px; }
.id-typescale span:nth-child(2) { width:38px; height:4px; }
.id-typescale span:nth-child(3) { width:28px; height:3px; }
.id-typescale span:nth-child(4) { width:20px; height:2px; }

/* ── Service 2: Content art ─────────────────────────────────── */
.svc-art-content { flex-direction:column; gap:0; padding:36px 40px; align-items:flex-start; }
.ct-line-group { width:100%; display:flex; flex-direction:column; gap:7px; }
.ct-line-group + .ct-line-group { margin-top:22px; }
.ct-ln { height:4px; border-radius:2px; background:rgba(255,255,255,0.07); position:relative; overflow:hidden; }
.ct-ln::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg,var(--green),var(--lime)); border-radius:2px; transform:scaleX(0); transform-origin:right; transition:transform 0.9s cubic-bezier(.25,.8,.25,1); }
.svc-block:hover .ct-ln::after { transform:scaleX(1); }
.ct-ln:nth-child(1)  { width:88%; } .ct-ln:nth-child(1)::after  { transition-delay:0.00s; }
.ct-ln:nth-child(2)  { width:72%; } .ct-ln:nth-child(2)::after  { transition-delay:0.07s; }
.ct-ln:nth-child(3)  { width:94%; } .ct-ln:nth-child(3)::after  { transition-delay:0.14s; }
.ct-ln:nth-child(4)  { width:60%; } .ct-ln:nth-child(4)::after  { transition-delay:0.21s; }
.ct-ln-b:nth-child(1) { width:80%; } .ct-ln-b:nth-child(1)::after { transition-delay:0.28s; }
.ct-ln-b:nth-child(2) { width:65%; } .ct-ln-b:nth-child(2)::after { transition-delay:0.35s; }
.ct-ln-b:nth-child(3) { width:88%; } .ct-ln-b:nth-child(3)::after { transition-delay:0.42s; }
.ct-ln-b:nth-child(4) { width:50%; } .ct-ln-b:nth-child(4)::after { transition-delay:0.49s; }
.ct-ln-c:nth-child(1) { width:75%; } .ct-ln-c:nth-child(1)::after { transition-delay:0.56s; }
.ct-ln-c:nth-child(2) { width:92%; } .ct-ln-c:nth-child(2)::after { transition-delay:0.63s; }
.ct-ln-c:nth-child(3) { width:58%; } .ct-ln-c:nth-child(3)::after { transition-delay:0.70s; }
.ct-divider { width:100%; height:1px; background:rgba(255,255,255,0.05); margin:4px 0; }
.ct-icon-row { margin-top:28px; display:flex; gap:12px; align-items:center; }
.ct-thumb { width:48px; height:36px; border-radius:6px; border:1px solid rgba(255,255,255,0.08); background:rgba(1,166,81,0.07); transition:background 0.3s,border-color 0.3s; }
.svc-block:hover .ct-thumb { background:rgba(1,166,81,0.12); border-color:rgba(1,166,81,0.22); }
.ct-thumb:nth-child(2) { background:rgba(1,251,29,0.04); width:36px; }
.ct-thumb:nth-child(3) { background:rgba(255,255,255,0.03); width:56px; }

/* ── Service 3: Digital / UI art ───────────────────────────── */
.svc-art-digital { padding:28px 32px; flex-direction:column; gap:12px; align-items:stretch; }
.dg-browser { border:1px solid rgba(255,255,255,0.1); border-radius:12px; overflow:hidden; flex:1; }
.dg-bar { height:28px; background:rgba(255,255,255,0.04); border-bottom:1px solid rgba(255,255,255,0.06); display:flex; align-items:center; padding:0 12px; gap:6px; }
.dg-dot { width:6px;height:6px;border-radius:50%; }
.dg-dot:nth-child(1) { background:rgba(255,80,80,0.5); }
.dg-dot:nth-child(2) { background:rgba(255,200,0,0.4); }
.dg-dot:nth-child(3) { background:rgba(1,166,81,0.6); }
.dg-url { flex:1; height:14px; background:rgba(255,255,255,0.06); border-radius:10px; margin:0 8px; }
.dg-content { padding:16px; display:grid; grid-template-columns:1fr 2fr; gap:10px; position:relative; }
.dg-sidebar { display:flex; flex-direction:column; gap:6px; }
.dg-side-item { height:20px; border-radius:4px; background:rgba(255,255,255,0.04); transition:background 0.3s; }
.dg-side-item.active { background:rgba(1,166,81,0.15); border-inline-start:2px solid var(--green); }
.svc-block:hover .dg-side-item.active { background:rgba(1,166,81,0.22); }
.dg-main { display:flex; flex-direction:column; gap:8px; }
.dg-hero-mock { height:70px; border-radius:6px; background:rgba(1,166,81,0.06); border:1px solid rgba(1,166,81,0.12); position:relative; overflow:hidden; }
.dg-hero-mock::after { content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(1,166,81,0.1) 0%,transparent 60%); }
.dg-cards { display:grid; grid-template-columns:1fr 1fr; gap:6px; }
.dg-card-mock { height:36px; border-radius:5px; background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.06); transition:border-color 0.3s; }
.svc-block:hover .dg-card-mock { border-color:rgba(1,166,81,0.14); }
.dg-cursor { position:absolute; width:12px;height:12px;border-radius:50%; background:var(--lime); box-shadow:0 0 14px rgba(1,251,29,0.5); top:52%;right:35%; animation:cursorFloat 3s ease-in-out infinite; }

/* ── Service 4: Production / Video art ──────────────────────── */
.svc-art-production { flex-direction:column; padding:28px 32px; gap:12px; align-items:stretch; }
.prd-viewfinder { flex:1; border:1px solid rgba(255,255,255,0.1); border-radius:12px; background:rgba(0,0,0,0.2); position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.prd-corner { position:absolute; width:20px;height:20px; border-color:rgba(1,166,81,0.5); border-style:solid; }
.prd-corner.tl { top:10px;inset-inline-start:10px; border-width:2px 0 0 2px; border-radius:3px 0 0 0; }
.prd-corner.tr { top:10px;inset-inline-end:10px;   border-width:2px 2px 0 0; border-radius:0 3px 0 0; }
.prd-corner.bl { bottom:10px;inset-inline-start:10px; border-width:0 0 2px 2px; border-radius:0 0 0 3px; }
.prd-corner.br { bottom:10px;inset-inline-end:10px;   border-width:0 2px 2px 0; border-radius:0 0 3px 0; }
.prd-play { width:52px;height:52px;border-radius:50%;background:rgba(1,166,81,0.12);border:1px solid rgba(1,166,81,0.35);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:rgba(1,251,29,0.8);transition:background 0.3s,box-shadow 0.3s;cursor:default; }
.svc-block:hover .prd-play { background:rgba(1,166,81,0.22); box-shadow:0 0 30px rgba(1,166,81,0.2); }
.prd-rec { position:absolute;top:12px;inset-inline-end:14px;display:flex;align-items:center;gap:5px;font-family:var(--font-display);font-size:0.55rem;letter-spacing:0.2em;color:rgba(255,255,255,0.4); }
.prd-rec-dot { width:6px;height:6px;border-radius:50%;background:#ff4a4a;animation:recBlink 1.4s ease-in-out infinite; }
.prd-timecode { position:absolute;bottom:10px;inset-inline-start:12px;font-family:var(--font-display);font-size:0.55rem;letter-spacing:0.15em;color:rgba(1,251,29,0.45); }
.prd-strip { display:flex;gap:4px;flex-shrink:0; }
.prd-frame { height:38px;flex:1;border-radius:4px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);transition:border-color 0.3s,background 0.3s; }
.prd-frame.lit { background:rgba(1,166,81,0.1); border-color:rgba(1,166,81,0.25); }
.svc-block:hover .prd-frame.lit { background:rgba(1,166,81,0.16); }

/* ── Service 5: Strategy art ────────────────────────────────── */
.svc-art-strategy { flex-direction:row; gap:36px; padding:0 28px; }
.str-radar { position:relative; width:240px;height:240px; }
.str-ring { position:absolute;border-radius:50%;border:1px solid rgba(1,166,81,0.1);top:50%;left:50%;transform:translate(-50%,-50%);animation:radarPing 3s ease-in-out infinite; }
.str-ring:nth-child(1) { width:240px;height:240px;animation-delay:0s; }
.str-ring:nth-child(2) { width:176px;height:176px;animation-delay:0.4s;border-color:rgba(1,166,81,0.14); }
.str-ring:nth-child(3) { width:112px;height:112px;animation-delay:0.8s;border-color:rgba(1,251,29,0.18); }
.str-ring:nth-child(4) { width:48px; height:48px; animation-delay:1.2s;border-color:rgba(1,251,29,0.25); }
.str-axis { position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:240px;height:240px; }
.str-axis::before { content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(1,166,81,0.15),transparent); }
.str-axis::after  { content:'';position:absolute;left:50%;top:0;bottom:0;width:1px;background:linear-gradient(180deg,transparent,rgba(1,166,81,0.15),transparent); }
.str-sweep { position:absolute;top:50%;left:50%;width:110px;height:1px;transform-origin:0 0;background:linear-gradient(90deg,rgba(1,251,29,0.6),transparent);animation:radarSweep 4s linear infinite; }
.str-sweep::after { content:'';position:absolute;top:-4px;right:0;width:8px;height:8px;border-radius:50%;background:rgba(1,251,29,0.7);box-shadow:0 0 12px rgba(1,251,29,0.5);transform:translateY(-50%); }
.str-blip { position:absolute;border-radius:50%;background:var(--lime);transform:translate(-50%,-50%);animation:blipFade 4s ease-in-out infinite; }
.str-blip:nth-child(1) { width:6px;height:6px;top:28%;left:68%;animation-delay:0.5s;box-shadow:0 0 8px rgba(1,251,29,0.6); }
.str-blip:nth-child(2) { width:5px;height:5px;top:62%;left:74%;animation-delay:1.2s;opacity:0.7; }
.str-blip:nth-child(3) { width:4px;height:4px;top:72%;left:40%;animation-delay:2.1s;opacity:0.5; }
.str-readout { position:static; display:flex; flex-direction:column; gap:10px; flex-shrink:0; }
.str-read-line { display:flex;gap:6px;align-items:center;font-family:var(--font-display);font-size:0.55rem;letter-spacing:0.18em;color:rgba(1,166,81,0.5); }
.str-read-line::before { content:'';width:14px;height:1px;background:rgba(1,166,81,0.3); }

/* ════════════════════════════════════════════════════════════
   PORTFOLIO PAGE — Hero
   ════════════════════════════════════════════════════════════ */
.pf-hero-section {
  padding: 160px 0 80px;
  position: relative;
  overflow: hidden;
}
.pf-hero-section .glow-1 { opacity: .5; }

.pf-hero-char {
  position: absolute;
  left: 0; bottom: 0;
  height: 100%; width: 42%;
  pointer-events: none;
  z-index: 1;
}
.pf-hero-char::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 70% at 48% 58%, rgba(18,60,230,0.12) 0%, rgba(10,30,120,0.06) 40%, transparent 72%);
  pointer-events: none;
  z-index: 1;
}
.pf-hero-char::after {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(to left,   var(--bg) 0%, transparent 32%),
    linear-gradient(to bottom, var(--bg) 0%, transparent 18%),
    linear-gradient(to top,    var(--bg) 0%, transparent 18%);
  pointer-events: none;
  z-index: 2;
}
.pf-hero-char-glow { display: none; }
.pf-hero-char-img {
  width: 100%; height: 100%;
  object-fit: contain;
  object-position: left bottom;
  position: relative;
  z-index: 1;
  opacity: 0.28;
  left: 300px;
}
.pf-hero-container { padding-inline-end: 44%; }

/* ── Folder card system ────────────────────────────────────── */
.portfolio-works-section {
  padding-top: 80px;
  position: relative;
  overflow: hidden;
}
.portfolio-works-section::before {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 80% 10%, rgba(1,251,29,0.06), transparent 32%),
    radial-gradient(circle at 15% 85%, rgba(255,255,255,0.035), transparent 34%);
  opacity: 0.9;
}
.portfolio-works-section .container { position: relative; z-index: 1; }

/* Folder card grids */
.home-folder-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 72px 44px;
  margin-bottom: 56px;
}
.portfolio-folder-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 72px 44px;
}

/* Folder card */
.folder-card {
  position: relative;
  min-height: 330px;
  cursor: pointer;
  perspective: 1000px;
  background: transparent;
  overflow: visible;
}
.folder-shape {
  position: relative;
  height: 100%;
  min-height: 330px;
  transform-style: preserve-3d;
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
  background: transparent;
  overflow: visible;
}
.folder-back {
  position: absolute;
  inset: 18px 12px 0;
  border-radius: 28px 0 28px 28px;
  background:
    linear-gradient(145deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018)),
    rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.075);
  box-shadow: 0 22px 55px rgba(0,0,0,0.32), inset 0 1px 0 rgba(255,255,255,0.06);
  transform: translateY(12px) scale(0.96);
  opacity: 0.75;
  isolation: isolate;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
.folder-front-group {
  position: absolute; inset: 0;
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1), filter 0.35s ease;
  background: transparent;
  overflow: visible;
}
.folder-tab {
  width: 45%;
  height: 44px;
  margin-left: auto;
  border-radius: 20px 20px 0 0;
  background:
    linear-gradient(135deg, rgba(1,251,29,0.16), rgba(255,255,255,0.045)),
    rgba(255,255,255,0.035);
  border: 1px solid rgba(255,255,255,0.08);
  border-bottom: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 18px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.07);
}
.folder-tab-dot {
  width: 7px; height: 7px;
  border-radius: 999px;
  background: var(--lime);
  box-shadow: 0 0 16px rgba(1,251,29,0.5);
  flex-shrink: 0;
}
.folder-tab-text {
  height: 5px; width: 52px;
  border-radius: 999px;
  background: rgba(255,255,255,0.12);
}
.folder-body {
  position: relative;
  min-height: 292px;
  border-radius: 28px 0 28px 28px;
  overflow: visible;
  background:
    linear-gradient(145deg, rgba(255,255,255,0.065), rgba(255,255,255,0.022)),
    rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow:
    0 28px 65px rgba(0,0,0,0.38),
    inset 0 1px 0 rgba(255,255,255,0.08),
    inset 0 0 0 1px rgba(1,251,29,0.035);
  isolation: isolate;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
/* Merged contain-mode image layout */
.folder-preview {
  position: absolute; inset: 0;
  overflow: hidden;
  border-radius: inherit;
  padding: 24px 20px 82px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.folder-preview-img {
  display: flex;
  align-items: center;
  justify-content: center;
}
.folder-preview-img img {
  width: auto; height: auto;
  max-width: 90%;
  max-height: 400px;
  object-fit: contain;
  object-position: center;
  opacity: 0.9;
  filter: brightness(1.06) drop-shadow(0 2px 14px rgba(0,0,0,0.55));
  transition: transform 0.65s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.4s ease;
  display: block;
  flex-shrink: 0;
}
.folder-preview-vignette {
  position: absolute; inset: 0;
  pointer-events: none;
  background:
    linear-gradient(to top, rgba(0,4,14,0.55) 0%, rgba(0,4,14,0.15) 30%, transparent 60%),
    radial-gradient(ellipse at 50% 0%, rgba(0,0,0,0.18) 0%, transparent 70%);
}
.folder-info {
  position: absolute;
  z-index: 2;
  inset-inline: 26px;
  bottom: 26px;
}
.folder-cat {
  display: inline-flex;
  align-items: center;
  margin-bottom: 10px;
  color: var(--lime);
  font-family: 'Noor', sans-serif;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.85;
}
.folder-title {
  margin: 0;
  color: var(--text);
  font-family: 'Noor', sans-serif !important;
  font-size: clamp(1.05rem, 1.6vw, 1.4rem);
  font-weight: 800;
  line-height: 1.45;
  letter-spacing: -0.02em;
  text-shadow: 0 8px 24px rgba(0,0,0,0.45);
  overflow: visible !important;
  padding-inline: 2px !important;
  padding-block: 4px !important;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

/* Folder card hover state */
.folder-card:hover .folder-shape         { transform: translateY(-10px); }
.folder-card:hover .folder-front-group   { transform: translateY(-8px) rotateX(2deg); filter: drop-shadow(0 24px 55px rgba(0,0,0,0.36)); }
.folder-card:hover .folder-body          { border-color: rgba(1,251,29,0.2); box-shadow: 0 34px 80px rgba(0,0,0,0.46), 0 0 0 1px rgba(1,251,29,0.07), inset 0 1px 0 rgba(255,255,255,0.1); }
.folder-card:hover .folder-preview-img img { transform: scale(1.07); opacity: 1; filter: brightness(1.1) drop-shadow(0 4px 18px rgba(1,251,29,0.18)); }
.folder-card:hover .folder-tab           { border-color: rgba(1,251,29,0.18); background: linear-gradient(135deg, rgba(1,251,29,0.2), rgba(255,255,255,0.055)), rgba(255,255,255,0.045); }

/* ── Portfolio modal ────────────────────────────────────────── */
.pf-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,6,18,0.72);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  z-index: 2000;
  display: flex;
  align-items: center; justify-content: center;
  padding: 24px;
  opacity: 0; visibility: hidden;
  transition: opacity 0.35s ease, visibility 0.35s ease;
}
.pf-modal-overlay.is-open { opacity: 1; visibility: visible; }
.pf-modal {
  background: rgba(5,8,20,0.97);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 24px;
  box-shadow: 0 40px 100px rgba(0,0,0,0.7), 0 0 0 1px rgba(1,251,29,0.04), inset 0 1px 0 rgba(255,255,255,0.06), inset 0 0 80px rgba(1,251,29,0.02);
  max-width: 640px;
  width: 100%;
  max-height: 85vh;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(1,251,29,0.25) transparent;
  padding: 44px 40px 48px;
  position: relative;
  transform: translateY(24px) scale(0.97);
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  font-family: 'Noor', sans-serif !important;
}
.pf-modal::-webkit-scrollbar       { width: 4px; }
.pf-modal::-webkit-scrollbar-track { background: transparent; }
.pf-modal::-webkit-scrollbar-thumb { background: rgba(1,251,29,0.25); border-radius: 4px; }
.pf-modal-overlay.is-open .pf-modal { transform: translateY(0) scale(1); }
.pf-modal-close {
  position: absolute;
  top: 20px; left: 20px;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--text-2);
  font-size: 1rem; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background 0.25s, border-color 0.25s, color 0.25s;
}
.pf-modal-close:hover { background: rgba(1,251,29,0.1); border-color: rgba(1,251,29,0.3); color: var(--lime); }
.pf-modal-eyebrow    { display:block; font-family:'Noor',sans-serif !important; font-size:.68rem; font-weight:800; letter-spacing:.18em; text-transform:uppercase; color:var(--lime); opacity:0.85; margin-bottom:14px; }
.pf-modal-title      { font-family:'Noor',sans-serif !important; font-size:clamp(1.3rem,3vw,1.8rem); font-weight:800; color:var(--text); line-height:1.35; margin:0 0 18px; letter-spacing:-0.02em; }
.pf-modal-desc       { font-family:'Noor',sans-serif !important; color:var(--text-2); font-size:.95rem; line-height:1.85; margin:0 0 32px; }
.pf-modal-divider    { height:1px; background:rgba(255,255,255,0.06); margin-bottom:28px; }
.pf-modal-section-title { display:block; font-family:'Noor',sans-serif !important; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--text-2); opacity:0.65; margin-bottom:18px; }
.pf-modal-deliverables { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:12px; }
.pf-modal-deliverables li { display:flex; align-items:flex-start; gap:12px; font-family:'Noor',sans-serif !important; font-size:.9rem; color:var(--text-2); line-height:1.65; }
.pf-modal-deliverables li::before { content:''; width:6px; height:6px; min-width:6px; border-radius:50%; background:var(--lime); box-shadow:0 0 8px rgba(1,251,29,0.45); margin-top:7px; flex-shrink:0; }

/* ════════════════════════════════════════════════════════════
   CONTACT PAGE
   ════════════════════════════════════════════════════════════ */
.contact-hero {
  padding: 160px 0 80px;
  position: relative;
  overflow: hidden;
}
.contact-hero .glow-1 { opacity: .6; }

.contact-cards-section { background: var(--bg-2); padding-top: 80px; }
.contact-cards-wrap   { margin-top: 80px; }

.contact-info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 80px;
  max-width: 1320px;
  margin-inline: auto;
}
.contact-info-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  transition: border-color .3s, transform .3s;
}
.contact-info-card:hover { border-color: var(--border-green); transform: translateY(-3px); }
.contact-info-card .contact-card-btn { margin-top: 32px; }
.contact-info-card .contact-info-value { margin-bottom: 0; }
.contact-info-icon {
  width: 44px; height: 44px;
  border: 1px solid var(--border-green);
  border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
  font-size: 1.2rem;
  background: rgba(1,166,81,0.06);
}
.contact-info-label {
  font-family: var(--font-display);
  font-size: .7rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--green); margin-bottom: 8px; display: block;
}
.contact-info-value {
  color: var(--text);
  text-decoration: none;
  font-size: .95rem;
  transition: color .25s;
  display: block;
}
.contact-info-value:hover { color: var(--lime); }

/* Social links */
.social-section { text-align: center; }
.contact-social-tag   { margin-top: 100px; }
.contact-social-title { margin-top: 20px; }
.social-links {
  display: flex; align-items: center; justify-content: center;
  gap: 12px; margin-top: 36px; flex-wrap: wrap;
}
.social-link {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 11px 24px;
  border: 1px solid var(--border);
  border-radius: 50px;
  color: var(--text-2);
  text-decoration: none;
  font-size: .85rem;
  transition: all .25s;
  font-family: var(--font-body);
}
.social-link:hover {
  border-color: var(--lime);
  color: var(--lime);
  background: rgba(1,251,29,0.04);
  transform: translateY(-2px);
}

/* Map section */
.contact-map-section { background: var(--bg); }
.contact-map-card    { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-xl); padding: 48px; text-align: center; }
.contact-map-title   { font-family: var(--font-display); font-size: 1.5rem; font-weight: 400; color: var(--text); margin: 20px 0 12px; }
.contact-map-address { color: var(--text-2); font-size: .95rem; line-height: 1.8; margin-bottom: 28px; }
.contact-map-box {
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid var(--border);
  height: 420px;
  margin-top: 32px;
}
.contact-map-box iframe { width: 100%; height: 100%; border: 0; display: block; filter: saturate(1.05) contrast(1.02) brightness(0.92); }

/* Misc contact helpers */
.phone-value { direction: ltr; display: block; text-align: right; }
.addr-value  { cursor: default; }

/* ════════════════════════════════════════════════════════════
   PER-PAGE HERO TITLE SIZE OVERRIDES
   ════════════════════════════════════════════════════════════ */
.about-hero .page-hero-title    { font-size: 50px; line-height: 1.30; white-space: nowrap; }
.svc-hero   .page-hero-title    { font-size: clamp(1.9rem, 3.2vw, 2.8rem); line-height: 1.22; white-space: nowrap; }
.pf-hero-section .page-hero-title { font-size: clamp(1.45rem, 3vw, 2.8rem); line-height: 1.0; white-space: nowrap; }
