/* ===== Abdul Bari Pro Theme ===== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:#1a1d24;background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--abp-electric);text-decoration:none;transition:color .2s}
a:hover{color:var(--abp-teal)}
h1,h2,h3,h4{font-family:'Space Grotesk','Inter',sans-serif;font-weight:700;line-height:1.15;color:var(--abp-primary);margin:0 0 .5em}
.abp-container{max-width:1200px;margin:0 auto;padding:0 24px}
.abp-h2{font-size:clamp(28px,4vw,44px);margin-bottom:.4em}
.abp-eyebrow{display:inline-block;font-size:13px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--abp-electric);margin-bottom:14px}
.abp-lead{font-size:17px;color:#3b4252;margin-bottom:24px}

/* ===== Buttons ===== */
.abp-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 26px;border-radius:10px;font-weight:600;font-size:15px;letter-spacing:.01em;transition:transform .2s,box-shadow .2s,background .2s,color .2s;border:1px solid transparent;cursor:pointer;text-decoration:none}
.abp-btn-primary{background:linear-gradient(135deg,var(--abp-electric),var(--abp-primary));color:#fff;box-shadow:0 10px 30px -10px rgba(0,123,255,.6)}
.abp-btn-primary:hover{transform:translateY(-2px);color:#fff;box-shadow:0 14px 34px -10px rgba(0,123,255,.8)}
.abp-btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.abp-btn-ghost:hover{background:rgba(255,255,255,.1);color:#fff}
.abp-btn-whatsapp{background:#25D366;color:#fff;margin-top:18px}
.abp-btn-whatsapp:hover{background:#1ebe5d;color:#fff;transform:translateY(-2px)}

/* ===== Header ===== */
.abp-header{position:sticky;top:0;z-index:50;background:rgba(11,31,58,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.06)}
.abp-nav-wrap{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px}
.abp-brand{display:flex;flex-direction:column;line-height:1.1;text-decoration:none}
.abp-brand-mark{color:#fff;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:20px;letter-spacing:.02em}
.abp-brand-tag{color:var(--abp-silver);font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-top:3px}
.abp-nav{display:flex;align-items:center;gap:28px}
.abp-menu{display:flex;list-style:none;margin:0;padding:0;gap:26px}
.abp-menu a{color:#e5e9f0;font-size:14px;font-weight:500;letter-spacing:.02em}
.abp-menu a:hover{color:var(--abp-teal)}
.abp-nav-cta{padding:10px 20px;font-size:14px}
.abp-burger{display:none;background:transparent;border:0;width:42px;height:42px;flex-direction:column;justify-content:center;gap:5px;cursor:pointer;padding:0}
.abp-burger span{display:block;width:24px;height:2px;background:#fff;margin:0 auto;transition:.3s}
.abp-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.abp-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.abp-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===== Hero ===== */
.abp-hero{position:relative;overflow:hidden;color:#fff;background:linear-gradient(135deg,#071630 0%,var(--abp-primary) 45%,#102a4d 100%);padding:90px 0 110px;isolation:isolate}
.abp-hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%);z-index:-1}
.abp-hero-glow{position:absolute;width:600px;height:600px;border-radius:50%;top:-200px;right:-200px;background:radial-gradient(circle,var(--abp-electric) 0%,transparent 65%);opacity:.35;filter:blur(40px);z-index:-1}
.abp-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.abp-hero .abp-eyebrow{color:var(--abp-teal)}
.abp-hero-headline{color:#fff;font-size:clamp(30px,4.6vw,54px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em;background:linear-gradient(135deg,#fff 30%,var(--abp-silver) 90%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.abp-hero-sub{color:var(--abp-silver);font-size:clamp(14px,1.5vw,18px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:18px 0 30px}
.abp-hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:46px}
.abp-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.abp-kpi{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:14px;padding:18px;backdrop-filter:blur(10px)}
.abp-kpi-num{font-family:'Space Grotesk',sans-serif;font-size:26px;font-weight:700;background:linear-gradient(135deg,var(--abp-teal),var(--abp-electric));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.abp-kpi-lbl{font-size:12px;color:var(--abp-silver);margin-top:4px;letter-spacing:.04em}

/* Hero photo */
.abp-hero-visual{display:flex;justify-content:flex-end;position:relative}
.abp-photo-wrap{position:relative;width:min(420px,100%);aspect-ratio:4/5}
.abp-photo{width:100%;height:100%;object-fit:cover;border-radius:24px;box-shadow:0 30px 80px -20px rgba(0,0,0,.6);position:relative;z-index:2;background:linear-gradient(135deg,#1a2a45,#0b1f3a)}
.abp-photo-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--abp-silver);background:linear-gradient(135deg,#1a2a45,#0b1f3a);border:1px dashed rgba(255,255,255,.2)}
.abp-photo-placeholder span{font-weight:600;font-size:18px}
.abp-photo-placeholder small{margin-top:6px;font-size:12px;opacity:.8}
.abp-photo-ring{position:absolute;inset:-20px;border-radius:28px;background:conic-gradient(from 90deg,var(--abp-electric),var(--abp-teal),var(--abp-gold),var(--abp-electric));opacity:.35;filter:blur(28px);z-index:1;animation:abpRotate 18s linear infinite}
@keyframes abpRotate{to{transform:rotate(360deg)}}
.abp-card-float{position:absolute;background:rgba(255,255,255,.95);color:var(--abp-primary);padding:12px 16px;border-radius:14px;box-shadow:0 18px 40px -10px rgba(0,0,0,.4);z-index:3;backdrop-filter:blur(10px)}
.abp-card-float-1{left:-30px;top:18%;animation:abpFloat 4s ease-in-out infinite}
.abp-card-float-2{right:-20px;bottom:14%;animation:abpFloat 4s ease-in-out infinite reverse}
@keyframes abpFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.abp-mini-chart{display:flex;gap:3px;align-items:flex-end;height:30px}
.abp-mini-chart span{display:block;width:6px;background:linear-gradient(to top,var(--abp-electric),var(--abp-teal));border-radius:2px}
.abp-mini-chart span:nth-child(1){height:40%}
.abp-mini-chart span:nth-child(2){height:60%}
.abp-mini-chart span:nth-child(3){height:35%}
.abp-mini-chart span:nth-child(4){height:75%}
.abp-mini-chart span:nth-child(5){height:55%}
.abp-mini-chart span:nth-child(6){height:90%}
.abp-mini-donut{width:30px;height:30px;border-radius:50%;background:conic-gradient(var(--abp-teal) 0 65%,#e6e9ee 65% 100%);position:relative}
.abp-mini-donut::after{content:"";position:absolute;inset:7px;background:#fff;border-radius:50%}
.abp-mini-label{font-size:12px;font-weight:600;margin-top:6px}

/* ===== Sections ===== */
.abp-section{padding:100px 0}
.abp-section-soft{background:#f6f8fc}
.abp-section-dark{background:linear-gradient(135deg,var(--abp-charcoal),var(--abp-primary));color:#fff}
.abp-section-dark h2{color:#fff}
.abp-section-dark .abp-eyebrow{color:var(--abp-teal)}
.abp-section-head{text-align:center;max-width:680px;margin:0 auto 56px}

/* About */
.abp-about-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:center}
.abp-about-image img,.abp-image-placeholder{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:20px;box-shadow:0 30px 60px -20px rgba(11,31,58,.3)}
.abp-image-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e6ecf5,#d9dce3);color:#6b7280;font-weight:600}

/* Cards (services) */
.abp-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.abp-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:28px;color:#fff;transition:transform .3s,box-shadow .3s,border-color .3s;backdrop-filter:blur(10px)}
.abp-section:not(.abp-section-dark) .abp-card{background:#fff;border-color:#eef0f5;color:#1a1d24;box-shadow:0 4px 14px -6px rgba(11,31,58,.08)}
.abp-card:hover{transform:translateY(-6px);border-color:var(--abp-teal);box-shadow:0 24px 48px -16px rgba(0,179,164,.35)}
.abp-card-icon{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--abp-electric),var(--abp-teal));color:#fff;font-weight:700;margin-bottom:18px;font-family:'Space Grotesk'}
.abp-card h3{font-size:18px;margin:0 0 8px;color:inherit}
.abp-card p{font-size:14px;margin:0;opacity:.85}

/* Portfolio */
.abp-portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.abp-port-item{display:block;background:#fff;border-radius:18px;overflow:hidden;box-shadow:0 4px 16px -4px rgba(11,31,58,.1);transition:transform .3s,box-shadow .3s;color:inherit}
.abp-port-item:hover{transform:translateY(-6px);box-shadow:0 26px 50px -14px rgba(11,31,58,.25);color:inherit}
.abp-port-img{aspect-ratio:4/3;overflow:hidden;background:linear-gradient(135deg,#e8edf5,#d9dce3)}
.abp-port-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.abp-port-item:hover .abp-port-img img{transform:scale(1.06)}
.abp-port-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;color:#a8b1c1}
.abp-port-meta{padding:20px}
.abp-port-cat{font-size:12px;font-weight:600;color:var(--abp-electric);letter-spacing:.12em;text-transform:uppercase}
.abp-port-meta h3{font-size:18px;margin:6px 0 0;color:var(--abp-primary)}

/* Skills */
.abp-skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px 40px;max-width:920px;margin:0 auto}
.abp-skill-head{display:flex;justify-content:space-between;margin-bottom:8px;font-weight:600;color:var(--abp-primary)}
.abp-skill-bar{height:8px;background:#e6eaf0;border-radius:99px;overflow:hidden}
.abp-skill-fill{height:100%;background:linear-gradient(90deg,var(--abp-electric),var(--abp-teal));border-radius:99px;transition:width 1.4s ease}

/* Testimonials */
.abp-test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.abp-test{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:28px;margin:0;backdrop-filter:blur(10px)}
.abp-test blockquote{margin:0 0 22px;font-size:16px;line-height:1.6;color:#e5e9f0}
.abp-test figcaption{display:flex;align-items:center;gap:14px}
.abp-test img,.abp-avatar-fallback{width:48px;height:48px;border-radius:50%;object-fit:cover;background:linear-gradient(135deg,var(--abp-electric),var(--abp-teal));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700}
.abp-test figcaption strong{display:block;color:#fff;font-size:15px}
.abp-test figcaption span{color:var(--abp-silver);font-size:13px}

/* Contact */
.abp-contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:start}
.abp-contact-info{list-style:none;padding:0;margin:24px 0 20px;color:#3b4252}
.abp-contact-info li{margin-bottom:10px}
.abp-form{background:#fff;border:1px solid #eef0f5;border-radius:20px;padding:30px;box-shadow:0 20px 50px -16px rgba(11,31,58,.12);display:grid;gap:14px}
.abp-form label{display:flex;flex-direction:column;font-weight:600;color:var(--abp-primary);font-size:14px;gap:6px}
.abp-form input,.abp-form textarea{padding:12px 14px;border:1px solid #d9dce3;border-radius:10px;font-family:inherit;font-size:15px;background:#fafbfd;color:#1a1d24;transition:border-color .2s,background .2s}
.abp-form input:focus,.abp-form textarea:focus{outline:none;border-color:var(--abp-electric);background:#fff}
.abp-form button{justify-self:start}
.abp-alert{padding:12px 14px;border-radius:10px;font-size:14px}
.abp-alert-ok{background:#e6f9f5;color:#0a7d6f;border:1px solid #b7ebd9}
.abp-alert-err{background:#fdecec;color:#a51c1c;border:1px solid #f5c2c2}

/* Footer */
.abp-footer{background:#06122a;color:#cfd5e0;padding:70px 0 0}
.abp-footer h4{color:#fff;font-size:16px;margin-bottom:14px}
.abp-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:50px}
.abp-footer-brand{font-family:'Space Grotesk',sans-serif;color:#fff;font-size:22px;font-weight:700;margin-bottom:10px}
.abp-footer-about{color:var(--abp-silver);margin-bottom:18px}
.abp-footer ul{list-style:none;padding:0;margin:0}
.abp-footer ul li{margin-bottom:8px}
.abp-footer ul a{color:#cfd5e0}
.abp-footer ul a:hover{color:var(--abp-teal)}
.abp-socials{display:flex;gap:10px;margin-top:14px}
.abp-social{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:rgba(255,255,255,.06);color:#fff;font-size:11px;font-weight:700;letter-spacing:.04em;border:1px solid rgba(255,255,255,.08);transition:.2s}
.abp-social:hover{background:var(--abp-electric);color:#fff;transform:translateY(-2px)}
.abp-footer-bar{border-top:1px solid rgba(255,255,255,.08);padding:20px 0;text-align:center;font-size:13px;color:var(--abp-silver)}

/* WhatsApp floating */
.abp-whatsapp{position:fixed;right:22px;bottom:22px;width:58px;height:58px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px -8px rgba(37,211,102,.6);z-index:60;animation:abpPulse 2.4s ease-out infinite}
.abp-whatsapp:hover{transform:scale(1.06)}
@keyframes abpPulse{0%{box-shadow:0 10px 30px -8px rgba(37,211,102,.6),0 0 0 0 rgba(37,211,102,.5)}100%{box-shadow:0 10px 30px -8px rgba(37,211,102,.6),0 0 0 22px rgba(37,211,102,0)}}

/* Reveal animation */
.abp-reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.abp-reveal.is-in{opacity:1;transform:none}

/* ===== Responsive ===== */
@media (max-width: 1024px){
  .abp-hero-grid,.abp-about-grid,.abp-contact-grid{grid-template-columns:1fr;gap:40px}
  .abp-hero-visual{justify-content:center}
  .abp-cards{grid-template-columns:repeat(2,1fr)}
  .abp-portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .abp-test-grid{grid-template-columns:1fr;max-width:640px;margin:0 auto}
  .abp-footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 760px){
  .abp-section{padding:70px 0}
  .abp-hero{padding:60px 0 80px}
  .abp-hero-headline,.abp-hero-sub{white-space:normal}
  .abp-kpis{grid-template-columns:repeat(2,1fr)}
  .abp-burger{display:flex}
  .abp-nav{position:fixed;top:74px;left:0;right:0;background:rgba(11,31,58,.98);backdrop-filter:blur(14px);flex-direction:column;align-items:stretch;gap:0;padding:20px 24px;transform:translateY(-110%);transition:transform .35s ease;border-bottom:1px solid rgba(255,255,255,.08)}
  .abp-nav.is-open{transform:translateY(0)}
  .abp-menu{flex-direction:column;gap:0}
  .abp-menu li{border-bottom:1px solid rgba(255,255,255,.06)}
  .abp-menu a{display:block;padding:16px 0;font-size:16px}
  .abp-nav-cta{margin-top:14px;align-self:flex-start}
  .abp-cards,.abp-portfolio-grid,.abp-skills-grid{grid-template-columns:1fr}
  .abp-footer-grid{grid-template-columns:1fr}
  .abp-card-float-1,.abp-card-float-2{display:none}
  .abp-whatsapp{width:54px;height:54px;right:16px;bottom:16px}
}

/* ===== v1.1 additions ===== */

/* Larger photo when no hero video */
.abp-hero-grid--photo-large .abp-photo-wrap{transform:scale(1.35);transform-origin:center}
@media (max-width:1024px){.abp-hero-grid--photo-large .abp-photo-wrap{transform:scale(1.15)}}
@media (max-width:760px){.abp-hero-grid--photo-large .abp-photo-wrap{transform:none}}

/* Hero video card */
.abp-hero-video-card{position:relative;width:100%;max-width:520px;aspect-ratio:4/5;border-radius:24px;overflow:hidden;cursor:pointer;background:linear-gradient(135deg,var(--abp-primary),var(--abp-electric));box-shadow:0 30px 70px -20px rgba(11,31,58,.45);margin:0 auto;transition:transform .35s,box-shadow .35s}
.abp-hero-video-card:hover{transform:translateY(-4px);box-shadow:0 40px 80px -20px rgba(0,123,255,.45)}
.abp-hero-video-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.abp-hero-video-thumb--placeholder{background:linear-gradient(135deg,var(--abp-electric),var(--abp-primary))}
.abp-hero-video-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(11,31,58,.18);border:0;cursor:pointer;transition:background .25s}
.abp-hero-video-play:hover{background:rgba(11,31,58,.32)}
.abp-hero-video-play svg{filter:drop-shadow(0 8px 24px rgba(0,0,0,.35));transition:transform .25s}
.abp-hero-video-card:hover .abp-hero-video-play svg{transform:scale(1.08)}
.abp-hero-video-el{width:100%;height:100%;display:block;background:#000}
.abp-hero-video-card.is-playing{cursor:default}

/* Hero social icons */
.abp-hero-socials{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.abp-hero-socials .abp-social{width:44px;height:44px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:#fff;color:var(--abp-primary);border:1px solid rgba(11,31,58,.08);box-shadow:0 4px 14px -6px rgba(11,31,58,.18);transition:transform .25s,background .25s,color .25s,box-shadow .25s}
.abp-hero-socials .abp-social:hover{transform:translateY(-3px);background:var(--abp-electric);color:#fff;box-shadow:0 14px 28px -10px rgba(0,123,255,.45)}
.abp-hero-socials .abp-social-whatsapp:hover{background:#25D366;box-shadow:0 14px 28px -10px rgba(37,211,102,.5)}
.abp-hero-socials .abp-social-youtube:hover{background:#FF0000;box-shadow:0 14px 28px -10px rgba(255,0,0,.45)}
.abp-hero-socials .abp-social-instagram:hover{background:linear-gradient(135deg,#f09433,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888);color:#fff}
.abp-hero-socials .abp-social-facebook:hover{background:#1877F2}
.abp-hero-socials .abp-social-linkedin:hover{background:#0A66C2}
.abp-hero-socials .abp-social-twitter:hover{background:#000}

/* Professional Journey */
.abp-journey-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.abp-journey-card{background:#fff;border:1px solid #eef0f5;border-radius:18px;padding:30px 26px;box-shadow:0 4px 16px -6px rgba(11,31,58,.1);transition:transform .3s,box-shadow .3s,border-color .3s;position:relative;overflow:hidden}
.abp-journey-card::before{content:"";position:absolute;left:0;top:0;width:100%;height:4px;background:linear-gradient(90deg,var(--abp-electric),var(--abp-teal));transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.abp-journey-card:hover{transform:translateY(-6px);border-color:var(--abp-teal);box-shadow:0 26px 50px -16px rgba(0,179,164,.3)}
.abp-journey-card:hover::before{transform:scaleX(1)}
.abp-journey-num{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--abp-electric),var(--abp-teal));color:#fff;font-weight:700;font-family:'Space Grotesk',sans-serif;margin-bottom:18px}
.abp-journey-card h3{font-size:18px;margin:0 0 8px;color:var(--abp-primary)}
.abp-journey-card p{font-size:14px;margin:0;color:#4b5563}
@media (max-width:1024px){.abp-journey-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.abp-journey-grid{grid-template-columns:1fr}}

/* Footer credit line */
.abp-footer-credit{margin-top:6px;font-size:13px;color:var(--abp-silver)}
.abp-footer-credit a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.25);transition:.2s}
.abp-footer-credit a:hover{color:var(--abp-teal);border-color:var(--abp-teal)}
