/* --- home.css --- */

/* --- RESET --- */
html,body{overflow-x:hidden;width:100%;margin:0;padding:0}
*,*::before,*::after{box-sizing:border-box}
.hidden{display:none!important}

/* --- HERO SECTION --- */
.hero-section{position:relative;padding-top:10rem;padding-bottom:6rem;overflow-x:hidden;width:100%}
.hero-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:900px;height:900px;background:radial-gradient(circle,rgba(0,123,255,.1) 0%,rgba(0,123,255,0) 70%);border-radius:50%;filter:blur(80px);z-index:-1;pointer-events:none}
.hero-grid-overlay{position:absolute;inset:0;background-image:linear-gradient(var(--glass-border) 1px,transparent 1px),linear-gradient(90deg,var(--glass-border) 1px,transparent 1px);background-size:60px 60px;opacity:.4;z-index:-1;mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 40%,transparent 100%);-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 40%,transparent 100%);pointer-events:none}
.container{max-width:1150px;margin:0 auto;padding:0 1.5rem;width:100%}
.text-center{text-align:center}
.hero-badge{display:inline-flex;align-items:center;gap:.625rem;padding:.5rem 1.25rem;border-radius:9999px;background-color:var(--glass-bg);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid var(--glass-border);margin-bottom:2rem;box-shadow:var(--shadow-ios)}
.badge-dot-wrapper{position:relative;display:flex;width:.5rem;height:.5rem}
.badge-dot{width:100%;height:100%;border-radius:50%;background-color:var(--cpw-primary);box-shadow:0 0 10px var(--cpw-primary),0 0 20px rgba(0,123,255,.4)}
.badge-text{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--cpw-text)}
.hero-title{font-size:2.25rem;font-weight:800;line-height:1.12;margin-bottom:1.5rem;color:var(--cpw-text);letter-spacing:-.03em}
.text-gradient{background:linear-gradient(135deg,var(--cpw-primary),#60a5fa);-webkit-background-clip:text;color:transparent;display:inline-block}
.hero-subtitle{font-size:1.125rem;color:var(--cpw-text);opacity:.75;line-height:1.8;max-width:44rem;margin:0 auto 3rem;font-weight:400}
.hero-actions{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;margin-bottom:6rem}
.hero-trust{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.75rem 1.5rem;margin-bottom:3rem}
.trust-item{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:600;color:var(--cpw-text);opacity:.65}
.trust-item i{color:var(--cpw-primary);font-size:.875rem}
.trust-divider{width:4px;height:4px;border-radius:50%;background-color:var(--glass-border);flex-shrink:0}

/* Boutons avec reflet interne */
.btn-primary-large{background:linear-gradient(135deg,var(--cpw-primary),#2563eb);color:#fff;padding:1rem 2.5rem;border-radius:9999px;font-weight:700;font-size:1.125rem;box-shadow:0 8px 24px -4px rgba(0,123,255,.45),inset 0 1px 0 rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.15);width:100%;position:relative;overflow:hidden}
.btn-primary-large::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 60%);border-radius:9999px;pointer-events:none}
.btn-primary-large:hover{box-shadow:0 12px 32px -4px rgba(0,123,255,.55),inset 0 1px 0 rgba(255,255,255,.2)}
.btn-outline-large{padding:1rem 2.5rem;border-radius:9999px;font-weight:700;font-size:1.125rem;border:1px solid var(--glass-border);width:100%;background-color:var(--glass-bg);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);color:var(--cpw-text);box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.06)}
.btn-outline-large:hover{background-color:var(--hover-bg)}

/* Tech stack card avec double bordure */
.tech-stack-card{background-color:var(--glass-bg);backdrop-filter:blur(40px) saturate(200%);-webkit-backdrop-filter:blur(40px) saturate(200%);border:1px solid var(--glass-border);box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.08);border-radius:2rem;padding:2rem;max-width:56rem;margin:0 auto;display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:2rem}
.tech-stack-title{font-size:.8125rem;font-weight:800;color:var(--cpw-text);opacity:.6;text-transform:uppercase;letter-spacing:.14em}
.tech-stack-icons{display:flex;flex-wrap:wrap;justify-content:center;gap:2.5rem;font-size:2.25rem}
.tech-stack-icons i{opacity:.4;filter:grayscale(100%);cursor:help}
.tech-stack-icons i:hover{filter:grayscale(0%);opacity:1}
.tech-stack-icons i.fa-react:hover{color:#61DAFB}
.tech-stack-icons i.fa-wordpress:hover{color:#21759B}
.tech-stack-icons i.fa-php:hover{color:#777BB4}
.tech-stack-icons i.fa-js:hover{color:#F7DF1E}
.tech-stack-icons i.fa-html5:hover{color:#E34F26}

/* --- UTILITAIRES SECTIONS --- */
.section-subtitle{color:var(--cpw-primary);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.8125rem;display:block;margin-bottom:.875rem}
.section-title{font-size:2.25rem;font-weight:800;color:var(--cpw-text);letter-spacing:-.025em;line-height:1.18}

/* --- SERVICES SECTION --- */
.services-section{padding:7rem 0;position:relative;overflow-x:hidden;width:100%}
.section-header{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:4rem}
.header-titles{max-width:42rem}
.header-desc{color:var(--cpw-text);opacity:.75;font-size:1.0625rem;max-width:28rem;line-height:1.75}
.services-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;width:100%}

/* Cards avec effet shine au hover */
.service-card{background-color:var(--glass-bg);backdrop-filter:blur(40px) saturate(200%);-webkit-backdrop-filter:blur(40px) saturate(200%);border:1px solid var(--glass-border);box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.06);padding:2.5rem 2rem;border-radius:2rem;position:relative;overflow:hidden}
.service-card-inner{position:relative;z-index:1}
.service-card-shine{position:absolute;top:-60%;left:-60%;width:100%;height:100%;background:radial-gradient(circle at top left,rgba(255,255,255,.07) 0%,transparent 60%);pointer-events:none;z-index:0;border-radius:2rem}
.service-card:hover{box-shadow:0 20px 50px -12px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.08);background-color:var(--glass-highlight)}
.service-icon{width:3.5rem;height:3.5rem;border-radius:1.125rem;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.375rem;margin-bottom:1.75rem;box-shadow:0 8px 20px -4px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.25)}
.box-blue{background:linear-gradient(145deg,#3b82f6,#22d3ee)}
.box-purple{background:linear-gradient(145deg,#a855f7,#ec4899)}
.box-orange{background:linear-gradient(145deg,#fb923c,#ef4444)}
.service-card h3{font-size:1.1875rem;font-weight:800;margin-bottom:1rem;color:var(--cpw-text);letter-spacing:-.015em;line-height:1.3}
.service-card p{color:var(--cpw-text);opacity:.65;line-height:1.75;font-size:.9375rem}
.services-footer{text-align:center;margin-top:4rem}
.link-arrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--cpw-primary)}
.link-arrow:hover{gap:.875rem;color:#2563eb}

/* --- ARGUMENTS SECTION --- */
.arguments-section{padding:8rem 0;background-color:var(--hover-bg);overflow-x:hidden;width:100%;position:relative}
.arguments-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(0,123,255,.04) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(96,165,250,.04) 0%,transparent 50%);pointer-events:none}
.arguments-container{display:flex;flex-direction:column;gap:8rem;position:relative;z-index:1}
.argument-row{display:flex;flex-direction:column;align-items:center;gap:4rem}
.icon-circle{width:3.5rem;height:3.5rem;border-radius:50%;background-color:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:var(--cpw-primary);display:flex;align-items:center;justify-content:center;font-size:1.25rem;box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.08);border:1px solid var(--glass-border);margin-bottom:1.5rem}
.argument-content h2{font-size:2rem;font-weight:800;line-height:1.18;margin-bottom:1.5rem;color:var(--cpw-text);letter-spacing:-.025em}
.argument-content p{font-size:1.0625rem;color:var(--cpw-text);opacity:.75;line-height:1.8;margin-bottom:2rem}
.features-list{display:flex;flex-direction:column;gap:.875rem}
.feature-item{display:flex;align-items:center;gap:1.25rem;padding:1.375rem 1.25rem;border-radius:1.25rem;background-color:var(--glass-bg);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border:1px solid var(--glass-border);box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.05)}
.feature-item:hover{background-color:var(--glass-highlight)}
.feature-icon{width:3rem;height:3rem;border-radius:.875rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.0625rem}
.icon-green{background-color:rgba(34,197,94,.12);color:#16a34a;box-shadow:inset 0 1px 0 rgba(255,255,255,.1)}
.icon-purple{background-color:rgba(168,85,247,.12);color:#9333ea;box-shadow:inset 0 1px 0 rgba(255,255,255,.1)}
.feature-item h4{font-weight:800;font-size:.9375rem;color:var(--cpw-text);margin-bottom:.3rem;letter-spacing:-.01em}
.feature-item p{font-size:.8125rem;color:var(--cpw-text);opacity:.65;margin:0;line-height:1.55}
.link-primary{font-weight:700;color:var(--cpw-primary);text-decoration:none;position:relative}
.link-primary::after{content:'';position:absolute;width:100%;transform:scaleX(0);height:2px;bottom:-4px;left:0;background-color:var(--cpw-primary);transform-origin:bottom right}
.link-primary:hover::after{transform:scaleX(1);transform-origin:bottom left}
.argument-image-wrapper{position:relative;width:100%}
.image-glow{position:absolute;top:-2rem;right:-2rem;bottom:-2rem;left:-2rem;border-radius:3rem;opacity:.12;filter:blur(60px);z-index:0}
.argument-image-wrapper:hover .image-glow{opacity:.22}
.glow-purple{background:linear-gradient(135deg,var(--cpw-primary),#a855f7)}
.glow-blue{background:linear-gradient(135deg,#60a5fa,#67e8f9)}
.argument-img{position:relative;z-index:10;border-radius:2rem;box-shadow:0 24px 60px -12px rgba(0,0,0,.18),var(--shadow-ios);border:1px solid var(--glass-border);width:100%;height:auto}

/* --- TESTIMONIALS SECTION --- */
.testimonials-section{padding:8rem 0;position:relative;overflow-x:hidden;width:100%}
.testimonials-intro{color:var(--cpw-text);opacity:.7;font-size:1.0625rem;max-width:36rem;margin:1rem auto 0;line-height:1.75}
.testimonials-stats{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0;background-color:var(--glass-bg);backdrop-filter:blur(40px) saturate(200%);-webkit-backdrop-filter:blur(40px) saturate(200%);border:1px solid var(--glass-border);box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.07);border-radius:2rem;padding:2rem;margin:3rem auto 5rem;max-width:640px}
.tstat-item{flex:1;text-align:center;padding:1rem;min-width:120px}
.tstat-number{font-size:2.75rem;font-weight:800;background:linear-gradient(135deg,var(--cpw-primary),#60a5fa);-webkit-background-clip:text;color:transparent;letter-spacing:-.03em;line-height:1}
.tstat-suffix{font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,var(--cpw-primary),#60a5fa);-webkit-background-clip:text;color:transparent}
.tstat-label{display:block;font-size:.75rem;font-weight:700;color:var(--cpw-text);opacity:.55;text-transform:uppercase;letter-spacing:.1em;margin-top:.5rem}
.tstat-divider{width:1px;height:3rem;background:linear-gradient(to bottom,transparent,var(--glass-border),transparent);flex-shrink:0}
.testimonials-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;width:100%}
.testimonial-card{padding:2rem;border-radius:2rem;display:flex;flex-direction:column;gap:1.25rem;background-color:var(--glass-bg);backdrop-filter:blur(32px) saturate(180%);-webkit-backdrop-filter:blur(32px) saturate(180%);border:1px solid var(--glass-border);box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.06);position:relative;overflow:hidden}
.testimonial-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent)}
.testimonial-card:hover{box-shadow:0 20px 50px -12px rgba(0,123,255,.1),inset 0 1px 0 rgba(255,255,255,.08);border-color:rgba(0,123,255,.15)}
.testimonial-header{display:flex;align-items:center;justify-content:space-between}
.testimonial-quote-mark{font-size:1.25rem;color:var(--cpw-primary);opacity:.25}
.testimonial-stars{display:flex;gap:.2rem;font-size:.875rem}
.testimonial-stars i{color:var(--cpw-muted)}
.testimonial-stars i.active{color:#f59e0b}
.testimonial-text{font-size:.9375rem;line-height:1.8;color:var(--cpw-text);opacity:.82;flex:1;font-style:italic}
.testimonial-author{display:flex;align-items:center;gap:1rem;padding-top:1.125rem;border-top:1px solid var(--glass-border)}
.testimonial-avatar{width:3rem;height:3rem;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--glass-border);box-shadow:0 4px 10px -2px rgba(0,0,0,.12)}
.testimonial-avatar img{width:100%;height:100%;object-fit:cover}
.testimonial-avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--cpw-primary),#60a5fa);display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:1.125rem}
.testimonial-author-info{display:flex;flex-direction:column;gap:.15rem}
.author-name{font-size:.9375rem;font-weight:800;color:var(--cpw-text);letter-spacing:-.01em}
.author-role{font-size:.8125rem;color:var(--cpw-muted);font-weight:500}
.testimonials-cta{text-align:center;margin-top:4rem}
.author-margin{margin-left:.5rem}
.testimonials-placeholder{text-align:center;padding:4rem;background:var(--glass-bg);border-radius:2rem;border:1px solid var(--glass-border)}
.testimonials-placeholder p{margin-bottom:1rem;color:var(--cpw-text)}

/* --- PORTFOLIO PREVIEW --- */
.portfolio-preview-section{padding:7rem 0;position:relative;overflow-x:hidden;width:100%}
.portfolio-preview-intro{color:var(--cpw-text);opacity:.7;font-size:1.0625rem;max-width:36rem;margin:1rem auto 0;line-height:1.75}
.portfolio-preview-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:4rem;width:100%}
@media(min-width:768px){.portfolio-preview-grid{grid-template-columns:repeat(3,1fr)}}
.portfolio-preview-card{background-color:var(--glass-bg);backdrop-filter:blur(40px) saturate(200%);border:1px solid var(--glass-border);box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.06);border-radius:1.75rem;overflow:hidden;display:flex;flex-direction:column;height:100%}
.portfolio-preview-card:hover{box-shadow:0 24px 50px -12px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.08);border-color:rgba(0,123,255,.2)}
.preview-img-wrapper{position:relative;overflow:hidden;height:200px;flex-shrink:0}
.preview-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden}
.preview-placeholder::before{content:'';position:absolute;inset:0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:0}
.preview-placeholder::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);z-index:2}
.preview-placeholder i{font-size:2.5rem;margin-bottom:.75rem;position:relative;z-index:1;filter:drop-shadow(0 4px 12px rgba(0,0,0,.25))}
.preview-placeholder span{font-size:.8125rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;position:relative;z-index:1;background:rgba(0,0,0,.3);padding:.3rem .875rem;border-radius:9999px;backdrop-filter:blur(4px)}
.preview-placeholder-ricc{background:linear-gradient(145deg,#1e3a5f,#2563eb)}.preview-placeholder-ricc i,.preview-placeholder-ricc span{color:#fff}
.preview-placeholder-given{background:linear-gradient(145deg,#b45309,#f59e0b)}.preview-placeholder-given i,.preview-placeholder-given span{color:#fff}
.preview-placeholder-faif{background:linear-gradient(145deg,#6b21a5,#a855f7)}.preview-placeholder-faif i,.preview-placeholder-faif span{color:#fff}
.preview-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.92) 0%,rgba(0,0,0,.45) 55%,transparent 100%);opacity:0;display:flex;align-items:flex-end;padding:1.25rem;z-index:10}
.portfolio-preview-card:hover .preview-overlay{opacity:1}
.preview-overlay-content{color:#fff}
.preview-overlay-content h3{font-size:1.125rem;font-weight:800;margin:.25rem 0;color:#fff}
.preview-overlay-content p{font-size:.75rem;opacity:.82;margin-bottom:.75rem;line-height:1.45;color:#fff}
.preview-tag{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;background:linear-gradient(135deg,var(--cpw-primary),#2563eb);color:#fff;box-shadow:0 4px 12px -2px rgba(0,123,255,.4)}
.preview-link{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .9rem;border-radius:9999px;background-color:#fff;color:#0f172a;font-size:.75rem;font-weight:700;text-decoration:none;box-shadow:0 4px 12px rgba(0,0,0,.2)}
.preview-link:hover{background-color:var(--cpw-primary);color:#fff}
.preview-card-body{padding:1.375rem;display:flex;flex-direction:column;gap:.5rem;flex:1;border-top:1px solid var(--glass-border)}
.preview-card-title{font-size:1rem;font-weight:800;color:var(--cpw-text);line-height:1.3;margin:0;letter-spacing:-.01em}
.portfolio-preview-card:hover .preview-card-title{color:var(--cpw-primary)}
.preview-card-desc{font-size:.8125rem;color:var(--cpw-text);opacity:.65;line-height:1.55;flex:1;margin:0}
.preview-result{display:inline-flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:700;color:var(--cpw-primary);background-color:rgba(0,123,255,.08);padding:.3rem .75rem;border-radius:9999px;width:fit-content;border:1px solid rgba(0,123,255,.12)}
.preview-result i{font-size:.6875rem}
.portfolio-preview-footer{text-align:center;margin-top:4rem}
.portfolio-preview-footer .link-arrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--cpw-primary);text-decoration:none}
.portfolio-preview-footer .link-arrow:hover{gap:.875rem;color:#2563eb}

/* --- BLOG SECTION --- */
.blog-section{padding:7rem 0;position:relative;overflow-x:hidden;width:100%}
.center{align-items:center;text-align:center}
.blog-grid{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:4rem;width:100%}
.blog-card{background-color:var(--panel-bg);border-radius:2rem;border:1px solid var(--glass-border);overflow:hidden;box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.05);display:flex;flex-direction:column;height:100%}
.blog-card:hover{box-shadow:0 20px 50px -12px rgba(0,0,0,.14),inset 0 1px 0 rgba(255,255,255,.07);border-color:rgba(0,123,255,.15)}
.blog-img-wrapper{display:block;height:14rem;position:relative;overflow:hidden}
.blog-img{width:100%;height:100%;object-fit:cover}
.blog-card:hover .blog-img{transform:scale(1.04)}
.blog-img-placeholder{width:100%;height:100%;background-color:var(--hover-bg);display:flex;align-items:center;justify-content:center;color:var(--cpw-muted);font-size:2.5rem}
.blog-date{position:absolute;top:1rem;left:1rem;background-color:var(--glass-bg);backdrop-filter:blur(16px) saturate(200%);-webkit-backdrop-filter:blur(16px) saturate(200%);padding:.375rem .875rem;border-radius:.875rem;font-size:.75rem;font-weight:800;color:var(--cpw-text);border:1px solid var(--glass-border);box-shadow:0 4px 12px rgba(0,0,0,.1)}
.blog-content{padding:2rem;display:flex;flex-direction:column;flex:1}
.blog-title{font-size:1.1875rem;font-weight:800;color:var(--cpw-text);margin-bottom:1rem;line-height:1.3;letter-spacing:-.015em}
.blog-card:hover .blog-title{color:var(--cpw-primary)}
.blog-excerpt{color:var(--cpw-text);opacity:.65;font-size:.9375rem;line-height:1.7;margin-bottom:1.5rem;flex:1}
.blog-footer{text-align:center}
.btn-outline{display:inline-block;padding:1rem 2.5rem;border-radius:9999px;border:1px solid var(--glass-border);background-color:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);font-size:.9375rem;font-weight:700;color:var(--cpw-text);box-shadow:var(--shadow-ios)}
.btn-outline:hover{background-color:var(--hover-bg)}

/* --- NEWSLETTER SECTION --- */
.newsletter-section{padding:6rem 0;position:relative;overflow-x:hidden;width:100%}
.newsletter-box{background-color:#fff!important;backdrop-filter:blur(40px) saturate(200%);-webkit-backdrop-filter:blur(40px) saturate(200%);border:1px solid var(--glass-border);box-shadow:var(--shadow-ios),inset 0 1px 0 rgba(255,255,255,.07);border-radius:2.5rem;padding:4rem 2rem;text-align:center;position:relative;overflow:hidden}
[data-theme="dark"] .newsletter-box{background-color:rgba(15,23,42,.85)!important}
.newsletter-box::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.14),transparent)}
.newsletter-icon{width:auto!important;height:auto!important;border-radius:0!important;background:none!important;box-shadow:none!important;border:none!important;font-size:2.5rem!important;color:var(--cpw-primary)!important;margin-bottom:1.5rem;display:block!important;align-items:unset!important;justify-content:unset!important}
.newsletter-title{font-size:2rem;font-weight:800;margin-bottom:1rem;color:var(--cpw-text);letter-spacing:-.025em;line-height:1.25}
.newsletter-desc{color:var(--cpw-text);opacity:.7;max-width:38rem;margin:0 auto 2.5rem;line-height:1.75;font-size:1.0625rem}
.newsletter-form{max-width:520px;margin:0 auto}
.newsletter-form-inner{display:flex;flex-direction:column;gap:.875rem}
.newsletter-input{flex:1;background-color:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:9999px;padding:.9375rem 1.75rem;font-size:.9375rem;color:var(--cpw-text);outline:none;box-shadow:inset 0 2px 4px rgba(0,0,0,.05);font-family:inherit}
.newsletter-input:focus{border-color:var(--cpw-primary);box-shadow:0 0 0 3px rgba(0,123,255,.12),inset 0 2px 4px rgba(0,0,0,.05)}
.newsletter-input::placeholder{color:var(--cpw-muted)}
.newsletter-submit{flex-shrink:0;cursor:pointer}
.newsletter-success{display:none;align-items:center;justify-content:center;gap:.625rem;color:#22c55e;font-weight:700;padding:1rem;font-size:.9375rem}
.newsletter-success.visible{display:flex}
.newsletter-privacy{font-size:.8125rem;color:var(--cpw-muted);margin-top:1rem}
.newsletter-privacy a{color:var(--cpw-primary);font-weight:600}
@media(min-width:640px){.newsletter-form-inner{flex-direction:row}.newsletter-submit{width:auto;white-space:nowrap}}
@media(min-width:768px){.newsletter-box{padding:5rem 4rem}.newsletter-title{font-size:2.5rem}}

/* --- CTA SECTION --- */
.cta-section{padding:6rem 0;position:relative;overflow-x:hidden;width:100%}
.cta-card{background-color:#0a0f1e;color:#fff;border-radius:2.5rem;padding:4rem 2rem;text-align:center;box-shadow:0 30px 60px -16px rgba(0,0,0,.4);position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.cta-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);pointer-events:none}
.cta-hover-layer{position:absolute;inset:0;background:radial-gradient(circle at center,rgba(255,255,255,.06) 0%,transparent 65%);opacity:0;pointer-events:none}
.cta-card:hover .cta-hover-layer{opacity:1}
.cta-glow{position:absolute;top:-8rem;right:-8rem;width:22rem;height:22rem;background-color:var(--cpw-primary);border-radius:50%;filter:blur(130px);opacity:.35;pointer-events:none}
.cta-glow-secondary{top:auto;right:auto;bottom:-8rem;left:-8rem;background-color:#60a5fa;opacity:.2}
.cta-title{font-size:2rem;font-weight:800;margin-bottom:1.5rem;position:relative;z-index:10;line-height:1.2;letter-spacing:-.025em}
.cta-desc{font-size:1.0625rem;opacity:.75;margin:0 auto 3rem;max-width:44rem;position:relative;z-index:10;line-height:1.7}
.cta-actions{position:relative;z-index:10;display:flex;flex-direction:column;justify-content:center;gap:1rem}
.btn-white{background-color:#fff;color:#0a0f1e;padding:1rem 2.5rem;border-radius:9999px;font-weight:700;font-size:1.0625rem;box-shadow:0 8px 24px -4px rgba(255,255,255,.15),inset 0 1px 0 rgba(255,255,255,.5)}
.btn-white:hover{box-shadow:0 12px 32px -4px rgba(255,255,255,.2)}
.btn-outline-white{padding:1rem 2.5rem;border-radius:9999px;font-weight:700;font-size:1.0625rem;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(12px);color:#fff;background-color:rgba(255,255,255,.05)}
.btn-outline-white:hover{background-color:rgba(255,255,255,.1)}

/* --- RESPONSIVE MEDIA QUERIES --- */
@media(min-width:640px){
    .hero-actions{flex-direction:row}
    .btn-primary-large,.btn-outline-large{width:auto}
    .cta-actions{flex-direction:row}
    .newsletter-form-inner{flex-direction:row}
    .newsletter-submit{width:auto;white-space:nowrap}
}
@media(min-width:768px){
    .hero-title{font-size:3rem}
    .hero-subtitle{font-size:1.25rem}
    .tech-stack-card{flex-direction:row;padding:2rem 3rem;text-align:left}
    .section-title{font-size:2.75rem}
    .section-header{flex-direction:row;justify-content:space-between;align-items:flex-end}
    .section-header .header-desc{text-align:right}
    .services-grid{grid-template-columns:repeat(3,1fr)}
    .argument-content h2{font-size:2.5rem}
    .blog-grid{grid-template-columns:repeat(3,1fr)}
    .cta-card{padding:6rem}
    .cta-title{font-size:3rem}
    .newsletter-box{padding:5rem 4rem}
    .newsletter-title{font-size:2.5rem}
    .testimonials-grid{grid-template-columns:repeat(2,1fr)}
    .portfolio-preview-grid{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:1024px){
    .hero-section{padding-top:13rem;padding-bottom:10rem}
    .hero-title{font-size:4rem}
    .argument-row{flex-direction:row}
    .argument-row.reverse{flex-direction:row-reverse}
    .argument-content,.argument-image-wrapper{width:50%}
    .testimonials-grid{grid-template-columns:repeat(3,1fr)}
    .portfolio-preview-grid{grid-template-columns:repeat(3,1fr)}
}