*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* Matched to the purple hijab avatar */
  --cream:#fdf8ff;
  --cream2:#f5eeff;
  --cream3:#ead9ff;
  --dark:#030712;
  --dark2:#0d0a1a;
  --white:#ffffff;
  --ink:#1a0f2e;
  --ink2:#3d2f5a;
  --ink3:#7a6a9a;
  --ink4:#a395c0;
  --p:#8b5cf6;
  --p2:#a78bfa;
  --p3:#c4b5fd;
  --p4:#ede9fe;
  --p5:#f5f3ff;
  --rose:#d4a0c0;
  --grad:linear-gradient(135deg,#7c3aed 0%,#a855f7 60%,#c084fc 100%);
  --grad-soft:linear-gradient(135deg,#f5f3ff 0%,#ede9fe 100%);
  --serif:'DM Serif Display',Georgia,serif;
  --sans:'Plus Jakarta Sans',system-ui,sans-serif;
  --border:#e8dff8;
  --shadow:0 4px 24px rgba(124,58,237,.10);
  --shadow-lg:0 16px 64px rgba(124,58,237,.15);
  --white:#ffffff;
  --accent:#7c3aed;        
  --accent-light:#ede9fe;    
  --accent-dark:#3d2f5a;     
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--ink);overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* ── NAV ── */
nav{position:fixed;inset:0 0 auto;z-index:200;height:66px;background:white;
  border-bottom:2px solid var(--ink3)}.nav-inner{max-width:1060px;margin:0 auto;width:100%;height:66px;display:flex;align-items:center;justify-content:space-between;
    }
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.nav-av{width:40px;height:40px;border-radius:50%;border:2.5px solid var(--p3);overflow:hidden;flex-shrink:0;background:var(--dark)}
.nav-av img{width:100%;height:100%;object-fit:cover;object-position:top}
.nav-name{font-family:var(--serif);font-size:1.05rem;color:var(--ink2);letter-spacing:-.01em}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-a{font-size:.82rem;font-weight:600;color:var(--ink2);text-decoration:none;padding:7px 14px;border-radius:8px;transition:color .18s,background .18s;white-space:nowrap}
.nav-a:hover{color:var(--p);background:var(--p4)}
.nav-icons{display:flex;gap:8px;margin-left:8px}
.nav-icon{width:36px;height:36px;border-radius:50%;background:var(--ink);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:.85rem;font-weight:700;color:var(--white);transition:background .18s,border-color .18s}
.nav-icon:hover{background:var(--p4);border-color:var(--p3)}
.hbg{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.hbg span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all .3s}
.hbg.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hbg.open span:nth-child(2){opacity:0}
.hbg.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mnav{display:none;position:fixed;inset:66px 0 0;background:rgba(253,249,245,.97);backdrop-filter:blur(16px);z-index:190;padding:28px clamp(20px,5vw,32px);flex-direction:column;gap:4px;border-top:1px solid var(--border)}
.mnav.open{display:flex}
.mnav .nav-a{font-size:1.05rem;padding:14px 16px;border-radius:12px;border-bottom:1px solid var(--border)}
.mnav .nav-icons{margin-top:16px;margin-left:0;gap:10px}

/* ── HERO ── */
.hero{min-height:100vh;display:flex;align-items:center;padding:80px clamp(20px,5vw,64px) 60px;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:var(--ink);pointer-events:none}
.spark{position:absolute;pointer-events:none;color:var(--p3);animation:twinkle 3s ease-in-out infinite}
.spark:nth-child(2){top:15%;left:8%;font-size:2.3rem;animation-delay:0s}
.spark:nth-child(3){top:20%;right:12%;font-size:1.8rem;animation-delay:.9s}
.spark:nth-child(4){bottom:28%;left:6%;font-size:1.9rem;animation-delay:1.8s}
.spark:nth-child(5){top:65%;right:6%;font-size:2.1rem;animation-delay:2.7s}
@keyframes twinkle{0%,100%{opacity:.25;transform:scale(.8) rotate(0deg)}50%{opacity:1;transform:scale(1.15) rotate(18deg)}}
.hero-inner{max-width:1060px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr auto;gap:clamp(40px,6vw,80px);align-items:center;position:relative;z-index:1}
.hero-pill{display:inline-flex;align-items:center;gap:7px;background:var(--p4);border:1px solid rgba(139,92,246,.2);border-radius:100px;
  padding:8px 16px 8px 16px;font-size:.72rem;font-weight:700;color:var(--p);margin-bottom:22px}
.pill-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 7px rgba(34,197,94,.6);flex-shrink:0;animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.6)}}
.hero h1{font-family:var(--serif);font-size:clamp(2.2rem,4.5vw,4rem);;line-height:1.05;letter-spacing:-.01em;color:var(--white);margin-bottom:20px}
.hero h1 .hl{color:#7c3aed}
.hero h1 .sep{color:var(--p3)}
.hero-desc{font-size:clamp(.9rem,1.3vw,1rem);color:var(--white);line-height:1.8;max-width:480px;margin-bottom:10px}
.hero-desc strong{color:var(--white);font-weight:700}
.hero-desc2{font-size:.92rem;color:var(--white);line-height:1.75;max-width:460px;margin-bottom:36px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-dark{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;font-weight:700;color:var(--white);background:#7c3aed;padding:13px 28px;border-radius:100px;text-decoration:none;transition:background .2s,transform .15s;box-shadow:0 4px 16px rgba(3,7,18,.2)}
.btn-dark:hover{background:var(--p);transform:translateY(-2px)}
.btn-line{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;font-weight:700;color:var(--ink);background:#ffffff;padding:13px 28px;border-radius:100px;border:1.5px solid var(--ink);text-decoration:none;transition:border-color .2s,color .2s,transform .15s}
.btn-line:hover{border-color:var(--p);color:var(--p);transform:translateY(-2px)}

/* ── HERO RIGHT — avatar ── */
.hero-right{display:flex;flex-direction:column;align-items:center;gap:20px;flex-shrink:0}
.avatar-wrap{position:relative;width:clamp(360px,28vw,470px)}
.avatar-circle{width:100%;aspect-ratio:1;overflow:hidden;
  ;position:relative}
.avatar-circle img{width:100%;height:100%;object-fit:cover;object-position:top center;transform:scale(1.25)}
.av-badge{position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);background:var(--white);border:2px solid var(--border);border-radius:100px;
  padding:8px 18px;font-size:.72rem;font-weight:700;color:var(--ink2);white-space:nowrap;box-shadow:var(--shadow);display:flex;align-items:center;gap:7px}
.av-badge::before{content:'';width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 7px rgba(34,197,94,.6);flex-shrink:0}
.av-spark1{position:absolute;top:200px;right:-8px;font-size:2.5rem;color:var(--p3);animation:twinkle 2.5s ease infinite}
.av-spark2{position:absolute;top:35%;left:-20px;font-size:1.9rem;color:var(--p2);animation:twinkle 3.5s ease infinite .6s}
/* mini role cards floating beside avatar */
.av-card{background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:12px 16px;box-shadow:var(--shadow);position:absolute}
.avc1{top:10px;right:-70px}
.avc2{bottom:80px;right:-70px}
.avc-icon{font-size:1.1rem;margin-bottom:4px}
.avc-label{font-size:.65rem;font-weight:700;color:var(--ink);white-space:nowrap}
.avc-sub{font-size:.6rem;color:var(--ink3);white-space:nowrap}



/* ── SECTIONS ── */
.section{padding:clamp(40px,6vw,80px) clamp(24px,5vw,64px)}
.sec-inner{max-width:1060px;margin:0 auto;width:100%}
.sec-pill{display:inline-flex;align-items:center;gap:6px;font-size:.6875rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--p);background:var(--p4);padding:5px 14px;border-radius:100px;margin-bottom:14px;border:1px solid rgba(124,58,237,.15)}
.hero-mob-av{display:none}
.sec-h{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,2.5rem);font-weight:900;line-height:1.1;color:var(--ink);margin-bottom:14px;letter-spacing:-.01em}
.sec-h em{font-style:italic;color:var(--p)}
.sec-sub{font-size:1rem;color:var(--ink2);line-height:1.75;font-weight:300;max-width:540px}

/* ── SKILLS ── */
.skills-sec{background:var(--white)}
.skills-top{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);align-items:end;margin-bottom:clamp(40px,6vw,64px)}
.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.sk-card{background:var(--cream);border:1.5px solid var(--border);border-radius:20px;padding:28px 24px;transition:border-color .25s,
  transform .25s,box-shadow .25s;display:flex;flex-direction:column;gap:14px;position:relative;overflow:hidden}
.sk-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--grad);transform:scaleX(0);
  transition:transform .3s;transform-origin:left}
.sk-card:hover{border-color:rgba(139,92,246,.3);transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.sk-card:hover::before{transform:scaleX(1)}
.sk-head{display:flex;align-items:flex-start;gap:14px}
.sk-ico{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
.sk-ico1{background:var(--ink4)}
.sk-ico2{background:#fdf4ff}
.sk-ico3{background:#f0fdf4}
.sk-ico4{background:#fdf2f8}
.sk-card h3{font-family:var(--sans);font-size:1.05rem;color:var(--ink);margin-bottom:6px;line-height:1.2}
.sk-card p{font-size:.82rem;color:var(--ink2);line-height:1.7}
.sk-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}
.sk-tag{font-size:.64rem;font-weight:700;padding:4px 11px;border-radius:100px;background:var(--white);color:var(--ink2);border:1.5px solid var(--border)}

/* ── PORTFOLIO ── */
.port-sec{background:var(--cream2)}
.port-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:clamp(28px,4vw,48px);flex-wrap:wrap;gap:14px}
/* port-link removed — replaced with btn-port-all */
.port-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(12px,2vw,20px);align-items:stretch}
.left-col,.right-col{display:flex;flex-direction:column;gap:clamp(12px,2vw,18px)}
.left-col .pcard,.right-col .pcard{flex:1}
.left-col .pthumb{aspect-ratio:16/9}
.right-col .pthumb{aspect-ratio:unset;flex:1;min-height:180px}
.right-col .pcard{display:flex;flex-direction:column}
.pthumb-lg{aspect-ratio:4/3!important}
.port-btn-wrap{text-align:center;margin-top:clamp(32px,5vw,48px)}
.btn-port-all{display:inline-flex;align-items:center;gap:10px;font-size:.875rem;font-weight:700;color:var(--p);background:var(--p4);border:2px solid rgba(124,58,237,.2);padding:14px 36px;border-radius:100px;text-decoration:none;transition:background .2s,border-color .2s,transform .15s,box-shadow .2s;letter-spacing:.04em}
.btn-port-all:hover{background:var(--p);color:var(--white);border-color:var(--p);transform:translateY(-2px);box-shadow:0 8px 24px rgba(124,58,237,.25)}
.btn-port-all:hover .port-arrow{transform:translateX(4px)}
.port-arrow{display:inline-block;transition:transform .2s}
.pcard{border-radius:20px;overflow:hidden;text-decoration:none;color:inherit;display:flex;flex-direction:column;background:var(--white);border:1.5px solid var(--border);transition:transform .25s,box-shadow .25s,border-color .25s;box-shadow:0 2px 12px rgba(124,58,237,.06)}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(124,58,237,.22)}
.pcard.tall{height:100%;grid-row:span 2}
.pthumb{overflow:hidden;position:relative;aspect-ratio:16/9;background:var(--cream2)}
.pcard.tall .pthumb{aspect-ratio:unset;flex:1;min-height:220px}
.pthumb img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .4s}
.pcard:hover .pthumb img{transform:scale(1.04)}
.pcard.tall .pthumb{aspect-ratio:unset;flex:1;min-height:180px}
.pt-in{width:100%;height:100%;min-height:150px;display:flex;align-items:center;justify-content:center;font-size:3rem;transition:transform .4s}
.pcard:hover .pt-in{transform:scale(1.06)}
.pt1{background:linear-gradient(135deg,#f3e8ff,#e9d5ff)}
.pt2{background:linear-gradient(135deg,#fdf4ff,#f5d0fe)}
.pt3{background:linear-gradient(135deg,#fdf9c3,#fde68a)}
.pt4{background:linear-gradient(135deg,#e0e7ff,#c7d2fe)}
.ph-ovr{position:absolute;inset:0;background:linear-gradient(to top,rgba(3,7,18,.75) 0%,transparent 55%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:18px}
.ph-ovr span{font-size:.6875rem;font-weight:700;color:white;letter-spacing:.08em;text-transform:uppercase}
.pbadge{position:absolute;top:10px;left:10px;font-size:.625rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--p);background:rgba(255,255,255,.92);padding:4px 10px;border-radius:100px;backdrop-filter:blur(8px)}
.pcard-body{padding:clamp(14px,2vw,22px) clamp(16px,2.5vw,24px);display:flex;flex-direction:column;gap:6px}
.ptag{font-size:.625rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--p)}
.pcard-body h3{font-family:var(--serif);font-size:1.375rem;font-weight:700;color:var(--ink);line-height:1.3}
.pcard-body p{font-size:.875rem;color:var(--ink2);line-height:1.65;font-weight:300}
.p-cta{font-size:.875rem;font-weight:700;color:var(--p);display:inline-flex;align-items:center;gap:5px;transition:gap .2s;margin-top:4px}
.pcard:hover .p-cta{gap:9px}
.psoon{font-size:.875rem;color:var(--ink3);font-weight:400;margin-top:4px}



/* ── DARK TECH STRIP ── */

.dark-strip{background:var(--ink);padding:clamp(50px,7vw,80px) clamp(20px,5vw,64px)}
.ds-inner{max-width:1060px;margin:0 auto}
.ds-inner .sec-pill{background:rgba(124,58,237,.25);color:var(--p3)}
.ds-inner .sec-h{color:var(--white)}
.tech-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-top:44px}
.t-item{background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.12);border-radius:18px;padding:24px 12px 18px;display:flex;flex-direction:column;align-items:center;gap:12px;transition:background .2s,border-color .2s,transform .2s,box-shadow .2s;cursor:default}
.t-item:hover{background:rgba(124,58,237,.2);border-color:rgba(196,181,253,.5);transform:translateY(-4px);box-shadow:0 8px 28px rgba(124,58,237,.25)}
.t-item img{width:52px;height:52px;object-fit:contain;display:block}
.t-item span{font-size:.72rem;font-weight:700;color:rgba(255,255,255,.7);text-align:center;letter-spacing:.02em}



/* ── PROCESS ── */
.process-sec{background:var(--cream)}
.proc-row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative;margin-top:52px}
.proc-row::before{content:'';position:absolute;top:36px;left:10%;right:10%;height:1.5px;background:linear-gradient(90deg,transparent,var(--border),transparent);z-index:0}
.proc-card{background:var(--white);border:1.5px solid var(--border);border-radius:18px;padding:28px 20px;text-align:center;position:relative;z-index:1;transition:border-color .2s,transform .2s,box-shadow .2s}
.proc-card:hover{border-color:rgba(139,92,246,.3);transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.proc-num{width:52px;height:52px;border-radius:50%;background:var(--p4);border:2px solid rgba(139,92,246,.18);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.1rem;font-weight:700;color:var(--p);margin:0 auto 18px}
.proc-ico{font-size:1.4rem;margin-bottom:12px;display:block}
.proc-card h4{font-family:var(--sans);font-size:.98rem;color:var(--ink);margin-bottom:8px;line-height:1.2}
.proc-card p{font-size:.78rem;color:var(--ink2);line-height:1.65}

/* ── ABOUT ── */
.about-sec{background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:center}
.about-photo-wrap{position:relative;
    display:flex;
    justify-content:center;position:relative}
.about-photo{aspect-ratio:4/5;border-radius:50px;overflow:hidden;border:2px solid var(--border);box-shadow:var(--shadow-lg);background:var(--ink)}
.about-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}
.about-float{position:absolute;background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:12px 16px;box-shadow:var(--shadow)}
.af1{top:24px;right:-20px}
.af2{bottom:60px;left:-20px}
.afl{font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-bottom:3px}
.afv{font-size:.88rem;font-weight:700;color:var(--ink)}
.about-right p{font-size:.95rem;color:var(--ink2);line-height:1.8;margin-bottom:18px}
.about-right p strong{color:var(--ink);font-weight:700}
.about-tags{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0}
.a-tag{display:flex;align-items:center;gap:8px;background:var(--cream);border:1.5px solid var(--border);border-radius:10px;padding:10px 14px;font-size:.78rem;font-weight:600;color:var(--ink2);transition:border-color .2s,color .2s}
.a-tag:hover{border-color:rgba(139,92,246,.3);color:var(--p)}
.a-tag::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--grad);flex-shrink:0}
.avail{display:inline-flex;align-items:center;gap:9px;background:#f0fdf4;border:1.5px solid #86efac;padding:11px 18px;border-radius:10px;font-size:.75rem;font-weight:700;color:#166534;margin:20px 0}
.avail::before{content:'';width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px rgba(34,197,94,.5);animation:pulse 2s infinite}
.about-btns{display:flex;gap:12px;flex-wrap:wrap}

/* ── CONTACT ── */
.contact-sec{background:var(--ink);padding:clamp(70px,10vw,120px) clamp(20px,5vw,64px)}
.contact-header{text-align:center;margin-bottom:clamp(40px,6vw,64px)}
.contact-header .sec-pill{margin:0 auto 16px}
.contact-header .sec-h{font-size:clamp(2rem,4vw,3rem);margin-bottom:16px}
.contact-header .sec-sub{margin:0 auto;max-width:480px;font-size:1rem;color:rgba(255,255,255,.5)}
.contact-sec .sec-pill{background:rgba(124,58,237,.25);color:var(--p3)}
.contact-sec .sec-h{color:var(--white)}

/* info row — 4 cards across */
.cinfo-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:clamp(28px,4vw,44px)}
.cinfo-card{display:flex;flex-direction:column;align-items:center;gap:10px;padding:24px 16px;background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.1);border-radius:18px;text-decoration:none;color:inherit;transition:background .2s,border-color .2s,transform .2s;text-align:center}
.cinfo-card:hover{background:rgba(124,58,237,.15);border-color:rgba(196,181,253,.4);transform:translateY(-4px)}
.cico{width:44px;height:44px;border-radius:12px;background:rgba(124,58,237,.2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.clbl{font-size:.6rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35)}
.cval{font-size:.875rem;font-weight:600;color:var(--white);line-height:1.3}

/* form — full width centered */
.cform-wrap{max-width:680px;margin:0 auto}
.cform{background:rgba(255,255,255,.05);border:1.5px solid rgba(124,58,237,.2);border-radius:24px;padding:clamp(28px,4vw,48px)}
.cform-title{font-family:var(--serif);font-size:1.5rem;font-weight:700;color:var(--white);margin-bottom:6px;text-align:center}
.cform-note{font-size:.6875rem;color:rgba(255,255,255,.3);margin-bottom:28px;line-height:1.5;font-weight:300;text-align:center}
.cform-note a{color:var(--p3);text-decoration:none}
.fg{margin-bottom:14px}
.fg label{display:block;font-size:.6875rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:8px}
.fg input,.fg textarea{width:100%;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.1);border-radius:10px;padding:13px 16px;font-family:var(--sans);font-size:.95rem;color:var(--white);outline:none;transition:border-color .2s,background .2s;font-weight:300}
.fg input:focus,.fg textarea:focus{border-color:var(--p2);background:rgba(255,255,255,.09)}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(255,255,255,.2)}
.fg textarea{min-height:120px;resize:vertical}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.submit{width:100%;background:var(--p);color:var(--white);border:none;border-radius:100px;padding:15px;font-family:var(--sans);font-size:.9rem;font-weight:700;letter-spacing:.06em;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 8px 28px rgba(124,58,237,.35);margin-top:8px}
.submit:hover{background:var(--p2);transform:translateY(-2px);box-shadow:0 12px 36px rgba(124,58,237,.45)}



/* ── FOOTER ── */
footer{background:#08040f;padding:clamp(24px,4vw,36px) clamp(20px,5vw,64px);border-top:1px solid rgba(124,58,237,.12)}
.footer-inner{max-width:1060px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px}
.f-logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.f-logo-av{width:30px;height:30px;border-radius:50%;overflow:hidden;border:2px solid rgba(196,181,253,.3);flex-shrink:0}
.f-logo-av img{width:100%;height:100%;object-fit:cover;object-position:top}
.f-logo-name{font-family:var(--serif);font-size:1rem;font-weight:700;color:rgba(255,255,255,.4);font-style:italic}
.f-logo-name span{color:var(--p3)}
.f-copy{font-size:.6875rem;color:rgba(255,255,255,.2);font-weight:300}
.f-nav{display:flex;gap:20px}
.f-nav a{font-size:.6875rem;font-weight:700;letter-spacing:.06em;color:rgba(255,255,255,.25);text-decoration:none;transition:color .2s}
.f-nav a:hover{color:var(--p3)}
/* ── REVEAL ── */
.rev{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease}
.rev.on{opacity:1;transform:translateY(0)}




/* ── PAGE WRAPPER ── */
.page{padding-top:66px}

/* ── HERO BANNER ── */
.about-hero{background:var(--ink);padding:clamp(56px,8vw,100px) clamp(20px,5vw,64px);position:relative;overflow:hidden}
.about-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(124,58,237,.3) 0%,transparent 65%);pointer-events:none}
.ah-inner{max-width:1060px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center;position:relative;z-index:1}
.ah-label{font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--p3);margin-bottom:14px}
.ah-title{font-family:var(--serif);font-size:clamp(2.4rem,5vw,4rem);color:var(--white);line-height:1.05;margin-bottom:16px}
.ah-title em{font-style:italic;color:var(--p3)}
.ah-sub{font-size:1rem;color:rgba(255,255,255,.55);line-height:1.7;max-width:440px;font-weight:300}
.ah-photo{width:clamp(180px,20vw,260px);aspect-ratio:4/5;border-radius:32px;overflow:hidden;border:2px solid rgba(196,181,253,.25);box-shadow:0 24px 60px rgba(0,0,0,.35);flex-shrink:0}
.ah-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}

/* ── SECTIONS ── */
.section{padding:clamp(56px,7vw,96px) clamp(20px,5vw,64px)}
.sec-inner{max-width:1060px;margin:0 auto}
.sec-pill{display:inline-flex;align-items:center;gap:6px;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--p);background:var(--p4);padding:5px 14px;border-radius:100px;margin-bottom:14px;border:1px solid rgba(139,92,246,.15)}
.sec-h{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,2.8rem);line-height:1.1;color:var(--ink);margin-bottom:12px}
.sec-h em{font-style:italic;color:var(--p)}
.sec-lead{font-size:1rem;color:var(--ink3);line-height:1.8;max-width:560px;font-weight:300;margin-bottom:40px}

/* ── STORY SECTION ── */
.story-sec{background:var(--white)}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,96px);align-items:start}
.story-text p{font-size:.95rem;color:var(--ink2);line-height:1.85;margin-bottom:18px;font-weight:300}
.story-text p strong{color:var(--ink);font-weight:700}
.story-flag{display:inline-flex;align-items:center;gap:10px;background:var(--cream2);border:1.5px solid var(--border);border-radius:12px;padding:10px 16px;font-size:.82rem;font-weight:700;color:var(--ink2);margin-bottom:28px}
.story-flag span{font-size:1.3rem}
.story-photo{position:relative}
.story-photo-img{width:100%;aspect-ratio:3/4;border-radius:28px;overflow:hidden;border:2px solid var(--border);box-shadow:var(--shadow-lg)}
.story-photo-img img{width:100%;height:100%;object-fit:cover;object-position:top center}
.story-float{position:absolute;background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:12px 16px;box-shadow:var(--shadow)}
.sf1{bottom:28px;left:-24px}
.sf2{top:28px;right:-24px}
.sf-label{font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-bottom:3px}
.sf-val{font-size:.88rem;font-weight:700;color:var(--ink)}

/* ── EDUCATION ── */
.edu-sec{background:var(--cream)}
.edu-grid{display:flex;flex-direction:column;gap:20px;margin-top:8px}
.edu-card{background:var(--white);border:1.5px solid var(--border);border-radius:20px;padding:28px 28px 28px 24px;display:flex;gap:20px;align-items:flex-start;transition:border-color .2s,transform .2s,box-shadow .2s;position:relative;overflow:hidden}
.edu-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--grad);border-radius:3px 0 0 3px}
.edu-card:hover{border-color:rgba(124,58,237,.25);transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.edu-icon{width:52px;height:52px;border-radius:14px;background:var(--p4);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.edu-body{flex:1}
.edu-badge{display:inline-block;font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--p);background:var(--p4);padding:3px 10px;border-radius:100px;margin-bottom:8px}
.edu-degree{font-family:var(--serif);font-size:1.1rem;font-weight:700;color:var(--ink);line-height:1.3;margin-bottom:4px}
.edu-school{font-size:.875rem;font-weight:700;color:var(--ink2);margin-bottom:4px}
.edu-detail{font-size:.8rem;color:var(--ink3);font-weight:300}
.edu-status{display:inline-flex;align-items:center;gap:6px;font-size:.7rem;font-weight:700;color:#166534;background:#f0fdf4;border:1.5px solid #86efac;padding:3px 10px;border-radius:100px;margin-top:8px}
.edu-status::before{content:'';width:6px;height:6px;border-radius:50%;background:#22c55e;flex-shrink:0}
.edu-awards{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}
.edu-grade{font-size:.72rem;font-weight:700;color:var(--p);background:var(--p4);border:1px solid rgba(124,58,237,.2);padding:4px 12px;border-radius:100px}
.edu-award{font-size:.72rem;font-weight:400;color:var(--ink2);background:var(--cream);border:1px solid var(--border);padding:4px 12px;border-radius:100px}
.edu-status::before{content:'';width:6px;height:6px;border-radius:50%;background:#22c55e;flex-shrink:0}

/* ── SKILLS TAGS ── */
.skills-sec{background:var(--white)}
.skills-cats{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:8px}
.sk-group{background:var(--cream);border:1.5px solid var(--border);border-radius:18px;padding:24px}
.sk-group-title{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--p);margin-bottom:14px}
.sk-tags{display:flex;flex-wrap:wrap;gap:8px}
.sk-tag{font-size:.78rem;font-weight:700;padding:6px 13px;border-radius:100px;background:var(--white);color:var(--ink2);border:1.5px solid var(--border);transition:border-color .2s,color .2s}
.sk-tag:hover{border-color:var(--p3);color:var(--p)}

/* ── VALUES / FUN FACTS ── */
.facts-sec{background:var(--cream2)}
.facts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.fact-card{background:var(--white);border:1.5px solid var(--border);border-radius:18px;padding:28px 22px;text-align:center;transition:border-color .2s,transform .2s}
.fact-card:hover{border-color:var(--p3);transform:translateY(-3px)}
.fact-icon{font-size:2rem;margin-bottom:12px;display:block}
.fact-num{font-family:var(--serif);font-size:2rem;font-weight:900;color:var(--p);display:block;line-height:1}
.fact-label{font-size:.78rem;color:var(--ink3);font-weight:300;margin-top:4px;line-height:1.4}

/* ── CTA ── */
.cta-sec{background:var(--ink);padding:clamp(56px,7vw,96px) clamp(20px,5vw,64px);text-align:center;position:relative;overflow:hidden}
.cta-sec::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(124,58,237,.25) 0%,transparent 70%)}
.cta-inner{max-width:600px;margin:0 auto;position:relative;z-index:1}
.cta-sec .sec-h{color:var(--white);margin-bottom:14px}
.cta-sec .sec-h em{color:var(--p3)}
.cta-sub{font-size:.95rem;color:rgba(255,255,255,.5);line-height:1.7;font-weight:300;margin-bottom:32px}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:8px;font-size:.875rem;font-weight:700;color:var(--white);background:var(--p);padding:14px 30px;border-radius:100px;text-decoration:none;transition:background .2s,transform .15s;box-shadow:0 8px 24px rgba(124,58,237,.35)}
.btn-primary:hover{background:var(--p2);transform:translateY(-2px)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;font-size:.875rem;font-weight:700;color:var(--white);background:transparent;padding:14px 30px;border-radius:100px;text-decoration:none;border:1.5px solid rgba(255,255,255,.3);transition:border-color .2s,background .2s,transform .15s}
.btn-outline:hover{border-color:var(--p3);background:rgba(255,255,255,.07);transform:translateY(-2px)}

/* ── FOOTER ── */
footer{background:#08040f;padding:clamp(24px,4vw,36px) clamp(20px,5vw,64px);border-top:1px solid rgba(124,58,237,.12)}
.footer-inner{max-width:1060px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px}
.f-logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.f-logo-av{width:30px;height:30px;border-radius:50%;overflow:hidden;border:2px solid rgba(196,181,253,.3);flex-shrink:0}
.f-logo-av img{width:100%;height:100%;object-fit:cover;object-position:top}
.f-logo-name{font-family:var(--serif);font-size:1rem;font-weight:700;color:rgba(255,255,255,.4);font-style:italic}
.f-logo-name span{color:var(--p3)}
.f-copy{font-size:.6875rem;color:rgba(255,255,255,.2);font-weight:300}
.f-nav{display:flex;gap:20px}
.f-nav a{font-size:.6875rem;font-weight:700;letter-spacing:.06em;color:rgba(255,255,255,.25);text-decoration:none;transition:color .2s}
.f-nav a:hover{color:var(--p3)}

/* ABOUT PAGE CODE BEGINS HERE */
/* ── WORK EXPERIENCE ── */
.work-sec{background:var(--cream2)}
.work-grid{display:flex;flex-direction:column;gap:0;margin-top:8px}
.work-card{display:flex;gap:0;position:relative}
.work-left{display:flex;flex-direction:column;align-items:center;margin-right:24px;flex-shrink:0}
.work-icon{width:48px;height:48px;border-radius:14px;background:var(--p4);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;z-index:1}
.work-line{width:2px;background:var(--border);flex:1;margin-top:8px;min-height:32px}
.work-card:last-child .work-line{display:none}
.work-body{flex:1;background:var(--white);border:1.5px solid var(--border);border-radius:18px;padding:24px;margin-bottom:20px;transition:border-color .2s,box-shadow .2s}
.work-body:hover{border-color:rgba(124,58,237,.2);box-shadow:var(--shadow)}
.work-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px;flex-wrap:wrap}
.work-badge{font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--p);background:var(--p4);padding:3px 10px;border-radius:100px;margin-bottom:6px;display:inline-block}
.work-title{font-family:var(--serif);font-size:1.1rem;font-weight:700;color:var(--ink);line-height:1.3;margin-bottom:3px}
.work-company{font-size:.82rem;color:var(--ink3);font-weight:400}
.work-date{font-size:.75rem;font-weight:700;color:var(--ink3);white-space:nowrap;background:var(--cream);border:1px solid var(--border);padding:4px 12px;border-radius:100px;flex-shrink:0;align-self:flex-start}
.work-list{list-style:none;margin-bottom:14px;display:flex;flex-direction:column;gap:6px}
.work-list li{font-size:.85rem;color:var(--ink2);line-height:1.65;font-weight:300;padding-left:16px;position:relative}
.work-list li::before{content:'→';position:absolute;left:0;color:var(--p);font-size:.75rem;top:2px}
.work-tags{display:flex;flex-wrap:wrap;gap:6px}
.work-tags span{font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:100px;background:var(--p4);color:var(--p);border:1px solid rgba(124,58,237,.15)}
@media(max-width:600px){
  .work-left{display:none}
  .work-body{margin-bottom:14px}
  .work-date{white-space:normal}
}


/* ABOUT PAGE CODE ENDS HERE */

/* PORTFOLIO PAGE CODE BEGINS HERE */
/* ── HERO ── */
.port-hero{background:var(--ink);padding:clamp(64px,10vw,110px) clamp(24px,5vw,64px) clamp(48px,7vw,80px);position:relative;overflow:hidden;margin-top:66px}
.port-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(124,58,237,.35) 0%,transparent 65%);pointer-events:none}
.ph-inner{max-width:1060px;margin:0 auto;position:relative;z-index:1}
.ph-label{font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--p3);margin-bottom:14px}
.ph-title{font-family:var(--serif);font-size:clamp(2.2rem,5vw,3.8rem);color:var(--white);line-height:1.05;margin-bottom:16px}
.ph-title em{font-style:italic;color:var(--p3)}
.ph-sub{font-size:1rem;color:rgba(255,255,255,.5);line-height:1.75;max-width:520px;font-weight:300;margin-bottom:36px}
.ph-stats{display:flex;gap:32px;flex-wrap:wrap}
.ph-stat-num{font-family:var(--serif);font-size:2rem;font-weight:900;color:var(--white);line-height:1}
.ph-stat-label{font-size:.72rem;color:rgba(255,255,255,.4);font-weight:300;margin-top:2px}

/* ── FILTER BAR ── */
.filter-bar{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:66px;z-index:100;padding:0 clamp(24px,5vw,64px)}
.filter-inner{max-width:1060px;margin:0 auto;display:flex;gap:4px;overflow-x:auto;padding:14px 0;scrollbar-width:none}
.filter-inner::-webkit-scrollbar{display:none}
.filter-btn{font-size:.78rem;font-weight:700;padding:7px 16px;border-radius:100px;border:1.5px solid var(--border);background:transparent;color:var(--ink3);cursor:pointer;white-space:nowrap;transition:all .18s;flex-shrink:0}
.filter-btn:hover{border-color:var(--p3);color:var(--p)}
.filter-btn.active{background:var(--p);color:var(--white);border-color:var(--p)}

/* ── SECTION BLOCK ── */
.port-section{padding:clamp(48px,6vw,80px) clamp(24px,5vw,64px)}
.port-section:nth-child(odd){background:var(--cream)}
.port-section:nth-child(even){background:var(--white)}
.ps-inner{max-width:1060px;margin:0 auto}
.ps-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:32px;gap:16px;flex-wrap:wrap}
.ps-left{}
.sec-pill{display:inline-flex;align-items:center;gap:6px;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--p);background:var(--p4);padding:5px 14px;border-radius:100px;margin-bottom:10px;border:1px solid rgba(139,92,246,.15)}
.ps-title{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.2rem);color:var(--ink);line-height:1.1}
.ps-title em{font-style:italic;color:var(--p)}
.ps-count{font-size:.78rem;color:var(--ink3);font-weight:300}

/* ── CARD GRIDS ── */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.grid-masonry{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* ── PROJECT CARD ── */
.pcard{border-radius:18px;overflow:hidden;background:var(--white);border:1.5px solid var(--border);transition:transform .25s,box-shadow .25s,border-color .25s;box-shadow:0 2px 12px rgba(124,58,237,.05);display:flex;flex-direction:column;text-decoration:none;color:inherit}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:rgba(124,58,237,.22)}
.pcard.dark{background:var(--ink2);border-color:rgba(255,255,255,.1)}
.pcard.dark:hover{border-color:rgba(196,181,253,.4)}

/* card thumbnail */
.pthumb{position:relative;overflow:hidden;background:var(--cream2)}
.pthumb img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .4s}
.pcard:hover .pthumb img{transform:scale(1.05)}
.pthumb-16{aspect-ratio:16/9}
.pthumb-sq{aspect-ratio:1/1}
.pthumb-43{aspect-ratio:4/3}
.pthumb-54{aspect-ratio:5/4}
.pthumb-tall{aspect-ratio:3/4}

/* placeholder thumb (when no image) */
.pthumb-ph{width:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:var(--p3)}
.ph-bg1{background:linear-gradient(135deg,#f3e8ff,#e9d5ff)}
.ph-bg2{background:linear-gradient(135deg,#fdf4ff,#f5d0fe)}
.ph-bg3{background:linear-gradient(135deg,#ede9fe,#ddd6fe)}
.ph-bg4{background:linear-gradient(135deg,#f0fdf4,#bbf7d0)}
.ph-bg5{background:linear-gradient(135deg,#fff7ed,#fed7aa)}
.ph-bg6{background:linear-gradient(135deg,#eff6ff,#bfdbfe)}
.ph-bg7{background:linear-gradient(135deg,#fdf2f8,#fbcfe8)}
.ph-bg8{background:linear-gradient(135deg,#f9fafb,#e5e7eb)}

/* hover overlay */
.poverlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(3,7,18,.8) 0%,transparent 50%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:16px}
.poverlay span{font-size:.72rem;font-weight:700;color:white;letter-spacing:.08em;text-transform:uppercase}
.pcard:hover .poverlay{opacity:1}

/* badge on thumb */
.pbadge{position:absolute;top:10px;left:10px;font-size:.625rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--p);background:rgba(255,255,255,.92);padding:4px 10px;border-radius:100px;backdrop-filter:blur(8px)}
.pbadge-dark{color:var(--white);background:rgba(124,58,237,.85)}

/* card body */
.pcbody{padding:18px 20px 20px;flex:1;display:flex;flex-direction:column;gap:6px}
.pcard.dark .pcbody{color:var(--white)}
.pctag{font-size:.625rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--p)}
.pcard.dark .pctag{color:var(--p3)}
.pctitle{font-family:var(--serif);font-size:1.05rem;font-weight:700;color:var(--ink);line-height:1.3}
.pcard.dark .pctitle{color:var(--white)}
.pcdesc{font-size:.845rem;color:var(--ink2);line-height:1.65;font-weight:300;flex:1}
.pcard.dark .pcdesc{color:rgba(255,255,255,.55)}
.pctool-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.pctool{font-size:.65rem;font-weight:700;padding:3px 9px;border-radius:100px;background:var(--p4);color:var(--p);border:1px solid rgba(124,58,237,.15)}
.pcard.dark .pctool{background:rgba(255,255,255,.1);color:var(--p3);border-color:rgba(255,255,255,.15)}
.pclink{display:inline-flex;align-items:center;gap:5px;font-size:.8rem;font-weight:700;color:var(--p);margin-top:10px;transition:gap .2s}
.pcard:hover .pclink{gap:9px}
.pcard.dark .pclink{color:var(--p3)}
.pcsoon{font-size:.8rem;color:var(--ink3);margin-top:10px;font-weight:300}

/* ── WIDE FEATURED CARD ── */
.pcard-wide{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:18px;overflow:hidden;border:1.5px solid var(--border);box-shadow:0 2px 12px rgba(124,58,237,.05);transition:transform .25s,box-shadow .25s;text-decoration:none;color:inherit;background:var(--white)}
.pcard-wide:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.pcard-wide .pthumb{aspect-ratio:unset;min-height:260px}
.pcard-wide .pcbody{padding:32px 28px;justify-content:center}
.pcard-wide .pctitle{font-size:1.25rem}


/* ── CTA STRIP ── */
.cta-strip{background:var(--ink);padding:clamp(48px,6vw,80px) clamp(24px,5vw,64px);text-align:center;position:relative;overflow:hidden}
.cta-strip::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50%,rgba(124,58,237,.25),transparent 70%)}
.cta-inner{max-width:560px;margin:0 auto;position:relative;z-index:1}
.cta-h{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.8rem);color:var(--white);margin-bottom:12px}
.cta-h em{font-style:italic;color:var(--p3)}
.cta-sub{font-size:.95rem;color:rgba(255,255,255,.45);line-height:1.7;font-weight:300;margin-bottom:28px}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-p{display:inline-flex;align-items:center;gap:8px;font-size:.875rem;font-weight:700;color:var(--white);background:var(--p);padding:13px 28px;border-radius:100px;text-decoration:none;transition:background .2s,transform .15s;box-shadow:0 8px 24px rgba(124,58,237,.35)}
.btn-p:hover{background:var(--p2);transform:translateY(-2px)}
.btn-o{display:inline-flex;align-items:center;gap:8px;font-size:.875rem;font-weight:700;color:var(--white);background:transparent;padding:13px 28px;border-radius:100px;text-decoration:none;border:1.5px solid rgba(255,255,255,.3);transition:all .2s}
.btn-o:hover{border-color:var(--p3);background:rgba(255,255,255,.07);transform:translateY(-2px)}


/* PORTFOLIO PAGE CODE ENDS HERE */

/* Contact Page code begins here */
/* ── HERO ── */
.contact-hero{background:var(--ink);margin-top:66px;padding:clamp(64px,9vw,110px) clamp(24px,5vw,64px);position:relative;overflow:hidden;text-align:center}
.contact-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 60%,rgba(124,58,237,.45) 0%,transparent 65%);pointer-events:none}
.contact-hero::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:48px 48px;pointer-events:none}
.ch-inner{max-width:700px;margin:0 auto;position:relative;z-index:1}
.ch-pill{display:inline-flex;align-items:center;gap:7px;background:rgba(196,181,253,.15);border:1px solid rgba(196,181,253,.25);border-radius:100px;padding:7px 16px;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--p3);margin-bottom:20px}
.ch-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px rgba(34,197,94,.6);animation:pulse 2s ease infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.6)}}
.ch-title{font-family:var(--serif);font-size:clamp(2.2rem,5vw,3.8rem);color:var(--white);line-height:1.05;margin-bottom:18px}
.ch-title em{font-style:italic;color:var(--p3)}
.ch-sub{font-size:1rem;color:rgba(255,255,255,.5);line-height:1.8;font-weight:300;max-width:480px;margin:0 auto}

/* ── MAIN CONTENT ── */
.contact-body{max-width:1060px;margin:0 auto;padding:clamp(56px,7vw,96px) clamp(24px,5vw,64px)}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(40px,6vw,80px);align-items:start}

/* ── LEFT: INFO ── */
.contact-info{}
.ci-title{font-family:var(--serif);font-size:1.5rem;font-weight:700;color:var(--ink);margin-bottom:8px}
.ci-sub{font-size:.925rem;color:var(--ink3);line-height:1.75;font-weight:300;margin-bottom:32px}

/* info cards */
.ci-cards{display:flex;flex-direction:column;gap:12px;margin-bottom:36px}
.ci-card{display:flex;align-items:center;gap:16px;background:var(--white);border:1.5px solid var(--border);border-radius:16px;padding:16px 18px;text-decoration:none;color:inherit;transition:border-color .2s,transform .2s,box-shadow .2s;position:relative;overflow:hidden}
.ci-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--grad);transform:scaleY(0);transition:transform .22s;transform-origin:bottom}
.ci-card:hover{border-color:rgba(124,58,237,.25);transform:translateY(-2px);box-shadow:var(--shadow)}
.ci-card:hover::before{transform:scaleY(1)}
.ci-icon{width:44px;height:44px;border-radius:12px;background:var(--p4);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.ci-label{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-bottom:3px}
.ci-val{font-size:.9rem;font-weight:700;color:var(--ink)}
.ci-arrow{margin-left:auto;color:var(--p3);font-size:.9rem;opacity:0;transition:opacity .2s,transform .2s}
.ci-card:hover .ci-arrow{opacity:1;transform:translateX(4px)}

/* availability badge */
.ci-avail{display:inline-flex;align-items:center;gap:9px;background:#f0fdf4;border:1.5px solid #86efac;padding:12px 18px;border-radius:12px;font-size:.8rem;font-weight:700;color:#166534;margin-bottom:28px}
.ci-avail::before{content:'';width:8px;height:8px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px rgba(34,197,94,.5);animation:pulse 2s infinite;flex-shrink:0}

/* social links */
.ci-social-title{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3);margin-bottom:12px}
.ci-socials{display:flex;gap:10px;flex-wrap:wrap}
.ci-social{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:100px;border:1.5px solid var(--border);background:var(--white);font-size:.78rem;font-weight:700;color:var(--ink2);text-decoration:none;transition:all .2s}
.ci-social:hover{border-color:var(--p);color:var(--p);background:var(--p4)}

/* what i can help with */
.ci-help{background:var(--cream2);border-radius:18px;padding:24px;margin-top:32px}
.ci-help-title{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--p);margin-bottom:14px}
.ci-help-list{display:flex;flex-direction:column;gap:8px}
.ci-help-item{display:flex;align-items:center;gap:10px;font-size:.875rem;color:var(--ink2);font-weight:300}
.ci-help-item::before{content:'✦';color:var(--p);font-size:.7rem;flex-shrink:0}

/* ── RIGHT: FORM ── */
.contact-form-wrap{}
.cf-card{background:var(--white);border:1.5px solid var(--border);border-radius:24px;padding:clamp(28px,4vw,44px);box-shadow:var(--shadow)}
.cf-title{font-family:var(--serif);font-size:1.4rem;font-weight:700;color:var(--ink);margin-bottom:6px}
.cf-sub{font-size:.875rem;color:var(--ink3);font-weight:300;margin-bottom:28px;line-height:1.6}
.cf-sub a{color:var(--p);text-decoration:none}

/* form fields */
.fg{margin-bottom:16px}
.fg label{display:block;font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-bottom:8px}
.fg input,.fg textarea,.fg select{width:100%;background:var(--cream);border:1.5px solid var(--border);border-radius:10px;padding:13px 16px;font-family:var(--sans);font-size:.95rem;color:var(--ink);outline:none;transition:border-color .2s,background .2s;font-weight:300;appearance:none}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--p2);background:var(--white)}
.fg input::placeholder,.fg textarea::placeholder{color:var(--ink3)}
.fg textarea{min-height:130px;resize:vertical}
.fg select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237a6a9a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.submit{width:100%;background:var(--p);color:var(--white);border:none;border-radius:100px;padding:15px;font-family:var(--sans);font-size:.9rem;font-weight:700;letter-spacing:.06em;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 8px 28px rgba(124,58,237,.3);margin-top:8px;display:flex;align-items:center;justify-content:center;gap:8px}
.submit:hover{background:var(--p2);transform:translateY(-2px);box-shadow:0 12px 36px rgba(124,58,237,.4)}
.submit:active{transform:translateY(0)}

/* success message */
.cf-success{display:none;text-align:center;padding:32px 20px}
.cf-success-icon{font-size:3rem;margin-bottom:12px;display:block}
.cf-success-title{font-family:var(--serif);font-size:1.4rem;color:var(--ink);margin-bottom:8px}
.cf-success-text{font-size:.9rem;color:var(--ink3);font-weight:300;line-height:1.7}

/* ── FAQ STRIP ── */
.faq-strip{background:var(--white);border-top:1px solid var(--border);padding:clamp(48px,6vw,80px) clamp(24px,5vw,64px)}
.faq-inner{max-width:1060px;margin:0 auto}
.faq-header{text-align:center;margin-bottom:40px}
.faq-pill{display:inline-flex;align-items:center;gap:6px;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--p);background:var(--p4);padding:5px 14px;border-radius:100px;margin-bottom:12px;border:1px solid rgba(139,92,246,.15)}
.faq-title{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.2rem);color:var(--ink)}
.faq-title em{font-style:italic;color:var(--p)}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.faq-item{background:var(--cream);border:1.5px solid var(--border);border-radius:16px;padding:22px 20px;cursor:pointer;transition:border-color .2s}
.faq-item:hover{border-color:var(--p3)}
.faq-q{font-size:.9rem;font-weight:700;color:var(--ink);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.faq-q::after{content:'＋';color:var(--p);font-size:1.1rem;flex-shrink:0;transition:transform .2s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{font-size:.85rem;color:var(--ink2);line-height:1.7;font-weight:300;display:none}
.faq-item.open .faq-a{display:block}

/* ── CTA BOTTOM ── */
.cta-bottom{background:var(--ink2);padding:clamp(56px,7vw,96px) clamp(24px,5vw,64px);text-align:center;position:relative;overflow:hidden}
.cta-bottom::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50%,rgba(124,58,237,.25),transparent 70%)}
.ctb-inner{max-width:560px;margin:0 auto;position:relative;z-index:1}
.ctb-title{font-family:var(--serif);font-size:clamp(1.6rem,3.5vw,2.4rem);color:var(--white);margin-bottom:12px}
.ctb-title em{font-style:italic;color:var(--p3)}
.ctb-sub{font-size:.95rem;color:rgba(255,255,255,.45);line-height:1.75;font-weight:300;margin-bottom:28px}
.ctb-links{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-p{display:inline-flex;align-items:center;gap:8px;font-size:.875rem;font-weight:700;color:var(--white);background:var(--p);padding:13px 28px;border-radius:100px;text-decoration:none;transition:background .2s,transform .15s}
.btn-p:hover{background:var(--p2);transform:translateY(-2px)}
.btn-o{display:inline-flex;align-items:center;gap:8px;font-size:.875rem;font-weight:700;color:var(--white);background:transparent;padding:13px 28px;border-radius:100px;text-decoration:none;border:1.5px solid rgba(255,255,255,.3);transition:all .2s}
.btn-o:hover{border-color:var(--p3);background:rgba(255,255,255,.07);transform:translateY(-2px)}

/* Contact Page code ends here */


/* Case Study Code Begins Here */



/* ══════════════════════════════
   PROGRESS BAR
══════════════════════════════ */
.progress-bar{position:fixed;top:66px;left:0;height:3px;background:var(--grad);z-index:9998;transition:width .1s linear;width:0%}

/* ══════════════════════════════
   HERO — SPLIT LAYOUT
══════════════════════════════ */
.cs-hero{
  background:var(--ink);
  margin-top:66px;
  min-height:88vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  position:relative;
  overflow:hidden;
  padding:0 clamp(24px,5vw,64px);
}
.cs-hero-inner{
  max-width:1060px;
  margin:0 auto;
  width:100%;
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:88vh;
  position:relative;
  z-index:1;
}
/* radial glow */
.cs-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 60%,rgba(124,58,237,.5) 0%,transparent 55%);pointer-events:none;z-index:0}
/* subtle grid pattern */
.cs-hero::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:48px 48px;pointer-events:none;z-index:0}

/* LEFT text panel */
.cs-hero-left{
  padding:clamp(56px,8vw,96px) 40px clamp(56px,8vw,96px) 0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  position:relative;
  z-index:1;
}
.cs-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:24px;font-size:.75rem;font-weight:700;color:rgba(255,255,255,.35)}
.cs-breadcrumb a{color:rgba(255,255,255,.35);text-decoration:none;transition:color .2s}
.cs-breadcrumb a:hover{color:var(--p3)}
.cs-breadcrumb span{color:rgba(255,255,255,.15)}
.cs-hero-tags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:24px}
.cs-tag{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--p3);background:rgba(196,181,253,.12);padding:5px 12px;border-radius:100px;border:1px solid rgba(196,181,253,.2)}
.cs-hero-title{font-family:var(--serif);font-size:clamp(2rem,4vw,3.4rem);color:var(--white);line-height:1.05;margin-bottom:18px;letter-spacing:-.01em}
.cs-hero-title em{font-style:italic;color:var(--p3)}
.cs-hero-sub{font-size:.975rem;color:rgba(255,255,255,.5);line-height:1.8;font-weight:300;margin-bottom:36px;max-width:420px}

/* meta pills row */
.cs-meta-row{display:flex;flex-wrap:wrap;gap:10px}
.cs-meta-item{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 16px;min-width:0}
.cs-meta-label{font-size:.58rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:4px}
.cs-meta-val{font-size:.82rem;font-weight:700;color:var(--white);white-space:nowrap}
.cs-meta-val.pill{display:inline-flex;align-items:center;gap:5px;color:var(--p3)}

/* RIGHT image panel */
.cs-hero-right{
  position:relative;
  overflow:hidden;
}
.cs-hero-right::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to right, var(--accent-dark) 0%, transparent 30%);
  z-index:2;
  pointer-events:none;
}
.cs-hero-img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
  opacity:.7;
  display:block;
}
.cs-hero-img-ph{
  width:100%;
  height:100%;
  min-height:500px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:12px;
  background:linear-gradient(135deg,rgba(124,58,237,.2),rgba(61,47,90,.8));
  color:rgba(255,255,255,.3);
  font-size:.82rem;
  font-weight:300;
}
.cs-hero-img-ph span:first-child{font-size:3rem;opacity:.4}

/* floating mockup card inside right panel */
.cs-hero-mockup{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:3;
  padding:clamp(20px,4vw,48px);
}
.cs-hero-mockup img{
  width:100%;
  max-width:520px;
  border-radius:12px;
  box-shadow:0 40px 80px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.08);
  display:block;
}
.cs-hero-mockup-ph{
  width:100%;
  max-width:480px;
  aspect-ratio:16/10;
  border-radius:12px;
  background:rgba(255,255,255,.05);
  border:1.5px dashed rgba(196,181,253,.2);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:8px;
  color:rgba(255,255,255,.3);
  font-size:.78rem;
  font-weight:300;
  box-shadow:0 40px 80px rgba(0,0,0,.3);
}
.cs-hero-mockup-ph span:first-child{font-size:2.5rem;opacity:.4}

/* scroll hint */
.cs-scroll-hint{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.1em;
  color:rgba(255,255,255,.2);
  text-transform:uppercase;
  margin-top:auto;
  padding-bottom:28px;
}
.cs-scroll-line{width:32px;height:1px;background:rgba(255,255,255,.2)}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .cs-hero{padding:0 clamp(20px,4vw,32px)}
  .cs-hero-inner{grid-template-columns:1fr;min-height:auto}
  .cs-hero-right{min-height:260px;order:-1}
  .cs-hero-left{padding:28px 0 40px}
  .cs-hero-img{max-height:260px;object-position:center 20%}
  .cs-scroll-hint{display:none}
}

/* ══════════════════════════════
   CONTENT WRAPPER
══════════════════════════════ */
.cs-content{max-width:1060px;margin:0 auto;padding:0 clamp(24px,5vw,64px)}

/* ══════════════════════════════
   SECTION SPACING
══════════════════════════════ */
.cs-section{padding:clamp(56px,7vw,96px) 0;border-bottom:1px solid var(--border)}
.cs-section:last-of-type{border-bottom:none}
.cs-section-label{font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--p);margin-bottom:10px}
.cs-section-title{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.4rem);color:var(--ink);line-height:1.1;margin-bottom:20px}
.cs-section-title em{font-style:italic;color:var(--p)}
.cs-body{font-size:.975rem;color:var(--ink2);line-height:1.85;font-weight:300}
.cs-body p{margin-bottom:16px}
.cs-body p:last-child{margin-bottom:0}
.cs-body strong{color:var(--ink);font-weight:700}

/* ── OVERVIEW GRID ── */
.cs-overview-grid{display:grid;grid-template-columns:2fr 1fr;gap:clamp(32px,5vw,64px);align-items:start;padding-top:48px}

/* ── PROBLEM / SOLUTION 2-col ── */
.cs-two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px}
.cs-box{background:var(--white);border:1.5px solid var(--border);border-radius:18px;padding:28px 24px;position:relative;overflow:hidden}
.cs-box::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad)}
.cs-box.problem::before{background:linear-gradient(90deg,#ef4444,#f97316)}
.cs-box.solution::before{background:var(--grad)}
.cs-box-icon{font-size:1.6rem;margin-bottom:12px;display:block}
.cs-box-title{font-family:var(--serif);font-size:1.1rem;font-weight:700;color:var(--ink);margin-bottom:10px}
.cs-box-text{font-size:.9rem;color:var(--ink2);line-height:1.75;font-weight:300}

/* ── RESEARCH ── */
.cs-research-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.cs-research-card{background:var(--white);border:1.5px solid var(--border);border-radius:16px;padding:24px 20px;text-align:center;transition:border-color .2s,transform .2s}
.cs-research-card:hover{border-color:var(--p3);transform:translateY(-3px)}
.cs-research-icon{font-size:2rem;display:block;margin-bottom:10px}
.cs-research-num{font-family:var(--serif);font-size:2rem;font-weight:900;color:var(--p);display:block;line-height:1}
.cs-research-label{font-size:.8rem;color:var(--ink3);font-weight:300;margin-top:4px;line-height:1.4}
.cs-research-note{font-size:.78rem;color:var(--ink2);margin-top:8px;line-height:1.5;font-weight:300}

/* ── PERSONA CARD ── */
.cs-persona-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:32px}
.cs-persona{background:var(--white);border:1.5px solid var(--border);border-radius:18px;padding:24px;display:flex;gap:16px;transition:border-color .2s}
.cs-persona:hover{border-color:var(--p3)}
.cs-persona-avatar{width:56px;height:56px;border-radius:50%;background:var(--p4);display:flex;align-items:center;justify-content:center;font-size:1.6rem;flex-shrink:0}
.cs-persona-name{font-family:var(--serif);font-size:1rem;font-weight:700;color:var(--ink);margin-bottom:2px}
.cs-persona-role{font-size:.75rem;color:var(--ink3);margin-bottom:8px;font-weight:300}
.cs-persona-quote{font-size:.82rem;color:var(--ink2);line-height:1.6;font-style:italic;border-left:2px solid var(--p3);padding-left:10px;font-weight:300}
.cs-persona-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
.cs-persona-tag{font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:100px;background:var(--p4);color:var(--p)}

/* ── PROCESS STEPS ── */
.cs-process{display:flex;flex-direction:column;gap:0;margin-top:32px;position:relative}
.cs-process::before{content:'';position:absolute;left:23px;top:0;bottom:0;width:2px;background:var(--border);z-index:0}
.cs-process-step{display:flex;gap:20px;position:relative;z-index:1;padding-bottom:32px}
.cs-process-step:last-child{padding-bottom:0}
.cs-step-num{width:48px;height:48px;border-radius:50%;background:var(--p4);border:2px solid var(--p3);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1rem;font-weight:900;color:var(--p);flex-shrink:0}
.cs-step-body{flex:1;padding-top:10px}
.cs-step-title{font-family:var(--serif);font-size:1.05rem;font-weight:700;color:var(--ink);margin-bottom:6px}
.cs-step-text{font-size:.9rem;color:var(--ink2);line-height:1.75;font-weight:300}

/* ── IMAGE FULL WIDTH ── */
.cs-img-full{width:100%;border-radius:14px;border:1px solid var(--border);display:block;margin-top:32px;box-shadow:var(--shadow)}
.cs-img-caption{font-size:.75rem;color:var(--ink3);text-align:center;margin-top:10px;font-weight:300;font-style:italic}

/* ── IMAGE 2-UP ── */
.cs-img-2up{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px}
.cs-img-2up img{width:100%;border-radius:14px;border:1px solid var(--border);box-shadow:var(--shadow)}

/* ── IMAGE 3-UP ── */
.cs-img-3up{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:32px}
.cs-img-3up img{width:100%;border-radius:12px;border:1px solid var(--border)}

/* ── PLACEHOLDER IMAGE ── */
.cs-img-ph{width:100%;border-radius:14px;background:var(--cream2);border:1.5px dashed var(--border);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:var(--ink3);font-size:.8rem;font-weight:300;padding:40px}
.cs-img-ph span{font-size:2rem}

/* ── WIREFRAMES / SCREENS SCROLL ── */
.cs-screens{display:flex;gap:16px;overflow-x:auto;padding-bottom:12px;margin-top:32px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.cs-screen{flex-shrink:0;width:220px;border-radius:16px;overflow:hidden;border:1.5px solid var(--border);box-shadow:0 4px 20px rgba(0,0,0,.12);
  background:var(--cream2);}
.cs-screen img{width:100%;display:block; border-radius:16px;}
/* placeholder when no image yet */
.cs-screen-ph{
  width:180px;
  aspect-ratio:9/19.5;   /* tall phone ratio */
  border-radius:16px;
  background:var(--cream2);
  border:1.5px dashed var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:6px;
  color:var(--ink3);
  font-size:.72rem;
  flex-shrink:0;
  text-align:center;
  padding:12px;
}
.cs-screen-ph span:first-child{font-size:1.8rem}


/* Wireframe grid */
.cs-wire-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-top:28px;
}
.cs-wire-grid img{
  width:100%;
  border-radius:10px;
  border:1px solid var(--border);
}
.cs-wire-grid-ph{
  aspect-ratio:9/16;
  border-radius:10px;
  background:var(--cream2);
  border:1.5px dashed var(--border);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:5px;
  color:var(--ink3);font-size:.65rem;text-align:center;padding:8px;
}
.cs-wire-grid-ph span:first-child{font-size:1.4rem}


/* HiFi mockup 4-col grid */
.cs-hifi-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-top:28px;
}
.cs-hifi-grid img{
  width:100%;
  border-radius:12px;
  border:1px solid var(--border);
  box-shadow:0 4px 16px rgba(0,0,0,.1);
}
.cs-hifi-grid-ph{
  aspect-ratio:9/19.5;
  border-radius:12px;
  background:var(--cream2);
  border:1.5px dashed var(--border);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:5px;
  color:var(--ink3);font-size:.65rem;text-align:center;padding:8px;
}
.cs-hifi-grid-ph span:first-child{font-size:1.4rem}

/* Figma embed */
.cs-figma-embed{
  width:100%;
  aspect-ratio:16/9;
  border:1.5px solid var(--border);
  border-radius:14px;
  margin-top:28px;
  overflow:hidden;
}
.cs-figma-embed iframe{width:100%;height:100%;border:none}
/* colour tags for design system section */
.cs-color-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.cs-chip{display:flex;align-items:center;gap:8px;background:var(--white);border:1.5px solid var(--border);border-radius:10px;padding:8px 12px;font-size:.8rem;font-weight:600}
.cs-chip-swatch{width:24px;height:24px;border-radius:6px;flex-shrink:0}


@media(max-width:768px){
  .cs-wire-grid,.cs-hifi-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .cs-wire-grid{grid-template-columns:repeat(2,1fr)}
  .cs-hifi-grid{grid-template-columns:repeat(2,1fr)}
}

/* wireframe full-width image */
.cs-wireframe-img{
  width:100%;
  border-radius:14px;
  border:1px solid var(--border);
  display:block;
  margin-top:32px;
  box-shadow:0 4px 24px rgba(124,58,237,.08);
}
/* placeholder for wireframe */
.cs-wireframe-ph{
  width:100%;
  aspect-ratio:16/7;
  border-radius:14px;
  background:var(--cream2);
  border:1.5px dashed var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:8px;
  color:var(--ink3);
  font-size:.8rem;
  margin-top:32px;
  text-align:center;
  padding:32px;
}
.cs-wireframe-ph span:first-child{font-size:2rem}

/* detail 2-up images */
.cs-img-2up{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px}
.cs-img-2up img{width:100%;border-radius:14px;border:1px solid var(--border)}
.cs-img-2up-ph{
  aspect-ratio:4/3;
  border-radius:14px;
  background:var(--cream2);
  border:1.5px dashed var(--border);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:6px;
  color:var(--ink3);font-size:.75rem;text-align:center;padding:16px;
}
.cs-img-2up-ph span:first-child{font-size:1.8rem}
.cs-img-caption{font-size:.75rem;color:var(--ink3);text-align:center;margin-top:10px;font-weight:300;font-style:italic}

/* final hero mockup image */
.cs-final-img{
  width:100%;
  border-radius:14px;
  border:1px solid var(--border);
  display:block;
  margin-top:32px;
  box-shadow:0 8px 32px rgba(124,58,237,.12);
}
.cs-final-ph{
  width:100%;
  aspect-ratio:16/8;
  border-radius:14px;
  background:var(--cream2);
  border:1.5px dashed var(--border);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:8px;
  color:var(--ink3);font-size:.8rem;
  margin-top:32px;text-align:center;padding:32px;
}
.cs-final-ph span:first-child{font-size:2rem}

/* image note helper */
.img-note{
  background:#fff8ed;
  border:1.5px solid #fcd34d;
  border-radius:10px;
  padding:10px 14px;
  font-size:.75rem;
  color:#92400e;
  margin-top:10px;
  line-height:1.5;
}

/* Full-width design system images */
.cs-ds-img{
  width:100%;
  border-radius:14px;
  border:1px solid var(--border);
  display:block;
  margin-top:28px;
  box-shadow:0 4px 24px rgba(22,163,74,.08);
}
.cs-ds-ph{
  width:100%;
  aspect-ratio:16/6;
  border-radius:14px;
  background:var(--cream2);
  border:1.5px dashed var(--border);
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:8px;
  color:var(--ink3);font-size:.8rem;
  margin-top:28px;text-align:center;padding:32px;
}
.cs-ds-ph span:first-child{font-size:2rem}


@media(max-width:600px){
  .cs-img-2up{grid-template-columns:1fr}
}
/* ── KEY FEATURES ── */
.cs-features{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:32px}
.cs-feature{background:var(--white);border:1.5px solid var(--border);border-radius:16px;padding:22px 20px;display:flex;gap:14px;align-items:flex-start;transition:border-color .2s,transform .2s}
.cs-feature:hover{border-color:var(--p3);transform:translateY(-2px)}
.cs-feature-icon{width:44px;height:44px;border-radius:12px;background:var(--p4);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.cs-feature-title{font-weight:700;color:var(--ink);font-size:.9rem;margin-bottom:4px}
.cs-feature-text{font-size:.82rem;color:var(--ink2);line-height:1.6;font-weight:300}

/* ── TECH STACK ── */
.cs-tech-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.cs-tech{display:flex;align-items:center;gap:8px;background:var(--white);border:1.5px solid var(--border);border-radius:12px;padding:10px 16px;transition:border-color .2s}
.cs-tech:hover{border-color:var(--p3)}
.cs-tech-icon{width:32px;height:32px;object-fit:contain}
.cs-tech-name{font-size:.82rem;font-weight:700;color:var(--ink2)}

/* ── CHALLENGES ── */
.cs-challenge-list{display:flex;flex-direction:column;gap:14px;margin-top:24px}
.cs-challenge{background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:20px;display:grid;grid-template-columns:1fr 1fr;gap:20px}
.cs-challenge-label{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}
.cs-challenge-label.prob{color:#dc2626}
.cs-challenge-label.sol{color:#16a34a}
.cs-challenge-text{font-size:.875rem;color:var(--ink2);line-height:1.65;font-weight:300}

/* ── OUTCOMES / RESULTS ── */
.cs-outcomes{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:32px}
.cs-outcome{background:var(--ink2);border-radius:18px;padding:28px 20px;text-align:center;border:1.5px solid rgba(196,181,253,.15)}
.cs-outcome-num{font-family:var(--serif);font-size:2.2rem;font-weight:900;color:var(--white);display:block;line-height:1;margin-bottom:4px}
.cs-outcome-label{font-size:.78rem;color:rgba(255,255,255,.5);font-weight:300;line-height:1.4}
.cs-outcome-note{font-size:.72rem;color:var(--p3);margin-top:6px;display:block}

/* ── LEARNINGS ── */
.cs-learnings{display:flex;flex-direction:column;gap:12px;margin-top:24px}
.cs-learning{display:flex;gap:14px;align-items:flex-start;background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:18px}
.cs-learning-num{width:32px;height:32px;border-radius:50%;background:var(--p4);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:var(--p);flex-shrink:0}
.cs-learning-text{font-size:.9rem;color:var(--ink2);line-height:1.7;font-weight:300}
.cs-learning-text strong{color:var(--ink);font-weight:700}

/* ── NEXT PROJECT NAV ── */
.cs-next{background:var(--ink);padding:clamp(48px,6vw,80px) clamp(24px,5vw,64px);position:relative;overflow:hidden}
.cs-next::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50%,rgba(124,58,237,.2),transparent 70%)}
.cs-next-inner{max-width:1060px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:32px;position:relative;z-index:1;flex-wrap:wrap}
.cs-next-label{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:8px}
.cs-next-title{font-family:var(--serif);font-size:clamp(1.4rem,3vw,2rem);color:var(--white)}
.cs-next-link{display:inline-flex;align-items:center;gap:10px;font-size:.875rem;font-weight:700;color:var(--white);background:var(--p);padding:13px 24px;border-radius:100px;text-decoration:none;transition:background .2s,transform .15s;white-space:nowrap}
.cs-next-link:hover{background:var(--p2);transform:translateY(-2px)}

/* ── BACK TO PORTFOLIO ── */
.cs-back-bar{background:var(--white);border-top:1px solid var(--border);padding:20px clamp(24px,5vw,64px)}
.cs-back-inner{max-width:1060px;margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.cs-back-link{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;font-weight:700;color:var(--ink3);text-decoration:none;transition:color .2s}
.cs-back-link:hover{color:var(--p)}
.cs-share{display:flex;align-items:center;gap:10px;font-size:.78rem;color:var(--ink3);font-weight:300}
.cs-share a{width:32px;height:32px;border-radius:50%;background:var(--p4);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;text-decoration:none;font-size:.75rem;font-weight:700;color:var(--p);transition:background .18s}
.cs-share a:hover{background:var(--p);color:var(--white)}





/* Case Study Code Ends Here */




/* ── RESPONSIVE ── */
@media(max-width:1100px){.avc1,.avc2{display:none}}
@media(max-width:960px){
  .nav-inner{padding:0 16px}
  .nav-links{display:none}.hbg{display:flex}
  .hero-inner{text-align:center}
  .btn-dark,.btn-line{width:100%;justify-content:center}
  .hero-pill{justify-content:center}
  .hero-btns{justify-content:center}
  .hero-desc,.hero-desc2{max-width:100%;margin-left:auto;margin-right:auto}
  .hero-inner{grid-template-columns:1fr;max-width:600px}
  .hero-right{display:none}
  /* show avatar circle on mobile inside hero */
  .hero-mob-av{display:flex;justify-content:center;margin-bottom:28px}
  .hero-mob-av .avatar-circle{width:200px;height:200px;border-radius:50%;overflow:hidden;border:3px solid var(--p3);box-shadow:0 0 40px rgba(124,58,237,.35)}
  .hero-mob-av .avatar-circle img{width:100%;height:100%;object-fit:cover;object-position:top center;transform:scale(1.2)}
  .skills-top{grid-template-columns:1fr;gap:20px}
  .about-grid{grid-template-columns:1fr;max-width:520px;margin:0 auto}
  .af1,.af2{display:none}
  .cinfo-row{grid-template-columns:1fr 1fr}
  .frow{grid-template-columns:1fr}
  .proc-row{grid-template-columns:1fr 1fr;gap:14px}
  .proc-row::before{display:none}
  

  /* about page */
   .ah-inner{grid-template-columns:1fr}
  .ah-photo{display:none}
  .story-grid{grid-template-columns:1fr}
  .sf1,.sf2{display:none}
  .skills-cats{grid-template-columns:1fr}
  .facts-grid{grid-template-columns:1fr 1fr}

  /* Portfolio Page */
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .pcard-wide{grid-template-columns:1fr}
  .pcard-wide .pthumb{min-height:220px}

  /* Contact Page */
  .contact-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr}


  /* Case Study Page */
  .cs-overview-grid{grid-template-columns:1fr}
  .cs-two-col{grid-template-columns:1fr}
  .cs-research-grid{grid-template-columns:repeat(2,1fr)}
  .cs-persona-grid{grid-template-columns:1fr}
  .cs-img-2up{grid-template-columns:1fr}
  .cs-img-3up{grid-template-columns:repeat(2,1fr)}
  .cs-features{grid-template-columns:1fr}
  .cs-challenge{grid-template-columns:1fr}
  .cs-outcomes{grid-template-columns:repeat(2,1fr)}


}
@media(max-width:680px){
  .port-top .sec-h{margin-bottom:16px}
  .skills-grid{grid-template-columns:1fr}
  .port-grid{grid-template-columns:1fr}
  .left-col,.right-col{gap:12px}
  .proc-row{grid-template-columns:1fr}
  .hero-btns{flex-direction:column;align-items:flex-start}
  .btn-primary,.btn-outline{width:100%;justify-content:center}
  .about-btns{flex-direction:column}
  .frow{grid-template-columns:1fr}
  .f-nav{display:none}
  .tech-grid{grid-template-columns:repeat(3,1fr)}
  .hero-btns{flex-direction:column;align-items:flex-start}
  /* About Page */
  .facts-grid{grid-template-columns:1fr}
  .edu-card{flex-direction:column;gap:14px}
  .edu-icon{width:44px;height:44px}
  .cta-btns{flex-direction:column;align-items:center}
  .f-nav{display:none}
}

@media(max-width:480px){
  .section{padding-left:22px;padding-right:22px}.tech-grid{grid-template-columns:repeat(3,1fr);gap:10px}}


/* ── MOBILE CONTENT BREATHING ROOM ── */
@media(max-width:520px){
  .sec-inner{padding-left:4px;padding-right:4px}
  .work-body{padding:20px 18px}
  .edu-card{padding:20px 18px 20px 18px}
  .pcard-body{padding:14px 16px}
  .cform{padding:24px 18px}
  .sk-group{padding:18px}
  .fact-card{padding:22px 16px}
  .proc-card{padding:22px 16px}
  .story-text p{font-size:.9rem}
  .work-list li{font-size:.82rem}
  .edu-detail{font-size:.78rem}
}

/* Portfolio page */
@media(max-width:600px){
  .grid-3,.grid-2,.grid-4,.grid-masonry{grid-template-columns:1fr}
  .ph-stats{gap:20px}
  .ps-header{flex-direction:column;align-items:flex-start}
  .f-nav{display:none}
  .cta-btns{flex-direction:column;align-items:center}
  .frow{grid-template-columns:1fr}
  .ctb-links{flex-direction:column;align-items:center}
  .f-nav{display:none}
  .ci-socials{gap:8px}


  /* Case Study Page */

  .cs-meta-row{flex-direction:column;gap:0}
  .cs-meta-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.08);padding:14px 0}
  .cs-research-grid{grid-template-columns:1fr}
  .cs-img-3up{grid-template-columns:1fr}
  .cs-outcomes{grid-template-columns:1fr}
  .cs-next-inner{flex-direction:column;align-items:flex-start}
  .cs-process::before{display:none}
  .f-nav{display:none}
}

/* ── RESPONSIVE TYPE ── */
@media(max-width:768px){
  body{font-size:15px}
  .pcdesc{font-size:.875rem}
  .pctitle{font-size:1rem}
  .pctag,.pbadge,.pctool,.sec-pill{font-size:.68rem}
  /* contact page */
  .ci-val,.ci-help-item,.cf-sub{font-size:.9rem}
  .faq-a{font-size:.875rem}


  /* Case Study Page */
  .cs-body{font-size:.925rem}
  .cs-step-text,.cs-feature-text,.cs-challenge-text,.cs-learning-text,.cs-box-text,.cs-persona-quote{font-size:.9rem}
  .cs-section-title{font-size:clamp(1.4rem,4vw,2rem)}
}