/*
Theme Name: BSL Welding
Theme URI: https://bslwelding.com
Author: BSL Welding Services
Author URI: https://bslwelding.com
Description: A navy, red and white corporate theme for BSL Welding Services — custom gate, fence, awning, grill and steel fabrication across Klang Valley, Selangor.
Version: 2.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: bsl-welding
*/

:root{
  --navy:#0B1440;
  --navy-2:#101B57;
  --navy-3:#152066;
  --red:#E2231A;
  --red-2:#C71B14;
  --white:#FFFFFF;
  --bg-soft:#F4F5FA;
  --ink:#1B2140;
  --ink-soft:#5C6178;
  --line:#E4E6F0;
  --radius:6px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--white);
  color:var(--ink);
  font-family:'Inter',sans-serif;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.display{
  font-family:'Oswald',sans-serif;
  text-transform:uppercase;
  letter-spacing:0.01em;
  font-weight:700;
  color:var(--navy);
  line-height:1.15;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
ul{list-style:none;}
:focus-visible{outline:2px solid var(--red);outline-offset:3px;}
.wrap{max-width:1200px;margin:0 auto;padding:0 32px;}
.eyebrow{
  font-family:'Oswald',sans-serif;
  font-size:0.82rem;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--red);
  font-weight:600;
  display:flex;align-items:center;gap:10px;
  margin-bottom:10px;
}
.eyebrow::before{content:"";width:26px;height:3px;background:var(--red);display:inline-block;}
.eyebrow.on-navy{color:#FF8A83;}
.eyebrow.on-navy::before{background:var(--red);}
.accent-red{color:var(--red);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 28px;
  font-family:'Oswald',sans-serif;
  font-size:0.85rem;
  letter-spacing:0.05em;
  text-transform:uppercase;
  font-weight:600;
  border-radius:var(--radius);
  border:none;
  cursor:pointer;
  transition:transform .15s, background .2s, box-shadow .2s;
}
.btn-red{background:var(--red);color:#fff;}
.btn-red:hover{background:var(--red-2);transform:translateY(-1px);}
.btn-navy{background:var(--navy);color:#fff;}
.btn-navy:hover{background:var(--navy-2);transform:translateY(-1px);}
.btn-outline{border:2px solid #fff;color:#fff;background:transparent;}
.btn-outline:hover{background:#fff;color:var(--navy);}
.btn-outline-navy{border:2px solid var(--navy);color:var(--navy);background:transparent;}
.btn-outline-navy:hover{background:var(--navy);color:#fff;}

/* ---------- Header ---------- */
header{
  position:sticky;top:0;z-index:50;
  background:#fff;
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:24px;}
.logo{display:flex;align-items:center;gap:10px;}
.logo-img{height:48px;width:auto;max-width:190px;object-fit:contain;display:block;}
.logo-badge{
  display:inline-flex;align-items:center;justify-content:center;
  background:#fff;border-radius:8px;padding:8px 14px;
}
.logo-badge .logo-img{height:38px;}
.logo--custom{gap:12px;}
.custom-logo-link{display:flex;align-items:center;}
.custom-logo{height:44px;width:auto;max-width:190px;object-fit:contain;display:block;}
nav.primary-nav ul{display:flex;gap:30px;flex-wrap:wrap;}
nav.primary-nav a{
  font-family:'Oswald',sans-serif;
  font-size:0.86rem;letter-spacing:0.04em;text-transform:uppercase;
  color:var(--navy);font-weight:600;
  padding-bottom:6px;border-bottom:2px solid transparent;
  transition:color .2s, border-color .2s;
}
nav.primary-nav a:hover, nav.primary-nav .current-menu-item a{
  color:var(--red);border-color:var(--red);
}
.call-badge{display:flex;align-items:center;gap:10px;white-space:nowrap;}
.call-badge .ico{
  width:38px;height:38px;border-radius:50%;background:var(--red);
  display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;
}
.call-badge .txt{line-height:1.2;}
.call-badge .txt small{display:block;font-size:0.66rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:0.08em;}
.call-badge .txt strong{font-family:'Oswald',sans-serif;font-size:1rem;color:var(--navy);}

/* ---------- Curve divider ---------- */
.curve{position:relative;overflow:hidden;}
.curve svg{position:absolute;bottom:-1px;left:0;width:100%;height:auto;display:block;}

/* ---------- Hero (shared banner style: navy or white) ---------- */
.page-hero{
  position:relative;
  padding:90px 0 130px;
  overflow:hidden;
}
.page-hero.navy-hero{background:linear-gradient(135deg,var(--navy),var(--navy-3));color:#fff;}
.page-hero.white-hero{background:var(--white);}
.hero-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:56px;align-items:center;}
.page-hero h1{font-size:clamp(2.2rem,4.6vw,3.2rem);}
.page-hero.navy-hero h1{color:#fff;}
.page-hero .script{
  font-family:'Oswald',sans-serif;font-style:italic;font-weight:500;
  font-size:1.15rem;color:var(--red);margin-bottom:10px;text-transform:none;letter-spacing:0;
}
.page-hero .lead{
  margin-top:16px;font-size:1.02rem;max-width:520px;
}
.page-hero.navy-hero .lead{color:#D7DAF0;}
.page-hero.white-hero .lead{color:var(--ink-soft);}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:30px;}

/* ---------- Photo placeholder ---------- */
.photo{
  position:relative;
  border-radius:14px;
  overflow:hidden;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.06) 0 2px, transparent 2px 14px),
    linear-gradient(135deg,var(--navy),#233069);
  display:flex;align-items:center;justify-content:center;
  min-height:280px;
  border:1px dashed rgba(255,255,255,0.35);
}
.photo img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;inset:0;}
.photo .label{
  font-family:'IBM Plex Mono',monospace;
  color:#C9CEEA;
  font-size:0.8rem;
  text-align:center;
  padding:0 24px;
  letter-spacing:0.02em;
}
.photo .label b{display:block;color:#fff;font-family:'Oswald',sans-serif;font-size:0.95rem;letter-spacing:0.06em;text-transform:uppercase;margin-bottom:6px;}
.photo.light{background:repeating-linear-gradient(135deg, rgba(11,20,64,0.05) 0 2px, transparent 2px 14px), var(--bg-soft);border-color:var(--line);}
.photo.light .label{color:var(--ink-soft);}
.photo.light .label b{color:var(--navy);}
.photo.small{min-height:170px;border-radius:10px;}
.photo.tiny{min-height:120px;border-radius:8px;}

/* ---------- Section shared ---------- */
section{padding:88px 0;}
.section-head{max-width:640px;margin:0 auto 50px;text-align:center;}
.section-head h2{font-size:clamp(1.8rem,3.2vw,2.4rem);margin-top:6px;}
.section-head p{color:var(--ink-soft);margin-top:14px;}
.section-head.left{margin:0 0 50px;text-align:left;}
.section-navy{background:var(--navy);color:#fff;}
.section-navy h2, .section-navy h3, .section-navy h4{color:#fff;}
.section-navy p{color:#C9CEEA;}
.section-soft{background:var(--bg-soft);}

/* ---------- Icon circle ---------- */
.icon-circle{
  width:56px;height:56px;border-radius:50%;
  background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'Oswald',sans-serif;font-weight:700;font-size:1.2rem;
  flex-shrink:0;
}
.icon-circle.red{background:var(--red);}
.icon-circle.outline{background:transparent;border:2px solid var(--navy);color:var(--navy);}

/* ---------- Grid cards (services icon row) ---------- */
.icon-card-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
  gap:24px;
}
.icon-card{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--radius);
  padding:30px 24px;
  text-align:center;
}
.section-soft .icon-card, .white-cards .icon-card{
  background:#fff;border:1px solid var(--line);
}
.icon-card .icon-circle{margin:0 auto 18px;}
.icon-card h3{font-size:1.02rem;margin-bottom:8px;}
.icon-card p{font-size:0.88rem;}
.section-navy .icon-card p{color:#C9CEEA;}
.section-soft .icon-card p, .white-cards .icon-card p{color:var(--ink-soft);}

/* ---------- Service detail cards (services page) ---------- */
.service-cards{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;
}
.service-card{
  position:relative;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
}
.service-card .num{
  position:absolute;
  background:var(--red);color:#fff;
  font-family:'Oswald',sans-serif;font-weight:700;
  padding:6px 14px;font-size:0.85rem;
  border-radius:4px;
  margin:14px;
  z-index:2;
}
.service-card .card-body{padding:24px 26px 26px;}
.service-card h3{font-size:1.15rem;margin-bottom:14px;}
.service-card .check-list{margin-bottom:18px;}
.service-card .check-list li{
  display:flex;gap:8px;align-items:flex-start;
  font-size:0.9rem;color:var(--ink-soft);
  padding:5px 0;
}
.service-card .check-list li::before{content:"✔";color:var(--red);font-size:0.8rem;margin-top:2px;}
.check-list-2col{display:grid;grid-template-columns:1fr 1fr;gap:0 12px;margin-bottom:18px;}
.check-list-2col li{display:flex;gap:6px;align-items:flex-start;font-size:0.86rem;color:var(--ink-soft);padding:4px 0;}
.check-list-2col li::before{content:"✔";color:var(--red);font-size:0.72rem;margin-top:3px;}

/* ---------- Feature list (checklist, two-column) ---------- */
.feature-check{
  display:grid;grid-template-columns:1fr 1fr;gap:6px 32px;
}
.feature-check li{
  display:flex;gap:10px;align-items:flex-start;
  padding:9px 0;font-size:0.94rem;color:var(--ink-soft);
}
.feature-check li .tick{
  width:20px;height:20px;border-radius:50%;
  background:var(--red);color:#fff;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:0.7rem;margin-top:1px;
}
.feature-check li:nth-child(even) .tick{background:var(--navy);}

/* ---------- Work process ---------- */
.process-row{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;}
.process-step{text-align:center;padding:0 16px;position:relative;}
.process-step .idx{
  width:56px;height:56px;border-radius:50%;background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;
  font-family:'Oswald',sans-serif;font-weight:700;
}
.process-step h3{font-size:1.02rem;margin-bottom:8px;}
.process-step p{font-size:0.88rem;color:var(--ink-soft);}
.process-arrow{
  position:absolute;top:28px;right:-8px;color:var(--line);font-size:1.4rem;
}

/* ---------- Why choose box (navy panel) ---------- */
.why-panel{background:var(--navy);border-radius:var(--radius);padding:34px;color:#fff;}
.why-panel h3{color:#fff;font-size:1.1rem;margin-bottom:18px;}
.why-panel ul{display:grid;gap:12px;}
.why-panel li{display:flex;gap:10px;align-items:flex-start;font-size:0.92rem;color:#D7DAF0;}
.why-panel li::before{content:"✔";color:var(--red);flex-shrink:0;}

/* ---------- Mission / Vision cards ---------- */
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.mv-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;display:flex;gap:16px;}
.mv-card .ico{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.1rem;
}
.mv-card.mission .ico{background:var(--red);}
.mv-card.vision .ico{background:var(--navy);}
.mv-card h4{font-size:1rem;margin-bottom:8px;}
.mv-card p{font-size:0.9rem;color:var(--ink-soft);}

/* ---------- Core values row ---------- */
.values-row{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;text-align:center;}
.values-row .icon-circle{margin:0 auto 14px;}
.values-row h4{font-size:0.95rem;margin-bottom:6px;}
.values-row p{font-size:0.82rem;color:var(--ink-soft);}

/* ---------- Areas we serve ---------- */
.areas-grid{display:grid;grid-template-columns:0.9fr 1.1fr 0.9fr;gap:36px;align-items:center;}
.areas-list li{display:flex;gap:10px;align-items:center;padding:8px 0;font-size:0.94rem;color:var(--ink-soft);}
.areas-list li .pin{color:var(--red);}
.cta-box{background:var(--navy);color:#fff;border-radius:var(--radius);padding:32px;}
.cta-box h3{color:#fff;font-size:1.3rem;margin-bottom:12px;}
.cta-box p{color:#D7DAF0;font-size:0.92rem;margin-bottom:18px;}
.cta-box .phone-line{display:flex;align-items:center;gap:12px;margin-bottom:18px;}
.cta-box .phone-line .ico{
  width:42px;height:42px;border-radius:50%;background:var(--red);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.cta-box .phone-line strong{font-family:'Oswald',sans-serif;font-size:1.2rem;display:block;}
.cta-box .phone-line small{color:#C9CEEA;font-size:0.78rem;text-transform:uppercase;letter-spacing:0.05em;}

/* ---------- FAQ ---------- */
.faq-item{border-bottom:1px solid var(--line);padding:16px 0;}
.faq-item summary{
  cursor:pointer;font-family:'Oswald',sans-serif;font-size:0.98rem;color:var(--navy);
  display:flex;justify-content:space-between;align-items:center;list-style:none;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:"+";font-size:1.3rem;color:var(--red);}
.faq-item[open] summary::after{content:"–";}
.faq-item p{margin-top:12px;font-size:0.9rem;color:var(--ink-soft);}

/* ---------- Recent projects gallery ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.gallery-grid figure figcaption{
  font-family:'Oswald',sans-serif;font-size:0.78rem;text-transform:uppercase;
  letter-spacing:0.04em;color:var(--ink-soft);margin-top:8px;text-align:center;
}

/* ---------- Bottom CTA split banner ---------- */
.cta-split{display:grid;grid-template-columns:1fr 1fr;}
.cta-split .half{padding:40px 32px;display:flex;flex-direction:column;justify-content:center;}
.cta-split .navy-half{background:var(--navy);color:#fff;}
.cta-split .red-half{background:var(--red);color:#fff;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.cta-split h3{color:#fff;font-size:1.3rem;}
.cta-split .navy-half p{color:#D7DAF0;margin-top:8px;}
.cta-split .call-line{display:flex;align-items:center;gap:12px;}
.cta-split .call-line .ico{
  width:46px;height:46px;border-radius:50%;background:#fff;color:var(--red);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.2rem;
}
.cta-split .call-line strong{font-family:'Oswald',sans-serif;font-size:1.3rem;display:block;}
.cta-split .call-line small{font-size:0.78rem;text-transform:uppercase;letter-spacing:0.05em;}

/* ---------- Contact / quote form (used on services/home) ---------- */
.ticket{border:1px solid var(--line);background:#fff;border-radius:var(--radius);padding:34px;}
.ticket h3{font-size:1.2rem;margin-bottom:22px;}
.field{margin-bottom:16px;}
.field label{display:block;font-family:'Oswald',sans-serif;font-size:0.72rem;text-transform:uppercase;letter-spacing:0.06em;color:var(--ink-soft);margin-bottom:6px;}
.field input,.field textarea{
  width:100%;background:var(--bg-soft);border:1px solid var(--line);border-radius:4px;
  padding:12px 14px;color:var(--ink);font-family:'Inter',sans-serif;font-size:0.92rem;
}
.field input:focus,.field textarea:focus{border-color:var(--red);outline:none;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.contact-info{display:flex;flex-direction:column;gap:24px;justify-content:center;}
.contact-info .row{display:flex;gap:14px;align-items:flex-start;}
.contact-info .ico{
  width:36px;height:36px;border-radius:50%;background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:0.85rem;
}
.contact-info h4{font-size:0.98rem;margin-bottom:3px;color:var(--navy);}
.contact-info p,.contact-info a{color:var(--ink-soft);font-size:0.9rem;}

/* ---------- Footer ---------- */
footer{background:var(--navy);color:#D7DAF0;padding-top:56px;}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:36px;padding-bottom:36px;}
.footer-grid h4{color:#fff;font-size:0.92rem;margin-bottom:16px;letter-spacing:0.04em;}
.footer-grid li{padding:5px 0;font-size:0.88rem;}
.footer-grid li a:hover{color:var(--red);}
.footer-brand .logo{margin-bottom:2px;}
.footer-brand p{font-size:0.86rem;margin-top:12px;max-width:260px;color:#B7BBDD;}
.footer-social{display:flex;gap:10px;margin-top:16px;}
.footer-social a{
  width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,0.1);
  display:flex;align-items:center;justify-content:center;transition:background .2s;
}
.footer-social a:hover{background:var(--red);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.12);padding:18px 0;text-align:center;font-size:0.8rem;color:#9FA4CC;}

/* ---------- WhatsApp float ---------- */
.wa-float{
  position:fixed;bottom:26px;right:26px;width:56px;height:56px;background:#25D366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(0,0,0,0.25);z-index:60;
  transition:transform .2s;
}
.wa-float:hover{transform:scale(1.08);}

@media (max-width:900px){
  nav.primary-nav ul{display:none;}
  .hero-grid,.about-grid,.areas-grid,.mv-grid,.service-cards{grid-template-columns:1fr;}
  .icon-card-grid{grid-template-columns:repeat(2,1fr);}
  .process-row,.values-row,.gallery-grid,.footer-grid{grid-template-columns:repeat(2,1fr);}
  .cta-split,.cta-split .red-half{grid-template-columns:1fr;}
  .feature-check{grid-template-columns:1fr;}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *{transition:none !important;animation:none !important;}
}

/* ================= ANIMATIONS ================= */

@keyframes fadeUp{
  from{opacity:0;transform:translateY(28px);}
  to{opacity:1;transform:translateY(0);}
}
@keyframes fadeIn{
  from{opacity:0;}
  to{opacity:1;}
}
@keyframes floatY{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-8px);}
}
@keyframes pulseRing{
  0%{box-shadow:0 0 0 0 rgba(226,35,26,0.35);}
  70%{box-shadow:0 0 0 10px rgba(226,35,26,0);}
  100%{box-shadow:0 0 0 0 rgba(226,35,26,0);}
}
@keyframes sparkPop{
  0%,100%{opacity:0.55;transform:scale(0.9);}
  50%{opacity:1;transform:scale(1.15);}
}

/* Scroll-reveal: elements start hidden, JS adds .is-visible when scrolled into view */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease, transform .7s ease;}
.reveal.is-visible{opacity:1;transform:translateY(0);}
.reveal-stagger.is-visible > *{animation:fadeUp .6s ease both;}
.reveal-stagger.is-visible > *:nth-child(1){animation-delay:.02s;}
.reveal-stagger.is-visible > *:nth-child(2){animation-delay:.10s;}
.reveal-stagger.is-visible > *:nth-child(3){animation-delay:.18s;}
.reveal-stagger.is-visible > *:nth-child(4){animation-delay:.26s;}
.reveal-stagger.is-visible > *:nth-child(5){animation-delay:.34s;}
.reveal-stagger.is-visible > *:nth-child(6){animation-delay:.42s;}
.reveal-stagger.is-visible > *:nth-child(7){animation-delay:.50s;}
.reveal-stagger.is-visible > *:nth-child(8){animation-delay:.58s;}

/* Hero entrance (plays immediately on load, no scroll trigger needed) */
.hero-enter{animation:fadeUp .8s ease both;}
.hero-enter.hero-enter-img{animation:fadeIn 1s ease .15s both;}

/* Card lift on hover */
.icon-card,.service-card,.mv-card,.material-swatch{
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.icon-card:hover,.service-card:hover,.mv-card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 32px rgba(11,20,64,0.12);
}
.section-navy .icon-card:hover{
  box-shadow:0 16px 32px rgba(0,0,0,0.28);
  border-color:rgba(255,255,255,0.3);
}

/* Icon circle: subtle pulse ring on hover */
.icon-circle{transition:transform .25s ease;}
.icon-card:hover .icon-circle,.values-row > div:hover .icon-circle{
  transform:scale(1.08);
  animation:pulseRing 1.4s ease-out infinite;
}

/* Buttons: existing translateY hover kept, add subtle press feedback */
.btn:active{transform:translateY(1px) scale(0.98);}

/* Gallery + service card photos: soft zoom on hover */
.gallery-grid figure .photo,.service-card .photo{overflow:hidden;}
.gallery-grid figure .photo img,.service-card .photo img{transition:transform .5s ease;}
.gallery-grid figure:hover .photo img,.service-card:hover .photo img{transform:scale(1.08);}

/* WhatsApp float: gentle idle float + entrance */
.wa-float{animation:floatY 3s ease-in-out infinite;}

/* FAQ open/close smoothness */
.faq-item p{animation:fadeIn .35s ease both;}

/* Curve divider: slight parallax-style fade on load */
.curve svg{animation:fadeIn 1s ease both;}
