/* ========================================
           SCROLL-TRIGGERED REVEAL ANIMATIONS
           ======================================== *//* Base keyframes */@keyframes fadeUp{from {
                opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}

        @keyframes fadeIn{from { opacity:0}to{opacity:1}}

        @keyframes slideInLeft{from {
                opacity:0;transform:translateX(-60px)}to{opacity:1;transform:translateX(0)}}

        @keyframes slideInRight{from {
                opacity:0;transform:translateX(60px)}to{opacity:1;transform:translateX(0)}}

        @keyframes scaleIn{from {
                opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}

        @keyframes slideUp{from {
                opacity:0;transform:translateY(80px) scale(0.98)}to{opacity:1;transform:translateY(0) scale(1)}}

        @keyframes pulse{0%, 100% { transform:scale(1)}50%{transform:scale(1.05)}}

        @keyframes float{0%, 100% { transform:translateY(0)}50%{transform:translateY(-10px)}}

        @keyframes shimmer{0% { background-position:-200% 0}100%{background-position:200% 0}}

        @keyframes heroIntro{from {
                opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}/* Reveal system - elements start hidden */}

        
        .reveal{opacity:0;transform:translateY(50px);transition:opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),transform 0.8s cubic-bezier(0.22, 1, 0.36, 1)}.reveal.revealed{opacity:1;transform:translateY(0)}/* Reveal variants */.reveal-fade{opacity:0;transition:opacity 1s ease-out}.reveal-fade.revealed{opacity:1}.reveal-left{opacity:0;transform:translateX(-60px);transition:opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),transform 0.8s cubic-bezier(0.22, 1, 0.36, 1)}.reveal-left.revealed{opacity:1;transform:translateX(0)}.reveal-right{opacity:0;transform:translateX(60px);transition:opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),transform 0.8s cubic-bezier(0.22, 1, 0.36, 1)}.reveal-right.revealed{opacity:1;transform:translateX(0)}.reveal-scale{opacity:0;transform:scale(0.9);transition:opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),transform 0.8s cubic-bezier(0.22, 1, 0.36, 1)}.reveal-scale.revealed{opacity:1;transform:scale(1)}/* Stagger delays for children */.stagger-children > *:nth-child(1){transition-delay:0s}.stagger-children > *:nth-child(2){transition-delay:0.1s}.stagger-children > *:nth-child(3){transition-delay:0.2s}.stagger-children > *:nth-child(4){transition-delay:0.3s}.stagger-children > *:nth-child(5){transition-delay:0.4s}.stagger-children > *:nth-child(6){transition-delay:0.5s}.stagger-children > *:nth-child(7){transition-delay:0.6s}.stagger-children > *:nth-child(8){transition-delay:0.7s}/* Section dividers with depth */.section-divider{position:relative}.section-divider::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg, 
                transparent, 
                rgba(27, 53, 96,0.2) 20%, 
                rgba(27, 53, 96,0.2) 80%, 
                transparent)}/* Smooth section transitions */section{position:relative}/* Enhanced hover states */.hover-lift{transition:transform 0.4s cubic-bezier(0.22, 1, 0.36, 1),box-shadow 0.4s cubic-bezier(0.22, 1, 0.36, 1)}.hover-lift:hover{transform:translateY(-8px);box-shadow:0 20px 40px rgba(27, 53, 96,0.15)}.hover-glow{transition:box-shadow 0.4s ease}.hover-glow:hover{box-shadow:0 0 30px rgba(255, 94, 58, 0.3)}/* Parallax container */.parallax-container{overflow:hidden;position:relative}.parallax-bg{position:absolute;inset:-20%;background-size:cover;background-position:center;will-change:transform}/* Animated gradient backgrounds */.animated-gradient{background:linear-gradient(
                135deg,
                var(--primary) 0%,
                var(--secondary) 25%,
                var(--tertiary) 50%,
                var(--secondary) 75%,
                var(--primary) 100%
            );background-size:400% 400%;animation:gradientShift 15s ease infinite}@keyframes gradientShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}/* Text reveal animation */.text-reveal{overflow:hidden}.text-reveal span{display:inline-block;transform:translateY(100%);transition:transform 0.6s cubic-bezier(0.22, 1, 0.36, 1)}.text-reveal.revealed span{transform:translateY(0)}/* Counter animation helper */.count-up{display:inline-block}/* Reduce motion for accessibility */@media (prefers-reduced-motion: reduce){.reveal,.reveal-fade,.reveal-left,.reveal-right,.reveal-scale{opacity:1;transform:none;transition:none}.stagger-children > *{transition-delay:0s !important}.animated-gradient{animation:none}}/* Legacy animation classes */.animate-fade-up{animation:fadeUp 0.8s ease-out forwards}.animate-fade-in{animation:fadeIn 1s ease-out forwards}.delay-1{animation-delay:0.1s}.delay-2{animation-delay:0.2s}.delay-3{animation-delay:0.3s}.delay-4{animation-delay:0.4s}.delay-5{animation-delay:0.5s}/* Hero Section */.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:8rem 4rem 6rem;position:relative;background-color:var(--primary);background-image:url('images/heroes/teesside-hero.jpg');background-image:image-set(
                url('images/heroes/teesside-hero.avif') type('image/avif'),
                url('images/heroes/teesside-hero.webp') type('image/webp'),
                url('images/heroes/teesside-hero.jpg') 1x
            );background-size:cover;background-position:center 40%;background-attachment:fixed;text-align:center;overflow:hidden}/* Fixed background doesn't work on iOS Safari ? fall back to scroll */@media (pointer: coarse){.hero{background-attachment:scroll}}/* Dark green overlay ? makes text readable over the photo */.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(
                170deg,
                rgba(10, 18, 35, 0.55) 0%,
                rgba(27, 53, 96, 0.8) 100%
            );z-index:0;pointer-events:none}/* Subtle amber glow at horizon */.hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 85%, rgba(255, 94, 58, 0.18) 0%, transparent 55%);z-index:0;pointer-events:none}/* Scroll indicator */.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:1;opacity:0.7;animation:float 2.5s ease-in-out infinite;color:white;cursor:pointer}.hero-content{max-width:900px;position:relative;z-index:1}.hero-tag{display:inline-block;background:rgba(255, 255, 255, 0.15);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(255, 255, 255, 0.35);color:#ffffff;padding:0.5rem 1.25rem;font-size:0.85rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:2rem;opacity:1;transform:translateY(0);animation:heroIntro 0.6s ease-out 0.2s both;border-radius:30px}.hero h1{font-family:'Poppins',sans-serif;font-size:clamp(2.75rem, 6vw, 5rem);font-weight:500;line-height:1.1;margin-bottom:1.5rem;opacity:1;transform:translateY(0);animation:heroIntro 0.8s ease-out 0.3s both;color:#ffffff}.hero h1 .highlight{color:#fff4e6;text-shadow:0 2px 12px rgba(8, 14, 30, 0.55);position:relative;display:inline-block}.hero-subtitle{font-size:1.25rem;color:rgba(255, 255, 255, 0.92);max-width:650px;margin:0 auto 2.5rem;line-height:1.7;opacity:1;transform:translateY(0);animation:heroIntro 0.8s ease-out 0.5s both}.hero-cta{display:inline-flex;align-items:center;gap:0.75rem;background:var(--primary);color:var(--text-light);padding:1.25rem 2.5rem;text-decoration:none;font-weight:600;font-size:1.1rem;transition:all 0.3s;opacity:1;transform:translateY(0);animation:heroIntro 0.8s ease-out 0.7s both;border-radius:12px}.hero-cta:hover{background:var(--secondary);color:var(--text-light);transform:translateY(-2px);box-shadow:0 10px 30px rgba(27, 53, 96,0.25)}.hero-cta svg{transition:transform 0.3s}.hero-cta:hover svg{transform:translateX(5px)}.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;opacity:1;transform:translateY(0);animation:heroIntro 0.8s ease-out 0.7s both}.hero-cta-secondary{display:inline-flex;align-items:center;padding:1.25rem 2.5rem;text-decoration:none;font-weight:600;font-size:1.1rem;border:2px solid rgba(255, 255, 255, 0.65);color:#ffffff;border-radius:12px;transition:all 0.3s}.hero-cta-secondary:hover{background:rgba(255, 255, 255, 0.15);border-color:rgba(255, 255, 255, 0.9);color:#ffffff;transform:translateY(-2px)}/* Examples Preview Section */.examples-preview{padding:5rem 4rem 6rem;background:var(--background-alt);text-align:center}.examples-preview-heading{font-family:'Poppins',sans-serif;font-size:clamp(1.75rem, 3.5vw, 2.5rem);font-weight:500;color:var(--text-primary);margin-bottom:0.5rem;letter-spacing:-0.02em}.examples-preview-label{font-size:1rem;color:var(--text-secondary);margin-bottom:3rem}.examples-preview-grid{display:grid;grid-template-columns:repeat(4, 1fr);gap:1.75rem;max-width:1100px;margin:0 auto 2.5rem;align-items:start}/* Card wrapper */.examples-preview-card{display:block;text-decoration:none;transition:transform 0.4s cubic-bezier(0.22, 1, 0.36, 1)}.examples-preview-card:hover{transform:translateY(-12px)}/* Phone shell */.phone-mockup{background:var(--text-primary);border-radius:36px;padding:14px 10px 20px;box-shadow:0 25px 50px rgba(27, 53, 96, 0.3),0 8px 16px rgba(0, 0, 0, 0.12),inset 0 0 0 1px rgba(255, 255, 255, 0.08);position:relative;transition:box-shadow 0.4s ease}.examples-preview-card:hover .phone-mockup{box-shadow:0 40px 70px rgba(27, 53, 96, 0.35),0 16px 28px rgba(0, 0, 0, 0.18),inset 0 0 0 1px rgba(255, 255, 255, 0.14)}/* Speaker pill */.phone-notch{width:52px;height:5px;background:rgba(255, 255, 255, 0.18);border-radius:3px;margin:0 auto 10px}/* Screen */.phone-screen{border-radius:24px;overflow:hidden;position:relative;background:#fff;aspect-ratio:9/16}.phone-screen picture{display:block;width:100%}.phone-screen img{width:100%;height:auto;display:block;transition:transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);transform-origin:top center}.examples-preview-card:hover .phone-screen img{transform:scale(1.04)}/* Hover overlay */.phone-overlay{position:absolute;inset:0;background:linear-gradient(
                to top,
                rgba(27, 53, 96, 0.92) 0%,
                rgba(27, 53, 96, 0.35) 45%,
                transparent 70%
            );border-radius:24px;opacity:0;transition:opacity 0.35s ease;display:flex;align-items:flex-end;justify-content:center;padding:1.5rem 1rem}.examples-preview-card:hover .phone-overlay{opacity:1}.phone-overlay-btn{color:#fff;font-family:'Poppins',sans-serif;font-weight:500;font-size:0.8rem;letter-spacing:0.04em;background:var(--secondary);padding:0.5rem 1.1rem;border-radius:20px;display:inline-block}/* Home bar */.phone-home-bar{width:44px;height:4px;background:rgba(255, 255, 255, 0.22);border-radius:2px;margin:12px auto 0}/* Label below phone */.examples-preview-card-label{margin-top:1rem;text-align:center}.card-trade{display:block;font-size:0.72rem;font-weight:500;text-transform:uppercase;letter-spacing:0.1em;color:var(--secondary);margin-bottom:0.2rem}.card-name{display:block;font-size:0.92rem;font-weight:500;color:var(--text-primary)}.examples-browse-link{display:inline-flex;align-items:center;gap:0.4rem;color:var(--primary);font-weight:500;font-size:0.95rem;text-decoration:none;border-bottom:2px solid var(--primary);padding-bottom:2px;transition:opacity 0.2s}.examples-browse-link:hover{opacity:0.7}@media (max-width: 900px){.examples-preview-grid{grid-template-columns:repeat(2, 1fr);gap:1.5rem;max-width:560px}}@media (max-width: 500px){.examples-preview{padding:3.5rem 1.25rem 4.5rem}.examples-preview-grid{grid-template-columns:repeat(2, 1fr);gap:1rem}}/* Founding Client Banner */.founding-banner{margin-top:1.5rem}.founding-count{display:inline-block;background:linear-gradient(135deg, #059669 0%, #10b981 100%);color:white;padding:0.75rem 1.5rem;border-radius:30px;font-weight:600;font-size:0.95rem;box-shadow:0 4px 15px rgba(5, 150, 105, 0.3)}/* Trust Badges */.trust-badges{background:var(--surface);padding:2rem 4rem;border-bottom:1px solid rgba(27, 53, 96,0.1)}.trust-badges-inner{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:2rem;max-width:900px;margin:0 auto}.trust-badge{display:flex;align-items:center;gap:0.6rem;color:var(--text-secondary);font-size:0.9rem;font-weight:500}.trust-badge-icon{width:40px;height:40px;background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-light);font-size:1.1rem;flex-shrink:0}.trust-badge span{display:flex;flex-direction:column}.trust-badge strong{color:var(--text-primary);font-weight:600}.trust-badge small{font-size:0.75rem;color:var(--text-secondary)}@media (max-width: 768px){.trust-badges{padding:1.5rem 1rem}.trust-badges-inner{gap:1.25rem}.trust-badge{font-size:0.85rem;flex:1 1 calc(50% - 1rem);min-width:140px}.trust-badge-icon{width:36px;height:36px;font-size:1rem}}@media (max-width: 480px){.trust-badge{flex:1 1 100%;justify-content:center}}/* Stats Bar */.stats-bar{background:var(--primary);padding:4rem;display:grid;grid-template-columns:repeat(3, 1fr);gap:2rem}.stat{text-align:center;color:var(--text-light)}.stat-number{font-family:'Poppins',sans-serif;font-size:3.5rem;font-weight:500;color:var(--secondary);line-height:1;margin-bottom:0.5rem}.stat-label{font-size:1rem;color:rgba(255, 255, 255, 0.8)}/* Problem Section */.problem{background:linear-gradient(135deg, #0F1E38 0%, #1B3560 100%);color:var(--text-light);padding:8rem 4rem;position:relative;overflow:hidden}.problem::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 50%, rgba(229, 62, 62, 0.08) 0%, transparent 50%);pointer-events:none}.section-header{text-align:center;margin-bottom:5rem;position:relative;z-index:1}.section-tag{display:inline-block;border:1px solid currentColor;padding:0.5rem 1rem;font-size:0.8rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;margin-bottom:1.5rem;color:var(--primary)}.problem .section-tag{color:var(--danger-light);border-color:var(--danger-light)}.section-header h2{font-family:'Poppins',sans-serif;font-size:clamp(2.5rem, 5vw, 4rem);font-weight:500;line-height:1.15;max-width:900px;margin:0 auto}.section-header p{max-width:65ch;margin-left:auto;margin-right:auto}.problem-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:2rem;max-width:900px;margin:0 auto;position:relative;z-index:1}@media (max-width: 700px){.problem-grid{grid-template-columns:1fr}}.problem-card{background:rgba(255, 255, 255, 0.03);border:1px solid rgba(255, 255, 255, 0.1);padding:2.5rem;transition:all 0.5s cubic-bezier(0.22, 1, 0.36, 1);position:relative;overflow:hidden;border-radius:16px}.problem-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:0;background:linear-gradient(180deg, var(--danger) 0%, rgba(229, 62, 62, 0.5) 100%);transition:height 0.5s cubic-bezier(0.22, 1, 0.36, 1);border-radius:4px 0 0 4px}.problem-card::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 0% 0%, rgba(229, 62, 62, 0.1) 0%, transparent 50%);opacity:0;transition:opacity 0.5s ease}.problem-card:hover::before{height:100%}.problem-card:hover::after{opacity:1}.problem-card:hover{background:rgba(255, 255, 255, 0.06);transform:translateY(-8px);box-shadow:0 20px 40px rgba(0, 0, 0, 0.3);border-color:rgba(229, 62, 62, 0.3)}.problem-icon{width:50px;height:50px;background:rgba(229, 62, 62, 0.15);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;color:var(--danger-light);border-radius:12px;transition:all 0.4s cubic-bezier(0.22, 1, 0.36, 1);position:relative;z-index:1}.problem-card:hover .problem-icon{transform:scale(1.1);background:rgba(229, 62, 62, 0.25)}.problem-card h3{font-family:'Poppins',sans-serif;font-size:1.5rem;font-weight:500;margin-bottom:1rem;position:relative;z-index:1}.problem-card p{color:rgba(255, 255, 255, 0.7);line-height:1.7;position:relative;z-index:1}/* Why You Need a Website bullets */.why-bullets{list-style:none;max-width:520px;margin:0 auto;display:flex;flex-direction:column;gap:1.25rem}.why-bullets li{color:rgba(255, 255, 255, 0.9);font-size:1.2rem;font-weight:500;padding-left:2rem;position:relative}.why-bullets li::before{content:'?';position:absolute;left:0;color:#10b981;font-weight:500}/* Solution Section - Stacking Cards */.solution{background:linear-gradient(135deg, #0F1E38 0%, #1B3560 100%);position:relative}.solution-intro{padding:6rem 4rem 2rem;text-align:center}.solution .section-tag{color:var(--secondary);border-color:var(--secondary)}.solution .section-header h2{color:var(--text-light)}/* Vertical Timeline */.timeline{position:relative;max-width:900px;margin:0 auto;padding:2rem 4rem 5rem}/* Central line */.timeline::before{content:'';position:absolute;left:50%;top:2rem;bottom:5rem;width:2px;background:linear-gradient(to bottom, transparent, var(--secondary) 10%, var(--secondary) 90%, transparent);transform:translateX(-50%)}.timeline-item{position:relative;width:50%;padding:0 2.5rem 3rem;opacity:0;transform:translateX(-30px);transition:opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1),transform 0.6s cubic-bezier(0.22, 1, 0.36, 1)}.timeline-item.revealed{opacity:1;transform:translateX(0)}/* Odd items (1, 3) go on the left */.timeline-item:nth-child(odd){left:0;text-align:right}/* Even items (2, 4) go on the right */.timeline-item:nth-child(even){left:50%;text-align:left;transform:translateX(30px)}.timeline-item:nth-child(even).revealed{transform:translateX(0)}/* Number marker on the line */.timeline-marker{position:absolute;top:0.25rem;width:48px;height:48px;border-radius:50%;background:var(--secondary);display:flex;align-items:center;justify-content:center;z-index:2;box-shadow:0 0 0 6px rgba(255, 94, 58, 0.25),0 4px 15px rgba(0, 0, 0, 0.3)}.timeline-marker span{font-family:'Poppins',sans-serif;font-weight:500;font-size:0.9rem;color:var(--text-light)}/* Position marker on the centre line */.timeline-item:nth-child(odd) .timeline-marker{right:-24px}.timeline-item:nth-child(even) .timeline-marker{left:-24px}/* Card */.timeline-card{background:rgba(255, 255, 255, 0.06);border:1px solid rgba(255, 255, 255, 0.1);border-radius:12px;padding:1.75rem;transition:background 0.3s,transform 0.3s,box-shadow 0.3s}.timeline-card:hover{background:rgba(255, 255, 255, 0.1);transform:translateY(-4px);box-shadow:0 15px 40px rgba(0, 0, 0, 0.3)}.timeline-card-icon{width:44px;height:44px;border-radius:10px;background:rgba(255, 255, 255, 0.1);display:inline-flex;align-items:center;justify-content:center;color:var(--text-light);margin-bottom:1rem}.timeline-card-icon svg{width:22px;height:22px}/* Align icon to the right for left-side cards */.timeline-item:nth-child(odd) .timeline-card-icon{float:right}.timeline-tag{display:inline-block;font-size:0.7rem;text-transform:uppercase;letter-spacing:0.15em;background:rgba(255, 255, 255, 0.15);color:var(--text-light);padding:0.35rem 0.85rem;border-radius:2rem;margin-bottom:0.75rem;font-weight:600}.timeline-card h3{font-family:'Poppins',sans-serif;font-size:1.35rem;font-weight:500;line-height:1.25;margin-bottom:0.75rem;color:var(--text-light)}.timeline-card p{font-size:0.95rem;color:rgba(255, 255, 255, 0.75);line-height:1.7}/* Stagger the reveal delays */.timeline-item:nth-child(1){transition-delay:0.1s}.timeline-item:nth-child(2){transition-delay:0.2s}.timeline-item:nth-child(3){transition-delay:0.3s}.timeline-item:nth-child(4){transition-delay:0.4s}/* Mobile timeline */@media (max-width: 768px){.timeline{padding:1rem 1.5rem 3rem}/* Line moves to the left */.timeline::before{left:24px}/* All items go full-width, aligned left */.timeline-item,.timeline-item:nth-child(odd),.timeline-item:nth-child(even){width:100%;left:0;text-align:left;padding:0 0 2rem 3.5rem;transform:translateY(20px)}.timeline-item.revealed,.timeline-item:nth-child(even).revealed{transform:translateY(0)}/* All markers on the left line */.timeline-marker,.timeline-item:nth-child(odd) .timeline-marker,.timeline-item:nth-child(even) .timeline-marker{left:0;right:auto;width:40px;height:40px}.timeline-marker span{font-size:0.8rem}.timeline-item:nth-child(odd) .timeline-card-icon{float:none}.solution-intro{padding:4rem 1.5rem 1.5rem}}@media (max-width: 480px){.timeline{padding:1rem 0.75rem 2rem}.solution-intro{padding:3rem 1rem 1rem}.timeline-card{padding:1.25rem}}/* Portfolio Section */.portfolio{background:var(--background);padding:8rem 4rem}.portfolio .section-tag{color:var(--primary);border-color:var(--primary)}.portfolio-intro{color:var(--text-secondary);font-size:1.15rem;margin-top:1rem;max-width:65ch;margin-left:auto;margin-right:auto}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:2rem;max-width:1200px;margin:3rem auto 0}.portfolio-card{background:var(--surface);padding:2.5rem;text-decoration:none;color:var(--text-primary);border:1px solid rgba(27, 53, 96,0.1);transition:all 0.5s cubic-bezier(0.22, 1, 0.36, 1);display:flex;flex-direction:column;border-radius:16px;position:relative;overflow:hidden}.portfolio-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);opacity:0;transition:opacity 0.5s cubic-bezier(0.22, 1, 0.36, 1);z-index:0}.portfolio-card:hover{color:var(--text-light);transform:translateY(-10px) scale(1.02);box-shadow:0 25px 50px rgba(27, 53, 96,0.25),0 0 0 1px rgba(255, 94, 58, 0.4);border-color:transparent}.portfolio-card:hover::before{opacity:1}.portfolio-card > *{position:relative;z-index:1}.portfolio-icon{width:60px;height:60px;background:rgba(27, 53, 96, 0.1);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;color:var(--primary);transition:all 0.5s cubic-bezier(0.22, 1, 0.36, 1);border-radius:12px}.portfolio-card:hover .portfolio-icon{background:rgba(255, 255, 255, 0.2);color:var(--text-light);transform:scale(1.1) rotate(5deg)}.portfolio-card h3{font-family:'Poppins',sans-serif;font-size:1.5rem;font-weight:500;margin-bottom:0.75rem;transition:transform 0.4s cubic-bezier(0.22, 1, 0.36, 1)}.portfolio-card:hover h3{transform:translateX(5px)}.portfolio-card p{color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem;transition:color 0.4s;flex:1}.portfolio-card:hover p{color:rgba(255, 255, 255, 0.85)}.portfolio-link{font-weight:600;color:var(--primary);transition:all 0.4s;display:inline-flex;align-items:center;gap:0.5rem}.portfolio-card:hover .portfolio-link{color:var(--text-light);transform:translateX(5px)}/* Services Section */.services{background:linear-gradient(135deg, #0F1E38 0%, #1B3560 100%);color:var(--text-light);padding:8rem 4rem}.services .section-tag{color:var(--secondary);border-color:var(--secondary)}.services-grid{display:grid;grid-template-columns:repeat(2, 1fr);gap:2rem;max-width:900px;margin:0 auto}.service-card{background:rgba(255, 255, 255, 0.03);border:1px solid rgba(255, 255, 255, 0.1);padding:3rem;transition:all 0.5s cubic-bezier(0.22, 1, 0.36, 1);border-radius:16px;position:relative;overflow:hidden}.service-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg, rgba(255, 94, 58, 0.1) 0%, transparent 60%);opacity:0;transition:opacity 0.5s ease}.service-card:hover::before{opacity:1}.service-card:hover{background:rgba(255, 255, 255, 0.08);border-color:var(--secondary);transform:translateY(-8px);box-shadow:0 20px 40px rgba(0, 0, 0, 0.3)}.service-card h3{font-family:'Poppins',sans-serif;font-size:1.5rem;font-weight:500;margin-bottom:1rem;color:var(--secondary);position:relative}.service-card p{color:rgba(255, 255, 255, 0.7);line-height:1.7;margin-bottom:1.5rem;position:relative}.service-features{list-style:none;position:relative}.service-features li{padding:0.5rem 0;color:rgba(255, 255, 255, 0.6);font-size:0.95rem;display:flex;align-items:center;gap:0.5rem;transition:color 0.3s ease,transform 0.3s ease}.service-card:hover .service-features li{color:rgba(255, 255, 255, 0.8)}.service-features li::before{content:'?';color:var(--secondary);transition:transform 0.3s ease}.service-card:hover .service-features li::before{transform:translateX(3px)}/* CTA Section */.cta{background:linear-gradient(135deg, var(--secondary) 0%, var(--tertiary) 100%);padding:8rem 4rem;text-align:center;position:relative;overflow:hidden}.cta::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.08'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:0.5}.cta-content{position:relative;z-index:1;max-width:700px;margin:0 auto}.cta h2{font-family:'Poppins',sans-serif;font-size:clamp(2.5rem, 5vw, 3.5rem);font-weight:500;color:var(--text-light);margin-bottom:1.5rem}.cta p{font-size:1.2rem;color:rgba(255, 255, 255, 0.85);margin-bottom:2.5rem}.cta-guide-bonus{display:flex;flex-direction:column;align-items:flex-start;gap:0.5rem;margin-top:0.75rem;margin-bottom:0}.cta-guide-icon{color:rgba(255, 255, 255, 0.85)}.cta-guide-bonus p{font-size:0.9rem;color:rgba(255, 255, 255, 0.85);margin:0}.cta-guide-link{color:#ffffff;font-weight:600;text-decoration:underline;text-underline-offset:3px;transition:opacity 0.2s}.cta-guide-link:hover{opacity:0.8}.cta-button{display:inline-flex;align-items:center;gap:0.75rem;background:var(--text-light);color:var(--primary);padding:1.25rem 3rem;text-decoration:none;font-weight:600;font-size:1.1rem;transition:all 0.3s;border-radius:12px}.cta-button:hover{transform:translateY(-3px);box-shadow:0 15px 40px rgba(0, 0, 0, 0.2);background:var(--primary);color:var(--text-light)}/* Contact Form Styles */.trust-credibility{max-width:600px;margin:0 auto 2rem;text-align:left;background:rgba(255, 255, 255, 0.08);border:1px solid rgba(255, 255, 255, 0.15);border-radius:14px;padding:1.75rem 2rem;backdrop-filter:blur(10px)}.trust-credibility h3{color:white;font-size:1.15rem;font-weight:500;margin-bottom:1rem}.trust-bullets{list-style:none;display:flex;flex-direction:column;gap:0.65rem}.trust-bullets li{color:rgba(255, 255, 255, 0.9);font-size:0.95rem;padding-left:1.75rem;position:relative}.trust-bullets li::before{content:'\2713';position:absolute;left:0;color:#ffffff;font-weight:500}.hero-pricing-note{font-size:1.05rem;font-weight:600;color:var(--secondary);margin-top:0.5rem;margin-bottom:0.25rem;letter-spacing:0.02em}.contact-form-wrapper{max-width:600px;margin:0 auto}.contact-choice{display:flex;align-items:center;justify-content:space-between;gap:1.25rem;margin-bottom:1.5rem;padding:1.25rem;text-align:left;background:rgba(255, 255, 255, 0.1);border:1px solid rgba(255, 255, 255, 0.18);border-radius:14px;backdrop-filter:blur(10px)}.contact-choice strong{display:block;color:#fff;font-family:'Poppins',sans-serif;font-size:1rem;font-weight:600;margin-bottom:0.25rem}.contact-choice p{color:rgba(255, 255, 255, 0.82);font-size:0.92rem;line-height:1.5;margin:0}.whatsapp-contact-btn{display:inline-flex;align-items:center;justify-content:center;gap:0.5rem;flex-shrink:0;min-height:44px;padding:0.85rem 1.1rem;color:#075e54;background:#fff;border-radius:10px;font-family:'Poppins',sans-serif;font-size:0.92rem;font-weight:600;text-decoration:none;transition:transform 0.2s ease,box-shadow 0.2s ease,background 0.2s ease}.whatsapp-contact-btn:hover{background:#f2fff8;transform:translateY(-2px);box-shadow:0 12px 28px rgba(0, 0, 0, 0.18)}@media (max-width: 620px){.contact-choice{align-items:stretch;flex-direction:column}.whatsapp-contact-btn{width:100%}}.contact-form{display:grid;gap:1.25rem;text-align:left}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media (max-width: 500px){.form-row{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:0.5rem}.form-group label{font-size:0.9rem;font-weight:600;color:rgba(255, 255, 255, 0.95);text-transform:uppercase;letter-spacing:0.05em}.form-group label .optional{font-weight:400;text-transform:none;letter-spacing:0;opacity:0.7}.contact-form input,.contact-form select,.contact-form textarea{width:100%;padding:1rem 1.25rem;font-family:'Poppins',sans-serif;font-size:1rem;border:2px solid rgba(255, 255, 255, 0.2);background:rgba(255, 255, 255, 0.1);color:white;border-radius:10px;transition:all 0.3s ease;backdrop-filter:blur(10px)}.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(255, 255, 255, 0.5)}.contact-form select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.7)' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;background-size:1.25rem;padding-right:3rem}.contact-form select option{background:var(--primary);color:white}.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:rgba(255, 255, 255, 0.6);background:rgba(255, 255, 255, 0.15);box-shadow:0 0 0 4px rgba(255, 255, 255, 0.1)}.contact-form textarea{min-height:120px;resize:vertical}.submit-btn{display:inline-flex;align-items:center;justify-content:center;gap:0.75rem;padding:1.25rem 2.5rem;font-family:'Poppins',sans-serif;font-size:1.1rem;font-weight:600;background:white;color:var(--primary);border:none;border-radius:12px;cursor:pointer;transition:all 0.3s ease;margin-top:0.5rem}.submit-btn:hover{transform:translateY(-3px);box-shadow:0 15px 40px rgba(0, 0, 0, 0.2);background:var(--background)}.submit-btn:disabled{opacity:0.6;cursor:not-allowed;transform:none}.submit-btn.loading{color:transparent;position:relative}.submit-btn.loading::after{content:'';position:absolute;width:24px;height:24px;border:3px solid rgba(27, 53, 96,0.3);border-top-color:var(--primary);border-radius:50%;animation:spin 0.8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}/* Success State */.form-success{text-align:center;padding:2rem 0;animation:fadeUp 0.5s ease}.success-icon{width:80px;height:80px;background:rgba(255, 255, 255, 0.2);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;animation:scaleIn 0.5s ease}@keyframes scaleIn{from{transform:scale(0);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.success-icon svg{width:40px;height:40px;stroke:white;stroke-width:3}.form-success h3{font-size:1.75rem;margin-bottom:0.75rem;color:white}.form-success p{font-size:1.1rem;color:rgba(255, 255, 255, 0.85);max-width:400px;margin:0 auto}/* (Footer, Nav, Mobile Menu styles in shared.css) */.mobile-submenu a{padding:0.85rem 1.5rem 0.85rem 2.5rem;font-size:0.95rem;border-bottom:1px solid rgba(27, 53, 96,0.05);color:var(--text-primary)}.mobile-submenu a:hover{background:rgba(27, 53, 96, 0.08);color:var(--primary)}.mobile-submenu-label{padding:0.6rem 1.5rem 0.4rem 2.5rem;font-size:0.75rem;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--primary);background:var(--surface)}.mobile-menu-links .home-link{color:var(--primary);font-weight:600}/* Responsive ? breakpoints handled in shared.css */@media (max-width: 768px){.hero{padding:7rem 1.5rem 3rem}.hero h1{font-size:clamp(2rem, 8vw, 3rem)}.hero-subtitle{font-size:1.05rem}.hero-cta{padding:1rem 2rem;font-size:1rem}.problem,.portfolio,.comparison,.services,.cta{padding:4rem 1.5rem}/* Solution section */.solution{padding:0}.stats-bar{grid-template-columns:1fr;padding:2.5rem 1.5rem}.stat-number{font-size:2.5rem}.comparison-container{grid-template-columns:1fr}.services-grid{grid-template-columns:1fr}.section-header h2{font-size:clamp(1.75rem, 6vw, 2.5rem)}.portfolio-grid,.problem-grid{grid-template-columns:1fr}}@media (max-width: 480px){.hero{padding:6rem 1rem 2.5rem}.hero h1{font-size:1.75rem}.problem,.solution,.portfolio,.comparison,.services,.cta{padding:3rem 1rem}}/* Founder intro in hero */.hero-founder{display:inline-flex;align-items:center;gap:0.85rem;margin-bottom:1.5rem;opacity:1;transform:translateY(0);animation:heroIntro 0.8s ease-out 0.1s both}.hero-founder-photo{width:60px;height:60px;border-radius:50%;border:2px solid rgba(255, 255, 255, 0.6);object-fit:cover;flex-shrink:0}.hero-founder-text{color:rgba(255, 255, 255, 0.9);font-size:1rem;text-align:left;line-height:1.4}.hero-founder-text strong{display:block;font-weight:600;color:#ffffff}/* Availability message */.hero-availability{font-size:0.9rem;color:rgba(255, 255, 255, 0.75);margin:0.75rem 0 0.25rem;letter-spacing:0.01em;min-height:1.4em}.hero-availability::before{content:'';display:inline-block;width:0.55em;height:0.55em;border-radius:50%;background:#22c55e;margin-right:0.45em;vertical-align:0.05em}/* Secondary CTA as text link */.hero-link{color:rgba(255, 255, 255, 0.85);text-decoration:underline;text-underline-offset:3px;font-size:0.95rem;transition:color 0.2s;align-self:center}.hero-link:hover{color:#ffffff}/* ── Why Michael / Meet the founder section ── */.why-michael{background:var(--surface, #fff);padding:4.5rem 4rem 4rem;border-bottom:1px solid rgba(27, 53, 96, 0.08)}.why-michael-inner{max-width:900px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:2.5rem}.why-michael-intro{display:flex;align-items:center;gap:2rem;text-align:left}.why-michael-photo{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid rgba(27, 53, 96, 0.15);flex-shrink:0;transition:transform 0.22s ease,box-shadow 0.22s ease}@media (hover: hover) and (pointer: fine){.why-michael-intro:hover .why-michael-photo{transform:scale(1.06);box-shadow:0 8px 24px rgba(0, 0, 0, 0.22)}}.why-michael-text strong{display:block;font-family:'Poppins',sans-serif;font-size:1.35rem;font-weight:600;color:var(--text-primary, #0F1E38);margin-bottom:0.5rem}.why-michael-text p{font-size:1.05rem;color:var(--text-secondary, #4A5A7A);line-height:1.7;max-width:56ch;margin:0}@media (max-width: 640px){.why-michael{padding:3.5rem 1.5rem 3rem}.why-michael-intro{flex-direction:column;text-align:center}.why-michael-text p{margin:0 auto}}@media (prefers-reduced-motion: reduce){.why-michael-photo{transition:none}}