/* ================================================
   MT PORTFOLIO — style.css  v2.0
   Clash Display + Plus Jakarta Sans
   Dark editorial · Green accent · Profile photo
   ================================================ */

/* ── Variables ──────────────────────────────── */
:root {
  --bg:           #0f1720;
  --bg-alt:       #16212c;
  --card:         #1b2835;
  --card-h:       #223242;
  --border:       rgba(148,163,184,0.18);
  --border-h:     rgba(45,212,191,0.34);
  --accent:       #2dd4bf;
  --accent2:      #14b8a6;
  --accent-glow:  rgba(45,212,191,0.12);
  --accent-glow2: rgba(45,212,191,0.22);
  --text:         #dbe4ec;
  --text-muted:   #9aaabd;
  --white:        #f8fafc;
  --font-display: 'Poppins', sans-serif;
  --font-body:    'Roboto', sans-serif;
  --r:            14px;
  --r-lg:         22px;
  --ease:         cubic-bezier(0.4,0,0.2,1);
  --t:            0.32s;
  --nav-bg:       rgba(15,23,32,0.82);
  --nav-bg-solid: rgba(15,23,32,0.96);
  --brand-grad:   linear-gradient(135deg, #0f766e 0%, #0d9488 55%, #14b8a6 100%);
  --shadow-soft:  0 16px 40px rgba(0,0,0,0.22);
  --input-bg:     rgba(255,255,255,0.03);
  --toggle-track: rgba(255,255,255,0.06);
  --toggle-thumb: rgba(255,255,255,0.08);
}

body.light-mode {
  --bg:           #f5f7fa;
  --bg-alt:       #eaf0f5;
  --card:         #ffffff;
  --card-h:       #ffffff;
  --border:       rgba(100,116,139,0.16);
  --border-h:     rgba(13,148,136,0.24);
  --accent:       #0f766e;
  --accent2:      #14b8a6;
  --accent-glow:  rgba(13,148,136,0.10);
  --accent-glow2: rgba(20,184,166,0.16);
  --text:         #1e293b;
  --text-muted:   #64748b;
  --white:        #0f172a;
  --nav-bg:       rgba(245,247,250,0.88);
  --nav-bg-solid: rgba(245,247,250,0.97);
  --shadow-soft:  0 16px 40px rgba(15, 23, 42, 0.08);
  --input-bg:     rgba(148, 163, 184, 0.08);
  --toggle-track: rgba(148, 163, 184, 0.14);
  --toggle-thumb: rgba(13, 148, 136, 0.10);
}

/* ── Reset ──────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  font-size:16px;
  line-height:1.7;
  overflow-x:hidden;
  transition:background var(--t) var(--ease), color var(--t) var(--ease);
}
a{text-decoration:none;color:inherit}
ul{list-style:none;padding:0}

/* ── Grain Overlay ──────────────────────────── */
.grain-overlay{
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:200px 200px;
  pointer-events:none;z-index:9999;opacity:0.6;
}

/* ── Shared Typography ──────────────────────── */
.eyebrow{
  font-family:var(--font-body);
  font-size:0.72rem;font-weight:600;
  letter-spacing:0.14em;text-transform:uppercase;
  color:var(--accent);margin-bottom:0.85rem;
}

.s-heading{
  font-family:var(--font-display);
  font-size:clamp(2.2rem,4.5vw,3.4rem);
  font-weight:700;line-height:1.08;
  color:var(--white);letter-spacing:-0.02em;
  margin-bottom:1.25rem;
}
.s-heading em{
  font-style:italic;
  font-family:'Playfair Display','Georgia',serif;
  color:var(--accent);font-weight:700;
}

.s-line{
  width:52px;height:3px;
  background:linear-gradient(90deg,var(--accent),transparent);
  border-radius:99px;margin-bottom:2.5rem;
}

.body-p{
  font-size:1rem;color:var(--text);
  line-height:1.85;margin-bottom:1.25rem;
}
.body-p strong{color:var(--white)}

mark.hl{
  background:var(--accent-glow);
  color:var(--accent);
  border-radius:4px;padding:1px 5px;
}

/* ── Layout ─────────────────────────────────── */
.section-pad{padding:110px 0}
.section-alt{background:var(--bg-alt)}

/* ── Reveal Animation ───────────────────────── */
.reveal{
  opacity:0;
  transform:translateY(40px);
  transition:opacity 0.75s var(--ease),transform 0.75s var(--ease);
}
.reveal.visible{opacity:1;transform:none}

/* ── NAVBAR ─────────────────────────────────── */
#mainNav{
  background:var(--nav-bg);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
  padding:16px 0;
  transition:padding var(--t) var(--ease),background var(--t) var(--ease);
  z-index:1000;
}
#mainNav.scrolled{
  padding:11px 0;
  background:var(--nav-bg-solid);
}

.navbar-brand{
  display:flex;
  align-items:center;
  gap:12px;
}
.brand-mark{
  width:48px;
  height:48px;
  border-radius:14px;
  display:grid;
  place-items:center;
  font-family:var(--font-display);
  font-size:1.65rem;
  font-weight:700;
  color:#f8fafc;
  background:var(--brand-grad);
  box-shadow:0 14px 28px rgba(13, 148, 136, 0.26);
}
.brand-text{
  font-family:var(--font-display);
  font-size:clamp(1rem, 2vw, 1.35rem);
  font-weight:700;
  color:var(--white);
  letter-spacing:0.1em;
}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:0.3}}

.nav-link{
  font-family:var(--font-body);font-size:0.83rem;
  font-weight:500;color:var(--text-muted) !important;
  padding:6px 11px !important;
  transition:color var(--t) var(--ease);
  position:relative;
}
.nav-link::after{
  content:'';position:absolute;
  bottom:0;left:50%;
  width:0;height:1.5px;
  background:var(--accent);
  transform:translateX(-50%);
  transition:width var(--t) var(--ease);
}
.nav-link:hover,.nav-link.active{color:var(--white) !important}
.nav-link:hover::after,.nav-link.active::after{width:60%}

.nav-cta-btn{
  display:inline-flex;align-items:center;
  background:var(--accent);color:#06201d !important;
  font-family:var(--font-display);font-size:0.83rem;font-weight:600;
  padding:9px 22px;border-radius:99px;
  transition:all var(--t) var(--ease);
  box-shadow:0 0 16px var(--accent-glow);
}
.nav-cta-btn:hover{
  background:var(--accent2);
  box-shadow:0 6px 24px rgba(45,212,191,0.28);
  transform:translateY(-1px);
}

body.light-mode .nav-cta-btn{
  color:#f8fafc !important;
}

.theme-toggle-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:46px;
  height:46px;
  padding:0;
  border-radius:50%;
  border:1px solid var(--border);
  background:var(--toggle-track);
  color:var(--white);
  font-family:var(--font-display);
  font-size:0.82rem;
  font-weight:600;
  cursor:pointer;
  transition:all var(--t) var(--ease);
}
.theme-toggle-btn:hover{
  transform:translateY(-1px);
  border-color:var(--border-h);
  background:var(--toggle-thumb);
  box-shadow:var(--shadow-soft);
}
.toggle-icon{
  position:absolute;
  width:18px;
  text-align:center;
  transition:opacity var(--t) var(--ease), transform var(--t) var(--ease), color var(--t) var(--ease);
}
.toggle-sun{
  opacity:0;
  transform:scale(0.8);
  color:#f59e0b;
}
.toggle-moon{
  opacity:1;
  transform:scale(1);
  color:#93c5fd;
}
body.light-mode .toggle-sun{
  opacity:1;
  transform:scale(1);
}
body.light-mode .toggle-moon{
  opacity:0;
  transform:scale(0.8);
}

/* Custom toggler */
.navbar-toggler{border:none;background:none;padding:6px}
.navbar-toggler:focus{box-shadow:none}
.toggler-icon{display:flex;flex-direction:column;gap:5px}
.toggler-icon span{
  display:block;width:22px;height:2px;
  background:var(--text);border-radius:2px;
  transition:var(--t);
}

/* ── HERO ────────────────────────────────────── */
.hero-section{
  min-height:100vh;
  position:relative;
  overflow:hidden;
  display:flex;align-items:center;
  padding:120px 0 90px;
}

.hero-layout{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:nowrap;
  gap:60px;
  position:relative;z-index:2;
}

.hero-text-side{
  flex:1 1 56%;
  max-width:640px;
}

/* Hero Text */
.hero-avail{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(34,197,94,0.08);border:1px solid rgba(34,197,94,0.2);
  padding:6px 14px;border-radius:99px;
  font-size:0.78rem;font-weight:500;color:var(--accent);
  margin-bottom:1.75rem;letter-spacing:0.02em;
}
.avail-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--accent);
  animation:pulse-dot 2s ease-in-out infinite;
}

.hero-name{
  font-family:var(--font-display);
  font-size:clamp(3.5rem,7vw,6.5rem);
  font-weight:700;line-height:0.95;
  color:var(--white);letter-spacing:-0.035em;
  margin-bottom:1.5rem;
}
.name-italic{
  font-style:italic;
  font-family:'Playfair Display','Georgia',serif;
  color:var(--accent);
}

.hero-typed{
  font-family:var(--font-body);
  font-size:clamp(1rem,2vw,1.25rem);
  color:var(--text-muted);
  min-height:2rem;margin-bottom:1.5rem;
}
.cursor{
  color:var(--accent);
  animation:blink 0.85s step-end infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

.hero-quote{
  display:flex;align-items:flex-start;gap:14px;
  font-family:var(--font-body);
  font-size:0.97rem;font-style:italic;font-weight:300;
  color:var(--text-muted);margin-bottom:2.5rem;line-height:1.7;
}
.quote-bar{
  display:block;flex-shrink:0;
  width:3px;height:40px;
  background:var(--accent);border-radius:99px;
  margin-top:2px;
}

.hero-btns{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:3rem}

.hero-stats{
  display:flex;align-items:center;gap:24px;
  padding-top:2rem;border-top:1px solid var(--border);
}
.hst{display:flex;flex-direction:column;gap:1px}
.hst strong{
  font-family:var(--font-display);
  font-size:1.4rem;font-weight:700;color:var(--white);
}
.hst span{font-size:0.75rem;color:var(--text-muted);letter-spacing:0.04em}
.hst-sep{width:1px;height:36px;background:var(--border)}

/* Hero Photo */
.hero-photo-side{
  position:relative;
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
  flex:1 1 44%;
  min-width:0;
  padding-top:18px;
}

.photo-container{
  position:relative;
  width:min(100%, 360px);
  aspect-ratio:1 / 1;
  display:flex;
  align-items:center;
  justify-content:center;
  margin-left:auto;
  margin-top:-22px;
}

.profile-img{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  border-radius:50%;
  position:relative;z-index:2;
  border:4px solid rgba(34,197,94,0.16);
  box-shadow:0 30px 80px rgba(0,0,0,0.6);
  transition:transform var(--t) var(--ease);
}
.profile-img:hover{transform:scale(1.02)}

/* Hero scroll cue */
.hero-scroll-indicator{
  position:absolute;bottom:36px;left:50%;
  transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--text-muted);
}
.scroll-mouse{
  width:22px;height:34px;
  border:1.5px solid rgba(255,255,255,0.15);
  border-radius:99px;
  display:flex;justify-content:center;padding-top:5px;
}
.scroll-ball{
  width:4px;height:8px;background:var(--accent);
  border-radius:99px;
  animation:scroll-ball 2s ease-in-out infinite;
}
@keyframes scroll-ball{
  0%,100%{transform:translateY(0);opacity:1}
  80%{transform:translateY(12px);opacity:0}
}

/* ── Buttons ─────────────────────────────────── */
.btn-primary-mt{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent);color:#000;
  font-family:var(--font-display);font-size:0.9rem;font-weight:600;
  padding:13px 28px;border-radius:99px;
  border:none;cursor:pointer;
  transition:all var(--t) var(--ease);
  box-shadow:0 0 20px var(--accent-glow);
}
.btn-primary-mt:hover{
  background:#16a34a;
  transform:translateY(-2px);
  box-shadow:0 10px 32px rgba(34,197,94,0.4);
  color:#000;
}

.btn-outline-mt{
  display:inline-flex;align-items:center;gap:8px;
  background:transparent;color:var(--white);
  font-family:var(--font-display);font-size:0.9rem;font-weight:600;
  padding:13px 28px;border-radius:99px;
  border:1.5px solid var(--border);
  cursor:pointer;
  transition:all var(--t) var(--ease);
}
.btn-outline-mt:hover{
  border-color:var(--accent);color:var(--accent);
  transform:translateY(-2px);
}

/* ── Tag Pills ──────────────────────────────── */
.tag-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:1.5rem}
.tag-pills span{
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  border-radius:99px;
  padding:5px 14px;font-size:0.8rem;color:var(--text);
  display:flex;align-items:center;gap:6px;
  transition:all var(--t) var(--ease);
}
.tag-pills span:hover{
  border-color:var(--accent);color:var(--accent);
  background:var(--accent-glow);
}
.tag-pills span i{color:var(--accent);font-size:0.75rem}

#about .about-hidden-meta{
  display:none;
}

/* ── Info Cards (Background) ────────────────── */
.info-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:2rem;height:100%;
  transition:all var(--t) var(--ease);
}
.info-card:hover{
  border-color:var(--border-h);
  background:var(--card-h);
  transform:translateY(-4px);
  box-shadow:var(--shadow-soft);
}
.ic-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:1rem}
.ic-icon{
  width:46px;height:46px;border-radius:12px;
  background:var(--accent-glow);
  display:grid;place-items:center;
  font-size:1.2rem;color:var(--accent);flex-shrink:0;
}
.ic-icon.cert{background:rgba(96,165,250,0.1);color:#60a5fa}
.ic-header h4{
  font-family:var(--font-display);font-weight:600;
  font-size:1rem;color:var(--white);margin-bottom:4px;
}
.ic-badge{
  display:inline-block;font-size:0.72rem;font-weight:500;
  color:var(--accent);background:var(--accent-glow);
  border:1px solid rgba(34,197,94,0.2);
  border-radius:99px;padding:2px 10px;
}
.info-card p{font-size:0.875rem;color:var(--text);margin:0}

.cert-list{margin-top:0.5rem}
.cert-list li{
  display:flex;align-items:center;gap:9px;
  font-size:0.875rem;color:var(--text);
  padding:5px 0;border-bottom:1px solid var(--border);
}
.cert-list li:last-child{border:none}
.cert-list .fa-circle-check{color:var(--accent);font-size:0.8rem}
.cert-list .fa-spinner{color:#60a5fa;font-size:0.8rem}

.cert-doc-card{
  display:flex;
  align-items:center;
  gap:14px;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  border-radius:16px;
  padding:1rem 1.1rem;
  color:var(--text);
  transition:all var(--t) var(--ease);
}

.cert-doc-card:hover{
  border-color:rgba(96,165,250,0.35);
  background:rgba(96,165,250,0.08);
  transform:translateY(-2px);
}

.cert-doc-icon{
  width:50px;
  height:50px;
  border-radius:14px;
  background:rgba(239,68,68,0.12);
  color:#f87171;
  display:grid;
  place-items:center;
  font-size:1.15rem;
  flex-shrink:0;
}

.cert-doc-meta{
  display:flex;
  flex-direction:column;
  gap:2px;
}

.cert-doc-meta strong{
  color:var(--white);
  font-family:var(--font-display);
  font-size:0.95rem;
}

.cert-doc-meta span{
  font-size:0.82rem;
  color:var(--text);
}

.cert-doc-meta small{
  font-size:0.76rem;
  color:var(--text-muted);
}

.cert-doc-arrow{
  margin-left:auto;
  color:var(--text-muted);
  transition:transform var(--t) var(--ease), color var(--t) var(--ease);
}

.cert-doc-card:hover .cert-doc-arrow{
  color:#93c5fd;
  transform:translate(2px,-2px);
}

.certificates-copy{
  max-width:720px;
  font-size:1rem;
  color:var(--text-muted);
  margin:0 0 1rem;
}

.certificate-card{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:1rem;
  min-height:220px;
  padding:2rem;
  border-radius:28px;
  border:1px solid var(--border);
  background:linear-gradient(180deg, var(--card-h), var(--card));
  color:var(--text);
  transition:transform var(--t) var(--ease), box-shadow var(--t) var(--ease), border-color var(--t) var(--ease);
}

.certificate-card:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 40px rgba(0,0,0,0.18);
  border-color:var(--border-h);
}

.certificate-card h3{
  font-family:var(--font-display);
  font-size:1.25rem;
  line-height:1.35;
  font-weight:700;
  margin:0;
  color:var(--white);
}

.certificate-logo{
  width:72px;
  height:72px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-display);
  font-size:1.1rem;
  font-weight:700;
}

.smit-logo{
  background:var(--accent-glow);
  color:var(--accent);
}

.placeholder-logo{
  background:var(--accent-glow);
  color:var(--accent);
  font-size:1rem;
}

.certificate-meta{
  margin-top:auto;
  display:inline-flex;
  align-self:flex-start;
  padding:0.72rem 1.15rem;
  border-radius:999px;
  background:var(--accent);
  color:#06201d;
  font-size:0.88rem;
  font-weight:700;
  letter-spacing:0.02em;
  text-decoration:none;
}

.certificate-card-placeholder{
  cursor:default;
}

/* ── Project Cards ───────────────────────────── */
.proj-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;height:100%;
  transition:all var(--t) var(--ease);
}
.proj-card:hover{
  border-color:var(--border-h);
  transform:translateY(-6px);
  box-shadow:0 24px 64px rgba(0,0,0,0.18),0 0 0 1px var(--accent-glow2);
}

.projects-stack{
  display:flex;
  flex-direction:column;
  gap:28px;
}

.proj-split{
  display:grid;
  grid-template-columns:minmax(320px, 1.15fr) minmax(280px, 0.85fr);
  align-items:center;
  padding:20px;
  gap:26px;
}

.proj-media{
  min-width:0;
}

.proj-content{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  min-width:0;
  padding-right:6px;
}

.proj-category{
  display:inline-flex;
  align-items:center;
  padding:0.42rem 0.85rem;
  border-radius:999px;
  border:1px solid rgba(34,197,94,0.18);
  background:rgba(34,197,94,0.08);
  color:var(--accent);
  font-size:0.74rem;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:1rem;
}

.proj-banner{
  height:160px;
  display:flex;align-items:center;justify-content:center;
  gap:12px;position:relative;overflow:hidden;
  border-bottom:1px solid var(--border);
}

.proj-image-wrap{
  position:relative;
  border-radius:20px;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
  box-shadow:0 22px 44px rgba(0,0,0,0.22);
}

.proj-shot{
  display:block;
  width:100%;
  height:320px;
  object-fit:cover;
  border-radius:20px;
  border:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
  transition:transform 0.6s var(--ease);
}

.proj-shot-clear{
  object-fit:contain;
  padding:14px;
  background:#f8fafc;
}

.proj-card:hover .proj-shot,
.proj-card:hover .proj-preview{
  transform:scale(1.04);
}
.proj-banner.agro{
  background:linear-gradient(135deg,#071a10 0%,#0b2318 50%,#071a10 100%);
}
.proj-banner.ecom{
  background:linear-gradient(135deg,#071020 0%,#0b1a35 50%,#071020 100%);
}
.proj-banner.portfolio{
  background:linear-gradient(135deg,#1a0d08 0%,#2a120b 50%,#160c08 100%);
}
.proj-banner-icon{
  font-size:1.8rem;
  color:var(--accent);
}
.proj-banner.ecom .proj-banner-icon{color:#60a5fa}
.proj-banner.portfolio .proj-banner-icon{color:#fb923c}
.proj-banner span{
  font-family:var(--font-display);
  font-size:1.15rem;font-weight:600;
  color:var(--white);
}
.proj-banner.ecom span{color:#93c5fd}
.proj-banner.portfolio span{color:#fdba74}
.proj-num{
  position:absolute;right:16px;bottom:4px;
  font-family:var(--font-display);
  font-size:4.5rem;font-weight:700;
  color:rgba(255,255,255,0.04);line-height:1;
  pointer-events:none;
}

.proj-preview{
  position:relative;
  height:320px;
  border-radius:20px;
  border:1px solid var(--border);
  overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.05);
  transition:transform 0.6s var(--ease);
}

.proj-preview-ecom{
  background:
    radial-gradient(circle at top right, rgba(239,68,68,0.2), transparent 36%),
    linear-gradient(180deg, #2a1312 0%, #170b0b 100%);
  padding:16px;
}

.proj-preview-quran{
  background:
    radial-gradient(circle at top left, rgba(34,197,94,0.18), transparent 36%),
    linear-gradient(180deg, #15603b 0%, #0f3d29 100%);
  padding:16px;
}

.proj-preview-agro{
  background:
    radial-gradient(circle at top right, rgba(45,212,191,0.24), transparent 34%),
    radial-gradient(circle at bottom left, rgba(34,197,94,0.18), transparent 36%),
    linear-gradient(180deg, #0b1f1c 0%, #071412 100%);
  padding:18px;
}

.mock-dashboard{
  height:100%;
  display:flex;
  flex-direction:column;
  gap:16px;
}

.mock-dashboard-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}

.mock-pill,
.mock-status{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0.45rem 0.85rem;
  border-radius:999px;
  font-size:0.74rem;
  font-weight:700;
  letter-spacing:0.04em;
}

.mock-pill{
  background:rgba(34,197,94,0.16);
  color:#dcfce7;
  border:1px solid rgba(34,197,94,0.24);
}

.mock-status{
  background:rgba(255,255,255,0.08);
  color:#99f6e4;
  border:1px solid rgba(255,255,255,0.08);
}

.mock-dashboard-grid{
  display:grid;
  grid-template-columns:1.2fr 0.8fr;
  gap:14px;
  flex:1;
}

.mock-chart-card,
.mock-score-card{
  border-radius:18px;
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.06);
}

.mock-chart-card{
  display:flex;
  align-items:flex-end;
  gap:12px;
  padding:18px;
}

.mock-chart-line{
  flex:1;
  border-radius:999px 999px 12px 12px;
  background:linear-gradient(180deg, rgba(45,212,191,0.95), rgba(34,197,94,0.25));
}

.mock-chart-line.one{height:54%}
.mock-chart-line.two{height:82%}
.mock-chart-line.three{height:68%}

.mock-score-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:#ecfeff;
}

.mock-score-card strong{
  font-family:var(--font-display);
  font-size:2.4rem;
  line-height:1;
}

.mock-score-card small{
  margin-top:8px;
  font-size:0.78rem;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#99f6e4;
}

.mock-tags-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.mock-tags-row span{
  display:inline-flex;
  align-items:center;
  padding:0.45rem 0.8rem;
  border-radius:999px;
  font-size:0.72rem;
  font-weight:700;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.08);
  color:#d1fae5;
}

.mock-browser-dots{
  display:flex;
  gap:8px;
  margin-bottom:14px;
}

.mock-browser-dots span{
  width:10px;
  height:10px;
  border-radius:50%;
  background:rgba(255,255,255,0.3);
}

.mock-ecom-layout{
  display:grid;
  grid-template-columns:1fr 128px;
  align-items:center;
  gap:14px;
  height:calc(100% - 24px);
}

.mock-ecom-copy h4{
  margin:0 0 14px;
  font-family:var(--font-display);
  font-size:2rem;
  line-height:0.95;
  color:#fff7ed;
}

.mock-ecom-lines{
  display:grid;
  gap:12px;
  margin-bottom:54px;
}

.mock-ecom-lines span{
  height:18px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(255,255,255,0.14), rgba(251,146,60,0.26));
  display:block;
}

.mock-ecom-lines span:nth-child(1){
  width:92%;
}

.mock-ecom-lines span:nth-child(2){
  width:72%;
}

.mock-ecom-lines span:nth-child(3){
  width:48%;
}

.mock-ecom-copy p{
  margin:0;
  font-size:0.82rem;
  font-weight:700;
  color:#fdba74;
}

.mock-burger-art{
  position:relative;
  width:128px;
  height:150px;
}

.mock-burger-art span{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  border-radius:999px;
}

.mock-burger-art .bun-top{
  top:12px;
  width:84px;
  height:48px;
  background:#f6ad55;
}

.mock-burger-art .patty{
  top:50px;
  width:100px;
  height:44px;
  background:#7c2d12;
}

.mock-burger-art .tomato{
  top:88px;
  width:108px;
  height:18px;
  background:#f43f5e;
}

.mock-burger-art .lettuce{
  top:102px;
  width:118px;
  height:16px;
  background:#22c55e;
}

.mock-burger-art .bun-bottom{
  top:114px;
  width:114px;
  height:34px;
  background:#fb923c;
}

.mock-burger-art .shadow{
  bottom:2px;
  width:98px;
  height:16px;
  background:rgba(0,0,0,0.32);
}

.mock-quran-title{
  font-family:var(--font-display);
  font-size:1.15rem;
  font-weight:700;
  color:#f0fdf4;
  margin-bottom:12px;
}

.mock-verse-card{
  min-height:104px;
  border-radius:16px;
  padding:18px;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.08);
  margin-bottom:14px;
}

.mock-verse-card span{
  display:block;
  margin-bottom:10px;
  font-size:0.75rem;
  font-weight:700;
  letter-spacing:0.05em;
  color:#fde68a;
}

.mock-verse-card p{
  margin:0;
  font-size:0.95rem;
  line-height:1.45;
  color:#f8fafc;
}

.mock-progress-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
}

.mock-progress-item{
  height:96px;
  border-radius:16px;
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.08);
  position:relative;
}

.mock-progress-item::before{
  content:'';
  position:absolute;
  top:20px;
  left:50%;
  transform:translateX(-50%);
  width:46px;
  height:46px;
  border-radius:50%;
  border:6px solid rgba(255,255,255,0.72);
  border-right-color:transparent;
}

.mock-progress-item::after{
  content:'';
  position:absolute;
  left:50%;
  bottom:16px;
  transform:translateX(-50%);
  width:40px;
  height:8px;
  border-radius:999px;
  background:rgba(255,255,255,0.4);
}

.mock-progress-item.green{background:linear-gradient(180deg, rgba(255,255,255,0.14), rgba(34,197,94,0.12))}
.mock-progress-item.gold{background:linear-gradient(180deg, rgba(255,255,255,0.14), rgba(245,158,11,0.12))}
.mock-progress-item.blue{background:linear-gradient(180deg, rgba(255,255,255,0.14), rgba(99,102,241,0.12))}

.mock-quran-footer{
  margin-top:10px;
  font-size:0.76rem;
  font-weight:700;
  color:#dcfce7;
  text-align:center;
}

.proj-body{padding:0}
.proj-role{
  font-size:0.75rem;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--accent);margin-bottom:0.5rem;
  display:flex;align-items:center;gap:7px;
}
.proj-body h3{
  font-family:var(--font-display);
  font-size:clamp(1.55rem, 2vw, 2rem);font-weight:700;
  color:var(--white);margin-bottom:0.9rem;
}
.proj-intro{
  font-size:1rem;
  color:var(--text);
  line-height:1.85;
  margin-bottom:1.2rem;
}
.ps-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1rem;margin-bottom:1rem;
}
.ps-tag{
  display:inline-block;font-size:0.68rem;font-weight:600;
  text-transform:uppercase;letter-spacing:0.1em;
  border-radius:4px;padding:2px 8px;margin-bottom:5px;
}
.ps-tag.problem{background:rgba(239,68,68,0.1);color:#f87171;border:1px solid rgba(239,68,68,0.2)}
.ps-tag.solution{background:var(--accent-glow);color:var(--accent);border:1px solid rgba(34,197,94,0.2)}
.ps-grid p{font-size:0.85rem;color:var(--text);margin:0;line-height:1.5}

.proj-outcome{
  font-size:0.85rem;color:var(--text);
  display:flex;align-items:center;gap:8px;
  margin-bottom:1rem;
}
.proj-outcome .fa-circle-check{color:var(--accent)}

.tech-tags{display:flex;flex-wrap:wrap;gap:7px}
.tech-tags span{
  background:rgba(34,197,94,0.06);
  color:var(--accent);
  border:1px solid rgba(34,197,94,0.18);
  border-radius:6px;padding:3px 11px;
  font-size:0.73rem;font-weight:600;
  letter-spacing:0.03em;
}

.proj-btn{
  margin-top:1.35rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:150px;
  padding:0.9rem 1.35rem;
  border-radius:999px;
  border:1px solid rgba(34,197,94,0.28);
  background:linear-gradient(135deg, rgba(34,197,94,0.18), rgba(34,197,94,0.08));
  color:var(--white);
  font-family:var(--font-display);
  font-size:0.92rem;
  font-weight:600;
  transition:transform var(--t) var(--ease), border-color var(--t) var(--ease), background var(--t) var(--ease), box-shadow var(--t) var(--ease);
}

.proj-btn:hover{
  transform:translateY(-2px);
  border-color:rgba(34,197,94,0.48);
  background:linear-gradient(135deg, rgba(34,197,94,0.3), rgba(34,197,94,0.12));
  box-shadow:0 16px 30px rgba(34,197,94,0.15);
  color:var(--white);
}

/* ── Skill Categories ────────────────────────── */
.skills-grid{
  justify-content:flex-start;
}

.skill-tile{
  min-height:220px;
  background:linear-gradient(180deg, rgba(12,12,14,0.96), rgba(15,15,18,0.96));
  border:1px solid rgba(255,255,255,0.09);
  border-radius:24px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:1.4rem;
  text-align:center;
  transition:transform var(--t) var(--ease), border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);
}

.skill-tile:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 44px rgba(0,0,0,0.2);
}

.skill-tile h5{
  margin:0;
  font-family:var(--font-display);
  font-size:1rem;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#a7a7b1;
}

.skill-tile-icon{
  font-size:4rem;
  line-height:1;
}

.skill-tile.html5 .skill-tile-icon{color:#f16529}
.skill-tile.css3 .skill-tile-icon{color:#2965f1}
.skill-tile.javascript .skill-tile-icon{color:#f7df1e}
.skill-tile.react .skill-tile-icon{color:#61dafb}
.skill-tile.python .skill-tile-icon{color:#ffd43b}
.skill-tile.flutter .skill-tile-icon{color:#46d1fd}
.skill-tile.mysql .skill-tile-icon{color:#4f8cc9}
.skill-tile.figma .skill-tile-icon{color:#f24e1e}
.skill-tile.sqat .skill-tile-icon{color:#ef4444}

.skill-tile.html5:hover{border-color:rgba(241,101,41,0.65)}
.skill-tile.css3:hover{border-color:rgba(41,101,241,0.65)}
.skill-tile.javascript:hover{border-color:rgba(247,223,30,0.65)}
.skill-tile.react:hover{border-color:rgba(97,218,251,0.65)}
.skill-tile.python:hover{border-color:rgba(255,212,59,0.65)}
.skill-tile.flutter:hover{border-color:rgba(70,209,253,0.65)}
.skill-tile.mysql:hover{border-color:rgba(79,140,201,0.65)}
.skill-tile.figma:hover{border-color:rgba(242,78,30,0.65)}
.skill-tile.sqat:hover{border-color:rgba(239,68,68,0.65)}

.skill-cat{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:1.75rem;
  height:100%;transition:all var(--t) var(--ease);
}
.skill-cat:hover{
  border-color:var(--border-h);
  transform:translateY(-4px);
}
.sc-icon{
  width:44px;height:44px;border-radius:11px;
  display:grid;place-items:center;font-size:1.1rem;
  margin-bottom:1rem;
}
.frontend-c{background:rgba(34,197,94,0.1);color:var(--accent)}
.backend-c{background:rgba(251,191,36,0.1);color:#fbbf24}
.concept-c{background:rgba(167,139,250,0.1);color:#a78bfa}
.tools-c{background:rgba(96,165,250,0.1);color:#60a5fa}

.skill-cat h5{
  font-family:var(--font-display);font-weight:700;
  color:var(--white);margin-bottom:0.85rem;
}
.skill-cat ul li{
  font-size:0.875rem;color:var(--text);
  padding:5px 0;border-bottom:1px solid var(--border);
}
.skill-cat ul li:last-child{border:none}

/* Skill Bars */
.bars{display:flex;flex-direction:column;gap:1.4rem}
.bar-item{}
.bar-head{
  display:flex;justify-content:space-between;
  margin-bottom:7px;font-size:0.875rem;color:var(--text);
}
.bar-track{
  height:5px;background:rgba(255,255,255,0.05);
  border-radius:99px;overflow:hidden;
}
.bar-fill{
  height:100%;width:0;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  border-radius:99px;
  transition:width 1.3s cubic-bezier(0.4,0,0.2,1);
}

/* ── Timeline ────────────────────────────────── */
.timeline{display:flex;flex-direction:column;gap:0}

.tl-item{
  display:grid;
  grid-template-columns:140px 28px 1fr;
  gap:0 20px;
  position:relative;
}
.tl-item:not(:last-child) .tl-track::after{
  content:'';
  position:absolute;
  top:20px;left:50%;
  transform:translateX(-50%);
  width:1px;
  height:calc(100% + 0px);
  background:linear-gradient(to bottom,var(--accent),rgba(34,197,94,0.1));
}

.tl-date-col{
  text-align:right;padding-top:14px;
}
.tl-date-col span{
  font-size:0.75rem;font-weight:600;
  text-transform:uppercase;letter-spacing:0.1em;
  color:var(--accent);
}

.tl-track{
  display:flex;justify-content:center;
  position:relative;
}
.tl-dot{
  width:14px;height:14px;
  border-radius:50%;
  background:var(--accent);
  border:3px solid var(--bg);
  box-shadow:0 0 0 3px rgba(34,197,94,0.25);
  margin-top:14px;flex-shrink:0;
  position:relative;z-index:1;
}

.tl-card-col{padding-bottom:3rem}

.tl-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:1.4rem;
  transition:all var(--t) var(--ease);
}
.tl-card:hover{
  border-color:var(--border-h);
  background:var(--card-h);
}
.tl-card h4{
  font-family:var(--font-display);font-weight:600;
  font-size:0.97rem;color:var(--white);margin-bottom:0.5rem;
}
.tl-card p{font-size:0.86rem;color:var(--text);margin:0}

/* ── Testimonials ────────────────────────────── */
.testi-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:2rem;height:100%;
  transition:all var(--t) var(--ease);
}
.testi-card:hover{
  border-color:var(--border-h);transform:translateY(-4px);
}
.testi-stars{color:#f59e0b;font-size:0.8rem;display:flex;gap:3px;margin-bottom:1rem}
.testi-card p{
  font-size:0.92rem;font-style:italic;font-weight:300;
  color:var(--text);line-height:1.85;margin-bottom:1.5rem;
}
.testi-author{display:flex;align-items:center;gap:12px}
.t-avatar{
  width:42px;height:42px;border-radius:50%;
  background:var(--accent-glow);
  border:1.5px solid rgba(34,197,94,0.3);
  display:grid;place-items:center;
  font-family:var(--font-display);font-size:0.75rem;font-weight:700;
  color:var(--accent);flex-shrink:0;
}
.testi-author strong{display:block;font-size:0.88rem;color:var(--white)}
.testi-author span{font-size:0.78rem;color:var(--text-muted)}

/* ── Blog ────────────────────────────────────── */
.blog-card{
  display:block;
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:2rem;height:100%;
  color:var(--text);
  transition:all var(--t) var(--ease);
}
.blog-card:hover{
  border-color:var(--border-h);
  transform:translateY(-4px);
  box-shadow:var(--shadow-soft);
}
.blog-cat{
  font-size:0.72rem;text-transform:uppercase;
  letter-spacing:0.1em;color:var(--accent);
  margin-bottom:0.75rem;font-weight:600;
}
.blog-card h4{
  font-family:var(--font-display);font-size:1.05rem;font-weight:600;
  color:var(--white);margin-bottom:0.75rem;line-height:1.4;
}
.blog-card p{font-size:0.875rem;color:var(--text-muted);margin-bottom:1.25rem}
.blog-foot{
  display:flex;justify-content:space-between;align-items:center;
  font-size:0.8rem;
}
.blog-foot span:first-child{color:var(--text-muted)}
.read-more{
  color:var(--accent);font-weight:600;
  display:flex;align-items:center;gap:6px;
  transition:gap var(--t) var(--ease);
}
.blog-card:hover .read-more{gap:10px}

/* ── Achievements ────────────────────────────── */
.ach-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:2rem;
  text-align:center;height:100%;
  transition:all var(--t) var(--ease);
  position:relative;overflow:hidden;
}
.ach-card:hover{
  border-color:var(--border-h);
  transform:translateY(-4px);
  box-shadow:var(--shadow-soft);
}
.ach-num{
  position:absolute;top:10px;right:16px;
  font-family:var(--font-display);
  font-size:3.5rem;font-weight:700;
  color:rgba(255,255,255,0.03);
  line-height:1;
}
.ach-icon{
  width:58px;height:58px;border-radius:50%;
  background:var(--accent-glow);
  display:grid;place-items:center;
  font-size:1.4rem;color:var(--accent);
  margin:0 auto 1.25rem;
}
.ach-card h5{
  font-family:var(--font-display);font-weight:600;
  color:var(--white);margin-bottom:0.75rem;
}
.ach-card p{font-size:0.875rem;color:var(--text-muted);margin:0}

/* ── Contact ─────────────────────────────────── */
.contact-links{display:flex;flex-direction:column;gap:12px;margin-top:1.5rem}
.c-link{
  display:flex;align-items:center;gap:14px;
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:14px 16px;
  transition:all var(--t) var(--ease);color:var(--text);
}
.c-link:hover{
  border-color:var(--border-h);
  background:var(--card-h);
  color:var(--white);
}
.c-icon{
  width:40px;height:40px;border-radius:10px;
  display:grid;place-items:center;font-size:0.95rem;flex-shrink:0;
}
.email-i{background:rgba(34,197,94,0.1);color:var(--accent)}
.phone-i{background:rgba(251,191,36,0.1);color:#fbbf24}
.li-i{background:rgba(96,165,250,0.1);color:#60a5fa}
.gh-i{background:rgba(255,255,255,0.06);color:var(--text)}
.c-link div strong{display:block;font-size:0.85rem;color:var(--white);margin-bottom:1px}
.c-link div span{font-size:0.78rem;color:var(--text-muted)}
.c-arrow{margin-left:auto;font-size:0.75rem;color:var(--text-muted);transition:transform var(--t) var(--ease)}
.c-link:hover .c-arrow{transform:translateX(4px);color:var(--accent)}

.contact-box{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:2rem;
}

.f-label{
  display:block;font-size:0.78rem;font-weight:600;
  letter-spacing:0.06em;text-transform:uppercase;
  color:var(--text-muted);margin-bottom:7px;
}
.f-input{
  display:block;width:100%;
  background:var(--input-bg);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:12px 16px;
  color:var(--white);
  font-family:var(--font-body);font-size:0.9rem;
  transition:all var(--t) var(--ease);
  outline:none;resize:vertical;
}
.f-input::placeholder{color:var(--text-muted)}
.f-input:focus{
  border-color:var(--accent);
  background:rgba(34,197,94,0.04);
  box-shadow:0 0 0 3px var(--accent-glow);
}

/* ── Footer ──────────────────────────────────── */
.site-footer{
  background:var(--bg-alt);
  border-top:1px solid var(--border);
  padding:3rem 0 1.5rem;
}
.footer-top{
  display:flex;justify-content:space-between;
  align-items:flex-start;flex-wrap:wrap;gap:1.5rem;
  padding-bottom:2rem;border-bottom:1px solid var(--border);
  margin-bottom:1.5rem;
}
.footer-brand{
  font-family:var(--font-display);
  font-size:1.35rem;font-weight:700;
  color:var(--accent);margin-bottom:4px;
  letter-spacing:0.04em;
}
.footer-sub{font-size:0.82rem;color:var(--text-muted);margin:0}
.footer-socials{display:flex;gap:12px;align-items:center}
.footer-socials a{
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  display:grid;place-items:center;
  color:var(--text-muted);font-size:0.9rem;
  transition:all var(--t) var(--ease);
}
.footer-socials a:hover{
  border-color:var(--accent);
  color:var(--accent);
  background:var(--accent-glow);
}
.footer-bottom p{font-size:0.8rem;color:var(--text-muted);text-align:center;margin:0}

/* ── Toast ───────────────────────────────────── */
.toast-msg{
  position:fixed;bottom:28px;right:28px;
  background:var(--accent);color:#000;
  font-family:var(--font-display);font-weight:600;font-size:0.86rem;
  padding:13px 22px;border-radius:12px;
  display:flex;align-items:center;gap:9px;
  transform:translateY(80px);opacity:0;
  transition:all 0.4s var(--ease);
  z-index:9998;pointer-events:none;
  box-shadow:0 8px 30px rgba(34,197,94,0.35);
}
.toast-msg.show{transform:translateY(0);opacity:1}

/* ── Responsive ──────────────────────────────── */
@media(max-width:991px){
  .hero-layout{
    flex-direction:column;
    text-align:center;
    gap:2.5rem;
  }
  .hero-text-side,
  .hero-photo-side{
    flex:none;
    width:100%;
    max-width:none;
  }
  .hero-photo-side{
    justify-content:center;
    align-items:center;
    padding-top:0;
    margin-bottom:0;
  }
  .photo-container{
    width:260px;
    height:260px;
    margin-top:0;
  }
  .hero-quote{justify-content:center}
  .hero-btns{justify-content:center}
  .hero-stats{justify-content:center}
  .hero-scroll-indicator{display:none}
  #navMenu{
    background:var(--nav-bg-solid);
    border-top:1px solid var(--border);
    padding:1rem;margin-top:12px;border-radius:var(--r);
  }
  .nav-link{padding:10px 14px !important}
  .theme-toggle-btn{
    width:46px;
    margin-top:10px;
  }
  .proj-split{
    grid-template-columns:1fr;
    gap:20px;
  }
  .proj-content{
    padding-right:0;
  }
  .proj-shot,
  .proj-preview{
    height:280px;
  }
}

@media(max-width:767px){
  .section-pad{padding:75px 0}
  .tl-item{grid-template-columns:0 28px 1fr}
  .tl-date-col{display:none}
  .hero-layout{gap:2rem}
  .photo-container{width:220px;height:220px}
  .proj-split{
    padding:16px;
  }
  .proj-shot,
  .proj-preview{
    height:230px;
  }
  .proj-btn{
    width:100%;
  }
  .mock-ecom-layout{
    grid-template-columns:1fr 100px;
    gap:10px;
  }
  .mock-ecom-copy h4{
    font-size:1.55rem;
  }
  .mock-burger-art{
    width:100px;
    height:128px;
  }
  .mock-quran-title{
    font-size:1rem;
  }
  .mock-verse-card{
    min-height:92px;
    padding:14px;
  }
  .mock-progress-grid{
    gap:8px;
  }
  .mock-progress-item{
    height:82px;
  }
  .ps-grid{grid-template-columns:1fr}
  .hero-btns{flex-direction:column;align-items:center}
  .btn-primary-mt,.btn-outline-mt{width:100%;justify-content:center}
  .footer-top{flex-direction:column;align-items:center;text-align:center}
  .navbar-brand{gap:10px}
  .brand-mark{
    width:42px;
    height:42px;
    border-radius:12px;
    font-size:1.45rem;
  }
  .brand-text{
    font-size:0.9rem;
    letter-spacing:0.08em;
  }
}

