/* ============================================================
   Reset & Base
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'Arial','Helvetica',sans-serif;line-height:1.6;color:#e0e0e0;background:#1a1a1a;}

/* ============================================================
   Loading Overlay
   ============================================================ */
.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#1a1a1a;display:flex;justify-content:center;align-items:center;z-index:9999;transition:opacity 0.5s ease;}
.loading-overlay.hide{opacity:0;pointer-events:none;}
.loader{width:60px;height:60px;border:4px solid #2a2a2a;border-top:4px solid #ff6b35;border-radius:50%;animation:spin 1s linear infinite;}
@keyframes spin{0%{transform:rotate(0deg);}100%{transform:rotate(360deg);}}

/* ============================================================
   Header & Nav
   ============================================================ */
header{background:linear-gradient(180deg,#2a2a2a 0%,#1a1a1a 100%);border-bottom:3px solid #ff6b35;color:white;padding:1rem 0;position:fixed;width:100%;top:0;z-index:1000;box-shadow:0 4px 15px rgba(0,0,0,0.5);}
nav{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:0 2rem;}
.logo{display:flex;align-items:center;gap:1rem;}
.logo svg{height:50px;width:auto;}
.logo-text{display:flex;flex-direction:column;line-height:1.2;}
.logo-name{font-size:1.3rem;font-weight:bold;color:#ff6b35;text-transform:uppercase;letter-spacing:1px;}
.logo-tagline{font-size:0.7rem;opacity:0.8;color:#b0b0b0;}
.nav-links{display:flex;gap:2rem;list-style:none;}
.nav-links a{color:#e0e0e0;text-decoration:none;text-transform:uppercase;font-size:0.9rem;font-weight:bold;letter-spacing:1px;transition:color 0.3s;border-bottom:2px solid transparent;padding-bottom:5px;}
.nav-links a:hover,.nav-links a.active{color:#ff6b35;border-bottom:2px solid #ff6b35;}
.hamburger{display:none;flex-direction:column;cursor:pointer;background:none;border:none;padding:5px;z-index:1001;}
.hamburger span{width:25px;height:3px;background:#e0e0e0;margin:3px 0;transition:0.3s;}
.hamburger.active span:nth-child(1){transform:rotate(-45deg) translate(-5px,6px);}
.hamburger.active span:nth-child(2){opacity:0;}
.hamburger.active span:nth-child(3){transform:rotate(45deg) translate(-5px,-6px);}

/* Logo Bubble Animations */
.logo svg circle:nth-of-type(2){animation:bubbleRise 3s linear infinite;}
.logo svg circle:nth-of-type(3){animation:bubbleRise 3.5s linear infinite 0.5s;}
.logo svg circle:nth-of-type(4){animation:bubbleRise 4s linear infinite 1s;}
.logo svg circle:nth-of-type(5){animation:bubbleRiseScale 3.2s linear infinite 1.5s;}
.logo svg circle:nth-of-type(6){animation:bubbleRiseScale 3.8s linear infinite 2s;}
.logo svg circle:nth-of-type(7){animation:bubbleRiseScale 4.2s linear infinite 2.5s;}
.logo svg circle:nth-of-type(8){animation:bubbleRiseScale 3.7s linear infinite 3s;}
.logo svg circle:nth-of-type(9){animation:bubbleRiseScale 4.5s linear infinite 3.5s;}
@keyframes bubbleRise{0%{transform:translateY(50px);opacity:0;}10%{opacity:0.4;}90%{transform:translateY(-30px);opacity:0.7;}100%{transform:translateY(-40px);opacity:0;}}
@keyframes bubbleRiseScale{0%{transform:translateY(50px) scale(0.85);opacity:0;}10%{opacity:0.4;transform:translateY(45px) scale(0.90);}25%{transform:translateY(25px) scale(1.0);}50%{transform:translateY(10px) scale(1.15);}75%{transform:translateY(-10px) scale(1.10);}90%{transform:translateY(-30px) scale(0.95);opacity:0.7;}100%{transform:translateY(-40px) scale(0.85);opacity:0;}}

/* ============================================================
   Hero
   ============================================================ */
.hero{background:linear-gradient(rgba(0,0,0,0.7),rgba(0,0,0,0.7)),repeating-linear-gradient(0deg,#2a2a2a 0px,#2a2a2a 2px,#333333 2px,#333333 4px);color:white;padding:180px 2rem 120px;text-align:center;margin-top:60px;border-bottom:4px solid #ff6b35;position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#ff6b35,#ffa500,#ff6b35);}
.hero::after{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="20" cy="20" r="1" fill="%23ff6b35" opacity="0.3"/><circle cx="80" cy="40" r="1.5" fill="%23ffa500" opacity="0.2"/><circle cx="40" cy="70" r="1" fill="%23ffd700" opacity="0.3"/><circle cx="70" cy="80" r="0.5" fill="%23ff6b35" opacity="0.4"/><circle cx="15" cy="60" r="0.8" fill="%23ACBED8" opacity="0.4"/><circle cx="55" cy="25" r="1.2" fill="%23E8EBF7" opacity="0.3"/></svg>') repeat;animation:parallaxFloat 20s ease-in-out infinite;pointer-events:none;}
@keyframes parallaxFloat{0%,100%{transform:translateY(0px) rotate(0deg) scale(1);}25%{transform:translateY(-10px) rotate(90deg) scale(1.15);}50%{transform:translateY(-20px) rotate(180deg) scale(0.85);}75%{transform:translateY(-10px) rotate(270deg) scale(1.15);}}
.hero h1{font-size:3rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:2px;color:#ff6b35;text-shadow:2px 2px 4px rgba(0,0,0,0.8);position:relative;z-index:1;}
.hero p{font-size:1.3rem;margin-bottom:1rem;color:#e0e0e0;position:relative;z-index:1;}
.certifications{font-size:1rem;margin-top:1.5rem;padding:1rem;background:rgba(255,107,53,0.1);border-left:4px solid #ff6b35;display:inline-flex;align-items:center;gap:0;color:#ffa500;font-weight:bold;position:relative;z-index:1;}

/* ============================================================
   Buttons
   ============================================================ */
.cta-button{display:inline-block;background:#ff6b35;color:white;padding:1rem 2.5rem;text-decoration:none;font-weight:bold;text-transform:uppercase;letter-spacing:1px;transition:all 0.3s;border:2px solid #ff6b35;margin-top:1.5rem;position:relative;z-index:1;overflow:hidden;}
.cta-button::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);transition:left 0.5s;}
.cta-button:hover{background:transparent;color:#ff6b35;transform:translateY(-2px);box-shadow:0 5px 15px rgba(255,107,53,0.4);}
.cta-button:hover::before{left:100%;}
.portal-button{display:inline-block;background:#ff6b35;color:white;padding:0.8rem 2rem;text-decoration:none;font-weight:bold;text-transform:uppercase;letter-spacing:1px;transition:all 0.3s;border:2px solid #ff6b35;}
.portal-button:hover{background:transparent;color:#ff6b35;}
.submit-btn{background:#ff6b35;color:white;padding:1rem 3rem;border:2px solid #ff6b35;font-size:1.1rem;cursor:pointer;text-transform:uppercase;letter-spacing:1px;font-weight:bold;transition:all 0.3s;width:100%;margin-top:1rem;position:relative;overflow:hidden;}
.submit-btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);transition:left 0.5s;}
.submit-btn:hover{background:transparent;color:#ff6b35;}
.submit-btn:hover::before{left:100%;}

/* ============================================================
   Layout
   ============================================================ */
.container{max-width:1200px;margin:0 auto;}
.section-title{text-align:center;font-size:2.5rem;margin-bottom:3rem;color:#ff6b35;text-transform:uppercase;letter-spacing:2px;position:relative;padding-bottom:1rem;}
.section-title::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:100px;height:3px;background:linear-gradient(90deg,transparent,#ff6b35,transparent);}

/* ============================================================
   Services Section (homepage portals)
   ============================================================ */
.services-section{background:#222222;padding:4rem 2rem;border-top:2px solid #3a3a3a;}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;}
.service-portal{background:linear-gradient(145deg,#2a2a2a,#1f1f1f);padding:3rem;border-left:4px solid #ff6b35;box-shadow:0 10px 30px rgba(0,0,0,0.5);transition:all 0.3s ease;text-align:center;position:relative;overflow:hidden;}
.service-portal::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,transparent 0%,rgba(255,107,53,0.1) 50%,transparent 100%);opacity:0;transition:opacity 0.3s ease;}
.service-portal:hover{transform:translateY(-10px);border-left:8px solid #ff6b35;box-shadow:0 15px 40px rgba(255,107,53,0.3);}
.service-portal:hover::before{opacity:1;}
.service-portal h2{color:#ff6b35;margin-bottom:1.5rem;font-size:1.6rem;text-transform:uppercase;letter-spacing:2px;}
.service-portal p{color:#b0b0b0;margin-bottom:2rem;font-size:1rem;line-height:1.8;}

/* ============================================================
   Services Page Cards
   ============================================================ */
.service-card{background:linear-gradient(145deg,#2a2a2a,#1f1f1f);padding:2rem;border-left:4px solid #ff6b35;box-shadow:0 5px 15px rgba(0,0,0,0.5);transition:transform 0.3s,border-left-width 0.3s;}
.service-card:hover{transform:translateX(10px);border-left-width:8px;}
.service-card h3{color:#ffa500;margin-bottom:1rem;font-size:1.5rem;text-transform:uppercase;letter-spacing:1px;}
.service-card p{color:#b0b0b0;margin-bottom:1.5rem;line-height:1.8;}
.service-features{list-style:none;margin-bottom:2rem;}
.service-features li{color:#e0e0e0;margin-bottom:0.6rem;padding-left:1.5rem;position:relative;font-size:0.95rem;}
.service-features li::before{content:'▶';color:#ff6b35;position:absolute;left:0;font-size:0.75rem;top:2px;}

/* ============================================================
   Portfolio
   ============================================================ */
.portfolio-section{background:#222222;padding:4rem 2rem;border-top:2px solid #3a3a3a;}
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:3rem;}
.portfolio-item{background:linear-gradient(145deg,#2a2a2a,#1f1f1f);border-left:4px solid #ff6b35;box-shadow:0 10px 30px rgba(0,0,0,0.5);transition:all 0.3s ease;overflow:hidden;}
.portfolio-item:hover{transform:translateY(-8px);border-left:8px solid #ff6b35;box-shadow:0 15px 40px rgba(255,107,53,0.3);}
.video-wrapper{position:relative;width:100%;background:#111;aspect-ratio:16/9;}
.video-wrapper video{width:100%;height:100%;display:block;object-fit:cover;}
.video-poster{position:absolute;inset:0;background:#111 center/cover no-repeat;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:opacity 0.3s ease;}
.video-poster:hover .play-btn-overlay svg circle{fill:rgba(255,107,53,0.25);}
.play-btn-overlay{width:72px;height:72px;filter:drop-shadow(0 4px 12px rgba(0,0,0,0.6));}
.play-btn-overlay svg{width:100%;height:100%;}
.poster-label{color:#e0e0e0;font-size:0.85rem;text-transform:uppercase;letter-spacing:2px;margin-top:1rem;font-weight:bold;opacity:0.7;}
.video-poster.hidden{opacity:0;pointer-events:none;}
.portfolio-info{padding:2rem;}
.portfolio-info h3{color:#ffa500;margin-bottom:0.75rem;font-size:1.5rem;text-transform:uppercase;letter-spacing:1px;}
.portfolio-tag{display:inline-block;background:rgba(255,107,53,0.15);border:1px solid #ff6b35;color:#ff6b35;font-size:0.75rem;font-weight:bold;text-transform:uppercase;letter-spacing:1px;padding:0.25rem 0.75rem;margin-bottom:1rem;}
.portfolio-info p{color:#b0b0b0;line-height:1.8;margin-bottom:1.5rem;}
.portfolio-details{list-style:none;border-top:1px solid #3a3a3a;padding-top:1rem;}
.portfolio-details li{color:#e0e0e0;font-size:0.9rem;padding:0.3rem 0 0.3rem 1.5rem;position:relative;}
.portfolio-details li::before{content:'▶';color:#ff6b35;position:absolute;left:0;font-size:0.7rem;top:5px;}

/* ============================================================
   CTA Banner
   ============================================================ */
.cta-banner{background:linear-gradient(135deg,#2a2a2a,#1a1a1a);border-top:3px solid #ff6b35;border-bottom:3px solid #ff6b35;padding:4rem 2rem;text-align:center;margin-top:0;}
.cta-banner h2{color:#ff6b35;font-size:2rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:1rem;}
.cta-banner p{color:#b0b0b0;font-size:1.1rem;margin-bottom:2rem;}

/* ============================================================
   Contact Form
   ============================================================ */
.contact-section{background:#222222;padding:4rem 2rem;border-top:2px solid #3a3a3a;}
.contact-section .container{max-width:800px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;}
.form-group{margin-bottom:1.5rem;}
.form-group label{display:block;margin-bottom:0.5rem;font-weight:bold;color:#ff6b35;text-transform:uppercase;letter-spacing:1px;font-size:0.85rem;}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:0.8rem;border:2px solid #3a3a3a;background:#1a1a1a;color:#e0e0e0;font-size:1rem;font-family:inherit;transition:border-color 0.3s;}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#ff6b35;}
.form-group select option{background:#1a1a1a;color:#e0e0e0;}
.form-group textarea{min-height:160px;resize:vertical;}
.checkbox-group{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:0.75rem;margin-top:0.75rem;}
.checkbox-item{display:flex;align-items:center;gap:0.5rem;}
.checkbox-item input[type="checkbox"]{width:auto;margin:0;transform:scale(1.2);accent-color:#ff6b35;}
.checkbox-item label{margin:0;font-size:0.9rem;text-transform:none;letter-spacing:normal;color:#e0e0e0;cursor:pointer;font-weight:normal;}
.reveal-section{overflow:hidden;max-height:0;opacity:0;margin-bottom:0;transition:max-height 0.45s ease,opacity 0.45s ease,margin-bottom 0.45s ease;}
.reveal-section.visible{max-height:400px;opacity:1;margin-bottom:1.5rem;}

/* ============================================================
   CSWA Badge
   ============================================================ */
.cswa-badge-link{display:inline-flex;align-items:center;gap:0.5rem;text-decoration:none;color:#ffa500;font-weight:bold;transition:opacity 0.2s;}
.cswa-badge-link:hover{opacity:0.8;}
.cswa-badge{height:48px;width:auto;vertical-align:middle;filter:drop-shadow(0 2px 6px rgba(0,0,0,0.5));}
.credentials-bar{text-align:center;margin-bottom:2.5rem;}

/* ============================================================
   Footer
   ============================================================ */
footer{background:#1a1a1a;color:#b0b0b0;text-align:center;padding:2rem;border-top:3px solid #ff6b35;}

/* ============================================================
   Pricing
   ============================================================ */
.pricing-section{padding:4rem 2rem;background:#1a1a1a;}
.pricing-section .container{max-width:1200px;margin:0 auto;}
.pricing-section .section-title{margin-top:3rem;}
.pricing-section .section-title:first-of-type{margin-top:0;}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-bottom:3rem;}
.pricing-grid--centered{grid-template-columns:repeat(auto-fit,minmax(280px,400px));justify-content:center;}
.pricing-card{background:linear-gradient(145deg,#2a2a2a,#1f1f1f);padding:2.5rem;border-left:4px solid #ff6b35;box-shadow:0 10px 30px rgba(0,0,0,0.5);transition:all 0.3s ease;position:relative;overflow:hidden;}
.pricing-card::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,transparent 0%,rgba(255,107,53,0.05) 50%,transparent 100%);opacity:0;transition:opacity 0.3s ease;}
.pricing-card:hover{transform:translateY(-6px);border-left:8px solid #ff6b35;box-shadow:0 15px 40px rgba(255,107,53,0.2);}
.pricing-card:hover::before{opacity:1;}
.pricing-type{display:inline-block;font-size:0.75rem;font-weight:bold;text-transform:uppercase;letter-spacing:2px;color:#ffa500;border:1px solid #ffa500;padding:0.2rem 0.6rem;margin-bottom:1rem;}
.pricing-card h3{color:#ff6b35;font-size:1.4rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:1rem;}
.pricing-amount{font-size:2.5rem;font-weight:bold;color:#e0e0e0;margin-bottom:1rem;line-height:1;}
.pricing-amount--quote{font-size:1.8rem;color:#ffa500;}
.pricing-amount .placeholder{color:#ffa500;}
.pricing-unit{font-size:1.1rem;color:#b0b0b0;font-weight:normal;}
.pricing-card p{color:#b0b0b0;font-size:0.95rem;line-height:1.7;margin-bottom:1.25rem;}
.pricing-includes{list-style:none;border-top:1px solid #3a3a3a;padding-top:1rem;}
.pricing-includes li{color:#b0b0b0;font-size:0.9rem;padding:0.3rem 0;padding-left:1.2rem;position:relative;}
.pricing-includes li::before{content:'✓';position:absolute;left:0;color:#ff6b35;font-weight:bold;}
.pricing-includes li.pricing-addon{color:#ffa500;margin-top:0.5rem;border-top:1px dashed #3a3a3a;padding-top:0.75rem;}
.pricing-includes li.pricing-addon::before{content:'+';color:#ffa500;}
.pricing-note{background:#222222;border-left:4px solid #ffa500;padding:2rem;margin-bottom:2rem;}
.pricing-note h3{color:#ffa500;text-transform:uppercase;letter-spacing:1px;margin-bottom:1rem;font-size:1rem;}
.pricing-note ul{list-style:none;}
.pricing-note li{color:#b0b0b0;font-size:0.9rem;padding:0.4rem 0;padding-left:1.2rem;position:relative;}
.pricing-note li::before{content:'•';position:absolute;left:0;color:#ffa500;}
.pricing-note a{color:#ff6b35;text-decoration:none;}
.pricing-note a:hover{text-decoration:underline;}
.pricing-cta{text-align:center;padding:2rem 0;}
.pricing-cta p{color:#b0b0b0;margin-bottom:1.5rem;font-size:1.1rem;}
.pricing-disclaimer{margin-top:1.25rem;padding:0.75rem 1rem;background:rgba(255,107,53,0.07);border-left:3px solid #ffa500;color:#b0b0b0;font-size:0.82rem;line-height:1.6;}

/* ============================================================
   Scroll Animations
   ============================================================ */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity 0.8s ease,transform 0.8s ease;}
.fade-in.visible{opacity:1;transform:translateY(0);}
.slide-in-left{opacity:0;transform:translateX(-50px);transition:opacity 0.8s ease,transform 0.8s ease;}
.slide-in-left.visible{opacity:1;transform:translateX(0);}
.slide-in-right{opacity:0;transform:translateX(50px);transition:opacity 0.8s ease,transform 0.8s ease;}
.slide-in-right.visible{opacity:1;transform:translateX(0);}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:768px){
  .hero h1{font-size:2rem;}
  .hero{padding:140px 2rem 80px;}
  .nav-links{position:fixed;top:77px;left:-100%;width:100%;height:calc(100vh - 77px);background:#1a1a1a;flex-direction:column;justify-content:flex-start;align-items:center;padding-top:2rem;gap:2rem;font-size:1.2rem;transition:left 0.3s ease;z-index:999;}
  .nav-links.active{left:0;}
  .hamburger{display:flex;}
  .services-grid{grid-template-columns:1fr;}
  .portfolio-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
}
