/* ============================================================
   ASL Website – Custom Stylesheet
   Absolute Solutions Limited
   ============================================================ */

/* ── CSS Variables ─────────────────────────────────────────── */
:root {
  --asl-primary:    #0d6efd;
  --asl-dark:       #0a1628;
  --asl-navy:       #0d2149;
  --asl-accent:     #fd7e14;
  --asl-light-bg:   #f8f9fa;
  --asl-text:       #212529;
  --asl-muted:      #6c757d;
  --asl-border:     #dee2e6;
  --asl-white:      #ffffff;
  --asl-success:    #198754;
  --border-radius:  0.5rem;
  --shadow-sm:      0 2px 8px rgba(0,0,0,.08);
  --shadow-md:      0 4px 20px rgba(0,0,0,.12);
  --shadow-lg:      0 8px 40px rgba(0,0,0,.16);
  --transition:     all .3s ease;
}

/* ── Global ────────────────────────────────────────────────── */
* { box-sizing: border-box; }

body {
  font-family: 'Segoe UI', -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--asl-text);
  background: var(--asl-white);
  line-height: 1.7;
}

a { text-decoration: none; transition: var(--transition); }
a:hover { color: var(--asl-primary); }

img { max-width: 100%; height: auto; }

h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
  line-height: 1.3;
  color: var(--asl-dark);
}

.section-padding { padding: 80px 0; }
.section-padding-sm { padding: 50px 0; }

/* ── Top Bar ───────────────────────────────────────────────── */
.topbar {
  background: #060d18;
  border-bottom: 1px solid rgba(255,255,255,.06);
  padding: 7px 0;
  font-size: 0.82rem;
}
.topbar-item {
  color: rgba(255,255,255,.65);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  transition: var(--transition);
  white-space: nowrap;
}
.topbar-item i { color: var(--asl-accent); font-size: 0.85rem; }
a.topbar-item:hover { color: var(--asl-white); }
.topbar-social-btn {
  width: 28px; height: 28px;
  background: rgba(255,255,255,.08);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.65);
  font-size: 0.78rem;
  text-decoration: none;
  transition: var(--transition);
}
.topbar-social-btn:hover { background: var(--asl-primary); color: var(--asl-white); }
.topbar-whatsapp:hover  { background: #25d366 !important; }

/* ── Navbar ────────────────────────────────────────────────── */
.navbar-asl {
  background: var(--asl-dark) !important;
  padding: 12px 0;
  transition: var(--transition);
  box-shadow: 0 2px 10px rgba(0,0,0,.3);
}
.navbar-asl.scrolled {
  padding: 8px 0;
  box-shadow: var(--shadow-md);
}
.navbar-asl .navbar-brand img {
  height: 42px;
}
.navbar-asl .navbar-brand .brand-text {
  color: var(--asl-white);
  font-weight: 700;
  font-size: 1.1rem;
  line-height: 1.2;
}
.navbar-asl .navbar-brand .brand-tagline {
  color: rgba(255,255,255,.65);
  font-size: 0.7rem;
  letter-spacing: 0.05em;
}
.navbar-asl .nav-link {
  color: rgba(255,255,255,.85) !important;
  font-weight: 500;
  padding: 8px 14px !important;
  border-radius: var(--border-radius);
  transition: var(--transition);
  font-size: 0.9rem;
}
.navbar-asl .nav-link:hover,
.navbar-asl .nav-link.active {
  color: var(--asl-white) !important;
  background: rgba(255,255,255,.1);
}
.navbar-asl .btn-consultation {
  background: var(--asl-accent);
  color: var(--asl-white) !important;
  border: none;
  padding: 8px 18px !important;
  font-weight: 600;
  border-radius: var(--border-radius);
}
.navbar-asl .btn-consultation:hover {
  background: #e8700f;
  transform: translateY(-1px);
}

/* ── Page Hero ─────────────────────────────────────────────── */
.page-hero {
  background: linear-gradient(135deg, var(--asl-dark) 0%, var(--asl-navy) 100%);
  color: var(--asl-white);
  padding: 80px 0 60px;
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><circle cx="80" cy="20" r="30" fill="rgba(255,255,255,0.03)"/><circle cx="20" cy="80" r="40" fill="rgba(255,255,255,0.02)"/></svg>');
  background-size: cover;
}
.page-hero h1 { color: var(--asl-white); font-size: 2.5rem; }
.page-hero .lead { color: rgba(255,255,255,.8); font-size: 1.1rem; }
.page-hero .breadcrumb-item,
.page-hero .breadcrumb-item a { color: rgba(255,255,255,.7); }
.page-hero .breadcrumb-item.active { color: var(--asl-accent); }
.page-hero .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,.4); }

/* ── Home Hero ─────────────────────────────────────────────── */
.hero-section {
  background: linear-gradient(135deg, var(--asl-dark) 0%, var(--asl-navy) 60%, #1a3a6e 100%);
  min-height: 90vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  overflow: hidden;
}
.hero-section::before {
  content: '';
  position: absolute;
  top: -50%; right: -20%;
  width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(13,110,253,.2) 0%, transparent 70%);
}
.hero-section::after {
  content: '';
  position: absolute;
  bottom: -30%; left: -10%;
  width: 400px; height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(253,126,20,.1) 0%, transparent 70%);
}
.hero-section .hero-content { position: relative; z-index: 2; }
.hero-section h1 {
  color: var(--asl-white);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 800;
  line-height: 1.2;
}
.hero-section h1 span { color: var(--asl-accent); }
.hero-section .lead {
  color: rgba(255,255,255,.8);
  font-size: 1.15rem;
  max-width: 560px;
}
.hero-badge {
  display: inline-block;
  background: rgba(253,126,20,.2);
  border: 1px solid rgba(253,126,20,.4);
  color: var(--asl-accent);
  padding: 6px 16px;
  border-radius: 50px;
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: 16px;
}
.hero-stats {
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
  margin-top: 32px;
}
.hero-stat-item .stat-num {
  font-size: 2rem;
  font-weight: 800;
  color: var(--asl-white);
  line-height: 1;
}
.hero-stat-item .stat-label {
  color: rgba(255,255,255,.6);
  font-size: 0.8rem;
}

/* ── Hero Carousel ─────────────────────────────────────────── */
.hero-carousel { width: 100%; position: relative; z-index: 2; }
.hero-carousel .carousel-item { padding: 70px 0 50px; }

.hero-visual-card {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 1rem;
  padding: 32px;
}
.hero-visual-icon {
  font-size: 5rem;
  color: rgba(255,255,255,.15);
  display: block;
}
.hero-mini-card {
  background: rgba(255,255,255,.08);
  border-radius: .5rem;
  padding: 16px;
  text-align: center;
}
.hero-mini-card i { font-size: 1.5rem; }
.hero-mini-card div { color: #fff; font-size: .8rem; margin-top: 6px; }

/* indicators — inside carousel, above overflow boundary */
.hero-indicators { bottom: 16px; z-index: 10; }
.hero-indicators [data-bs-target] {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,.4);
  border: none;
  transition: var(--transition);
}
.hero-indicators .active { background: var(--asl-accent); transform: scale(1.3); }

/* prev/next — let Bootstrap handle top/bottom centering, just style the icon */
.hero-ctrl { width: 56px; opacity: 1; }
.hero-ctrl-icon {
  width: 44px; height: 44px;
  background: rgba(255,255,255,.12);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--asl-white);
  font-size: 1.1rem;
  transition: var(--transition);
  border: 1px solid rgba(255,255,255,.2);
}
.hero-ctrl:hover .hero-ctrl-icon { background: var(--asl-accent); border-color: var(--asl-accent); }
.carousel-control-prev.hero-ctrl { left: 8px; }
.carousel-control-next.hero-ctrl { right: 8px; }

/* stats bar */
.hero-stats-bar { position: relative; z-index: 2; padding: 8px 0 44px; }

@media (max-width: 768px) {
  .hero-carousel .carousel-item { padding: 50px 0 30px; }
  .hero-ctrl { display: none; }
}

/* ── Section Headers ───────────────────────────────────────── */
.section-header { margin-bottom: 48px; }
.section-header .subtitle {
  color: var(--asl-primary);
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.section-header h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); }
.section-header .divider {
  width: 60px; height: 4px;
  background: var(--asl-accent);
  border-radius: 2px;
  margin: 16px 0;
}
.section-header.text-center .divider { margin: 16px auto; }

/* ── Service Cards ─────────────────────────────────────────── */
.service-card {
  background: var(--asl-white);
  border: 1px solid var(--asl-border);
  border-radius: var(--border-radius);
  padding: 32px 24px;
  height: 100%;
  transition: var(--transition);
  position: relative;
  overflow: hidden;
}
.service-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
  border: 1px solid var(--asl-primary);
}
.service-card .service-icon {
  width: 64px; height: 64px;
  background: rgba(13,110,253,.1);
  border-radius: var(--border-radius);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.8rem;
  color: var(--asl-primary);
  margin-bottom: 20px;
  transition: var(--transition);
}
.service-card:hover .service-icon {
  background: var(--asl-primary);
  color: var(--asl-white);
}
.service-card h5 { font-weight: 700; margin-bottom: 12px; }
.service-card p { color: var(--asl-muted); font-size: 0.92rem; }

/* ── Portfolio Cards ───────────────────────────────────────── */
.portfolio-card {
  border-radius: var(--border-radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: var(--transition);
  background: var(--asl-white);
}
.portfolio-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-4px);
}
.portfolio-card .portfolio-img {
  height: 220px;
  object-fit: cover;
  width: 100%;
  background: linear-gradient(135deg, #1a3a6e, #0d6efd);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.3);
  font-size: 4rem;
}
.portfolio-card .card-body { padding: 24px; }
.portfolio-card .category-badge {
  display: inline-block;
  background: rgba(13,110,253,.1);
  color: var(--asl-primary);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 4px 12px;
  border-radius: 50px;
  margin-bottom: 12px;
}

/* ── Testimonials ──────────────────────────────────────────── */
.testimonial-card {
  background: var(--asl-white);
  border: 1px solid var(--asl-border);
  border-radius: var(--border-radius);
  padding: 32px;
  height: 100%;
  position: relative;
}
.testimonial-card::before {
  content: '"';
  position: absolute;
  top: 16px; left: 24px;
  font-size: 5rem;
  color: var(--asl-primary);
  opacity: 0.15;
  font-family: Georgia, serif;
  line-height: 1;
}
.testimonial-card .stars { color: #ffc107; font-size: 0.9rem; margin-bottom: 12px; }
.testimonial-card .testimonial-text {
  color: var(--asl-text);
  font-style: italic;
  margin-bottom: 20px;
  line-height: 1.8;
}
.testimonial-card .client-photo {
  width: 50px; height: 50px;
  border-radius: 50%;
  background: var(--asl-primary);
  display: flex; align-items: center; justify-content: center;
  color: var(--asl-white);
  font-weight: 700;
  font-size: 1.1rem;
  margin-right: 12px;
  flex-shrink: 0;
}
.testimonial-card .client-name { font-weight: 700; font-size: 0.95rem; }
.testimonial-card .client-company { color: var(--asl-muted); font-size: 0.83rem; }

/* ── Stats ─────────────────────────────────────────────────── */
.stats-section {
  background: linear-gradient(135deg, var(--asl-primary), var(--asl-navy));
  color: var(--asl-white);
  padding: 60px 0;
}
.stat-box { text-align: center; padding: 20px; }
.stat-box .stat-number {
  font-size: 3rem;
  font-weight: 800;
  color: var(--asl-white);
  line-height: 1;
  display: block;
}
.stat-box .stat-label {
  color: rgba(255,255,255,.75);
  font-size: 0.9rem;
  margin-top: 8px;
}
.stat-box .stat-icon {
  font-size: 2rem;
  margin-bottom: 8px;
  color: rgba(255,255,255,.7);
}

/* ── CTA Sections ──────────────────────────────────────────── */
.cta-section {
  background: linear-gradient(135deg, var(--asl-accent), #e8700f);
  color: var(--asl-white);
  padding: 70px 0;
}
.cta-section h2, .cta-section h3 { color: var(--asl-white); }
.cta-section .lead { color: rgba(255,255,255,.9); }
.cta-dark {
  background: linear-gradient(135deg, var(--asl-dark), var(--asl-navy));
  color: var(--asl-white);
  padding: 70px 0;
}
.cta-dark h2, .cta-dark h3 { color: var(--asl-white); }

/* ── Buttons ───────────────────────────────────────────────── */
.btn-asl-primary {
  background: var(--asl-primary);
  color: var(--asl-white);
  border: none;
  padding: 12px 28px;
  border-radius: var(--border-radius);
  font-weight: 600;
  transition: var(--transition);
}
.btn-asl-primary:hover {
  background: #0b5ed7;
  color: var(--asl-white);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(13,110,253,.4);
}
.btn-asl-accent {
  background: var(--asl-accent);
  color: var(--asl-white);
  border: none;
  padding: 12px 28px;
  border-radius: var(--border-radius);
  font-weight: 600;
  transition: var(--transition);
}
.btn-asl-accent:hover {
  background: #e8700f;
  color: var(--asl-white);
  transform: translateY(-2px);
}
.btn-asl-outline {
  border: 2px solid var(--asl-white);
  color: var(--asl-white);
  background: transparent;
  padding: 12px 28px;
  border-radius: var(--border-radius);
  font-weight: 600;
  transition: var(--transition);
}
.btn-asl-outline:hover {
  background: var(--asl-white);
  color: var(--asl-dark);
}

/* ── Forms ─────────────────────────────────────────────────── */
.form-control, .form-select {
  border: 1.5px solid var(--asl-border);
  border-radius: var(--border-radius);
  padding: 10px 16px;
  font-size: 0.95rem;
  transition: var(--transition);
}
.form-control:focus, .form-select:focus {
  border-color: var(--asl-primary);
  box-shadow: 0 0 0 3px rgba(13,110,253,.15);
}
.form-label { font-weight: 600; font-size: 0.9rem; margin-bottom: 6px; }

/* ── FAQ Accordion ─────────────────────────────────────────── */
.faq-accordion .accordion-button {
  font-weight: 600;
  background: var(--asl-white);
  color: var(--asl-dark);
}
.faq-accordion .accordion-button:not(.collapsed) {
  background: rgba(13,110,253,.06);
  color: var(--asl-primary);
  box-shadow: none;
}
.faq-accordion .accordion-button::after {
  filter: none;
}
.faq-accordion .accordion-item {
  border: 1px solid var(--asl-border);
  border-radius: var(--border-radius) !important;
  margin-bottom: 12px;
  overflow: hidden;
}

/* ── Why Choose Us ─────────────────────────────────────────── */
.why-item {
  display: flex;
  gap: 16px;
  margin-bottom: 24px;
}
.why-icon {
  width: 48px; height: 48px;
  background: rgba(13,110,253,.1);
  border-radius: var(--border-radius);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem;
  color: var(--asl-primary);
  flex-shrink: 0;
}
.why-text h6 { font-weight: 700; margin-bottom: 4px; }
.why-text p { color: var(--asl-muted); font-size: 0.88rem; margin: 0; }

/* ── News Cards ────────────────────────────────────────────── */
.news-card {
  border: 1px solid var(--asl-border);
  border-radius: var(--border-radius);
  overflow: hidden;
  transition: var(--transition);
  height: 100%;
  background: var(--asl-white);
}
.news-card:hover { box-shadow: var(--shadow-md); transform: translateY(-4px); }
.news-card .news-img {
  height: 200px;
  object-fit: cover;
  width: 100%;
  background: linear-gradient(135deg, var(--asl-navy), var(--asl-primary));
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.3);
  font-size: 3rem;
}
.news-card .card-body { padding: 24px; }
.news-card .news-date { color: var(--asl-muted); font-size: 0.83rem; }
.news-card .news-category {
  background: rgba(13,110,253,.1);
  color: var(--asl-primary);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 50px;
}
.news-card h5 { font-weight: 700; margin: 12px 0 8px; font-size: 1rem; }
.news-card h5 a { color: var(--asl-dark); }
.news-card h5 a:hover { color: var(--asl-primary); }

/* ── Contact Section ───────────────────────────────────────── */
.contact-info-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 28px;
}
.contact-icon {
  width: 52px; height: 52px;
  background: rgba(13,110,253,.1);
  border-radius: var(--border-radius);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem;
  color: var(--asl-primary);
  flex-shrink: 0;
}
.contact-info-item h6 { font-weight: 700; margin-bottom: 4px; }
.contact-info-item p { color: var(--asl-muted); margin: 0; font-size: 0.9rem; }

/* ── Timeline ──────────────────────────────────────────────── */
.timeline { position: relative; padding-left: 32px; }
.timeline::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(to bottom, var(--asl-primary), var(--asl-accent));
  border-radius: 2px;
}
.timeline-item {
  position: relative;
  margin-bottom: 32px;
}
.timeline-item::before {
  content: '';
  position: absolute;
  left: -38px; top: 6px;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--asl-primary);
  border: 3px solid var(--asl-white);
  box-shadow: 0 0 0 3px var(--asl-primary);
}
.timeline-year {
  font-weight: 800;
  color: var(--asl-primary);
  font-size: 0.85rem;
  margin-bottom: 4px;
}
.timeline-title { font-weight: 700; margin-bottom: 6px; }
.timeline-desc { color: var(--asl-muted); font-size: 0.9rem; }

/* ── Footer ────────────────────────────────────────────────── */
.footer-main {
  background: var(--asl-dark);
  color: rgba(255,255,255,.8);
  padding: 60px 0 40px;
}
.footer-main h5 {
  color: var(--asl-white);
  font-weight: 700;
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 2px solid rgba(255,255,255,.1);
}
.footer-main .footer-links { list-style: none; padding: 0; }
.footer-main .footer-links li { margin-bottom: 8px; }
.footer-main .footer-links a {
  color: rgba(255,255,255,.65);
  font-size: 0.9rem;
  transition: var(--transition);
}
.footer-main .footer-links a:hover {
  color: var(--asl-accent);
  padding-left: 4px;
}
.footer-contact-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  margin-bottom: 12px;
  font-size: 0.88rem;
  color: rgba(255,255,255,.65);
}
.footer-contact-item i { color: var(--asl-accent); font-size: 1rem; margin-top: 2px; flex-shrink: 0; }
.footer-social a {
  width: 36px; height: 36px;
  background: rgba(255,255,255,.1);
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.7);
  font-size: 0.9rem;
  margin-right: 8px;
  transition: var(--transition);
}
.footer-social a:hover {
  background: var(--asl-primary);
  color: var(--asl-white);
}
.footer-bottom {
  background: #060d18;
  color: rgba(255,255,255,.5);
  padding: 16px 0;
  font-size: 0.85rem;
}

/* ── Alerts ────────────────────────────────────────────────── */
.alert { border-radius: var(--border-radius); border: none; }
.alert-success { background: rgba(25,135,84,.12); color: #0f5132; }
.alert-danger  { background: rgba(220,53,69,.12); color: #842029; }

/* ── Breadcrumb ────────────────────────────────────────────── */
.breadcrumb { margin: 0; background: none; }
.breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,.4); }

/* ── Process Steps ─────────────────────────────────────────── */
.process-step {
  text-align: center;
  padding: 24px 16px;
  position: relative;
}
.process-number {
  width: 56px; height: 56px;
  background: var(--asl-primary);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--asl-white);
  margin: 0 auto 16px;
}
.process-step h6 { font-weight: 700; margin-bottom: 8px; }
.process-step p { color: var(--asl-muted); font-size: 0.88rem; }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 768px) {
  .section-padding { padding: 50px 0; }
  .hero-section { min-height: auto; padding: 0; }
  .hero-stats { gap: 20px; }
  .page-hero { padding: 60px 0 40px; }
  .page-hero h1 { font-size: 1.8rem; }
  .stat-box .stat-number { font-size: 2.2rem; }
}

/* ── Animations ────────────────────────────────────────────── */
.fade-in-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity .6s ease, transform .6s ease;
}
.fade-in-up.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Misc ──────────────────────────────────────────────────── */
.text-accent { color: var(--asl-accent) !important; }
.bg-dark-navy { background: var(--asl-navy); }
.bg-dark-main { background: var(--asl-dark); }
.feature-list { list-style: none; padding: 0; }
.feature-list li {
  padding: 5px 0;
  padding-left: 24px;
  position: relative;
  color: var(--asl-muted);
  font-size: 0.9rem;
}
.feature-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--asl-success);
  font-weight: 700;
}
.back-to-top {
  position: fixed;
  bottom: 24px; right: 24px;
  width: 44px; height: 44px;
  background: var(--asl-primary);
  color: var(--asl-white);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: var(--shadow-md);
  opacity: 0;
  pointer-events: none;
  transition: var(--transition);
  z-index: 9999;
  cursor: pointer;
  border: none;
}
.back-to-top.visible {
  opacity: 1;
  pointer-events: all;
}
