:root {
--brand-orange: #f16622;
--bg-main: #0d0d0d;   /* Main Off-Black */
--bg-alt: #212934;/* Deep Blue-Grey */
--text-main: #ffffff;
--text-muted: #A9A9A9;
}

* {
margin: 0;
padding: 0;
box-sizing: border-box;
}

body {
font-family: 'Open Sans', sans-serif;
background-color: var(--bg-main);
color: var(--text-main);
overflow-x: hidden;
}

a {
  color: #fff;
  text-decoration: underline;
}

a:hover {
color:darkgrey !important;
}

.border-primary {
border-color: #f16622 !important;
}

.btn-primary {
color: #fff;
background-color: #f16622;
border-color: #fff;
}

.text-orange {
color: #f16622 !important;
}

.btn-primary:hover {
color: #f16622;
background-color: #fff;
border-color: #f16622;
}

/* --- Utility Classes --- */
.bg-main {
background-color: var(--bg-main);
}

.vgrey {
background-color: var(--bg-alt);
color: var(--text-main);
}

.brand-orange-text {
color: var(--brand-orange);
}

.alt-bgrey {
background-color: #191919;
}

.txt-ltg {
color: #A9A9A9;
}
.txt-smlmed {
font-size: 0.75rem;
}
img {
width:100%;
height: auto;
}
.iorange {
font-style:italic;
color:#f16622;
}

.text-muted {
  color: #999 !important;
}

.clearit {
  clear: both;
  height: 0;
  line-height: 0.0;
  font-size: 0;
}

.l1space {
letter-spacing: 1px;
}

.greenBg {
background: rgba(76, 175, 80, 0.08); 
border: 1px solid rgba(76, 175, 80, 0.3);
}
/* --- Navigation --- */
.navbar {
padding: 1rem 0;
position: fixed;
top: 0;
width: 100%;
z-index: 1000;
background-color: var(--bg-main);
transition: background-color 0.4s ease, padding 0.4s ease;
   /* background-color: transparent;*/
box-shadow: 0 0 2px #1a1a1a;
border: 2px solid #292929;
}

.navbar.scrolled {
background-color: var(--bg-main);
padding: 0.5rem 0;
box-shadow: 0 2px 10px rgba(0,0,0,0.5);
}

.navbar-brand img {
height: 40px;
width: auto;
transition: height 0.3s ease;
}

.navbar.scrolled .navbar-brand img {
height: 35px;
}

.navbar-toggler {
border: none;
padding: 0.5rem;
}

.navbar-toggler:focus {
box-shadow: none;
}

/* Custom Hamburger Icon (Soft White) */
.navbar-toggler-icon {
background-image: url("../images/global/hamburger.svg");
}

.navbar-nav .nav-link {
color: #999;
font-size: .875rem;
line-height: 1.42857em;
padding: 9px 19px;
margin:0 10px;
transition: color 0.3s ease;
}

.navbar-nav .nav-link:hover {
color: #fff;
border-radius: 8px;
font-size: .875rem;
text-decoration: none;
position: relative;
overflow: hidden;
box-shadow: 0 0 12px rgba(241,102,34,0.55);
}


/* Active Link Styling */
.navbar-nav .nav-link.active-link {
    color: #fff !important;
    border-radius: 8px;
    box-shadow: 0 0 12px rgba(241, 102, 34, 0.55); /* Brand Orange Glow */
    border-bottom: 1px solid var(--brand-orange);
}

/* Ensure the contact button still looks like a button even when active */
.btn-contact.active-link {
    background-image: linear-gradient(#d1581d, #55220a) !important;
    border-bottom: none !important;
}

/* Mobile Menu Background (Now applies to all sizes) */
.navbar-collapse {
background-color: var(--bg-main);
}

 /* --- HERO SECTION CUSTOM STYLES --- */
.hero-bs {
position: relative;
display: flex;
align-items: center;
background-repeat: no-repeat;
object-fit: cover;
   /* The ISBS Glow */
/* background: radial-gradient(circle at 75% 40%, rgba(241, 102, 34, 0.08) 0%, rgba(0,0,0,0) 60%);*/
margin-top: 40px;
}
.hero-px {
/* The ISBS Glow */
/*background: radial-gradient(circle at 75% 40%, rgba(241, 102, 34, 0.08) 0%, rgba(0,0,0,0) 60%);*/
background-image: url("../images/bg/isbs.jpg");
background-repeat: no-repeat;
object-fit: cover;
/*margin-top: 80px;
min-height: 700px;*/
}
.hero-pxx {
/*background: radial-gradient(circle at 75% 40%, rgba(241, 102, 34, 0.08) 0%, rgba(0,0,0,0) 60%);*/
background-image: url("../images/bg/isbs-websites-and-ai.webp");
background-repeat: no-repeat;
object-fit: cover;
margin-top: 80px;
}
.hero-sx {
background-image: url("../images/bg/isbs-expertise.webp");
background-repeat: no-repeat;
margin-top: 80px;
}
.hero-ax {
background-image: url("../images/bg/isbs-ai.webp");
background-repeat: no-repeat;
margin-top: 80px;
}
.hero-xx {
background-image: url("../images/bg/isbs-porto.webp");
background-repeat: no-repeat;
margin-top: 80px;
padding-bottom: 50px;
}
.hero-tx {
background-image: url("../images/testimonials/isbs-testimonials.jpg");
background-repeat: no-repeat;
object-fit: cover;
height: 100%;
width: 100%;
margin-top: 80px;
min-height: 700px;
}
/*.gradient-background {
background: linear-gradient(224deg,#f16622,#0d0d0d,#0d0d0d,#0d0d0d);
background: radial-gradient(circle at 75% 40%, rgba(241, 102, 34, 0.08) 0%, rgba(0,0,0,0) 60%);
background-size: 300% 300%;
animation: gradient-animation 16s ease infinite;
}*/

@keyframes gradient-animation {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}
/* Text Styling */
.hero-title {
font-size: 3rem; /* Mobile default */
font-weight: 700;
line-height: 1.1;
}

.italic-highlight {
font-style: italic;
color: #f7f8f8cc;
text-shadow: 0px 0px 30px rgba(241, 102, 34, 0.2);
}

.hd-highlight {
/*color: #f7f8f8cc;*/
color: #f16622;
text-shadow: 0px 0px 30px rgba(241, 102, 34, 0.5);
}
.hero-desc {
color: #dcdcdc;
font-size: 1.1rem;
line-height: 1.7;
}

.btn-isbs-primary {
background-color: #1a1a1a; 
color: #fff !important;
text-align: center;
background-image: radial-gradient(circle at 30% 10%, #ffffff1a, #0000), linear-gradient(#31353f, #1b1c1f);
border-radius: 8px;
padding: 9px 19px;
font-size: .875rem;
line-height: 1.42857em;
text-decoration: none;
box-shadow: 0 0 12px rgba(255,255,255,0.05);
position: relative;
overflow: hidden;
background: radial-gradient(89.39% 89.39% at 50% 50%, rgba(16, 18, 21, .1) 0, hsla(0, 0%, 100%, .15) 100%);
border: 1px solid rgba(255, 255, 255, 0.08);
}

.btn-isbs-primary:hover {
background-image: radial-gradient(circle at 30% 10%, #ffffff1a, #0000), linear-gradient(#31353f, #1b1c1f);
background-color: #f16622;/* brand orange */
box-shadow: 0 0 12px rgba(241,102,34,0.55);
color: var(--brand-orange);
}
.btn-isbs-outline {
color: white;
border-color: rgba(255,255,255,0.3);
font-weight: 600;
padding: 12px 30px;
background-color: #1A1A1A;
transition: all 0.3s ease;
}

.btn-isbs-outline:hover {
/*background-image: radial-gradient(circle at 20% 10%, #ffffff1a, #0000), linear-gradient(#1a1a1a, #292929);*/
background-color: #f16622;/* brand orange */
box-shadow: 0 0 12px rgba(241,102,34,0.55);
color: #fff;
border:1px solid white;
}

.btn-isbs-outline:visited {
color: white;
border-color: rgba(255,255,255,0.3);
font-weight: 600;
padding: 12px 30px;
background: transparent;
transition: all 0.3s ease;
}
/* --- DASHBOARD VISUAL (Keep this custom CSS) --- */
.dashboard-wrapper {
position: relative;
width: 100%; /* Adapts to col size */
/*max-width: 500px;*/
height: 550px; /* Fixed height for the art */
perspective: 1000px;
margin: 0 auto; /* Center in column */
}

/* Animations */
@keyframes float {
0% { transform: translateY(0px) rotateY(-5deg); }
50% { transform: translateY(-10px) rotateY(-5deg); }
100% { transform: translateY(0px) rotateY(-5deg); }
}



/* Chart SVG Styling */
.chart-svg { width: 100%; height: 70%; overflow: visible; }
.chart-line { fill: none; stroke: #f16622; stroke-width: 3; stroke-linecap: round; filter: drop-shadow(0px 4px 6px rgba(241, 102, 34, 0.4)); }
.chart-fill { fill: rgba(241, 102, 34, 0.1); stroke: none; }
.stat { font-size: 1.8rem; font-weight: 700; color: white; }
.stat span { color: #f16622; font-size: 1rem; margin-left: 10px; }
.label { font-size: 0.75rem; color: #888; letter-spacing: 1px; font-weight: 600; display: block; margin-bottom: 5px;}

/* Floating Cards */
.card-seo {
display:none;
width: 160px; height: 80px; bottom: 20px; left: 0; z-index: 2;
transform: rotateY(-5deg); animation: float 6s ease-in-out infinite; animation-delay: 1s;
}
.card-social {
display:none;
width: 190px; height: 90px; bottom: 50px; right: -20px; z-index: 3;
background: rgba(40, 40, 40, 0.8);
transform: rotateY(-5deg); animation: float 6s ease-in-out infinite; animation-delay: 2s;
}
.badge-orange { background: rgba(241, 102, 34, 0.2); color: #f16622; padding: 3px 8px; border-radius: 4px; font-size: 0.7rem; font-weight: 700; }

/* TYPOGRAPHY */
.font-playfair { font-family: 'Playfair Display', serif; }
.text-orange { color: #f16622; }

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

.wind-powered-sml {
height: 100px;
width:100px;
}
/* LEFT SIDE STYLING */
.experience-number {
font-size: 5rem;
font-weight: 700;
line-height: 1;
background: linear-gradient(180deg, #fff 20%, #666 100%);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
margin-bottom: 20px;
}

.lead-text {
font-size: 1.25rem;
color: #e0e0e0;
font-weight: 300;
line-height: 1.6;
border-left: 3px solid #f16622;
padding-left: 20px;
}

.secondary-text {
color: #999;
font-size: 1rem;
margin-top: 30px;
}

   
   /* RIGHT SIDE "FLASHY" CARDS */
.feature-card {
background: rgba(255, 255, 255, 0.03);
border: 1px solid rgba(255, 255, 255, 0.1);
padding: 30px;
margin-bottom: 20px;
border-radius: 12px;
position: relative;
overflow: hidden;
transition: all 0.3s ease;
}

.feature-card:hover {
background: rgba(255, 255, 255, 0.07);
border-color: #f16622;
transform: translateY(-5px);
box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

/* A little glow effect on hover */
.feature-card::before {
content: '';
position: absolute;
top: 0; left: 0; width: 4px; height: 100%;
background: #f16622;
opacity: 0;
transition: opacity 0.3s;
}
.feature-card:hover::before { opacity: 1; }

.card-icon {
font-size: 1.5rem;
color: #f16622;
margin-bottom: 15px;
}



  /* Base Settings */
.services-section {
background-image: url("../images/bg/isbs-services.jpg");
background-repeat: no-repeat;
object-fit: cover;
padding: 50px 0;
background-color: #010101;
position: relative;
  }
  
  .font-playfair { font-family: 'Playfair Display', serif; }
  .text-orange { color: #f16622; }
  .letter-spacing-2 { letter-spacing: 2px; font-size: 0.9rem; font-weight: 600; }
  .section-title { font-size: 3rem; color: white; margin-bottom: 20px; }

  /* Card Styling */
  .service-card {
background: #111; /* Slightly lighter than body */
border: 1px solid #222;
padding: 40px;
height: 100%;
position: relative;
overflow: hidden; /* Keeps the watermark inside */
transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
z-index: 1;
  }

  /* The Hover "Pop" Effect */
  .service-card:hover {
transform: translateY(-10px); /* Lifts up */
border-color: #f16622; /* Orange Border */
box-shadow: 0 20px 40px rgba(0,0,0,0.5);
  }

  /* The Watermark Number (01, 02...) */
  .watermark {
position: absolute;
top: -20px;
right: -10px;
font-size: 8rem;
font-weight: 900;
color: rgba(255, 255, 255, 0.03); /* Very subtle */
font-family: 'Playfair Display', serif;
z-index: -1;
transition: all 0.4s ease;
  }

  .service-card:hover .watermark {
color: rgba(241, 102, 34, 0.1); /* Turns faint orange on hover */
transform: scale(1.1);
  }

  /* Icons */
  .icon-wrapper {
margin-bottom: 25px;
display: inline-block;
padding: 15px;
background: rgba(255,255,255,0.05);
border-radius: 50%;
transition: background 0.3s ease;
  }

.isbsmarksml {
font-size: 12rem;
opacity: 0.10;
bottom: -50px;
right: 20px;
top: auto;
color:#fff;
}

  .service-card:hover .icon-wrapper {
background: rgba(241, 102, 34, 0.2); /* Glows on hover */
  }

  /* Typography */
  .service-card h3 {
font-size: 2rem;
margin-bottom: 10px;
font-weight: 700;
  }

  .sub-head {
font-family: 'Open Sans', sans-serif;
color: #f16622;
font-size: 1rem;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 1px;
margin-bottom: 20px;
  }

  .card-text {
color: #b0b0b0;
font-family: 'Open Sans', sans-serif;
line-height: 1.7;
margin-bottom: 30px;
  }

  /* Link Styling */
  .read-more {
color: #fff;
text-decoration: none;
font-weight: 600;
font-size: 0.9rem;
border-bottom: 1px solid #f16622;
padding-bottom: 2px;
transition: color 0.3s ease;
  }
  
  .read-more:hover {
color: #f16622;
  }


  /* CTA SECTION */
  .cta-section {
padding-bottom: 100px;
background-color: #0b0b0b;
  }
  .ctax-section {
padding-bottom: 40px;
  }

  .cta-box {
background: linear-gradient(135deg, #f16622 0%, #d1440c 100%);
border-radius: 20px;
padding: 60px;
box-shadow: 0 20px 50px rgba(241, 102, 34, 0.2);
position: relative;
overflow: hidden;
  }

  /* Abstract background shapes for CTA */
  .cta-box::before {
content: '';
position: absolute;
top: -50%; left: -20%;
width: 500px; height: 500px;
background: rgba(255,255,255,0.1);
border-radius: 50%;
  }

.btn-white-glow {
position: relative; 
z-index: 10; 
background: white;
color: #f16622 !important;
font-weight: 700;
padding: 18px 40px;
border-radius: 50px;
border: none;
font-family: 'Open Sans', sans-serif;
text-transform: uppercase;
letter-spacing: 1px;
transition: all 0.3s ease;
  }

.btn-white-glow:hover {
box-shadow: 0 0 20px rgba(255,255,255,0.6);
transform: scale(1.05);
color: #f16622;
  }


/* --- Testimonials Section --- */
.quote-icon {
font-size: 5rem;
color: var(--brand-orange);
display: block;
margin-bottom: 1rem;
line-height: 1;
}

.testimonial-text {
font-family: 'Open Sans', sans-serif;
font-size: 1.25rem;
font-style: italic;
color: var(--text-main);
line-height: 1.8;
max-width: 800px;
margin: 0 auto 2rem auto;
}

.testimonial-author {
font-weight: 700;
color: #fff;
font-style: normal;
margin-bottom: 0.8rem;
}

.testimonial-role {
color: var(--text-muted);
font-size: 0.9rem;
}


/* --- Back to Top Button --- */
#btn-back-to-top {
position: fixed;
bottom: 100px;
right: 30px;
display: none;
width: 50px;
height: 50px;
border-radius: 50%;
background-color: #fff;
color: #0d0d0d;
border: none;
z-index: 1000;
padding: 0;
align-items: center;
justify-content: center;
box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.3);
transition: all 0.3s ease;
}

#btn-back-to-top i {
font-size: 1.5rem;
line-height: 50px;
}

#btn-back-to-top:hover {
background-color: #fff;
color: var(--brand-orange);
transform: translateY(-5px);
}



/* --- ISBS.CSS Additions (From previous steps) --- */

/* Typography */
.display-title-1 {
font-family: "Playfair Display", serif;
font-style: italic;
font-size: 3.5rem;
font-weight: 400;
margin-bottom: 0.5rem;
color: var(--text-main);
}

.display-title-2 {
font-family: "Playfair Display", serif;
font-style: italic;
font-size: 2.5rem; /* Used for "We Deliver..." testimonial heading */
color: var(--text-main);
}
.display-title-3 {
font-size: 3.5rem;
font-weight: 700;
margin-bottom: 0.5rem;
color: var(--text-main);
}
.display-title-4 {
font-size: 3rem;
font-weight: 700;
margin-bottom: 0.5rem;
}
.intro-lead {
font-size: 1.4rem; 
color: rgba(255, 255, 255, 0.75);
}

.sub-text-p {
font-size: 1.1rem;
color: rgba(255, 255, 255, 0.5); /* Replicating text-white-50 */
}

/* Custom Image Opacity */
.img-subtle-opacity {
opacity: 0.9;
}

/* Custom Divider */
.border-divider {
border-top: 1px solid #292929 !important;
}

/* Custom Font for Headings */
.playfair-italic-lg {
font-family: 'Playfair Display', serif;
font-style: italic;
}


/* --- Services Intro Text Styles --- */

.lead-text-white-lg {
font-size: 1.25rem;
color: var(--text-main) !important; /* Pure white for high contrast */
}

/* Services sub-section introductory text style (from text-muted lead) */
.services-sub-intro {
color: var(--text-muted) !important;
font-size: 1.15rem; /* Slightly smaller than the main lead */
}

.glass-panel {
background: rgba(255, 255, 255, 0.05);
border: 1px solid rgba(255, 255, 255, 0.08);
box-shadow: 0 20px 40px rgba(0,0,0,0.6);
border-radius: 1rem;
margin-top: 20px;
}

.section-title-underline {
position: relative;
display: inline-block;
padding-bottom: 0.5rem;
}

.section-title-underline::after {
content: "";
position: absolute;
left: 50%;
bottom: 0;
transform: translateX(-50%);
width: 80px;
height: 3px;
background-color: var(--brand-orange);
border-radius: 2px;
}

.icon-glow i {
position: relative;
z-index: 2;
}

.icon-glow::before {
content: "";
position: absolute;
top: 50%;
left: 50%;
width: 70px;
height: 70px;
transform: translate(-50%, -50%);
background: radial-gradient(
rgba(241, 102, 34, 0.35),
rgba(241, 102, 34, 0)
);
border-radius: 50%;
filter: blur(12px);
z-index: 1;
}


@keyframes shimmer {
0% { transform: translateX(0); }
100% { transform: translateX(50%); }
}

.parallax-drift {
transition: transform 0.2s ease-out;
}

.tilt-card {
transition: transform 0.25s ease, box-shadow 0.25s ease;
transform-style: preserve-3d;
}

@media (hover: hover) {
.tilt-card:hover {
transform: perspective(800px) rotateX(6deg) rotateY(6deg) translateY(-6px);
box-shadow: 0 15px 35px rgba(0,0,0,0.45);
}
}

.breath-glow {
position: relative;
}

.breath-glow::after {
content: "";
position: absolute;
inset: 0;
border-radius: 0.5rem;
padding: 2px;
background: radial-gradient(
circle,
rgba(241,102,34,0.35),
rgba(241,102,34,0)
);
animation: breathe 6s ease-in-out infinite;
opacity: 0.4;
pointer-events: none;
}

@keyframes breathe {
0% { opacity: 0.25; }
50% { opacity: 0.55; }
100% { opacity: 0.25; }
}

.hspace {
letter-spacing: 2px; 
font-size: 0.8rem;
}

/* REVIEWS */
  .reviews-section {
padding: 50px 0;
background-color: #0b0b0b;
  }

  .review-card {
background: #121212;
padding: 40px 30px;
border-radius: 4px;
position: relative;
border-top: 3px solid #333; /* Default top border */
height: 100%;
transition: all 0.3s ease;
  }

  /* The Center Card Highlight */
  .active-card, .review-card:hover {

background: #161616;
border-top: 3px solid #f16622; /* Orange top border on hover/active */
transform: translateY(-5px);
  }

  .quote-icon {
font-family: 'Playfair Display', serif;
font-size: 5rem;
color: rgba(255, 255, 255, 0.05);
position: absolute;
top: 10px;
right: 20px;
line-height: 1;
  }

  .review-text {
font-size: 1.2rem;
color: #e0e0e0;
margin-bottom: 30px;
position: relative;
z-index: 1;
  }

  .reviewer-info {
display: flex;
align-items: center;
gap: 15px;
margin-bottom: 25px;
  }

  .reviewer-avatar {
width: 50px;
height: 50px;
background: #333;
color: #fff;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-weight: 700;
font-family: 'Open Sans', sans-serif;
  }
 
  .reviewer-avatar-testimonial {
width: 50px;
height: 50px;
background: #f16622;
color: #fff;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-weight: 700;
font-family: 'Open Sans', sans-serif;
  }
  .orange-bg { background: #f16622; }

  .reviewer-name { font-size: 1rem; margin: 0; color: white; }
  .reviewer-role { font-size: 0.8rem; color: #888; }

  /* The "Tech" Badge */
  .verified-badge {
border-top: 1px solid rgba(255,255,255,0.1);
padding-top: 15px;
font-size: 0.75rem;
color: #666;
font-family: monospace;
text-transform: uppercase;
letter-spacing: 1px;
display: flex;
align-items: center;
gap: 8px;
  }
  
  .dot {
width: 8px; 
height: 8px; 
background: #4caf50; /* Green for verified */
border-radius: 50%;
display: inline-block;
box-shadow: 0 0 5px #4caf50;
  }

 /* --- FOOTER SPECIFIC CSS --- */
.footer-section {
background-color: #050505; /* Slightly darker than body */
position: relative;
padding-top: 80px;
overflow: hidden;
margin-top: 100px; /* Separation from previous content */
}

/* The "Hemline" - Fixes the frayed bottom */
.footer-border-top {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 1px;
background: linear-gradient(90deg, transparent 0%, #f16622 50%, transparent 100%);
opacity: 0.5;
}

/* Ambient Glow (Reusing the hero concept) */
.footer-glow {
position: absolute;
bottom: -100px;
left: -100px;
width: 400px;
height: 400px;
background: radial-gradient(circle, rgba(241, 102, 34, 0.1) 0%, rgba(0,0,0,0) 70%);
pointer-events: none;
}

/* Typography */
.footer-brand {
width:150px;
height: auto;
margin-bottom: 20px;
display: block;
text-decoration: none;
}

.footer-heading {
font-family: 'Open Sans', sans-serif;
font-size: 0.9rem;
font-weight: 700;
color: #fff;
text-transform: uppercase;
letter-spacing: 2px;
margin-bottom: 25px;
}

.footer-message {
color:#999; 
margin-bottom: 30px;
}

.footer-tag {
font-size:0.9rem;
color:#999; 
margin-bottom: 30px;
}

/* Link Styling with Hover Slide */
.footer-link {
color: #999;
text-decoration: none;
display: block;
margin-bottom: 15px;
transition: all 0.3s ease;
position: relative;
padding-left: 0;
}

.footer-link:hover {
color: #f16622;
padding-left: 10px; /* Slide effect */
}

/* CTA Section inside Footer */
.footer-cta-text {
font-family: 'Playfair Display', serif;
font-size: 2.5rem;
line-height: 1.2;
color: white;
margin-bottom: 20px;
}

.arrlink
{
background:transparent; 
color:#999; 
border:none; 
padding:0; 
font-size:0.9rem; 
cursor:pointer;
}

/* Form Inputs */
.footer-input {
background: rgba(255,255,255,0.05);
border: 1px solid rgba(255,255,255,0.1);
color: white;
padding: 15px;
border-radius: 8px;
width: 100%;
margin-bottom: 15px;
}
.footer-input:focus {
background: rgba(255,255,255,0.1);
border-color: #f16622;
outline: none;
color: white;
}

/* Bottom Bar */
.footer-bottom {
border-top: 1px solid rgba(255,255,255,0.05);
padding: 30px 0;
margin-top: 60px;
font-size: 0.85rem;
color: #666;
}

.social-icon {
width: 40px;
height: 40px;
border-radius: 50%;
border: 1px solid rgba(255,255,255,0.1);
display: inline-flex;
align-items: center;
justify-content: center;
color: #fff;
margin-right: 10px;
transition: all 0.3s ease;
text-decoration: none;
}
.social-icon:hover {
background-color: #f16622;
border-color: #f16622;
color: white;
transform: translateY(-3px);
}


/* Success State Styling */
.form-success-container {
    background: rgba(76, 175, 80, 0.1);
    border: 1px solid rgba(76, 175, 80, 0.3);
    padding: 20px;
    border-radius: 12px;
    text-align: center;
    animation: fadeInUp 0.5s ease forwards;
}

.success-icon-circle {
    width: 50px;
    height: 50px;
    background: #4caf50;
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 15px;
    box-shadow: 0 0 15px rgba(76, 175, 80, 0.4);
}

.success-title {
    color: #fff;
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 5px;
}

.success-text {
    color: #A9A9A9;
    font-size: 0.85rem;
    line-height: 1.4;
}

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}


/* --- Responsive Adjustments --- */


/* Desktop-only pill styling */
@media (min-width: 992px) {

.btn-contact {
background-color: #1a1a1a; 
color: #fff !important;
text-align: center;
/*background-image: radial-gradient(circle at 30% 10%, #f16622, #0000), linear-gradient(#31353f, #1b1c1f);*/
border-radius: 8px;
padding: 9px 19px;
font-size: .875rem;
line-height: 1.42857em;
text-decoration: none;
box-shadow: 0 0 12px rgba(255,255,255,0.05);
position: relative;
overflow: hidden;
border: 1px solid rgba(255, 255, 255, 0.08);
background-image: linear-gradient(#f16622, #93390d);
}

.btn-contact:hover {
background-image: linear-gradient(#d1581d, #55220a);
}
    
.hero-title { 
font-size: 3.5rem; 
line-height: 4.5rem;
} 
}

/* Tablet & Mobile (< 992px) */
@media (max-width: 991px) {
.hero-bs {
display: block; /* Stack block */
}

.dashboard-wrapper {
/* SCALE DOWN THE WHOLE IMAGE CLUSTER */
  /*  transform: scale(0.90); */
/* Fix alignment after scaling */
transform-origin: center top; 
/* Remove ghost whitespace caused by scaling */
margin-bottom: -100px; /* Pull following content up */
}
}

@media(max-width: 991px) {
.footer-cta-text { font-size: 2rem; }
.footer-section { text-align: left; }
}

@media(max-width: 900px) {
.hero-px {
margin-top:  20px;
background-image: url("../images/bg/isbs-900.jpg");
}
.hero-pxx {
margin-top: 30px;
}
.hero-sx {
background-image: url("../images/bg/isbs-expertise-900.webp");
margin-top: 20px;
}
.hero-ax {
background-image: url("../images/bg/isbs-ai-900.webp");
margin-top: 20px;
} 
.hero-xx {
background-image: url("../images/bg/isbs-porto-900.webp");
background-repeat: no-repeat;
}
.services-section {
background-image: url("../images/bg/isbs-services-900.jpg");
}
    
}

@media (max-width: 768px) {
      
.title-content h1 { font-size: 2.2rem; }
.title-content h2 { font-size: 1.6rem; margin-bottom: 2rem; }
#muteButton { bottom: 100px; }
      
.section-title { font-size: 2.5rem; }
.service-card { padding: 30px; }
.watermark { font-size: 6rem; top: -10px; right: 0; }
      
.fade-overlay { width: 50px; } /* Smaller fade on phone */
.tech-badge { padding: 10px 20px; font-size: 0.8rem; }
      
@media (max-width: 768px) {
.cta-box { padding: 40px 20px; text-align: center; }
.btn-white-glow { width: 100%; }
  }
 .isbsmarksml {
font-size: 8rem;
opacity: 0.10;
bottom: -50px;
right: 20px;
top: auto;
color:#fff;
}     
}

@media(max-width: 600px) {
.hero-px {
background-image: url("../images/bg/isbs-600.jpg");
}
 .hero-pxx {
background-image: url("../images/bg/isbs-websites-and-ai-600.webp");
}  
.hero-sx {
background-image: url("../images/bg/isbs-expertise-600.webp");
margin-top: 20px;
}
 .hero-ax {
background-image: url("../images/bg/isbs-ai-600.webp");
margin-top: 20px;
}   
.hero-xx {
background-image: url("../images/bg/isbs-porto-600.webp");
background-repeat: no-repeat;
}
.services-section {
background-image: url("../images/bg/isbs-services-600.jpg");
}
}

@media(max-width: 500px) {
.hero-px .col-10 {
width:100%;
}
.hero-sx .col-10 {
width:100%;
}
.hero-xx .col-10 {
width:100%;
}
.hero-ax .col-10 {
width:100%;
}
.isbsmarksml {
font-size: 6rem;
opacity: 0.10;
bottom: -50px;
right: 20px;
top: auto;
color:#fff;
}
    
}

@media (max-width: 440px) {
.dashboard-wrapper {
   margin-top: 0; 
height:0;}
}

@media (max-width: 400px) {
.experience-number {
font-size: 4rem;
}   
.italic-highlight {
font-size: 2.5rem;
}
.hd-highlight {
font-size: 2.5rem;
}

}


