/*
Theme Name: Ahmed Youssef - Social Media
Theme URI: https://ahmedyoussef.com
Author: Ahmed Youssef
Description: Custom theme for Ahmed Youssef Social Media Consultation portfolio
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: ahmed-theme
*/

/* ===== CSS Variables ===== */
:root{
  --brand-green:#245C44;
  --brand-green-dark:#1a4538;
  --brand-green-soft:#2d7a5e;
  --accent:#358f6d;
  --accent-soft:#e8f5f0;
  --text:#171421;
  --muted:#5a6b63;
  --border:#dce8e3;
  --shadow:0 18px 50px rgba(36,92,68,.08);
  --container:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Poppins',sans-serif;color:var(--text);background:#fff;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

.container{width:min(var(--container),calc(100% - 32px));margin-inline:auto}

/* Navbar */
.navbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);background:rgba(255,255,255,.86);border-bottom:1px solid rgba(220,232,227,.85);transition:box-shadow .3s ease}
.navbar.scrolled{box-shadow:0 4px 24px rgba(36,92,68,.06)}
.nav-wrap{min-height:80px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-wrap .brand{flex-shrink:0}
.nav-wrap .nav-links{flex:1;justify-content:center}
.nav-wrap .btn{flex-shrink:0}
.brand{display:flex;align-items:center;gap:12px;font-weight:700;font-size:1.1rem}
.brand-badge{width:44px;height:44px;border-radius:14px;background:var(--brand-green);display:grid;place-items:center;box-shadow:0 12px 28px rgba(36,92,68,.22);overflow:hidden;flex:0 0 44px}
.brand-badge img{width:100%;height:100%;object-fit:cover}
.brand span strong{display:block;color:var(--text);line-height:1.1;font-size:1.25rem}
.brand span small{display:none}
.nav-links{display:flex;align-items:center;gap:28px;color:#423d52;font-size:.94rem;font-weight:500}
.nav-links a{position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-8px;width:0;height:2px;border-radius:2px;background:var(--accent);transition:.25s ease}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-dropdown{position:relative}
.nav-dropdown:hover .nav-dropdown-menu{opacity:1;visibility:visible}
.nav-dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);margin-top:8px;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);min-width:240px;padding:12px 0;opacity:0;visibility:hidden;transition:.2s ease;z-index:100}
.nav-dropdown-menu a{display:block;padding:10px 20px;font-size:.9rem;color:var(--text)}
.nav-dropdown-menu a:hover{background:var(--accent-soft);color:var(--accent)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 22px;border-radius:16px;border:0;cursor:pointer;font-weight:700;font-size:.95rem;transition:.25s ease;white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--brand-green) 0%,var(--brand-green-soft) 100%);color:#fff;box-shadow:0 16px 35px rgba(36,92,68,.22)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{background:#fff;border:1px solid var(--border);color:var(--text);box-shadow:var(--shadow)}
.btn-accent{background:linear-gradient(135deg,var(--accent) 0%,#4aab8a 100%);color:#fff;box-shadow:0 16px 35px rgba(53,143,109,.22)}
.btn-yellow{background:linear-gradient(135deg,var(--accent) 0%,#4aab8a 100%);color:#fff;box-shadow:0 16px 35px rgba(53,143,109,.25)}
.btn-yellow:hover{transform:translateY(-3px);box-shadow:0 20px 40px rgba(53,143,109,.3)}

/* Animations */
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.animate-on-scroll{opacity:0;transform:translateY(40px);transition:opacity .7s ease-out,transform .7s ease-out}
.animate-on-scroll.visible{opacity:1;transform:translateY(0)}
.animate-on-scroll.delay-1{transition-delay:.1s}.animate-on-scroll.delay-2{transition-delay:.2s}.animate-on-scroll.delay-3{transition-delay:.3s}
.animate-on-scroll.delay-4{transition-delay:.4s}.animate-on-scroll.delay-5{transition-delay:.5s}.animate-on-scroll.delay-6{transition-delay:.6s}

/* Hero */
.hero{padding:80px 0 60px;position:relative;text-align:center;overflow:hidden}
.hero::before{content:"";position:absolute;right:-100px;top:-80px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(53,143,109,.12) 0%,transparent 70%);animation:float 6s ease-in-out infinite}
.hero::after{content:"";position:absolute;left:-100px;bottom:-50px;width:350px;height:350px;border-radius:50%;background:radial-gradient(circle,rgba(36,92,68,.08) 0%,transparent 70%);animation:float 8s ease-in-out infinite reverse}
.hero-copy{max-width:720px;margin:0 auto;position:relative;z-index:2}
.hero-copy h1{font-size:clamp(2.5rem,5vw,3.8rem);line-height:1.15;margin:0 0 20px;font-weight:800;letter-spacing:-.03em;animation:fadeInUp .8s ease-out forwards}
.hero-copy h1 .accent{color:var(--accent)}
.hero-copy p{margin:0 0 28px;color:var(--muted);font-size:1.1rem;line-height:1.8;opacity:0;animation:fadeInUp .8s ease-out .2s forwards}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-bottom:28px;opacity:0;animation:fadeInUp .8s ease-out .4s forwards}
.hero-sub{padding:24px 0 0;border-top:1px solid var(--border);margin-top:24px;opacity:0;animation:fadeInUp .8s ease-out .6s forwards}
.hero-sub h4{font-size:.86rem;color:var(--muted);font-weight:600;margin:0 0 16px;letter-spacing:.02em}

/* Stats */
.stats-section{padding:60px 0 80px;background:#fafcfb}
.stats-section .section-header{margin-bottom:48px}
.stats-section .section-header h2{font-size:clamp(1.8rem,3vw,2.5rem);max-width:800px;margin:0 auto}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat-card{text-align:center;padding:24px 16px;transition:transform .3s ease}
.stat-card:hover{transform:translateY(-6px)}
.stat-card strong{display:block;font-size:clamp(2rem,4vw,3rem);color:var(--brand-green);line-height:1.1;margin-bottom:8px}
.stat-card span{font-size:.9rem;color:var(--muted);line-height:1.5}

/* Brands */
.brands{padding:40px 0 50px}
.brands-box{text-align:center}
.brands-box p{color:var(--muted);margin:0 0 24px;font-size:.95rem;font-weight:500}
.brand-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:32px}
.brand-pill{color:var(--muted);font-weight:600;font-size:.9rem;opacity:.85}

/* Section */
.section{padding:88px 0}
.section-header{text-align:center;max-width:680px;margin:0 auto 44px}
.section-tag{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border-radius:999px;background:var(--brand-green);color:#fff;font-size:.86rem;font-weight:600;margin-bottom:14px}
.section-header h2{font-size:clamp(2rem,4vw,3.3rem);line-height:1.08;margin:0 0 14px;letter-spacing:-.03em}
.section-header h2 .accent{color:var(--accent)}
.section-header p{margin:0;color:var(--muted);line-height:1.9}

/* Services */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-card{background:linear-gradient(180deg,#fff 0%,#fafcfb 100%);border:1px solid var(--border);border-radius:28px;padding:24px;box-shadow:var(--shadow);transition:transform .35s ease,box-shadow .35s ease}
.service-card:hover{transform:translateY(-8px);box-shadow:0 24px 60px rgba(36,92,68,.12)}
.service-media{aspect-ratio:1.08/1;border-radius:22px;margin-bottom:18px;overflow:hidden;position:relative;background:linear-gradient(135deg,#eef5f2 0%,#fff 100%);border:1px solid #dce8e3}
.service-media.demo1::before{content:"";position:absolute;inset:20px;border-radius:20px;background:linear-gradient(160deg,#d4f0e4 0%,#fff 40%,#e8f5f0 100%)}
.service-media.demo1::after{content:"";position:absolute;left:28px;right:28px;bottom:18px;height:22px;border-radius:12px;background:#f7f7fa;box-shadow:0 -18px 0 #fff, 0 -52px 0 #e8f5f0}
.service-media.demo2::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(-12deg);width:64%;height:52%;border-radius:20px;background:linear-gradient(180deg,#fefefe 0%,#eef5f2 100%);box-shadow:0 18px 35px rgba(36,92,68,.12)}
.service-media.demo2::after{content:"";position:absolute;left:50%;bottom:20%;transform:translateX(-50%);width:74%;height:10px;border-radius:10px;background:#b8d4c8}
.service-media.demo3::before{content:"";position:absolute;left:24px;right:24px;bottom:24px;top:24px;border-radius:20px;background:#fff;box-shadow:inset 0 0 0 1px #e5f0ec}
.service-media.demo3::after{content:"";position:absolute;left:46px;right:46px;bottom:48px;height:120px;background:linear-gradient(180deg,var(--accent) 0%,#5bb999 100%) left 0 bottom/22px 74%,linear-gradient(180deg,var(--accent) 0%,#5bb999 100%) left 42px bottom/22px 52%,linear-gradient(180deg,var(--accent) 0%,#5bb999 100%) left 84px bottom/22px 86%,linear-gradient(180deg,var(--accent) 0%,#5bb999 100%) left 126px bottom/22px 62%,linear-gradient(180deg,var(--accent) 0%,#5bb999 100%) left 168px bottom/22px 96%,linear-gradient(180deg,var(--accent) 0%,#5bb999 100%) left 210px bottom/22px 68%;background-repeat:no-repeat;border-bottom:1px solid #dce8e3}
.service-card h3{margin:0 0 10px;font-size:1.3rem}
.service-card p{margin:0 0 16px;color:var(--muted);line-height:1.85}
.service-card a{color:var(--accent);font-weight:600;font-size:.9rem}
.service-card a:hover{text-decoration:underline}

/* Testimonials */
.testimonials-section{padding:88px 0;background:#fff}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial-card{background:#fafcfb;border:1px solid var(--border);border-radius:24px;padding:28px;box-shadow:var(--shadow);transition:transform .35s ease,box-shadow .35s ease}
.testimonial-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(36,92,68,.1)}
.testimonial-card blockquote{margin:0 0 20px;font-size:1rem;line-height:1.8;color:var(--text);font-style:italic}
.testimonial-card .author{display:flex;align-items:center;gap:14px;margin-bottom:12px}
.testimonial-card .author strong{display:block;font-size:1rem}
.testimonial-card .author span{font-size:.85rem;color:var(--muted)}

/* Results */
.results-section{padding:88px 0;background:#fafcfb}
.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.result-card{background:#fff;border:1px solid var(--border);border-radius:24px;overflow:hidden;box-shadow:var(--shadow);transition:transform .35s ease,box-shadow .35s ease}
.result-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(36,92,68,.1)}
.result-card .result-media{aspect-ratio:4/3;background:linear-gradient(135deg,#eef5f2 0%,#fff 100%);display:grid;place-items:center;font-size:2rem;color:var(--accent)}
.result-card .result-body{padding:20px}
.result-card h4{margin:0 0 8px;font-size:1.1rem}

/* Process */
.process-section{padding:88px 0;background:#fff}
.process-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px}
.process-step{text-align:center;position:relative;transition:transform .35s ease}
.process-step:hover{transform:scale(1.05)}
.process-step::after{content:"";position:absolute;top:28px;right:-12px;width:24px;height:2px;background:var(--border)}
.process-step:last-child::after{display:none}
.process-num{width:56px;height:56px;border-radius:50%;background:var(--brand-green);color:#fff;font-weight:800;font-size:1.25rem;display:grid;place-items:center;margin:0 auto 16px}
.process-step h4{margin:0 0 8px;font-size:1rem}
.process-step p{margin:0;font-size:.88rem;color:var(--muted);line-height:1.6}

/* Booking */
.booking{padding-top:30px}
.booking-shell{background:linear-gradient(135deg,#0c1824 0%,#13263d 100%);border-radius:38px;padding:34px;position:relative;overflow:hidden;box-shadow:0 24px 60px rgba(8,18,31,.18)}
.booking-shell::before{content:"";position:absolute;right:-70px;top:-90px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(53,143,109,.28) 0%,rgba(53,143,109,0) 70%)}
.booking-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;align-items:stretch;position:relative;z-index:2}
.booking-copy{color:#fff;padding:14px 6px;display:flex;flex-direction:column;justify-content:center}
.booking-copy h2{font-size:clamp(2rem,4vw,3.2rem);line-height:1.05;margin:0 0 16px;letter-spacing:-.03em}
.booking-contact{display:flex;flex-direction:column;gap:12px;margin-bottom:28px}
.contact-item{display:flex;align-items:center;gap:12px}
.contact-item a{color:#b8e6d4;font-weight:600}
.contact-item a:hover{text-decoration:underline}
.booking-copy p{margin:0 0 22px;color:rgba(255,255,255,.82);line-height:1.95}
.booking-points{display:grid;gap:12px}
.booking-points div{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);padding:14px 16px;border-radius:16px;color:#eff5ff}
.booking-card{background:#fff;border-radius:28px;padding:18px;border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 40px rgba(9,19,34,.15)}
.calendly-inline-widget{min-width:320px;height:760px;border-radius:20px;overflow:hidden}

/* About page */
.about-hero{padding:80px 0 100px}
.about-grid{display:grid;grid-template-columns:320px 1fr;gap:60px;align-items:start}
.about-photo{width:100%;aspect-ratio:1;border-radius:24px;background:linear-gradient(135deg,#eef5f2 0%,#fff 100%);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow)}
.about-photo img{width:100%;height:100%;object-fit:cover}
.about-content h1{font-size:clamp(2.2rem,4vw,3.2rem);line-height:1.1;margin:0 0 28px;font-weight:800;letter-spacing:-.03em}
.about-content h1 .accent{color:var(--accent)}
.about-content p{margin:0 0 20px;font-size:1.05rem;line-height:1.9;color:var(--text)}
.about-content ul{margin:24px 0;padding-left:24px}
.about-content li{margin-bottom:12px;font-size:1.05rem;line-height:1.8}
.about-content .closing{margin-top:28px;font-weight:600;color:var(--muted)}

/* Results page */
.results-hero{padding:80px 0 60px;text-align:center}
.results-hero h1{font-size:clamp(2.2rem,4vw,3.2rem);line-height:1.1;margin:0;font-weight:800;letter-spacing:-.03em}
.results-hero h1 .accent{color:var(--accent)}
.results-page .results-section{padding:48px 0 64px}
.results-page .results-section h2{font-size:1.5rem;font-weight:700;margin:0 0 28px}
.results-page .results-grid{grid-template-columns:repeat(4,1fr);gap:20px}
.results-page .result-card .result-media{font-size:2.5rem}
.results-page .result-card .result-body{padding:20px}
.results-page .result-card h4{font-size:1.05rem}
.results-page .result-card p{font-size:.88rem}

/* Blogs page */
.blogs-hero{padding:80px 0 60px;text-align:center}
.blogs-hero h1{font-size:clamp(2.2rem,4vw,3.2rem);line-height:1.1;margin:0;font-weight:800;letter-spacing:-.03em}
.blogs-section{padding:48px 0 80px}
.blogs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.blog-card{background:#fff;border:1px solid var(--border);border-radius:24px;overflow:hidden;box-shadow:var(--shadow);transition:transform .3s ease,box-shadow .3s ease}
.blog-card:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(36,92,68,.1)}
.blog-card .blog-media{aspect-ratio:16/10;background:linear-gradient(135deg,#eef5f2 0%,#fff 100%);display:grid;place-items:center;font-size:3rem;color:var(--accent)}
.blog-card .blog-body{padding:24px}
.blog-card h4{margin:0 0 12px;font-size:1.15rem;font-weight:600;line-height:1.4}
.blog-card h4:hover{color:var(--accent)}
.blog-card p{margin:0;font-size:.92rem;color:var(--muted);line-height:1.6}
.blog-card .read-more{margin-top:16px;font-size:.9rem;font-weight:600;color:var(--accent)}
.blog-card .read-more:hover{text-decoration:underline}

/* Service single */
.service-hero{padding:80px 0 100px}
.service-hero h1{font-size:clamp(2.2rem,4vw,3.2rem);line-height:1.1;margin:0 0 24px;font-weight:800;letter-spacing:-.03em}
.service-hero h1 .accent{color:var(--accent)}
.service-hero .lead{margin:0 0 40px;font-size:1.15rem;line-height:1.9;color:var(--text);max-width:720px}
.service-content h3{font-size:1.35rem;margin:32px 0 16px;font-weight:700}
.service-content p{margin:0 0 16px;font-size:1.05rem;line-height:1.9}
.service-content ul{margin:16px 0;padding-left:24px}
.service-content li{margin-bottom:10px;font-size:1.05rem;line-height:1.8}
.service-cta{margin-top:48px;padding:32px;background:var(--accent-soft);border-radius:24px;text-align:center}
.service-cta h3{margin:0 0 16px;font-size:1.2rem}
.service-cta a{display:inline-block;margin-top:16px}

/* Footer */
.footer{padding:38px 0 46px;color:#6b6877}
.footer .brand small{display:block;font-size:.8rem;font-weight:500;margin-top:2px}
.footer-box{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;border-top:1px solid var(--border);padding-top:24px}
.footer-contact{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.footer-contact a{display:flex;align-items:center;gap:8px;color:var(--accent);font-weight:600}
.footer-contact a:hover{text-decoration:underline}

/* Responsive */
@media (max-width: 1100px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:1fr 1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .results-grid{grid-template-columns:1fr}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .process-step::after{display:none}
  .booking-grid{grid-template-columns:1fr}
  .results-page .results-grid{grid-template-columns:repeat(2,1fr)}
  .blogs-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 760px){
  .nav-links{display:none}
  .hero-copy h1{font-size:2.2rem}
  .section,.hero{padding-block:64px}
  .booking-shell{padding:20px}
  .stats-grid{grid-template-columns:1fr}
  .services-grid,.brand-row{grid-template-columns:1fr}
  .calendly-inline-widget{min-height:600px}
  .about-grid{grid-template-columns:1fr}
  .about-photo{max-width:280px;margin:0 auto}
  .about-hero{padding:60px 0 80px}
  .results-hero{padding:60px 0 48px}
  .results-page .results-grid{grid-template-columns:1fr}
  .blogs-grid{grid-template-columns:1fr}
  .footer-box{flex-direction:column;text-align:center}
  .footer-contact{justify-content:center}
  .service-hero{padding:60px 0 80px}
}
