/* ── RESET & BASE ─────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Outfit',sans-serif;background:#fafafa;color:#0d1b2e;overflow-x:hidden;line-height:1.6}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ── TOKENS ───────────────────────────────────────── */
:root{
  --blue:#1a3a6b;
  --blue-mid:#1e4db7;
  --blue-light:#2563eb;
  --white:#ffffff;
  --off:#f5f7fb;
  --gray:#8a9ab5;
  --dark:#0d1b2e;
  --radius:16px;
  --shadow:0 8px 40px rgba(13,27,46,.08);
  --shadow-lg:0 20px 60px rgba(13,27,46,.14);
  --trans:all .3s cubic-bezier(.4,0,.2,1);
}

/* ── CONTAINER ────────────────────────────────────── */
.container{max-width:1200px;margin:0 auto;padding:0 clamp(20px,5vw,60px)}
.section{padding:clamp(80px,10vw,140px) 0}

/* ── TYPOGRAPHY HELPERS ───────────────────────────── */
.sec-label{font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--blue-light);font-weight:500;margin-bottom:1rem}
.sec-title{font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.15;color:var(--dark)}
.sec-title em{font-style:normal;color:var(--blue-light)}

/* ── BUTTONS ──────────────────────────────────────── */
.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 2rem;background:var(--blue-light);color:#fff;border-radius:50px;font-size:.9rem;font-weight:600;letter-spacing:.02em;transition:var(--trans)}
.btn-primary:hover{background:var(--blue);transform:translateY(-2px);box-shadow:0 12px 32px rgba(37,99,235,.35)}
.btn-ghost{display:inline-flex;align-items:center;padding:.85rem 2rem;border:1.5px solid rgba(13,27,46,.15);border-radius:50px;font-size:.9rem;font-weight:500;color:var(--dark);transition:var(--trans)}
.btn-ghost:hover{border-color:var(--blue-light);color:var(--blue-light)}

/* ── REVEAL ANIMATIONS ────────────────────────────── */
[data-reveal],[data-reveal-right]{opacity:0;transform:translateY(36px);transition:opacity .65s ease,transform .65s ease}
[data-reveal-right]{transform:translateX(36px)}
.visible{opacity:1!important;transform:none!important}

/* ═══════════════════════════════════════════════════ */
/*  NAV                                                */
/* ═══════════════════════════════════════════════════ */
.nav{position:fixed;top:0;left:0;width:100%;z-index:900;padding:0;transition:var(--trans)}
.nav.scrolled{background:rgba(250,250,252,.92);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);box-shadow:0 1px 0 rgba(13,27,46,.08)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 clamp(20px,5vw,60px);display:flex;align-items:center;justify-content:space-between;height:72px;position:relative}
.nav-logo{display:flex;align-items:center}
.brutal-logo-img-container{display:flex;align-items:center;justify-content:center}
.brutal-logo-img{height:42px;width:auto;object-fit:contain;max-width:220px;transition:transform .3s ease}
.logo-img{height:48px;width:auto;object-fit:contain;max-width:160px}
.nav-links{display:flex;align-items:center;gap:3.5rem;list-style:none}
.nl{font-size:.85rem;font-weight:500;color:var(--dark);letter-spacing:.02em;transition:color .25s}
.nl:hover{color:var(--blue-light)}
.nl-cta{padding:.8rem 1.8rem;background:var(--blue-light);color:#fff!important;border-radius:50px;font-size:.82rem;transition:var(--trans)!important;box-shadow:0 4px 15px rgba(37,99,235,0.15)}
.nl-cta:hover{background:var(--blue);transform:translateY(-1px);box-shadow:0 8px 25px rgba(37,99,235,0.25)}
.burger{display:none;flex-direction:column;gap:5px;padding:4px}
.burger span{display:block;width:24px;height:2px;background:var(--dark);border-radius:2px;transition:var(--trans)}

/* ═══════════════════════════════════════════════════ */
/*  HERO                                               */
/* ═══════════════════════════════════════════════════ */
.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:linear-gradient(145deg,#eef3ff 0%,#fafafa 60%)}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4}
.orb-1{width:600px;height:600px;background:radial-gradient(circle,#c7d9ff,transparent 70%);top:-200px;right:-100px}
.orb-2{width:400px;height:400px;background:radial-gradient(circle,#dbeafe,transparent 70%);bottom:-100px;left:-60px}
.grid-lines{position:absolute;inset:0;background-image:linear-gradient(rgba(37,99,235,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.04) 1px,transparent 1px);background-size:60px 60px}
.hero-inner{max-width:1200px;margin:0 auto;padding:0 clamp(20px,5vw,60px);padding-top:100px;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:4rem;min-height:100vh}
.hero-tag{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem 1.1rem;background:rgba(37,99,235,.08);color:var(--blue-light);border-radius:50px;font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1.5rem}
.hero-tag::before{content:'';width:6px;height:6px;background:#22c55e;border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero-title{font-size:clamp(3.5rem,7vw,6rem);font-weight:800;line-height:1;letter-spacing:-.02em;color:var(--dark);margin-bottom:.75rem}
.ht-top{display:block}
.ht-bot{display:block;color:var(--blue-light)}
.hero-role{font-size:1.1rem;color:var(--gray);font-weight:300;margin-bottom:1.25rem;letter-spacing:.08em}
.hero-role em{font-style:italic;color:var(--blue-mid);font-weight:500}
.hero-desc{font-size:1.05rem;color:#4a5568;max-width:440px;line-height:1.75;margin-bottom:2rem}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap}
.hero-portrait{position:relative;display:flex;justify-content:center;align-items:center}
.portrait-frame{position:relative;width:clamp(280px,35vw,440px);height:clamp(360px,45vw,560px)}
.portrait-img{width:100%;height:100%;object-fit:cover;object-position:top;border-radius:var(--radius);position:relative;z-index:2}
.portrait-ring{position:absolute;inset:-12px;border:2px solid rgba(37,99,235,.2);border-radius:calc(var(--radius)+12px);z-index:1;animation:ringFloat 6s ease-in-out infinite}
@keyframes ringFloat{0%,100%{transform:translate(0,0)}50%{transform:translate(-4px,-6px)}}
.hero-stat-card{position:absolute;background:var(--white);border-radius:14px;box-shadow:var(--shadow-lg);padding:1rem 1.4rem;z-index:10;display:flex;flex-direction:column;gap:.15rem}
.sc-top{top:12%;right:-32px}
.sc-bot{bottom:18%;left:-28px}
.sc-num{font-size:1.6rem;font-weight:800;color:var(--dark);line-height:1}
.sc-label{font-size:.7rem;color:var(--gray);text-transform:uppercase;letter-spacing:.1em}
.scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem}
.sh-line{width:1px;height:40px;background:linear-gradient(to bottom,transparent,var(--blue-light));animation:scrollAnim 2s ease-in-out infinite}
@keyframes scrollAnim{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
.sh-text{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gray)}

/* ═══════════════════════════════════════════════════ */
/*  ABOUT                                              */
/* ═══════════════════════════════════════════════════ */
.about{background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:5rem;align-items:start}
.about-lead{font-size:1.2rem;font-weight:500;line-height:1.65;color:var(--dark);margin-bottom:1.25rem}
.about-body{font-size:.95rem;color:#4a5568;line-height:1.85;margin-bottom:2.5rem}
.about-stats{display:flex;gap:3rem}
.as-num{display:block;font-size:2.5rem;font-weight:800;color:var(--blue-light);line-height:1}
.as-lbl{font-size:.75rem;color:var(--gray);text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem;display:block}

/* ═══════════════════════════════════════════════════ */
/*  SERVICES                                           */
/* ═══════════════════════════════════════════════════ */
.services{background:var(--off)}
.sec-head{margin-bottom:4rem;display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.srv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.srv-card{background:var(--white);border-radius:var(--radius);padding:2.5rem 2rem;border:1px solid rgba(13,27,46,.06);transition:var(--trans);position:relative;overflow:hidden}
.srv-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--blue-light),var(--blue));opacity:0;transition:opacity .35s}
.srv-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.srv-card:hover .srv-num,.srv-card:hover .srv-icon i,.srv-card:hover .srv-title,.srv-card:hover .srv-desc{color:#fff;position:relative;z-index:1}
.srv-card:hover::before{opacity:1}
.srv-card:hover .srv-tools span{background:rgba(255,255,255,.15);color:rgba(255,255,255,.85);border-color:transparent}
.srv-card.featured{border-color:var(--blue-light);box-shadow:0 0 0 1px var(--blue-light),var(--shadow)}
.srv-num{font-size:.75rem;color:var(--gray);letter-spacing:.14em;margin-bottom:1.5rem;font-weight:500;transition:color .3s}
.srv-icon{margin-bottom:1.25rem}
.srv-icon i{font-size:1.75rem;color:var(--blue-light);transition:color .3s}
.srv-title{font-size:1.25rem;font-weight:700;color:var(--dark);margin-bottom:.75rem;transition:color .3s}
.srv-desc{font-size:.9rem;color:#64748b;line-height:1.75;margin-bottom:1.5rem;transition:color .3s}
.srv-tools{display:flex;flex-wrap:wrap;gap:.5rem}
.srv-tools span{font-size:.72rem;padding:.3rem .75rem;border-radius:50px;border:1px solid rgba(13,27,46,.1);color:var(--gray);letter-spacing:.06em;transition:var(--trans)}

/* ═══════════════════════════════════════════════════ */
/*  SKILLS                                             */
/* ═══════════════════════════════════════════════════ */
.skills{background:var(--white)}
.skills-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.skill-bars{margin-top:2.5rem;display:flex;flex-direction:column;gap:1.5rem}
.sb-item{}
.sb-info{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.85rem;font-weight:500}
.sb-track{height:3px;background:rgba(13,27,46,.08);border-radius:2px;overflow:hidden}
.sb-fill{height:100%;background:linear-gradient(90deg,var(--blue-light),var(--blue-mid));border-radius:2px;width:0;transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.skill-tags{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:3rem}
.stag{padding:.5rem 1.1rem;background:rgba(37,99,235,.06);color:var(--blue);border-radius:50px;font-size:.82rem;font-weight:500;letter-spacing:.03em;border:1px solid rgba(37,99,235,.12);transition:var(--trans)}
.stag:hover{background:var(--blue-light);color:#fff;border-color:transparent}
.exp-card{background:var(--off);border-radius:var(--radius);padding:1.75rem 2rem;border-left:3px solid var(--blue-light)}
.exp-year{font-size:.75rem;color:var(--blue-light);letter-spacing:.12em;text-transform:uppercase;font-weight:600}
.exp-role{font-size:1.15rem;font-weight:700;color:var(--dark);margin:.5rem 0}
.exp-desc{font-size:.88rem;color:#64748b;line-height:1.75}

/* ═══════════════════════════════════════════════════ */
/*  PORTFOLIO — TRUE MASONRY (CSS columns)             */
/* ═══════════════════════════════════════════════════ */
.portfolio{background:var(--off)}
.pf-head{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap;margin-bottom:3rem}

/* Filter pills */
.pf-filters{display:flex;gap:.5rem;flex-wrap:wrap}
.pf-btn{padding:.5rem 1.3rem;border-radius:50px;font-size:.8rem;font-weight:600;color:var(--gray);border:1.5px solid rgba(13,27,46,.1);background:var(--white);transition:var(--trans);letter-spacing:.03em}
.pf-btn.active,.pf-btn:hover{background:var(--blue-light);color:#fff;border-color:var(--blue-light);box-shadow:0 4px 16px rgba(37,99,235,.25)}

/* Masonry container */
.pf-masonry{columns:3;column-gap:1.25rem}

/* Each brick sits in a column, never breaks across */
.pf-brick{break-inside:avoid;margin-bottom:1.25rem;display:block}
.pf-brick.pf-hidden{display:none}

/* Card shell */
.pf-card{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--white);box-shadow:0 2px 16px rgba(13,27,46,.06);transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s}
.pf-card:hover{transform:translateY(-5px);box-shadow:0 16px 48px rgba(13,27,46,.14)}

/* Image — 100% width, height auto = natural ratio, NO cropping */
.pf-card img{width:100%;height:auto;display:block;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.pf-card:hover img{transform:scale(1.04)}

/* Hover overlay */
.pf-info{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,20,50,.82) 0%,rgba(10,20,50,.18) 50%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:1.25rem 1.35rem;opacity:0;transition:opacity .32s}
.pf-card:hover .pf-info{opacity:1}
.pf-tag{font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:.3rem;display:block}
.pf-info h4{font-size:.95rem;font-weight:700;color:#fff;line-height:1.3}

/* ═══════════════════════════════════════════════════ */
/*  STATS BAND                                         */
/* ═══════════════════════════════════════════════════ */
.stats-band{background:var(--dark);padding:5rem 0}
.sb-grid{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap}
.sb-stat{flex:1;min-width:160px;text-align:center;padding:2rem 1rem}
.sb-divider{width:1px;height:60px;background:rgba(255,255,255,.1)}
.sbs-num{display:block;font-size:clamp(2.5rem,5vw,3.5rem);font-weight:800;color:#fff;line-height:1}
.sbs-lbl{font-size:.75rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.14em;margin-top:.5rem;display:block}

/* ═══════════════════════════════════════════════════ */
/*  FOOTER                                             */
/* ═══════════════════════════════════════════════════ */
.footer{background:var(--off);padding:clamp(80px,10vw,140px) 0 0}
.footer-inner{text-align:center;padding-bottom:5rem}
.footer-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:800;line-height:1.1;color:var(--dark);margin:1rem 0 1.25rem}
.footer-desc{color:#64748b;margin-bottom:2.5rem;font-size:1rem}
.footer-cta{margin:0 auto 4rem}
.footer-socials{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem}
.fsoc{display:inline-flex;align-items:center;gap:.6rem;padding:.75rem 1.5rem;border:1px solid rgba(13,27,46,.1);border-radius:50px;font-size:.85rem;color:var(--dark);transition:var(--trans)}
.fsoc:hover{background:var(--blue-light);color:#fff;border-color:var(--blue-light);transform:translateY(-2px)}
.fsoc i{font-size:1rem}
.footer-bottom{border-top:1px solid rgba(13,27,46,.08);padding:1.75rem 0;display:flex;align-items:center;justify-content:space-between}
.footer-bottom p{font-size:.82rem;color:var(--gray)}
.back-top{width:42px;height:42px;border-radius:50%;background:var(--dark);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:var(--trans)}
.back-top:hover{background:var(--blue-light);transform:translateY(-3px)}

/* ── WA FAB ───────────────────────────────────────── */
.wa-fab{position:fixed;bottom:2rem;right:2rem;z-index:800;width:52px;height:52px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.4rem;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:var(--trans)}
.wa-fab:hover{transform:scale(1.1);box-shadow:0 8px 30px rgba(37,211,102,.5)}

/* ═══════════════════════════════════════════════════ */
/*  RESPONSIVE                                         */
/* ═══════════════════════════════════════════════════ */
@media(max-width:1024px){
  .srv-grid{grid-template-columns:1fr 1fr}
  .pf-masonry{columns:2}
}
@media(max-width:768px){
  .hero-inner{grid-template-columns:1fr;text-align:center;gap:3rem;padding-top:90px;min-height:auto;padding-bottom:80px}
  .hero-desc{margin:0 auto 2rem}
  .hero-ctas{justify-content:center}
  .hero-portrait{order:-1}
  .portrait-frame{width:260px;height:330px}
  .sc-top{right:-10px}
  .sc-bot{left:-10px}
  .about-grid{grid-template-columns:1fr}
  .about-stats{gap:2rem;flex-wrap:wrap}
  .skills-inner{grid-template-columns:1fr}
  .srv-grid{grid-template-columns:1fr}
  .pf-masonry{columns:2}
  .pf-head{flex-direction:column;align-items:flex-start;gap:1.5rem}
  .sb-grid{flex-direction:column}
  .sb-divider{width:80px;height:1px}
  .footer-inner{text-align:left}
  .footer-socials{justify-content:flex-start}
  .footer-cta{margin-left:0}
  .sec-head{flex-direction:column;align-items:flex-start}
  .nav-links{display:none;position:fixed;inset:0;background:rgba(250,250,252,.97);flex-direction:column;justify-content:center;align-items:center;gap:2.5rem;z-index:800}
  .nav-links.open{display:flex}
  .burger{display:flex;z-index:810}
}
@media(max-width:480px){
  .pf-masonry{columns:1}
}

/* ═══════════════════════════════════════════════════
   WORLD-CLASS INTERACTION LAYERS
   (Appended — zero color changes)
═══════════════════════════════════════════════════ */

/* ── Override trans to premium cubic-bezier ─────── */
:root{--trans:all .35s cubic-bezier(.22,1,.36,1);--reveal-ease:cubic-bezier(.22,1,.36,1)}

/* ── Progress Bar ───────────────────────────────── */
.progress-bar{position:fixed;top:0;left:0;height:3px;width:0%;background:linear-gradient(90deg,var(--blue-light),var(--blue-mid));z-index:9999;transition:width .1s linear;border-radius:0 2px 2px 0}

/* ── Custom Cursor Blob ─────────────────────────── */
.cursor-blob{position:fixed;top:0;left:0;width:28px;height:28px;background:var(--blue-light);border-radius:50%;pointer-events:none;z-index:9998;mix-blend-mode:multiply;transition:transform .12s cubic-bezier(.22,1,.36,1),width .3s,height .3s;transform:translate(-50%,-50%);opacity:.7}
@media(pointer:coarse){.cursor-blob{display:none}}

/* ── Upgraded Reveal System ─────────────────────── */
[data-reveal]{opacity:0;transform:translateY(40px);transition:opacity .7s var(--reveal-ease),transform .7s var(--reveal-ease);transition-delay:var(--d,0s)}
[data-reveal-right]{opacity:0;transform:translateX(40px);transition:opacity .7s var(--reveal-ease),transform .7s var(--reveal-ease)}
.visible{opacity:1!important;transform:none!important}

/* ── Eyebrow Text ───────────────────────────────── */
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.7rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--blue-light);margin-bottom:1rem}
.eyebrow span{opacity:.45;font-size:.65rem}

/* ── Magnetic Buttons ───────────────────────────── */
.btn-primary{transition:transform .35s cubic-bezier(.22,1,.36,1),background .25s,box-shadow .35s;will-change:transform}
.btn-primary:hover{transform:translateY(-3px) scale(1.03);box-shadow:0 16px 40px rgba(37,99,235,.4)}
.btn-ghost:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,99,235,.15)}
.pf-btn{transition:all .35s cubic-bezier(.22,1,.36,1)}
.pf-btn.active,.pf-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,99,235,.28)}

/* ── Glassmorphism Hero Chips ───────────────────── */
.glass-chip{position:absolute;display:flex;align-items:center;gap:.75rem;padding:.85rem 1.2rem;background:rgba(255,255,255,.72);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.6);border-radius:14px;box-shadow:0 8px 32px rgba(13,27,46,.12),0 1px 0 rgba(255,255,255,.8) inset;z-index:10;animation:chipFloat 5s ease-in-out infinite;animation-delay:var(--float-delay,0s)}
.glass-chip strong{display:block;font-size:1rem;font-weight:800;color:var(--dark);line-height:1}
.glass-chip span{display:block;font-size:.65rem;color:var(--gray);text-transform:uppercase;letter-spacing:.1em;margin-top:.15rem}
.chip-icon{width:36px;height:36px;background:var(--blue-light);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;flex-shrink:0}
.chip-top{top:10%;right:-28px}
.chip-mid{top:50%;left:-32px;transform:translateY(-50%)}
.chip-bot{bottom:14%;right:-24px}
@keyframes chipFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.chip-mid{animation-delay:var(--float-delay,.8s)}

/* ── Skills Marquee ─────────────────────────────── */
.marquee-section{overflow:hidden;padding:1.25rem 0;background:var(--white);border-top:1px solid rgba(13,27,46,.06);border-bottom:1px solid rgba(13,27,46,.06)}
.marquee-track-wrap{overflow:hidden;mask-image:linear-gradient(90deg,transparent,black 10%,black 90%,transparent)}
.marquee-inner{display:flex;width:max-content;animation:marqueeScroll 28s linear infinite}
.marquee-inner:hover{animation-play-state:paused}
.marquee-inner span{font-size:.8rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--gray);padding:0 1.5rem;white-space:nowrap;transition:color .3s}
.marquee-inner span:hover{color:var(--blue-light)}
.mq-sep{font-style:normal;color:var(--blue-light);opacity:.5;align-self:center;font-size:.55rem;padding:0 .15rem}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── Full-Screen Mobile Overlay ─────────────────── */
.mobile-overlay{position:fixed;inset:0;background:var(--dark);z-index:950;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:3rem;opacity:0;pointer-events:none;transition:opacity .45s cubic-bezier(.22,1,.36,1)}
.mobile-overlay.open{opacity:1;pointer-events:all}
.mobile-overlay.open .overlay-link{opacity:1;transform:none}
.overlay-close{position:absolute;top:1.5rem;right:1.5rem;width:44px;height:44px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;cursor:pointer;z-index:10}
.overlay-close span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:var(--trans)}
.overlay-close span:first-child{transform:rotate(45deg) translate(5px,5px)}
.overlay-close span:last-child{transform:rotate(-45deg) translate(5px,-5px)}
.overlay-nav ul{list-style:none;text-align:center;display:flex;flex-direction:column;gap:1.5rem}
.overlay-link{display:inline-flex;align-items:center;gap:.75rem;font-size:2rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--white);opacity:0;transform:translateY(24px);transition:opacity .5s var(--reveal-ease),transform .5s var(--reveal-ease),color .25s;transition-delay:calc(var(--i,.0) * 0.08s + .1s)}
.overlay-link:hover{color:var(--blue-light)}
.ol-num{font-size:.7rem;color:var(--blue-light);font-weight:700;letter-spacing:.12em;margin-top:.15rem}
.overlay-cta{margin-top:1rem}
.overlay-social{display:flex;gap:1.5rem}
.overlay-social a{width:44px;height:44px;border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1rem;transition:var(--trans)}
.overlay-social a:hover{border-color:var(--blue-light);color:var(--blue-light);transform:translateY(-2px)}

/* ── Service card micro-interaction upgrade ─────── */
.srv-card{transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s cubic-bezier(.22,1,.36,1)}
.srv-card:hover{transform:translateY(-8px) scale(1.01)}

/* ── Portfolio card upgrade ─────────────────────── */
.pf-card{transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s cubic-bezier(.22,1,.36,1)}
.pf-card:hover{transform:translateY(-6px)}

/* ── Social links ───────────────────────────────── */
.fsoc{transition:transform .35s cubic-bezier(.22,1,.36,1),background .25s,color .25s}
.fsoc:hover{transform:translateY(-3px) scale(1.03)}

/* ── Burger opens overlay on mobile ─────────────── */
@media(max-width:768px){
  .nav-links{display:none!important}
  .burger{display:flex;z-index:960}
  .chip-top{right:-8px}
  .chip-mid{left:-8px}
  .chip-bot{right:-6px}
}

/* ═══════════════════════════════════════════════════
   BRUTALIST HERO (Reference Inspired)
═══════════════════════════════════════════════════ */
.brutal-logo-text {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--dark);
  letter-spacing: -0.02em;
}

.brutal-hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  background: var(--white);
  padding-top: 72px; /* nav height offset */
  overflow: hidden;
}

.brutal-hero-inner {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  height: calc(100vh - 72px);
}

.brutal-hero-left {
  height: 100%;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  position: relative;
}

.brutal-portrait {
  max-height: 90vh;
  width: auto;
  object-fit: contain;
  object-position: bottom;
  filter: grayscale(100%) contrast(1.1) drop-shadow(0 0 40px rgba(0,0,0,0.05));
  transition: var(--trans);
}

.brutal-hero-right {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-right: clamp(20px, 5vw, 60px);
}

.brutal-content {
  position: relative;
  max-width: 600px;
}

.brutal-eyebrow {
  font-size: 1rem;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--dark);
  margin-bottom: 2.5rem;
  font-weight: 500;
}

.d-block { display: block; }

.brutal-title {
  font-size: clamp(3.5rem, 8vw, 6.5rem);
  font-weight: 400;
  line-height: 1.2;
  color: var(--dark);
  margin-bottom: 3.5rem;
  letter-spacing: 0.03em;
}

.brutal-star {
  position: absolute;
  top: -20px;
  right: 0;
  color: var(--dark);
  width: 50px;
  height: 50px;
}

@keyframes pulseRotate {
  0% { transform: scale(1) rotate(0deg); }
  50% { transform: scale(1.1) rotate(180deg); }
  100% { transform: scale(1) rotate(360deg); }
}

.brutal-links {
  display: flex;
  gap: 3.5rem;
  flex-wrap: wrap;
}

.bl-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--dark);
  text-decoration: none;
  border-bottom: 1.5px solid var(--dark);
  padding-bottom: 0.4rem;
  transition: var(--trans);
}

.bl-link:hover {
  color: var(--blue-light);
  border-bottom-color: var(--blue-light);
  transform: translateY(-2px);
}

@media(max-width: 900px) {
  .brutal-hero-inner {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
    height: auto;
    padding-top: 60px;
  }
  .brutal-hero-left {
    order: 2;
    height: auto;
    margin-top: 2rem;
  }
  .brutal-portrait {
    max-height: 55vh;
  }
  .brutal-hero-right {
    order: 1;
    padding: 0 clamp(20px, 5vw, 60px);
    text-align: center;
    align-items: center;
  }
  .brutal-content {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .brutal-star {
    right: 10%;
    top: -30px;
    width: 40px;
    height: 40px;
  }
  .brutal-links {
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════════════
   HERO ANIMATIONS
   Colors untouched. will-change used for GPU promotion.
═══════════════════════════════════════════════════ */

/* ── 1. Fade-up text reveal ─────────────────────── */
/* Default state: hidden, shifted down */
.hero-fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s cubic-bezier(.22,1,.36,1),
              transform 0.7s cubic-bezier(.22,1,.36,1);
  transition-delay: var(--anim-delay, 0s);
  will-change: opacity, transform;
}
/* Revealed state (added by JS) */
.hero-fade-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── 2. Portrait zoom-in on page load ───────────── */
@keyframes heroPortraitZoom {
  from { transform: scale(1.05); }
  to   { transform: scale(1); }
}
.hero-portrait-zoom {
  animation: heroPortraitZoom 3s cubic-bezier(.22,1,.36,1) both;
  will-change: transform;
}

/* ── 3. Star continuous slow spin ───────────────── */
@keyframes heroStarSpin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.hero-star-spin {
  animation: heroStarSpin 20s linear infinite;
  will-change: transform;
}

/* ── 4. Mobile override: instant fade-in on load ── */
/* On mobile disable scroll-trigger; use CSS animation directly */
@media (max-width: 768px) {
  @keyframes heroFadeUpLoad {
    from { opacity: 0; transform: translateY(30px); }
    to   { opacity: 1; transform: translateY(0); }
  }
  .hero-fade-up {
    animation: heroFadeUpLoad 0.7s cubic-bezier(.22,1,.36,1) both;
    animation-delay: var(--anim-delay, 0s);
    /* Override transition-based approach so JS isn't needed */
    transition: none;
  }
  /* Ensure already-revealed stays visible */
  .hero-fade-up.is-visible {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ═══════════════════════════════════════════════════
   PREMIUM PORTFOLIO IMAGE MARQUEE
═══════════════════════════════════════════════════ */
.portfolio-marquee-section {
  background: var(--white);
  padding: clamp(60px, 8vw, 100px) 0;
  overflow: hidden;
  border-top: 1px solid rgba(13,27,46,.04);
  border-bottom: 1px solid rgba(13,27,46,.04);
}

.marquee-label-container {
  margin-bottom: 2rem;
}

.image-marquee-wrap {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding: 1rem 0;
  mask-image: linear-gradient(90deg, transparent, black 15%, black 85%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, black 15%, black 85%, transparent);
}

.image-marquee-track {
  display: flex;
  width: max-content;
  gap: 24px;
  animation: imageMarqueeScroll 35s linear infinite;
  will-change: transform;
}

.marquee-img-item {
  width: 260px;
  height: 160px;
  border-radius: var(--radius, 16px);
  overflow: hidden;
  box-shadow: var(--shadow, 0 8px 40px rgba(13,27,46,.08));
  transition: transform 0.4s cubic-bezier(.22,1,.36,1), box-shadow 0.4s cubic-bezier(.22,1,.36,1);
  flex-shrink: 0;
  background: rgba(37,99,235,.03);
  cursor: pointer;
}

.marquee-img-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s cubic-bezier(.22,1,.36,1);
  decoding: async;
}

.marquee-img-item:hover {
  transform: translateY(-5px) scale(1.02);
  box-shadow: var(--shadow-lg, 0 20px 60px rgba(13,27,46,.14));
}

.marquee-img-item:hover img {
  transform: scale(1.05);
}

@keyframes imageMarqueeScroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-33.33333%);
  }
}

/* Hide scrollbars just in case */
.image-marquee-wrap,
.image-marquee-track {
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.image-marquee-wrap::-webkit-scrollbar,
.image-marquee-track::-webkit-scrollbar {
  display: none;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .portfolio-marquee-section {
    padding: clamp(40px, 6vw, 60px) 0;
  }
  .marquee-label-container {
    margin-bottom: 1.5rem;
  }
  .image-marquee-track {
    gap: 12px;
  }
  .marquee-img-item {
    width: 160px;
    height: 110px;
    border-radius: 12px;
  }
  .image-marquee-wrap {
    mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
    -webkit-mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
  }
}

