/* ============================================================
   Design Tokens
   ============================================================ */
:root {
  /* Brand Colors */
  --color-accent: #ff6b35;
  --color-gold:   #ffa500;

  /* Backgrounds */
  --bg-base:    #1a1a1a;
  --bg-raised:  #2a2a2a;
  --bg-card:    #1f1f1f;
  --bg-section: #222222;

  /* Borders & Dividers */
  --border-color: #3a3a3a;

  /* Text */
  --text-primary: #e0e0e0;
  --text-muted:   #b0b0b0;

  /* Accent with Opacity */
  --accent-subtle: rgba(255, 107, 53, 0.05);
  --accent-tint:   rgba(255, 107, 53, 0.1);
  --accent-glow:   rgba(255, 107, 53, 0.3);
  --accent-shadow: rgba(255, 107, 53, 0.4);

  /* Shadows */
  --shadow:       rgba(0, 0, 0, 0.5);
  --shadow-heavy: rgba(0, 0, 0, 0.7);

  /* Layout */
  --max-width: 1200px;

  /* Typography */
  --font-family: 'Arial', 'Helvetica', sans-serif;
}

/* ============================================================
   Reset & Base
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:var(--font-family);line-height:1.6;color:var(--text-primary);background:var(--bg-base);}

/* Skip to main content */
.skip-to-main{position:absolute;top:-100%;left:1rem;background:var(--color-accent);color:white;padding:0.75rem 1.5rem;font-weight:bold;text-decoration:none;z-index:10000;border-radius:0 0 4px 4px;}
.skip-to-main:focus{top:0;}

/* Focus styles */
:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;}
.nav-links a:focus-visible{border-bottom-color:var(--color-accent);}
.cta-button:focus-visible,.portal-button:focus-visible,.submit-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;}
.hamburger:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px;}
.video-poster:focus-visible{outline:3px solid var(--color-accent);outline-offset:-3px;}

/* ============================================================
   Loading Overlay
   ============================================================ */
.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-base);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 var(--bg-raised);border-top:4px solid var(--color-accent);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,var(--bg-raised) 0%,var(--bg-base) 100%);border-bottom:3px solid var(--color-accent);color:white;padding:1rem 0;position:fixed;width:100%;top:0;z-index:1000;box-shadow:0 4px 15px var(--shadow);}
nav{max-width:var(--max-width);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:var(--color-accent);text-transform:uppercase;letter-spacing:1px;}
.logo-tagline{font-size:0.7rem;opacity:0.8;color:var(--text-muted);}
.nav-links{display:flex;gap:2rem;list-style:none;margin-right:10%;}
.nav-links a{color:var(--text-primary);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;text-align:center;}
.nav-links a:hover{color:var(--color-accent);border-bottom:2px solid var(--color-accent);}
.nav-links a.active{color:var(--color-gold);border-bottom:2px solid var(--color-gold);}
.nav-line-top{display:block;text-align:center;line-height:1.1;}
.hamburger{display:none;flex-direction:column;cursor:pointer;background:none;border:none;padding:5px;z-index:1001;}
.hamburger span{width:25px;height:3px;background:var(--text-primary);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(var(--shadow-heavy),var(--shadow-heavy)),repeating-linear-gradient(0deg,var(--bg-raised) 0px,var(--bg-raised) 2px,#333333 2px,#333333 4px);color:white;padding:180px 2rem 120px;text-align:center;margin-top:60px;border-bottom:4px solid var(--color-accent);position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-accent),var(--color-gold),var(--color-accent));}
.hero::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;}
.hero-tank{position:absolute;right:8%;bottom:0;height:75%;opacity:0;pointer-events:none;z-index:0;user-select:none;}
.hero-sil-left{position:absolute;left:8%;bottom:15%;height:48%;opacity:0;pointer-events:none;z-index:0;user-select:none;}
/* Scrolling wave lines */
.hero-waves{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0;}
.hero-waves svg{position:absolute;bottom:0;left:0;width:100%;height:100%;}
/* Rising bubble particles */
.hero-bubble{position:absolute;bottom:-20px;border-radius:50%;background:radial-gradient(circle at 35% 35%, rgba(147,197,253,0.55), rgba(96,165,250,0.2));border:1px solid rgba(147,197,253,0.35);animation:bubbleFloat linear forwards;z-index:0;pointer-events:none;}
@keyframes bubbleFloat{0%{transform:translateY(0) translateX(0);opacity:0;}10%{opacity:0.7;}85%{opacity:0.5;}100%{transform:translateY(var(--rise)) translateX(var(--drift));opacity:0;}}
.hero h1{font-size:3rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:2px;color:var(--color-accent);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:var(--text-primary);position:relative;z-index:1;}
.certifications{font-size:1rem;margin-top:1.5rem;padding:1rem;background:var(--accent-tint);border-left:4px solid var(--color-accent);display:inline-flex;align-items:center;gap:0;color:var(--color-gold);font-weight:bold;position:relative;z-index:1;}

/* ============================================================
   Buttons
   ============================================================ */
.cta-button{display:inline-block;background:var(--color-accent);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 var(--color-accent);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:var(--color-accent);transform:translateY(-2px);box-shadow:0 5px 15px var(--accent-shadow);}
.cta-button:hover::before{left:100%;}
.portal-button{display:inline-block;background:var(--color-accent);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 var(--color-accent);}
.portal-button:hover{background:transparent;color:var(--color-accent);}
.submit-btn{background:var(--color-accent);color:white;padding:1rem 3rem;border:2px solid var(--color-accent);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:var(--color-accent);}
.submit-btn:hover::before{left:100%;}

/* ============================================================
   Layout
   ============================================================ */
.container{max-width:var(--max-width);margin:0 auto;}
.section-title{text-align:center;font-size:2.5rem;margin-bottom:3rem;color:var(--color-accent);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,var(--color-accent),transparent);}

/* ============================================================
   Services Section (homepage portals)
   ============================================================ */
.services-section{background:var(--bg-section);padding:4rem 2rem;border-top:2px solid var(--border-color);}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;}
.service-portal{background:linear-gradient(145deg,var(--bg-raised),var(--bg-card));padding:3rem;border-left:4px solid var(--color-accent);box-shadow:0 10px 30px var(--shadow);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%,var(--accent-tint) 50%,transparent 100%);opacity:0;transition:opacity 0.3s ease;}
.service-portal:hover{transform:translateY(-10px);border-left:8px solid var(--color-accent);box-shadow:0 15px 40px var(--accent-glow);}
.service-portal:hover::before{opacity:1;}
.service-portal h2{color:var(--color-accent);margin-bottom:1.5rem;font-size:1.6rem;text-transform:uppercase;letter-spacing:2px;}
.service-portal p{color:var(--text-muted);margin-bottom:2rem;font-size:1rem;line-height:1.8;}

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

/* ============================================================
   Portfolio
   ============================================================ */
.portfolio-section{background:var(--bg-section);padding:4rem 2rem;border-top:2px solid var(--border-color);}
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:3rem;}
.portfolio-item{background:linear-gradient(145deg,var(--bg-raised),var(--bg-card));border-left:8px solid var(--color-accent);box-shadow:0 10px 30px var(--shadow);transition:all 0.3s ease;overflow:hidden;}
.portfolio-item:hover{transform:translateY(-8px);box-shadow:0 15px 40px var(--accent-glow);}
.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:var(--text-primary);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:var(--color-gold);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 var(--color-accent);color:var(--color-accent);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:var(--text-muted);line-height:1.8;margin-bottom:1.5rem;}
.portfolio-details{list-style:none;border-top:1px solid var(--border-color);padding-top:1rem;}
.portfolio-details li{color:var(--text-primary);font-size:0.9rem;padding:0.3rem 0 0.3rem 1.5rem;position:relative;}
.portfolio-details li::before{content:'▶';color:var(--color-accent);position:absolute;left:0;font-size:0.7rem;top:5px;}
.portfolio-item--wide{grid-column:1/-1;}
.portfolio-item--wide .video-wrapper{max-width:50%;margin:0 auto;}
.portfolio-gallery{display:flex;gap:0.5rem;padding:0.75rem;background:#0a0a0a;overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--color-accent) #111;}
.portfolio-gallery::-webkit-scrollbar{height:4px;}
.portfolio-gallery::-webkit-scrollbar-track{background:#111;}
.portfolio-gallery::-webkit-scrollbar-thumb{background:var(--color-accent);border-radius:2px;}
.portfolio-thumb{height:90px;width:auto;object-fit:cover;cursor:pointer;border:2px solid transparent;transition:border-color 0.2s ease,transform 0.2s ease;flex-shrink:0;}
.portfolio-thumb:hover{border-color:var(--color-accent);transform:scale(1.05);}
.portfolio-thumb.active,.portfolio-thumb--video.active{border-color:var(--color-accent);}
.portfolio-thumb--video{background:#111 center/cover no-repeat;border:none;padding:0;width:120px;display:flex;align-items:center;justify-content:center;}
.portfolio-thumb--video svg{width:32px;height:32px;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.6));}
.media-image{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#111;z-index:1;display:none;}
.media-image.visible{display:block;}
#lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.92);z-index:1000;align-items:center;justify-content:center;}
#lightbox.active{display:flex;}
#lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;box-shadow:0 0 40px rgba(0,0,0,0.8);}
.lightbox-close{position:absolute;top:1.25rem;right:1.5rem;background:none;border:none;color:#fff;font-size:2.5rem;cursor:pointer;line-height:1;opacity:0.7;transition:opacity 0.2s;}
.lightbox-close:hover{opacity:1;}

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

/* ============================================================
   About Teaser (homepage)
   ============================================================ */
.about-teaser{background:var(--bg-section);padding:5rem 2rem;border-top:2px solid var(--border-color);}
.about-teaser-inner{display:flex;align-items:center;gap:4rem;max-width:1100px;margin:0 auto;}
.about-teaser-text{flex:1;}
.about-teaser-text .section-title{text-align:left;margin-bottom:1rem;}
.about-teaser-text p{color:var(--text-muted);font-size:1.05rem;line-height:1.8;margin-bottom:2rem;}
.about-teaser-stats{display:flex;flex-direction:column;gap:1.5rem;min-width:180px;}
.stat-item{text-align:center;background:var(--bg-raised);border:1px solid var(--border-color);border-left:3px solid var(--color-accent);padding:1rem 1.5rem;}
.stat-number{display:block;font-size:2rem;font-weight:bold;color:var(--color-accent);letter-spacing:1px;line-height:1;}
.stat-plus{font-size:1.4rem;}
.stat-label{display:block;font-size:0.75rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-top:0.3rem;}

/* ============================================================
   About Page
   ============================================================ */
.about-section{padding:5rem 2rem;background:var(--bg-base);}
.about-block{display:flex;gap:2.5rem;align-items:flex-start;max-width:900px;margin:0 auto 4rem;}
.about-block--reverse{flex-direction:row-reverse;}
.about-block-icon{font-size:3rem;flex-shrink:0;width:64px;text-align:center;margin-top:0.25rem;}
.about-icon-svg{width:56px;height:56px;filter:invert(60%) sepia(80%) saturate(400%) hue-rotate(340deg) brightness(1.1);}
.about-block-content h2{color:var(--color-accent);font-size:1.6rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:1rem;border-bottom:2px solid var(--border-color);padding-bottom:0.5rem;}
.about-block-content p{color:var(--text-muted);line-height:1.8;margin-bottom:1rem;}
.about-stats-row{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;max-width:900px;margin:0 auto 2rem;padding-top:2rem;border-top:2px solid var(--border-color);}
.about-stats-row .stat-item{flex:1;min-width:140px;}
@media(max-width:768px){
  .about-teaser-inner{flex-direction:column;gap:2rem;}
  .about-teaser-stats{flex-direction:row;flex-wrap:wrap;justify-content:center;}
  .about-block,.about-block--reverse{flex-direction:column;}
  .about-block-icon{width:auto;}
}

/* ============================================================
   Cosplay Props Page
   ============================================================ */
.cosplay-intro{background:var(--bg-section);padding:5rem 2rem;border-top:2px solid var(--border-color);}
.cosplay-intro-inner{display:flex;align-items:center;gap:4rem;max-width:900px;}
.cosplay-intro-text{flex:1;}
.cosplay-intro-text h2{color:var(--color-accent);font-size:1.8rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:1rem;}
.cosplay-intro-text p{color:var(--text-muted);line-height:1.8;margin-bottom:1rem;}
.cosplay-intro-icon{font-size:5rem;flex-shrink:0;opacity:0.6;}
.cosplay-hero-svg{width:120px;height:auto;}

.cosplay-coming-soon{background:var(--bg-base);padding:5rem 2rem;text-align:center;border-top:2px solid var(--border-color);}
.cosplay-coming-soon-inner{max-width:700px;margin:0 auto;}
.cosplay-coming-soon h2{color:var(--text-primary);font-size:1.8rem;text-transform:uppercase;letter-spacing:2px;margin-bottom:1rem;}
.cosplay-coming-soon p{color:var(--text-muted);line-height:1.8;margin-bottom:0.75rem;}
.coming-soon-badge{display:inline-block;background:var(--color-gold);color:#000;font-size:0.75rem;font-weight:bold;letter-spacing:2px;text-transform:uppercase;padding:0.3rem 1rem;margin-bottom:1.5rem;}

.cosplay-capabilities{background:var(--bg-section);padding:5rem 2rem;border-top:2px solid var(--border-color);}
.cosplay-caps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem;margin-top:2rem;}
.cosplay-cap-card{background:var(--bg-raised);border:1px solid var(--border-color);padding:2rem;text-align:center;transition:border-color 0.3s,transform 0.3s;}
.cosplay-cap-card:hover{border-color:var(--color-accent);transform:translateY(-4px);}
.cosplay-cap-icon{font-size:2.5rem;margin-bottom:1rem;}
.cosplay-cap-card h3{color:var(--color-accent);font-size:1rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:0.75rem;}
.cosplay-cap-card p{color:var(--text-muted);font-size:0.9rem;line-height:1.7;}

/* ============================================================
   Contact Form
   ============================================================ */
.contact-section{background:var(--bg-section);padding:4rem 2rem;border-top:2px solid var(--border-color);}
.contact-section .container{max-width:800px;}
.cosplay-printers{background:var(--bg-raised);padding:5rem 2rem;border-top:2px solid var(--border-color);}
.printer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:1rem;}
.printer-card{background:var(--bg-base);border:1px solid var(--border-color);padding:2rem;transition:border-color 0.3s;}
.printer-card:hover{border-color:var(--color-accent);}
.printer-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;}
.printer-icon{font-size:2rem;}
.printer-header h3{color:var(--color-accent);font-size:1.1rem;text-transform:uppercase;letter-spacing:1px;margin:0 0 0.25rem;}
.printer-tag{font-size:0.75rem;color:var(--color-gold);text-transform:uppercase;letter-spacing:1px;font-weight:bold;}
.printer-specs{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0.75rem;}
.printer-specs li{display:grid;grid-template-columns:110px 1fr;gap:0.5rem;font-size:0.9rem;color:var(--text-muted);line-height:1.5;}
.printer-specs li span{color:var(--color-accent);font-weight:bold;text-transform:uppercase;font-size:0.75rem;letter-spacing:0.5px;padding-top:0.1rem;}

.cosplay-quote-section{background:var(--bg-base);border-top:3px solid var(--color-gold);}
.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:var(--color-accent);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 var(--border-color);background:var(--bg-base);color:var(--text-primary);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:var(--color-accent);}
.form-group select option{background:var(--bg-base);color:var(--text-primary);}
.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:var(--color-accent);}
.checkbox-item label{margin:0;font-size:0.9rem;text-transform:none;letter-spacing:normal;color:var(--text-primary);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:var(--color-gold);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 var(--shadow));}
.credentials-bar{text-align:center;margin-bottom:2.5rem;}

/* ============================================================
   Footer
   ============================================================ */
footer{background:var(--bg-base);color:var(--text-muted);text-align:center;padding:2rem;border-top:3px solid var(--color-accent);}

/* ============================================================
   Pricing
   ============================================================ */
.pricing-section{padding:4rem 2rem;background:var(--bg-base);}
.pricing-section .container{max-width:var(--max-width);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,var(--bg-raised),var(--bg-card));padding:2.5rem;border-left:4px solid var(--color-accent);box-shadow:0 10px 30px var(--shadow);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%,var(--accent-subtle) 50%,transparent 100%);opacity:0;transition:opacity 0.3s ease;}
.pricing-card:hover{transform:translateY(-6px);border-left:8px solid var(--color-accent);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:var(--color-gold);border:1px solid var(--color-gold);padding:0.2rem 0.6rem;margin-bottom:1rem;}
.pricing-card h3{color:var(--color-accent);font-size:1.4rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:1rem;}
.pricing-amount{font-size:2.5rem;font-weight:bold;color:var(--text-primary);margin-bottom:1rem;line-height:1;}
.pricing-amount--quote{font-size:1.8rem;color:var(--color-gold);}
.pricing-amount .placeholder{color:var(--color-gold);}
.pricing-unit{font-size:1.1rem;color:var(--text-muted);font-weight:normal;}
.pricing-card p{color:var(--text-muted);font-size:0.95rem;line-height:1.7;margin-bottom:1.25rem;}
.pricing-includes{list-style:none;border-top:1px solid var(--border-color);padding-top:1rem;}
.pricing-includes li{color:var(--text-muted);font-size:0.9rem;padding:0.3rem 0;padding-left:1.2rem;position:relative;}
.pricing-includes li::before{content:'✓';position:absolute;left:0;color:var(--color-accent);font-weight:bold;}
.pricing-includes li.pricing-addon{color:var(--color-gold);margin-top:0.5rem;border-top:1px dashed var(--border-color);padding-top:0.75rem;}
.pricing-includes li.pricing-addon::before{content:'+';color:var(--color-gold);}
.pricing-note{background:var(--bg-section);border-left:4px solid var(--color-gold);padding:2rem;margin-bottom:2rem;}
.pricing-note h3{color:var(--color-gold);text-transform:uppercase;letter-spacing:1px;margin-bottom:1rem;font-size:1rem;}
.pricing-note ul{list-style:none;}
.pricing-note li{color:var(--text-muted);font-size:0.9rem;padding:0.4rem 0;padding-left:1.2rem;position:relative;}
.pricing-note li::before{content:'•';position:absolute;left:0;color:var(--color-gold);}
.pricing-note a{color:var(--color-accent);text-decoration:none;}
.pricing-note a:hover{text-decoration:underline;}
.pricing-cta{text-align:center;padding:2rem 0;}
.pricing-cta p{color:var(--text-muted);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 var(--color-gold);color:var(--text-muted);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:var(--bg-base);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;}
}
