/* ============================================
   CV MASTER PRETORIA — DESIGN TOKENS
   Palette: graphite / steel / raw white / safety-orange
   ============================================ */
:root{
  --graphite: #1A1D21;
  --steel: #2E3338;
  --steel-light: #3A4148;
  --raw-white: #F7F6F3;
  --grey-mid: #9AA0A6;
  --orange: #FF5A1F;
  --orange-dim: #C8470F;

  --font-display: 'Archivo Expanded', sans-serif;
  --font-body: 'Archivo', sans-serif;

  --wrap: 1180px;
  --radius: 2px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  background:var(--graphite);
  color:var(--raw-white);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
ul{list-style:none;}

:focus-visible{
  outline:2px solid var(--orange);
  outline-offset:3px;
}

.wrap{
  max-width:var(--wrap);
  margin:0 auto;
  padding:0 28px;
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important;}
}

/* subtle film-grain texture overlay, gives the dark surface some depth */
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none;
  opacity:0.035; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='100' height='100'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ============ TYPE SCALE ============ */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:800;
  letter-spacing:-0.01em;
  line-height:1.08;
  text-transform:none;
}
h1{font-size:clamp(2.6rem, 5.5vw, 4.6rem);}
h2{font-size:clamp(1.9rem, 3.4vw, 2.8rem); margin-bottom:18px;}
h3{font-size:1.2rem; font-weight:700; margin-bottom:8px;}

.eyebrow{
  font-family:var(--font-body);
  font-weight:700;
  font-size:0.78rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--orange);
  margin-bottom:14px;
}
.hl{color:var(--orange);}
.section-lead{
  max-width:620px;
  color:var(--grey-mid);
  font-size:1.05rem;
  margin-bottom:44px;
}

/* ============ HEADER ============ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(26,29,33,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:76px;
}
.logo{display:flex; align-items:center; gap:10px; color:var(--raw-white);}
.logo-mark{color:var(--orange); display:flex;}
.logo-text{
  font-family:var(--font-display); font-weight:800; font-size:1.05rem;
  letter-spacing:0.02em; line-height:1;
  display:flex; flex-direction:column;
}
.logo-text small{
  font-family:var(--font-body); font-weight:600; font-size:0.6rem;
  letter-spacing:0.18em; color:var(--grey-mid); margin-top:2px;
}
.main-nav{display:flex; gap:36px;}
.main-nav a{
  font-weight:600; font-size:0.92rem; color:var(--raw-white);
  position:relative; padding:6px 0;
}
.main-nav a::after{
  content:''; position:absolute; left:0; bottom:0; width:0; height:2px;
  background:var(--orange); transition:width 0.25s ease;
}
.main-nav a:hover::after{width:100%;}

.btn-phone{
  display:flex; align-items:center; gap:8px;
  font-weight:700; font-size:0.92rem;
  color:var(--graphite); background:var(--orange);
  padding:10px 18px; border-radius:var(--radius);
  transition:background 0.2s ease;
}
.btn-phone:hover{background:#ff7340;}

.nav-toggle{display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px;}
.nav-toggle span{width:22px; height:2px; background:var(--raw-white);}

/* ============ HERO ============ */
.hero{
  position:relative; z-index:2;
  padding:88px 0 60px;
  background:
    radial-gradient(ellipse 900px 500px at 80% 0%, rgba(255,90,31,0.10), transparent 60%),
    var(--graphite);
}
.hero-inner{
  display:grid; grid-template-columns:1.15fr 0.85fr;
  gap:40px; align-items:center;
}
.hero-sub{
  max-width:480px; color:var(--grey-mid); font-size:1.08rem; margin:22px 0 32px;
}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap;}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--font-body); font-weight:700; font-size:0.95rem;
  padding:15px 28px; border-radius:var(--radius);
  transition:transform 0.18s ease, background 0.2s ease, border-color 0.2s ease;
}
.btn-primary{background:var(--orange); color:var(--graphite);}
.btn-primary:hover{background:#ff7340; transform:translateY(-2px);}
.btn-ghost{border:1.5px solid rgba(247,246,243,0.25); color:var(--raw-white);}
.btn-ghost:hover{border-color:var(--orange); color:var(--orange); transform:translateY(-2px);}
.btn-large{padding:18px 38px; font-size:1.05rem;}

.trust-row{
  display:flex; gap:32px; margin-top:48px; flex-wrap:wrap;
}
.trust-row span{display:flex; flex-direction:column; font-size:0.82rem; color:var(--grey-mid);}
.trust-row strong{font-family:var(--font-display); font-size:1.5rem; color:var(--raw-white); font-weight:800;}

/* --- the joint diagram: signature element --- */
.hero-visual{display:flex; justify-content:center;}
.joint-diagram{width:100%; max-width:420px; height:auto;}
.joint-ring{
  transform-origin:200px 230px;
  animation:ring-pulse 3.2s ease-in-out infinite;
}
.joint-arm{
  transform-origin:200px 230px;
  animation:articulate 4.5s cubic-bezier(0.45,0,0.2,1) infinite;
}
.angle-arc{animation:arc-fade 4.5s ease-in-out infinite;}

@keyframes articulate{
  0%,100%{transform:rotate(0deg);}
  50%{transform:rotate(-18deg);}
}
@keyframes ring-pulse{
  0%,100%{opacity:1;}
  50%{opacity:0.55;}
}
@keyframes arc-fade{
  0%,100%{opacity:0.7;}
  50%{opacity:0.15;}
}

/* ============ TRUST BAR ============ */
.trust-bar{
  background:var(--steel);
  border-top:1px solid rgba(255,255,255,0.06);
  border-bottom:1px solid rgba(255,255,255,0.06);
  padding:30px 0;
  position:relative; z-index:2;
}
.trust-bar-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:20px; text-align:center;
}
.trust-bar-grid .num{
  display:block; font-family:var(--font-display); font-weight:800;
  font-size:1.7rem; color:var(--orange);
}
.trust-bar-grid .label{display:block; font-size:0.82rem; color:var(--grey-mid); margin-top:4px;}

/* ============ SECTIONS ============ */
.section{padding:96px 0; position:relative; z-index:2;}

/* ============ SERVICES GRID ============ */
.service-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:18px;
}
.service-card{
  background:var(--steel);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:var(--radius);
  padding:30px 26px;
  transition:transform 0.22s ease, border-color 0.22s ease, background 0.22s ease;
}
.service-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,90,31,0.4);
  background:var(--steel-light);
}
.service-card--primary{
  background:linear-gradient(160deg, var(--orange-dim), #8a2f08);
  border-color:transparent;
}
.service-card--primary .service-icon{color:var(--raw-white);}
.service-card--primary p{color:rgba(247,246,243,0.85);}
.service-icon{color:var(--orange); display:inline-flex; margin-bottom:16px;}
.service-card p{color:var(--grey-mid); font-size:0.94rem;}
.service-card--cta{
  display:flex; flex-direction:column; justify-content:center;
  border:1.5px dashed rgba(255,90,31,0.4); background:transparent;
}
.service-card--cta .card-link{color:var(--orange); font-weight:700; margin-top:10px;}

/* ============ STORY SECTION ============ */
.story-section{background:var(--steel);}
.story-grid{display:grid; grid-template-columns:0.85fr 1.15fr; gap:60px; align-items:center;}
.story-frame{
  aspect-ratio:4/5;
  background:var(--graphite);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--radius);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:30px;
  position:relative;
}
.story-frame::before{
  content:''; position:absolute; inset:14px;
  border:1px solid rgba(255,90,31,0.25);
}
.story-year{
  font-family:var(--font-display); font-weight:800;
  font-size:4.2rem; color:var(--orange); line-height:1;
}
.story-caption{color:var(--grey-mid); font-size:0.9rem; margin-top:14px; max-width:200px;}
.story-copy p{color:var(--grey-mid); margin-bottom:18px; max-width:560px;}
.story-points{display:grid; gap:18px; margin:30px 0 26px;}
.story-points strong{display:block; font-size:0.98rem; margin-bottom:3px;}
.story-points span{color:var(--grey-mid); font-size:0.9rem;}
.text-link{color:var(--orange); font-weight:700;}

/* ============ TESTIMONIALS ============ */
.testimonial-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px;}
.testimonial{
  background:var(--steel); border-left:3px solid var(--orange);
  padding:28px 26px; border-radius:var(--radius);
}
.testimonial p{font-size:0.96rem; color:var(--raw-white); margin-bottom:16px;}
.testimonial cite{font-size:0.82rem; color:var(--grey-mid); font-style:normal;}

/* ============ LOCATION ============ */
.location-grid{display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center;}
.hours-list{margin:26px 0 32px; border-top:1px solid rgba(255,255,255,0.08);}
.hours-list li{
  display:flex; justify-content:space-between;
  padding:13px 0; border-bottom:1px solid rgba(255,255,255,0.08);
  font-size:0.95rem;
}
.hours-list li span:first-child{color:var(--grey-mid);}
.map-embed{
  height:380px; border-radius:var(--radius); overflow:hidden;
  border:1px solid rgba(255,255,255,0.1); filter:grayscale(0.3) contrast(1.05);
}

/* ============ FINAL CTA ============ */
.final-cta{
  background:linear-gradient(135deg, var(--orange-dim), #7a2a08);
  padding:90px 0; text-align:center; position:relative; z-index:2;
}
.final-cta-inner h2{color:var(--graphite); max-width:640px; margin:0 auto 14px;}
.final-cta-inner p{color:rgba(26,29,33,0.75); max-width:480px; margin:0 auto 34px; font-size:1.05rem;}
.final-cta .btn-primary{background:var(--graphite); color:var(--raw-white);}
.final-cta .btn-primary:hover{background:#000;}

/* ============ FOOTER ============ */
.site-footer{background:#121417; padding:70px 0 0; position:relative; z-index:2;}
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px;
  padding-bottom:50px; border-bottom:1px solid rgba(255,255,255,0.08);
}
.footer-logo{margin-bottom:14px; display:flex;}
.footer-grid p{color:var(--grey-mid); font-size:0.9rem; max-width:240px;}
.footer-grid h4{font-family:var(--font-body); font-size:0.82rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--grey-mid); margin-bottom:16px; font-weight:700;}
.footer-grid a, .footer-grid span{
  display:block; margin-bottom:10px; font-size:0.92rem; color:var(--raw-white);
}
.footer-grid a:hover{color:var(--orange);}
.footer-bottom{
  display:flex; justify-content:space-between; padding:24px 0;
  font-size:0.82rem; color:var(--grey-mid);
}

/* ============ PAGE HERO (sub-pages) ============ */
.page-hero{
  padding:120px 0 64px;
  background:radial-gradient(ellipse 800px 400px at 85% 0%, rgba(255,90,31,0.08), transparent 60%);
  position:relative; z-index:2;
}
.page-hero .hero-sub{max-width:560px; color:var(--grey-mid); font-size:1.05rem; margin-top:18px;}

/* ============ SERVICE DETAIL ROWS ============ */
.service-detail{padding:64px 0;}
.service-detail--alt{background:var(--steel);}
.service-detail-grid{
  display:grid; grid-template-columns:140px 1fr; gap:44px; align-items:start;
}
.service-detail-grid--reverse{grid-template-columns:1fr 140px;}
.service-detail-grid--reverse > div:first-child{order:1;}
.service-detail-grid--reverse > .service-detail-num{order:2;}
.service-detail-num{
  font-family:var(--font-display); font-weight:800; font-size:3.4rem;
  color:rgba(255,90,31,0.25); line-height:1;
}
.service-detail h2{margin-bottom:10px;}
.service-detail .section-lead{margin-bottom:26px;}
.service-detail p{color:var(--grey-mid); max-width:640px; margin-bottom:18px;}
.symptom-block{
  background:rgba(255,255,255,0.03); border-left:3px solid var(--orange);
  padding:22px 24px; margin-bottom:24px; max-width:640px; border-radius:var(--radius);
}
.symptom-block h4{font-size:0.85rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--orange); margin-bottom:14px; font-weight:700;}
.symptom-list li{
  color:var(--raw-white); font-size:0.95rem; padding:7px 0 7px 22px;
  position:relative; border-top:1px solid rgba(255,255,255,0.06);
}
.symptom-list li:first-child{border-top:none;}
.symptom-list li::before{content:'—'; position:absolute; left:0; color:var(--orange);}

/* ============ CONTACT PAGE ============ */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start;}
.contact-info-list{margin-top:30px; display:grid; gap:22px;}
.contact-info-list strong{display:block; font-size:0.85rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--orange); margin-bottom:4px;}
.contact-form{display:grid; gap:16px;}
.contact-form label{font-size:0.85rem; color:var(--grey-mid); margin-bottom:6px; display:block;}
.contact-form input, .contact-form select, .contact-form textarea{
  width:100%; background:var(--steel); border:1px solid rgba(255,255,255,0.1);
  color:var(--raw-white); padding:13px 14px; border-radius:var(--radius);
  font-family:var(--font-body); font-size:0.95rem;
}
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus{
  outline:none; border-color:var(--orange);
}
.contact-form button{
  justify-self:start; border:none; cursor:pointer; margin-top:6px;
}

/* ============ ABOUT PAGE ============ */
.timeline{display:grid; gap:0; margin-top:40px;}
.timeline-item{
  display:grid; grid-template-columns:110px 1fr; gap:30px;
  padding:28px 0; border-top:1px solid rgba(255,255,255,0.08);
}
.timeline-item:first-child{border-top:none;}
.timeline-item .t-year{font-family:var(--font-display); font-weight:800; color:var(--orange); font-size:1.3rem;}
.timeline-item p{color:var(--grey-mid); font-size:0.95rem; max-width:540px;}
.timeline-item h4{margin-bottom:6px;}

/* ============ BLOG ============ */
.blog-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:24px;}
.blog-card{
  background:var(--steel); border-radius:var(--radius); padding:30px;
  border:1px solid rgba(255,255,255,0.06); transition:border-color 0.2s ease, transform 0.2s ease;
}
.blog-card:hover{border-color:rgba(255,90,31,0.4); transform:translateY(-3px);}
.blog-card .eyebrow{font-size:0.7rem;}
.blog-card h3{font-size:1.25rem; margin-bottom:10px;}
.blog-card p{color:var(--grey-mid); font-size:0.92rem; margin-bottom:16px;}
.blog-article{padding:60px 0 90px;}
.blog-article-body{max-width:680px;}
.blog-article-body h2{margin-top:42px;}
.blog-article-body p{color:var(--grey-mid); margin-bottom:18px; font-size:1.02rem;}
.blog-article-body ul{margin:0 0 24px; display:grid; gap:10px;}
.blog-article-body ul li{
  color:var(--raw-white); padding-left:20px; position:relative; font-size:0.98rem;
}
.blog-article-body ul li::before{content:'—'; position:absolute; left:0; color:var(--orange);}
.article-meta{color:var(--grey-mid); font-size:0.85rem; margin-bottom:8px;}

/* ============ RESPONSIVE ============ */
@media (max-width: 880px){
  .main-nav, .header-cta{display:none;}
  .nav-toggle{display:flex;}
  .main-nav.nav-open{
    display:flex; flex-direction:column; gap:0;
    position:absolute; top:76px; left:0; right:0;
    background:var(--graphite); border-bottom:1px solid rgba(255,255,255,0.08);
    padding:8px 28px 20px;
  }
  .main-nav.nav-open a{padding:14px 0; border-bottom:1px solid rgba(255,255,255,0.06);}
  .header-cta.nav-open{
    display:flex; position:absolute; top:128px; left:28px; right:28px;
  }
  .header-cta.nav-open .btn-phone{justify-content:center; width:100%;}
  .hero-inner{grid-template-columns:1fr;}
  .hero-visual{order:-1; margin-bottom:10px;}
  .joint-diagram{max-width:280px;}
  .trust-bar-grid{grid-template-columns:repeat(2,1fr);}
  .service-grid{grid-template-columns:repeat(2,1fr);}
  .story-grid, .location-grid{grid-template-columns:1fr;}
  .story-grid{gap:36px;}
  .testimonial-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr; gap:32px;}
  .service-detail-grid, .service-detail-grid--reverse{grid-template-columns:1fr; gap:14px;}
  .service-detail-grid--reverse > div:first-child{order:0;}
  .service-detail-grid--reverse > .service-detail-num{order:0;}
  .service-detail-num{font-size:2rem; color:var(--orange);}
  .contact-grid{grid-template-columns:1fr; gap:40px;}
  .blog-grid{grid-template-columns:1fr;}
  .timeline-item{grid-template-columns:70px 1fr; gap:18px;}
}
@media (max-width: 540px){
  .service-grid{grid-template-columns:1fr;}
  .hero-actions{flex-direction:column;}
  .btn{width:100%;}
  .footer-grid{grid-template-columns:1fr;}
  .trust-row{gap:20px;}
}

/* ============================================
   IMAGERY — photographs layered into the dark
   surface. Shared treatment: a thin orange inset
   rule and a desaturate that warms up on hover,
   so photos read as part of the brand, not stock.
   ============================================ */
.media-frame{
  position:relative; overflow:hidden;
  border-radius:var(--radius); border:1px solid rgba(255,255,255,0.08);
  background:var(--steel);
}
.media-frame::after{
  content:''; position:absolute; inset:12px; z-index:2;
  border:1px solid rgba(255,90,31,0.30); pointer-events:none;
}
.media-frame img{
  width:100%; height:100%; object-fit:cover; display:block;
  filter:grayscale(0.42) contrast(1.05);
  transition:filter 0.5s ease, transform 0.7s ease;
}
.media-frame:hover img{filter:grayscale(0) contrast(1.05); transform:scale(1.045);}

/* --- hero: workshop photograph behind the copy + diagram --- */
.hero::before{
  content:''; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse 900px 500px at 82% 4%, rgba(255,90,31,0.20), transparent 58%),
    linear-gradient(102deg, rgba(26,29,33,0.97) 32%, rgba(26,29,33,0.74) 78%, rgba(26,29,33,0.55) 100%),
    url('images/workshop-interior.jpg') center/cover no-repeat;
}
.hero-inner{position:relative; z-index:1;}

/* --- story section: real photo in the frame, with a 1979 badge --- */
.story-frame{padding:0; overflow:hidden;}
.story-frame::before{z-index:2;}
.story-frame img{width:100%; height:100%; object-fit:cover; filter:grayscale(0.32) contrast(1.05);}
.story-badge{
  position:absolute; left:0; bottom:0; z-index:3;
  background:var(--orange); color:var(--graphite);
  padding:14px 20px; display:flex; flex-direction:column; line-height:1;
}
.story-badge strong{font-family:var(--font-display); font-weight:800; font-size:2rem;}
.story-badge span{font-size:0.72rem; font-weight:700; letter-spacing:0.03em; margin-top:6px; max-width:160px;}

/* --- "inside the workshop" gallery band --- */
.gallery-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:6px;}
.gallery-item{position:relative; aspect-ratio:3/4;}
.gallery-item figcaption{
  position:absolute; left:0; right:0; bottom:0; z-index:3;
  padding:30px 18px 16px; font-size:0.86rem; font-weight:700; color:var(--raw-white);
  background:linear-gradient(to top, rgba(18,20,23,0.92), transparent);
}

/* --- service detail rows: a photo column carrying the step number --- */
.service-detail-grid{grid-template-columns:340px 1fr; align-items:start;}
.service-detail-grid--reverse{grid-template-columns:1fr 340px;}
.service-detail-grid--reverse .service-media{order:2;}
.service-media{position:relative; aspect-ratio:4/5;}
.service-media::before{
  content:''; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(to top, rgba(26,29,33,0.78), transparent 52%);
}
.service-media .service-detail-num{
  position:absolute; left:18px; bottom:12px; z-index:3; margin:0;
  font-size:3.2rem; color:var(--raw-white); text-shadow:0 2px 16px rgba(0,0,0,0.7);
}

/* --- wide feature banner (about / contact) --- */
.feature-img{aspect-ratio:21/9;}
.feature-cap{
  position:absolute; left:0; bottom:0; z-index:3;
  background:rgba(18,20,23,0.78); backdrop-filter:blur(4px);
  color:var(--raw-white); font-size:0.85rem; font-weight:600;
  padding:12px 20px; border-top:2px solid var(--orange);
}
.about-intro{display:grid; grid-template-columns:1fr 0.82fr; gap:54px; align-items:start;}
.about-intro .media-frame{aspect-ratio:4/5;}

@media (max-width: 880px){
  .service-media{aspect-ratio:16/10;}
  .service-detail-grid--reverse .service-media{order:0;}
  .about-intro{grid-template-columns:1fr; gap:34px;}
  .feature-img{aspect-ratio:16/9;}
  .gallery-grid{grid-template-columns:repeat(3,1fr); gap:10px;}
}
@media (max-width: 540px){
  .gallery-grid{grid-template-columns:1fr;}
}
