/*
Theme Name: Misnah Portfolio — Ultra Black
Theme URI: https://misnah.com
Author: Fathima Misnah
Description: Ultra-premium dark portfolio theme — fully black, animated logo splash, split-screen hero, magnetic cursor, parallax, 3D scroll, glitch type, orbital animations and full motion design.
Version: 3.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: misnah-portfolio
Tags: portfolio, dark, one-page, animation, premium
*/

/* ═══ TOKENS ═══ */
:root {
  --void:    #000000;
  --ink:     #06060f;
  --deep:    #0a0a16;
  --surface: #0e0e1c;
  --raise:   #141428;
  --lift:    #1a1a35;
  --border:  rgba(255,255,255,.06);
  --border2: rgba(255,255,255,.12);
  --violet:  #8b5cf6;
  --violet2: #6d28d9;
  --violet3: #4c1d95;
  --emerald: #10b981;
  --emerald2:#059669;
  --gold:    #f59e0b;
  --rose:    #f43f5e;
  --white:   #ffffff;
  --muted:   rgba(255,255,255,.55);
  --dim:     rgba(255,255,255,.30);
  --faint:   rgba(255,255,255,.08);
  --r:       12px;
  --r2:      20px;
  --r3:      32px;
  --ui:      'DM Sans', 'Inter', sans-serif;
  --serif:   'Playfair Display', Georgia, serif;
  --sh:      0 24px 60px rgba(0,0,0,.7);
  --sh2:     0 4px 20px rgba(0,0,0,.5);
  --tr:      .28s cubic-bezier(.4,0,.2,1);
}

/* ═══ RESET ═══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  background:var(--void);color:var(--white);
  font-family:var(--ui);line-height:1.6;
  overflow-x:hidden;min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;color:inherit;font-family:inherit}
ul{list-style:none}
input,select,textarea{font-family:inherit;font-size:inherit}

/* ═══ CURSOR ═══ */
#cur-dot{
  width:8px;height:8px;background:var(--violet);border-radius:50%;
  position:fixed;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);transition:transform .1s,background .2s;
}
#cur-ring{
  width:32px;height:32px;border:1.5px solid rgba(139,92,246,.5);border-radius:50%;
  position:fixed;pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);transition:transform .18s ease,width .25s,height .25s,border-color .25s;
}
body.hovered #cur-ring{width:48px;height:48px;border-color:var(--violet)}

/* ═══ BG ═══ */
.bg-grid{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:60px 60px;
}
.bg-glow{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 40% at 70% 30%,rgba(139,92,246,.10) 0%,transparent 60%),
             radial-gradient(ellipse 40% 40% at 20% 70%,rgba(16,185,129,.06) 0%,transparent 60%);
}
.bg-noise{
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
#scroll-bar{
  position:fixed;top:0;left:0;height:2px;background:linear-gradient(90deg,var(--violet),var(--emerald));
  z-index:9997;width:0%;transition:width .1s;
}

/* ═══════════════════════════
   SPLASH SCREEN (Logo)
═══════════════════════════ */
#splash{
  position:fixed;inset:0;z-index:99999;
  background:var(--void);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  transition:opacity .9s ease,transform .9s ease;
}
#splash.hide{opacity:0;transform:scale(1.04);pointer-events:none}
#splash.gone{display:none}

.splash-inner{
  position:relative;display:flex;flex-direction:column;align-items:center;
  gap:1.2rem;
}

/* Big M Logo */
.splash-logo-ring{
  position:relative;width:160px;height:160px;
  display:flex;align-items:center;justify-content:center;
  animation:splashRingPulse 2s ease-in-out infinite;
}
.splash-logo-ring::before{
  content:'';position:absolute;inset:0;border-radius:50%;
  border:2px solid transparent;
  background:linear-gradient(135deg,var(--violet),var(--emerald)) border-box;
  -webkit-mask:linear-gradient(#fff 0 0) padding-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:destination-out;mask-composite:exclude;
  animation:rotateSlow 4s linear infinite;
}
.splash-logo-ring::after{
  content:'';position:absolute;inset:8px;border-radius:50%;
  border:1px solid rgba(139,92,246,.3);
  animation:rotateSlow 7s linear infinite reverse;
}
@keyframes rotateSlow{to{transform:rotate(360deg)}}
@keyframes splashRingPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(139,92,246,.4)}
  50%{box-shadow:0 0 0 20px rgba(139,92,246,0)}
}

.splash-m{
  font-family:var(--serif);font-size:5.5rem;font-weight:700;
  background:linear-gradient(135deg,var(--white) 0%,var(--violet) 50%,var(--emerald) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:splashMIn 1s cubic-bezier(.34,1.56,.64,1) both;
  line-height:1;
}
@keyframes splashMIn{
  from{opacity:0;transform:scale(.4) rotate(-15deg)}
  to{opacity:1;transform:scale(1) rotate(0deg)}
}

.splash-name{
  font-family:var(--ui);font-size:1.1rem;letter-spacing:.35em;text-transform:uppercase;
  color:var(--muted);animation:fadeUp .8s .6s both;
}
.splash-sub{
  font-family:var(--ui);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--dim);animation:fadeUp .8s .9s both;
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:1;transform:translateY(0)}
}

.splash-line{
  width:1px;height:0;background:linear-gradient(to bottom,var(--violet),transparent);
  animation:splashLineGrow 1s 1.2s ease-out forwards;
  margin:0 auto;
}
@keyframes splashLineGrow{to{height:60px}}

.splash-progress{
  width:120px;height:1.5px;background:var(--lift);border-radius:2px;
  overflow:hidden;margin-top:.5rem;
  animation:fadeUp .5s 1s both;
}
.splash-progress-fill{
  height:100%;background:linear-gradient(90deg,var(--violet),var(--emerald));
  animation:splashLoad 2.2s ease-out forwards;
  transform-origin:left;
}
@keyframes splashLoad{
  0%{width:0%}
  60%{width:70%}
  100%{width:100%}
}

.splash-skip{
  position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  font-size:.72rem;letter-spacing:.12em;color:var(--dim);cursor:pointer;
  animation:fadeUp .6s 1.8s both;
  transition:color .2s;
}
.splash-skip:hover{color:var(--muted)}

/* ═══ PAGE FLASH ═══ */
#pg-flash{
  position:fixed;inset:0;z-index:9996;pointer-events:none;
  background:var(--violet);opacity:0;
}

/* ═══ NAV ═══ */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:900;
  display:flex;align-items:center;gap:1.5rem;
  padding:.9rem 2.4rem;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
  transition:padding var(--tr),background var(--tr);
}
#navbar.scrolled{padding:.6rem 2.4rem;background:rgba(0,0,0,.88)}
.nav-brand{
  font-family:var(--serif);font-size:1.45rem;font-weight:700;
  background:linear-gradient(135deg,var(--white),var(--violet));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  cursor:pointer;white-space:nowrap;
}
.nav-links{display:flex;gap:.2rem;flex:1;justify-content:center}
.nav-links a{
  font-size:.78rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted);padding:.45rem .8rem;border-radius:6px;
  transition:color var(--tr),background var(--tr);position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:4px;left:50%;transform:translateX(-50%) scaleX(0);
  width:16px;height:1.5px;background:var(--violet);border-radius:2px;
  transition:transform var(--tr);
}
.nav-links a:hover,
.nav-links a.active{color:var(--white)}
.nav-links a:hover::after,
.nav-links a.active::after{transform:translateX(-50%) scaleX(1)}
.nav-cta{display:flex;gap:.6rem;align-items:center;white-space:nowrap}
.btn-hire{
  font-size:.78rem;font-weight:600;letter-spacing:.04em;
  padding:.45rem 1.1rem;border-radius:8px;
  background:linear-gradient(135deg,var(--violet),var(--violet2));
  color:#fff;transition:opacity var(--tr),transform var(--tr);
}
.btn-hire:hover{opacity:.85;transform:translateY(-1px)}
.btn-wa{
  display:flex;align-items:center;gap:.4rem;
  font-size:.75rem;font-weight:500;padding:.42rem .9rem;
  border:1px solid var(--border2);border-radius:8px;color:var(--muted);
  transition:color var(--tr),border-color var(--tr),background var(--tr);
}
.btn-wa:hover{color:var(--white);border-color:var(--emerald);background:rgba(16,185,129,.08)}
.hamburger{display:none;flex-direction:column;gap:4px;padding:.4rem}
.hamburger span{width:22px;height:1.5px;background:var(--muted);transition:var(--tr);border-radius:2px}

/* ═══ MOBILE MENU ═══ */
.mobile-menu{
  position:fixed;inset:0;top:60px;z-index:899;
  background:rgba(0,0,0,.97);backdrop-filter:blur(24px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.4rem;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);
}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a{
  font-size:1.5rem;font-weight:600;color:var(--muted);
  letter-spacing:.04em;transition:color var(--tr);
}
.mobile-menu a:hover{color:var(--white)}

/* ═══ PAGES ═══ */
.page{
  display:none;min-height:100vh;padding-top:70px;
  position:relative;z-index:1;
}
.page.active{display:block}
section.page > *{animation:pageIn .5s ease both}
@keyframes pageIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ═══ HERO ═══ */
.hero{
  min-height:calc(100vh - 70px);
  display:grid;grid-template-columns:1fr 480px;grid-template-rows:1fr auto;
  gap:2rem;align-items:center;
  padding:3rem 2.4rem 2rem;max-width:1400px;margin:0 auto;
  position:relative;
}
.hero-orbit{position:absolute;right:10%;top:15%;width:500px;height:500px;pointer-events:none}
.orbit-ring{
  position:absolute;border-radius:50%;border:1px solid rgba(139,92,246,.15);
  animation:orbitSpin 20s linear infinite;
}
.orbit-ring-1{inset:0}
.orbit-ring-2{inset:30px;animation-duration:14s;animation-direction:reverse}
.orbit-dot{
  position:absolute;top:50%;left:0;width:6px;height:6px;
  background:var(--violet);border-radius:50%;margin-top:-3px;margin-left:-3px;
  box-shadow:0 0 12px var(--violet);
  animation:orbitSpin 20s linear infinite;transform-origin:253px 3px;
}
@keyframes orbitSpin{to{transform:rotate(360deg)}}
.glow-orb{
  position:absolute;border-radius:50%;pointer-events:none;filter:blur(80px);opacity:.15;
}
.orb-v{width:500px;height:500px;background:var(--violet);top:-10%;right:5%}
.orb-e{width:300px;height:300px;background:var(--emerald);bottom:5%;left:-5%}
.scan-line{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(to bottom,transparent 40%,rgba(139,92,246,.03) 50%,transparent 60%);
  animation:scanMove 8s ease-in-out infinite;
}
@keyframes scanMove{0%,100%{transform:translateY(-20%)}50%{transform:translateY(20%)}}

/* Hero Text */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.7rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;
  color:var(--violet);
  padding:.35rem .9rem;border:1px solid rgba(139,92,246,.3);border-radius:100px;
  background:rgba(139,92,246,.08);
  margin-bottom:1.3rem;
}
.hero-name-wrap{margin-bottom:.9rem}
.hero-name{
  font-family:var(--serif);font-size:clamp(3rem,5.5vw,5.5rem);
  line-height:1.05;font-weight:700;
}
.hero-name .name-line{display:block;color:var(--white)}
.hero-name em{
  display:block;font-style:italic;
  background:linear-gradient(135deg,var(--violet),var(--emerald));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-role-line{
  display:flex;align-items:center;gap:.8rem;
  font-size:.82rem;color:var(--muted);margin-bottom:1.4rem;
  font-weight:500;letter-spacing:.04em;
}
.hero-role-tw{min-width:160px;font-weight:600;color:var(--white)}
.role-sep{width:1px;height:14px;background:var(--border2)}
.hero-bio{
  font-size:1rem;color:var(--muted);line-height:1.75;
  max-width:520px;margin-bottom:2rem;
}
.hero-btns{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:2.4rem}
.btn-p{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.75rem 1.6rem;border-radius:var(--r);font-weight:600;font-size:.88rem;
  background:linear-gradient(135deg,var(--violet),var(--violet2));
  color:#fff;letter-spacing:.03em;
  transition:transform var(--tr),box-shadow var(--tr),opacity var(--tr);
  box-shadow:0 8px 24px rgba(139,92,246,.35);
}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(139,92,246,.45);opacity:.9}
.btn-o{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.72rem 1.4rem;border-radius:var(--r);font-weight:500;font-size:.88rem;
  border:1px solid var(--border2);color:var(--muted);
  transition:color var(--tr),border-color var(--tr),background var(--tr),transform var(--tr);
}
.btn-o:hover{color:var(--white);border-color:var(--white);background:var(--faint);transform:translateY(-1px)}
.btn-g{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.72rem 1.4rem;border-radius:var(--r);font-weight:600;font-size:.88rem;
  background:linear-gradient(135deg,var(--emerald),var(--emerald2));
  color:#fff;transition:transform var(--tr),box-shadow var(--tr);
  box-shadow:0 6px 20px rgba(16,185,129,.3);
}
.btn-g:hover{transform:translateY(-2px);box-shadow:0 10px 28px rgba(16,185,129,.4)}

/* Stats */
.hero-stats{display:flex;gap:2rem;flex-wrap:wrap}
.stat-item{display:flex;flex-direction:column}
.stat-n{
  font-family:var(--serif);font-size:2rem;font-weight:700;
  background:linear-gradient(135deg,var(--white),var(--violet));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1;
}
.stat-l{font-size:.7rem;color:var(--dim);text-transform:uppercase;letter-spacing:.08em;margin-top:.2rem}

/* Hero Photo */
.hero-img-col{
  position:relative;display:flex;align-items:center;justify-content:center;
  grid-column:2;
}
.hero-img-frame{
  position:relative;width:100%;max-width:420px;
}
.hero-corner{
  position:absolute;width:20px;height:20px;z-index:2;
}
.corner-tl{top:-6px;left:-6px;border-top:2px solid var(--violet);border-left:2px solid var(--violet)}
.corner-tr{top:-6px;right:-6px;border-top:2px solid var(--emerald);border-right:2px solid var(--emerald)}
.corner-br{bottom:-6px;right:-6px;border-bottom:2px solid var(--violet);border-right:2px solid var(--violet)}
.corner-bl{bottom:-6px;left:-6px;border-bottom:2px solid var(--emerald);border-left:2px solid var(--emerald)}

.hero-photo-mask{
  border-radius:var(--r2);overflow:hidden;
  border:1px solid var(--border2);
  position:relative;
  background:var(--surface);
}
.hero-photo{
  width:100%;height:520px;object-fit:cover;object-position:center top;
  display:block;
  transition:transform .6s ease;
  filter:brightness(.95) contrast(1.05);
}
.hero-img-frame:hover .hero-photo{transform:scale(1.03)}
.hero-img-glow{
  position:absolute;inset:0;border-radius:var(--r2);pointer-events:none;
  background:linear-gradient(to top,rgba(139,92,246,.2) 0%,transparent 50%);
}
.hero-pill{
  position:absolute;
  font-size:.7rem;font-weight:600;
  padding:.35rem .8rem;border-radius:100px;
  background:rgba(0,0,0,.8);border:1px solid var(--border2);
  backdrop-filter:blur(12px);white-space:nowrap;color:var(--white);
  letter-spacing:.02em;
}
.pill-1{top:1.2rem;left:-1.2rem;border-color:rgba(16,185,129,.4)}
.pill-1 .pill-dot{
  display:inline-block;width:6px;height:6px;background:var(--emerald);
  border-radius:50%;margin-right:.4rem;animation:blink 1.5s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.pill-2{bottom:3.5rem;left:-1.2rem}
.pill-3{bottom:1rem;right:-1rem;border-color:rgba(139,92,246,.4)}

.hero-availability{
  grid-column:1/-1;
  display:flex;align-items:center;gap:.6rem;
  font-size:.72rem;color:var(--dim);letter-spacing:.06em;
  padding-top:1rem;border-top:1px solid var(--border);
}
.avail-dot{width:6px;height:6px;background:var(--emerald);border-radius:50%;animation:blink 1.5s ease-in-out infinite}

/* ═══ ABOUT ═══ */
.about-wrap{max-width:1200px;margin:0 auto;padding:4rem 2.4rem}
.section-title{
  font-family:var(--serif);font-size:clamp(2.2rem,4vw,3.5rem);
  font-weight:700;line-height:1.15;margin-bottom:.9rem;
}
.section-title em{
  font-style:italic;
  background:linear-gradient(135deg,var(--violet),var(--emerald));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.section-sub{font-size:1rem;color:var(--muted);max-width:520px;margin-bottom:3rem}
.about-grid{display:grid;grid-template-columns:420px 1fr;gap:4rem;align-items:start}
.about-img-col{position:relative}
.about-photo-mask{
  border-radius:var(--r3);overflow:hidden;
  border:1px solid var(--border2);
  position:relative;
  background:var(--surface);
}
.about-photo{
  width:100%;height:580px;object-fit:cover;object-position:center top;
  display:block;filter:brightness(.92) contrast(1.05);
}
.about-img-lines{
  position:absolute;inset:0;border-radius:var(--r3);
  background:linear-gradient(to top,rgba(139,92,246,.3) 0%,transparent 50%);
  pointer-events:none;
}
.about-badge{
  position:absolute;bottom:-1.2rem;right:-1.2rem;
  background:linear-gradient(135deg,var(--violet),var(--violet2));
  border-radius:var(--r);padding:1rem 1.4rem;
  display:flex;flex-direction:column;gap:.1rem;
  box-shadow:var(--sh);
}
.badge-n{font-family:var(--serif);font-size:2rem;font-weight:700;color:#fff;line-height:1}
.badge-l{font-size:.68rem;color:rgba(255,255,255,.75);line-height:1.3}

.about-txt{display:flex;flex-direction:column;gap:1.8rem}
.about-block h3{
  font-family:var(--serif);font-size:1.15rem;font-weight:600;
  color:var(--white);margin-bottom:.6rem;
}
.about-block p{font-size:.92rem;color:var(--muted);line-height:1.75}

/* Skill bars */
.skill-bars{display:flex;flex-direction:column;gap:.9rem}
.sb-item{}
.sb-head{display:flex;justify-content:space-between;margin-bottom:.35rem;font-size:.78rem}
.sb-pct{color:var(--violet);font-weight:600}
.sb-track{background:var(--lift);border-radius:100px;height:4px;overflow:hidden}
.sb-fill{
  height:100%;border-radius:100px;
  background:linear-gradient(90deg,var(--violet),var(--emerald));
  width:0%;transition:width 1.2s cubic-bezier(.4,0,.2,1);
}
.sb-item.in .sb-fill{width:var(--w)}

/* Timeline */
.timeline{display:flex;flex-direction:column;gap:1.1rem;padding-left:1rem;border-left:1px solid var(--border2)}
.t-item{padding-left:1.2rem;position:relative}
.t-item::before{
  content:'';position:absolute;left:-5px;top:.45rem;
  width:8px;height:8px;border-radius:50%;
  background:linear-gradient(135deg,var(--violet),var(--emerald));
}
.t-year{font-size:.7rem;color:var(--violet);font-weight:600;letter-spacing:.06em;text-transform:uppercase;margin-bottom:.15rem}
.t-title{font-size:.88rem;font-weight:600;color:var(--white)}
.t-co{font-size:.75rem;color:var(--dim)}

/* ═══ SERVICES ═══ */
.services-wrap{max-width:1200px;margin:0 auto;padding:4rem 2.4rem}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.2rem;margin-top:2rem}
.svc-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);
  padding:1.8rem;position:relative;overflow:hidden;
  transition:transform var(--tr),border-color var(--tr),box-shadow var(--tr);
  cursor:default;
}
.svc-card::before{
  content:'';position:absolute;inset:0;border-radius:var(--r2);
  background:linear-gradient(135deg,rgba(139,92,246,.06),transparent);
  opacity:0;transition:opacity var(--tr);
}
.svc-card:hover{transform:translateY(-4px);border-color:rgba(139,92,246,.3);box-shadow:0 20px 50px rgba(139,92,246,.12)}
.svc-card:hover::before{opacity:1}
.svc-num{
  position:absolute;top:1.2rem;right:1.4rem;
  font-size:.65rem;font-weight:700;letter-spacing:.12em;
  color:rgba(139,92,246,.35);
}
.svc-icon{font-size:1.8rem;margin-bottom:.9rem;display:block}
.svc-name{font-family:var(--serif);font-size:1.15rem;font-weight:700;margin-bottom:.6rem}
.svc-desc{font-size:.82rem;color:var(--muted);line-height:1.7;margin-bottom:1rem}
.svc-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.tag{
  font-size:.65rem;padding:.25rem .6rem;border-radius:100px;
  border:1px solid var(--border2);color:var(--dim);letter-spacing:.04em;
}

/* ═══ PORTFOLIO ═══ */
.portfolio-wrap{max-width:1200px;margin:0 auto;padding:4rem 2.4rem}
.port-filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem}
.f-btn{
  font-size:.75rem;font-weight:500;padding:.4rem .9rem;border-radius:100px;
  border:1px solid var(--border2);color:var(--muted);
  transition:color var(--tr),background var(--tr),border-color var(--tr);
}
.f-btn.active,.f-btn:hover{color:var(--white);background:rgba(139,92,246,.15);border-color:var(--violet)}
.port-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.2rem}
.port-card{
  border-radius:var(--r2);overflow:hidden;cursor:pointer;
  background:var(--surface);border:1px solid var(--border);
  transition:transform var(--tr),box-shadow var(--tr);
}
.port-card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.port-img-w{position:relative;overflow:hidden;aspect-ratio:4/3}
.port-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.port-card:hover .port-img{transform:scale(1.06)}
.port-ov{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(139,92,246,.25) 100%);
  opacity:0;transition:opacity var(--tr);
  display:flex;flex-direction:column;justify-content:flex-end;padding:1.2rem;
}
.port-card:hover .port-ov{opacity:1}
.port-ov-cat{font-size:.65rem;color:var(--violet);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.4rem}
.port-ov-name{font-size:.88rem;font-weight:600;color:var(--white);line-height:1.3}
.port-ov-arr{font-size:1.3rem;position:absolute;top:1rem;right:1rem;color:var(--white)}
.port-info{padding:1rem 1.2rem}
.port-info-cat{font-size:.65rem;color:var(--dim);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.25rem}
.port-info-name{font-size:.88rem;font-weight:600;color:var(--white)}

/* Modal */
#modal-ov{
  position:fixed;inset:0;z-index:9000;
  background:rgba(0,0,0,.85);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s;padding:1.5rem;
}
#modal-ov.open{opacity:1;pointer-events:all}
#modal-box{
  background:var(--surface);border-radius:var(--r2);
  border:1px solid var(--border2);max-width:680px;width:100%;
  overflow:hidden;position:relative;max-height:85vh;overflow-y:auto;
  transform:scale(.95);transition:transform .3s;
}
#modal-ov.open #modal-box{transform:scale(1)}
.m-close{
  position:absolute;top:1rem;right:1rem;z-index:1;
  width:32px;height:32px;border-radius:50%;
  background:rgba(0,0,0,.5);border:1px solid var(--border2);
  font-size:.8rem;color:var(--muted);
  display:flex;align-items:center;justify-content:center;
  transition:background var(--tr),color var(--tr);
}
.m-close:hover{background:var(--lift);color:var(--white)}
.m-img{width:100%;aspect-ratio:16/9;object-fit:cover}
.m-body{padding:1.6rem}
.m-cat{font-size:.68rem;color:var(--violet);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.4rem}
.m-title{font-family:var(--serif);font-size:1.4rem;font-weight:700;margin-bottom:.7rem}
.m-desc{font-size:.88rem;color:var(--muted);line-height:1.7;margin-bottom:1rem}
.m-results{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:1rem;padding:1rem;background:var(--raise);border-radius:var(--r)}
.m-results > div{display:flex;flex-direction:column}
.m-results .mn{font-size:1.4rem;font-weight:700;color:var(--violet);font-family:var(--serif)}
.m-results .ml{font-size:.65rem;color:var(--dim);text-transform:uppercase;letter-spacing:.07em}
.m-tags{display:flex;flex-wrap:wrap;gap:.4rem}

/* ═══ TESTIMONIALS ═══ */
.test-wrap{max-width:1200px;margin:0 auto;padding:4rem 2.4rem}
.feat-q{
  background:linear-gradient(135deg,rgba(139,92,246,.1),rgba(16,185,129,.06));
  border:1px solid rgba(139,92,246,.2);border-radius:var(--r2);
  padding:2rem 2.4rem;margin-bottom:2.5rem;
}
.feat-txt{
  font-family:var(--serif);font-size:1.15rem;color:var(--white);
  line-height:1.75;margin-bottom:1rem;font-style:italic;
}
.feat-auth{font-size:.78rem;color:var(--violet);font-weight:600;letter-spacing:.04em}
.test-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.2rem}
.test-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);
  padding:1.6rem;transition:transform var(--tr),border-color var(--tr);
}
.test-card:hover{transform:translateY(-3px);border-color:rgba(139,92,246,.25)}
.t-stars{color:var(--gold);font-size:.85rem;letter-spacing:.1em;margin-bottom:.8rem}
.t-txt{font-size:.84rem;color:var(--muted);line-height:1.75;margin-bottom:1.2rem;font-style:italic}
.t-auth{display:flex;align-items:center;gap:.8rem}
.t-av{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--violet),var(--violet2));
  display:flex;align-items:center;justify-content:center;
  font-size:.7rem;font-weight:700;color:#fff;
}
.t-name{font-size:.84rem;font-weight:600;color:var(--white)}
.t-role{font-size:.7rem;color:var(--dim)}

/* ═══ BLOG ═══ */
.blog-wrap{max-width:1200px;margin:0 auto;padding:4rem 2.4rem}
.blog-grid{display:grid;grid-template-columns:1fr 360px;gap:1.5rem;margin-top:2rem}
.bm-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r2);
  overflow:hidden;transition:transform var(--tr),box-shadow var(--tr);cursor:pointer;
}
.bm-card:hover{transform:translateY(-3px);box-shadow:var(--sh)}
.bm-img{width:100%;aspect-ratio:16/9;object-fit:cover}
.bm-body{padding:1.4rem}
.b-cat{font-size:.65rem;color:var(--violet);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.5rem}
.bm-title{font-family:var(--serif);font-size:1.3rem;font-weight:700;margin-bottom:.7rem;line-height:1.3}
.bm-exc{font-size:.82rem;color:var(--muted);line-height:1.7}
.blog-side{display:flex;flex-direction:column;gap:.9rem}
.bs-card{
  display:flex;gap:1rem;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r);padding:.9rem;cursor:pointer;
  transition:transform var(--tr),border-color var(--tr);
}
.bs-card:hover{transform:translateX(4px);border-color:rgba(139,92,246,.2)}
.bs-img{width:72px;height:60px;object-fit:cover;border-radius:8px;flex-shrink:0}
.bs-cat{font-size:.62rem;color:var(--violet);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.2rem}
.bs-title{font-size:.78rem;font-weight:600;color:var(--white);line-height:1.4}

/* ═══ CONTACT ═══ */
.contact-wrap{max-width:1100px;margin:0 auto;padding:4rem 2.4rem}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-top:2rem}
.c-info-list{display:flex;flex-direction:column;gap:1.1rem;margin-bottom:2rem}
.c-item{display:flex;align-items:flex-start;gap:.9rem}
.c-ico{font-size:1.2rem;flex-shrink:0;margin-top:.1rem}
.c-lbl{font-size:.65rem;color:var(--dim);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.15rem}
.c-val{font-size:.88rem;color:var(--white)}
.c-val a:hover{color:var(--violet)}
.soc-row{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.8rem}
.soc-btn{
  font-size:.75rem;font-weight:500;padding:.4rem .9rem;
  border:1px solid var(--border2);border-radius:8px;color:var(--muted);
  transition:color var(--tr),border-color var(--tr),background var(--tr);
}
.soc-btn:hover{color:var(--white);border-color:var(--violet);background:rgba(139,92,246,.1)}

/* Contact Form */
.cf{display:flex;flex-direction:column;gap:.9rem}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.fg{display:flex;flex-direction:column;gap:.4rem}
.fg label{font-size:.72rem;color:var(--muted);font-weight:500;letter-spacing:.04em}
.fg input,.fg select,.fg textarea{
  background:var(--surface);border:1px solid var(--border2);border-radius:var(--r);
  padding:.7rem .9rem;color:var(--white);font-size:.88rem;
  transition:border-color var(--tr),background var(--tr);
  outline:none;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:var(--violet);background:var(--raise);
}
.fg textarea{min-height:120px;resize:vertical}
.fg select{appearance:none;cursor:pointer}
.fg select option{background:var(--ink)}
.cf-submit{
  padding:.85rem;border-radius:var(--r);font-weight:600;font-size:.9rem;
  background:linear-gradient(135deg,var(--violet),var(--violet2));
  color:#fff;letter-spacing:.03em;
  transition:transform var(--tr),box-shadow var(--tr),opacity var(--tr);
  box-shadow:0 8px 24px rgba(139,92,246,.35);
}
.cf-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 32px rgba(139,92,246,.45)}
.cf-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}

/* ═══ FOOTER ═══ */
footer{
  background:var(--ink);border-top:1px solid var(--border);
  position:relative;z-index:1;
}
.footer-inner{
  max-width:1200px;margin:0 auto;padding:3rem 2.4rem;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;
}
.f-brand{
  font-family:var(--serif);font-size:1.8rem;font-weight:700;
  background:linear-gradient(135deg,var(--white),var(--violet));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:.8rem;
}
.f-desc{font-size:.8rem;color:var(--dim);line-height:1.7;max-width:260px}
.f-col-title{font-size:.65rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;font-weight:600;margin-bottom:.9rem}
.f-links{display:flex;flex-direction:column;gap:.5rem}
.f-links a{font-size:.8rem;color:var(--dim);transition:color var(--tr)}
.f-links a:hover{color:var(--white)}
.footer-bottom{
  border-top:1px solid var(--border);padding:1.2rem 2.4rem;
  display:flex;justify-content:space-between;align-items:center;
  font-size:.72rem;color:var(--dim);
  max-width:1200px;margin:0 auto;
}
.footer-love span{color:var(--rose)}

/* ═══ FLOATERS ═══ */
.wa-float{
  position:fixed;bottom:1.8rem;right:1.8rem;z-index:890;
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,#25D366,#128C7E);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 24px rgba(37,211,102,.35);
  animation:waPulse 2.5s ease-in-out infinite;
  transition:transform var(--tr);
}
.wa-float:hover{transform:scale(1.1) translateY(-2px)}
@keyframes waPulse{0%,100%{box-shadow:0 6px 24px rgba(37,211,102,.35)}50%{box-shadow:0 6px 32px rgba(37,211,102,.6)}}
#music-btn{
  position:fixed;bottom:5rem;right:1.9rem;z-index:890;
  width:36px;height:36px;border-radius:50%;
  background:var(--lift);border:1px solid var(--border2);
  font-size:.85rem;color:var(--muted);
  transition:color var(--tr),background var(--tr);
}
#music-btn:hover{color:var(--white);background:var(--raise)}
#back-top{
  position:fixed;bottom:1.8rem;left:1.8rem;z-index:890;
  width:40px;height:40px;border-radius:50%;
  background:var(--lift);border:1px solid var(--border2);
  font-size:.85rem;color:var(--muted);
  opacity:0;transform:translateY(10px);
  transition:opacity var(--tr),transform var(--tr),color var(--tr);
}
#back-top.show{opacity:1;transform:translateY(0)}
#back-top:hover{color:var(--white)}

/* ═══ ANIMATIONS DATA-A ═══ */
[data-a]{opacity:0;transition:opacity .6s ease,transform .6s ease}
[data-a="up"]{transform:translateY(30px)}
[data-a="left"]{transform:translateX(-30px)}
[data-a="right"]{transform:translateX(30px)}
[data-a="img"]{transform:scale(.94)}
[data-a="flip"]{transform:perspective(600px) rotateX(8deg)}
[data-a="zoom"]{transform:scale(.9)}
[data-a="tag"]{transform:translateY(10px)}
[data-a].in{opacity:1;transform:none}

/* ═══ RESPONSIVE ═══ */
@media(max-width:1024px){
  .hero{grid-template-columns:1fr;text-align:center;padding:2rem 1.5rem}
  .hero-txt{order:2}
  .hero-img-col{order:1;grid-column:1}
  .hero-photo{height:360px}
  .hero-btns{justify-content:center}
  .hero-stats{justify-content:center}
  .hero-bio{margin:0 auto 2rem}
  .hero-availability{justify-content:center}
  .about-grid{grid-template-columns:1fr}
  .about-img-col{max-width:400px;margin:0 auto}
  .blog-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr;gap:2rem}
  .contact-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-links{display:none}
  .nav-cta{display:none}
  .hamburger{display:flex}
  .hero-name{font-size:2.8rem}
  .services-wrap,.portfolio-wrap,.test-wrap,.blog-wrap,.contact-wrap,.about-wrap{padding:3rem 1.2rem}
  .hero{padding:2rem 1.2rem}
  .fr{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;gap:1.5rem}
  .footer-bottom{flex-direction:column;gap:.5rem;text-align:center}
  .pill-1,.pill-2,.pill-3{display:none}
}
