:root{
  --bg:#0b1220;
  --card:#071021;
  --muted:#94a3b8;
  --brand:#06b6d4;
  --accent:#7c3aed;
  --text:#e6eef6;
  --glass: rgba(255,255,255,0.03);

  /* spacing & scale */
  --space-xs:6px;
  --space-sm:12px;
  --space-md:20px;
  --space-lg:32px;
  --radius:12px;
  --container-width:1100px;
}

/* Light theme (optional) */
:root[data-theme='light']{
  --bg: #f6fbff;
  --card: #ffffff;
  --muted: #566076;
  --brand: #0ea5e9;
  --accent: #7c3aed;
  --text: #041124;
  --glass: rgba(2,6,23,0.04);
} 

/* Smooth scrolling and prevent horizontal overflow globally */
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;background:var(--bg) !important;background-color:#0b1220 !important}
*{box-sizing:border-box}
html,body{height:100%; max-width: 100%; overflow-x: hidden;background:var(--bg) !important;background-color:#0b1220 !important}
/* Prevent mobile browsers from auto-resizing text and ensure images don't overflow */
img{max-width:100%;height:auto;display:block}

/* Ensure all containers respect viewport width */
.container{max-width:1100px;margin:0 auto;padding:0 20px;width:100%;box-sizing:border-box}

/* Prevent text overflow */
h1,h2,h3,p{word-wrap:break-word;overflow-wrap:break-word}

/* Ensure buttons don't overflow */
.btn{box-sizing:border-box;max-width:100%}

/* Prevent form elements from overflowing */
.field input,.field textarea,.field select{box-sizing:border-box;max-width:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:linear-gradient(180deg,var(--bg),#071226) !important;
  background-color:#0b1220 !important;
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  -webkit-font-variant-ligatures:contextual;
  min-height:100vh;
}

h1,h2,h3{letter-spacing:-0.01em}
h1{font-weight:700}
h2{font-weight:700}
h3{font-weight:700}

.lead{font-size:1.05rem}

/* improve hero CTA spacing */
.hero-ctas .btn{padding:12px 18px}


.skip-link{position:absolute;left:-9999px;top:auto;background:var(--card);color:var(--text);padding:8px 12px;border-radius:8px;z-index:90}
.skip-link:focus{left:20px;top:14px}

/* profile-card styles defined below */

/* highlights strip */
.highlights{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap;align-items:center;padding:6px 0}
/* modern pill cards with subtle depth and hover / active states */
.highlights li{background:var(--card);padding:12px 16px;border-radius:12px;font-weight:700;color:var(--text);display:flex;flex-direction:row;align-items:center;gap:12px;border:1px solid rgba(255,255,255,0.03);min-width:220px;transition:transform .18s ease,box-shadow .18s ease,background .12s ease,border-color .12s ease}
.highlights li strong{font-weight:800}
.highlights li span{font-weight:600;color:var(--muted);font-size:0.9rem;margin:0}
.highlights li::before{content:"";width:10px;height:10px;border-radius:50%;background:linear-gradient(90deg,var(--brand),var(--accent));display:inline-block;flex:0 0 10px}
.highlights li:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(2,6,23,0.5);border-color:rgba(255,255,255,0.06)}
/* active state used by JS rotator */
.highlights li.active{background:linear-gradient(180deg,rgba(124,58,237,0.07),rgba(6,182,212,0.02));border-color:rgba(6,182,212,0.12);box-shadow:0 22px 48px rgba(2,6,23,0.55);color:var(--text);transform:translateY(-8px)}
/* staggered entrance */
.highlights li{opacity:0;transform:translateY(8px);animation:hlRise .5s ease forwards}
.highlights li:nth-child(1){animation-delay:.06s}
.highlights li:nth-child(2){animation-delay:.12s}
.highlights li:nth-child(3){animation-delay:.18s}
.highlights li:nth-child(4){animation-delay:.24s}
@keyframes hlRise{to{opacity:1;transform:none}}
@media (max-width:520px){.highlights li{min-width:unset;padding:10px;border-radius:10px;display:flex;width:100%}}


/* featured case study */
section#case-study{padding:24px 0}
.case-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:6px}
.card.featured{display:flex;flex-direction:column;gap:10px;padding:18px;border-radius:12px}
.card.featured h3{margin:0 0 6px}
.card.featured p{margin:0 0 10px;color:var(--muted);line-height:1.5}
.card-actions{display:flex;gap:12px}
.card-actions .btn{padding:10px 14px}

/* subtle entrance animations (consolidated here) */
.reveal{opacity:0;transform:translateY(12px) scale(.995);transition:opacity .66s ease,transform .66s cubic-bezier(.2,.9,.2,1)}
.reveal.visible{opacity:1;transform:none}

/* small screens tweaks */
@media (max-width:980px){
  .hero-inner{flex-direction:column-reverse;text-align:center}
  .hero-visual{width:120px}
  .hero{padding:48px 0}
}

@media (min-width:900px){.case-grid{grid-template-columns:repeat(2,1fr)}}

.container{max-width:1100px;margin:0 auto;padding:0 20px}

.site-header{backdrop-filter:blur(6px);position:sticky;top:0;z-index:50;background:rgba(6,10,16,0.45);border-bottom:1px solid rgba(255,255,255,0.03)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{color:var(--text);text-decoration:none;font-weight:700;font-size:1.1rem}
.accent{color:var(--brand);margin-left:4px}
/* Navigation Styles */
.nav-toggle{background:transparent;border:0;color:var(--muted);display:none;cursor:pointer;padding:8px;border-radius:6px;transition:color .2s ease}
.nav-toggle:hover{color:var(--text)}
.main-nav{display:block}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:20px;align-items:center}
.main-nav a{color:var(--muted);text-decoration:none;font-weight:600;position:relative;transition:color .3s ease;padding:8px 12px;border-radius:6px}
.main-nav a:hover{color:var(--text)}
.main-nav a.active{color:var(--brand)}
.main-nav a.active::after{content:'';position:absolute;bottom:-8px;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--brand),var(--accent));border-radius:2px}

/* Mobile Navigation */
@media (max-width:880px){
  .nav-toggle{
    display:inline-flex;
    align-items:center;
    gap:8px;
    z-index:1001;
    position:relative;
  }
  
  .main-nav{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:var(--card);
    border:1px solid var(--glass);
    border-radius:0 0 12px 12px;
    box-shadow:0 8px 30px rgba(2,6,23,0.6);
    z-index:1000;
    opacity:0;
    visibility:hidden;
    transform:translateY(-10px);
    transition:opacity .3s ease, visibility .3s ease, transform .3s ease;
    max-height:0;
    overflow:hidden;
  }
  
  .main-nav.open{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
    max-height:300px;
  }
  
  .main-nav ul{
    flex-direction:column;
    gap:0;
    padding:16px 0;
    display:flex !important; /* Force display even if other rules try to hide */
  }
  
  .main-nav li{
    width:100%;
  }
  
  .main-nav a{
    display:block;
    padding:12px 20px;
    color:var(--text);
    border-radius:0;
    transition:background .2s ease, color .2s ease;
    width:100%;
    text-align:left;
  }
  
  .main-nav a:hover{
    background:rgba(6,182,212,0.1);
    color:var(--brand);
  }
  
  .main-nav a.active{
    background:rgba(6,182,212,0.15);
    color:var(--brand);
  }
  
  .main-nav a.active::after{
    display:none; /* Hide the underline in mobile */
  }
  
  /* Ensure header has proper positioning context */
  .site-header{
    position:relative;
  }
}

.header-actions{display:flex;align-items:center;gap:12px}
.icon-btn{background:transparent;border:0;padding:8px;border-radius:8px;color:var(--muted);cursor:pointer}
.icon-btn:hover{color:var(--text);background:var(--glass)}

.social-links-header{display:flex;gap:8px;align-items:center}
.icon-link{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;color:var(--muted);background:transparent;border:0;text-decoration:none}
.icon-link svg{width:18px;height:18px;display:block;fill:currentColor}
.icon-link:hover{color:var(--text);background:var(--glass)}
.icon-link:focus-visible{outline:3px solid rgba(6,182,212,0.18);outline-offset:3px;border-radius:8px}

.sr-only{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}

.hero{padding:80px 0;display:flex;align-items:center;position:relative}
.hero-inner{display:flex;gap:40px;align-items:center}
.hero-copy{flex:1}
.hero h1{font-size:clamp(1.6rem,4vw,2.6rem);margin:0 0 12px;color:var(--text);line-height:1.05}
/* hero subtitle styling */
.hero h3{font-size:1.05rem;color:var(--muted);font-weight:600;margin:0 0 8px;line-height:1.25}
@media (max-width:640px){.hero h3{font-size:0.95rem}}
.lead{color:var(--muted);margin-bottom:18px}

:focus{outline:none}
:focus-visible{outline:3px solid rgba(6,182,212,0.12);outline-offset:3px} 
.hero-ctas{display:flex;gap:12px}
.btn{display:inline-flex;align-items:center;gap:10px;padding:12px 20px;border-radius:10px;text-decoration:none;font-weight:700;transition:transform .15s ease, box-shadow .15s ease,background .12s ease}
.btn:focus-visible{outline:3px solid rgba(6,182,212,0.18);outline-offset:3px;border-radius:10px}
.btn.primary{background:transparent;color:var(--text);border:1px solid rgba(255,255,255,0.06);box-shadow:none}
.btn.primary:hover{transform:translateY(-3px);box-shadow:0 10px 28px rgba(2,6,23,0.35)}
.btn.ghost{border:1px solid rgba(255,255,255,0.06);color:var(--text);background:transparent}

/* general hover for all buttons */
.btn:hover{transform:translateY(-3px) scale(1.02)}

/* bold dot used in CTA buttons */
.btn-dot{font-weight:900;color:var(--accent);margin-right:8px;line-height:1;font-size:1.1rem;display:inline-block;transform:translateY(-1px);transition:color .12s ease}
.btn:hover .btn-dot{color:var(--brand)}

/* reduce contact section vertical padding for tighter layout */
section#contact{padding:40px 0}

.hero-visual{width:200px;display:flex;justify-content:center}

/* typed cursor */
#typed{font-weight:600}
#typed::after{content:"|";display:inline-block;margin-left:8px;opacity:0.9;animation:blink .8s steps(1) infinite}
@keyframes blink{50%{opacity:0}}

/* subtle animated hero gradient */
.hero::before{content:"";position:absolute;left:0;right:0;top:0;height:48vh;pointer-events:none;background:radial-gradient(600px 200px at 10% 10%, rgba(124,58,237,0.08), transparent 10%), radial-gradient(500px 180px at 90% 60%, rgba(6,182,212,0.06), transparent 12%);mix-blend-mode:screen;opacity:0.9}

/* unified profile-card */
.profile-card{padding:28px;border-radius:14px;border:1px solid rgba(255,255,255,0.03);background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(255,255,255,0.00));text-align:center}
/* framed profile image wrapper */
.profile-image-wrap{display:inline-block;position:relative;border-radius:999px;padding:10px;background:linear-gradient(135deg,var(--brand),var(--accent));box-shadow:0 18px 44px rgba(2,6,23,0.45);transition:transform .22s ease,box-shadow .22s ease}
.profile-image{width:160px;height:160px;display:block;border-radius:999px;object-fit:cover;border:4px solid var(--card);box-shadow:0 12px 30px rgba(2,6,23,0.45);transition:transform .22s ease}
.profile-image-wrap:hover{transform:translateY(-6px) rotate(-2deg);box-shadow:0 30px 70px rgba(2,6,23,0.6)}
.profile-badge{position:absolute;right:8px;bottom:8px;background:var(--brand);color:#021124;font-weight:800;padding:6px 8px;border-radius:999px;font-size:0.8rem;border:2px solid var(--card);box-shadow:0 6px 18px rgba(2,6,23,0.45);display:inline-flex;align-items:center;justify-content:center}
@media (max-width:880px){.profile-image{width:120px;height:120px}.profile-image-wrap{padding:6px}}
@media (max-width:520px){.profile-image{width:100px;height:100px}.profile-image-wrap{padding:5px}}


/* profile role block (stacked title + tech icons) */
.profile-role-block{margin-top:8px}
.profile-title{font-size:0.95rem;font-weight:800;color:var(--text);margin:6px 0 10px}
.profile-title::after{content:"";display:block;height:4px;width:54px;border-radius:6px;background:linear-gradient(90deg,var(--brand),var(--accent));margin-top:8px}
.tech-row{display:flex;gap:10px;justify-content:center;align-items:center;margin-top:10px}
.tech{width:38px;height:38px;border-radius:8px;background:rgba(255,255,255,0.02);display:inline-flex;align-items:center;justify-content:center;transition:transform .15s ease,box-shadow .15s ease}
.tech img{width:20px;height:20px;display:block}
.tech:hover{transform:translateY(-6px);box-shadow:0 12px 30px rgba(2,6,23,0.5)}
.tech:focus-visible{outline:3px solid rgba(6,182,212,0.12);outline-offset:3px}

section{padding:60px 0}
h2{font-size:1.05rem;color:var(--brand);text-transform:uppercase;letter-spacing:1px;margin:0 0 18px}
.about-text{max-width:760px;color:var(--muted);margin:0}

/* About section layout */
.about-grid{display:grid;grid-template-columns:1fr 320px;gap:18px;align-items:center}
/* reduce vertical space specifically for About section */
section#about{padding:28px 0}
.about h2{font-size:1.12rem;margin:0 0 8px;text-transform:none;letter-spacing:0.6px}
.section-divider{height:1px;width:54px;background:linear-gradient(90deg,var(--brand),var(--accent));margin:8px 0 18px;border-radius:4px}
.about-copy{max-width:720px}
.about-copy .lead{font-size:1.02rem;margin-bottom:10px}
.about-cta{margin-top:16px;display:flex;gap:12px;align-items:center}
.about-details{background:var(--card);padding:18px;border-radius:12px;border:1px solid rgba(255,255,255,0.03)}

/* technologies section */
.tech-card {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.04);
  border-radius: 12px;
}

.tech-card img {
  width: 38px;
  height: 38px;
}

.tech-card h4 {
  margin: 0;
  font-size: 15px;
  color: #fff;
}
.tech-card p {
  margin: 4px 0 0;
  font-size: 13px;
  color: #9ca3af;
}

/* compact skill cards */
.skills-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.skill-mini{background:linear-gradient(180deg,rgba(255,255,255,0.01),transparent);border-radius:10px;padding:12px;border:1px solid rgba(255,255,255,0.03);transition:transform .18s ease,box-shadow .18s ease,background .12s ease;cursor:pointer}
.skill-mini:focus{outline:none;box-shadow:0 12px 30px rgba(2,6,23,0.4);transform:translateY(-6px)}
.skill-mini-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.skill-mini h4{margin:0;font-size:0.95rem;color:var(--text);font-weight:800}
.mini-dot{width:10px;height:10px;border-radius:50%;background:linear-gradient(90deg,var(--brand),var(--accent));display:inline-block}
.skill-mini-desc{color:var(--muted);font-weight:600;font-size:0.95rem;margin:0}
.skill-mini:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(2,6,23,0.5)}
.skill-mini.active{background:linear-gradient(180deg,rgba(124,58,237,0.06),rgba(6,182,212,0.02));border-color:rgba(6,182,212,0.12);box-shadow:0 28px 60px rgba(2,6,23,0.55)}
/* small detail area that appears for active cards */
.skill-mini .skill-extra{display:none;color:var(--muted);margin-top:10px;font-size:0.9rem}
.skill-mini.active .skill-extra{display:block}
@media (max-width:820px){.skills-cards{grid-template-columns:1fr}}


@media (max-width:980px){.about-grid{grid-template-columns:1fr;align-items:start}.about-cta{justify-content:flex-start}}


.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;margin-top:24px}
.card{background:var(--card);padding:24px;border-radius:12px;border:1px solid rgba(255,255,255,0.03);display:flex;flex-direction:column;gap:16px;overflow:hidden;transition:transform .22s ease,box-shadow .22s ease}
.card:hover{transform:translateY(-8px);box-shadow:0 18px 40px rgba(2,6,23,0.6)}

/* Enhanced project cards */
.featured-project{border:1px solid rgba(6,182,212,0.2);background:linear-gradient(180deg,rgba(6,182,212,0.02),var(--card))}
.production-project{border:1px solid rgba(34,197,94,0.2);background:linear-gradient(180deg,rgba(34,197,94,0.02),var(--card))}
.fullstack-project{border:1px solid rgba(168,85,247,0.2);background:linear-gradient(180deg,rgba(168,85,247,0.02),var(--card))}
.project-badge{font-size:0.75rem;font-weight:700;padding:4px 8px;border-radius:12px;margin-left:auto}
.project-badge{background:linear-gradient(90deg,var(--brand),var(--accent));color:#021124}
.project-badge.production{background:linear-gradient(90deg,#22c55e,#16a34a);color:#021124}
.project-badge.fullstack{background:linear-gradient(90deg,#a855f7,#7c3aed);color:#ffffff}

.card .card-media{height:140px;background:linear-gradient(180deg,rgba(255,255,255,0.02),transparent);border-radius:10px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.card .card-media img{width:100%;height:100%;object-fit:cover;display:block}
.project h3{margin:0 0 8px;color:var(--text);font-size:1.1rem;font-weight:700}
.card p{color:var(--muted);margin:0 0 16px;flex:1;line-height:1.5}

.card-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.card-icon{width:32px;height:32px;object-fit:contain;filter:grayscale(0.1) brightness(1.1)}

/* Tech stack tags */
.tech-stack{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.tech-tag{background:rgba(6,182,212,0.1);color:var(--brand);font-size:0.75rem;font-weight:600;padding:4px 8px;border-radius:12px;border:1px solid rgba(6,182,212,0.2)}

/* Project links */
.project-links{display:flex;gap:12px;align-items:center;margin-top:auto}
.github-link{background:rgba(255,255,255,0.05);color:var(--text);text-decoration:none;font-weight:600;padding:8px 12px;border-radius:8px;display:inline-flex;align-items:center;gap:6px;transition:background .2s ease}
.github-link:hover{background:rgba(255,255,255,0.1)}
.details-link{color:var(--brand);font-weight:700;text-decoration:none}
.details-link:hover{text-decoration:underline}

.card .card-meta{display:flex;gap:10px;align-items:center;color:var(--muted);font-size:0.9rem}

.skill-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:8px}
.skill{background:var(--card);padding:14px;border-radius:10px;border:1px solid var(--glass);display:flex;flex-direction:column;gap:8px}
.skill::before{content:attr(data-skill);font-weight:700;color:var(--text)}
.skill .bar{height:10px;background:linear-gradient(90deg,var(--brand),var(--accent));border-radius:999px;width:0}
.skill .bar-wrap{background:rgba(255,255,255,0.04);height:10px;border-radius:999px;overflow:hidden;margin-top:6px}
.skill .percent{font-size:0.8rem;color:var(--muted);margin-left:auto}
/* New detailed skills grid */
.skills-detailed-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:20px}
.skill-detailed-card{background:var(--card);padding:20px;border-radius:12px;border:1px solid var(--glass);transition:transform .22s ease,box-shadow .22s ease}
.skill-detailed-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(2,6,23,0.4)}
.skill-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.skill-header img{width:32px;height:32px;object-fit:contain}
.skill-header h3{margin:0;font-size:1.1rem;color:var(--text);font-weight:700}
.skill-list{list-style:none;padding:0;margin:0}
.skill-list li{color:var(--muted);margin-bottom:8px;padding-left:16px;position:relative;line-height:1.4}
.skill-list li::before{content:"•";color:var(--brand);font-weight:bold;position:absolute;left:0;top:0}
.skill-list li:last-child{margin-bottom:0}

/* make detailed skills responsive */
@media (max-width:980px){.skills-detailed-grid{grid-template-columns:1fr}}

/* Old skills grid (keep for backward compatibility but hide) */
.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:14px}
.skill-card{background:var(--card);padding:18px;border-radius:12px;border:1px solid var(--glass);display:flex;flex-direction:column;align-items:center;gap:12px;transition:transform .28s cubic-bezier(.2,.9,.2,1),box-shadow .28s ease;cursor:default}
.skill-card img{width:56px;height:56px;object-fit:contain;filter:grayscale(0.05)}
.skill-card .skill-name{font-weight:700;color:var(--text)}
.skill-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 18px 40px rgba(2,6,23,0.6)}

/* circular progress */
.skill-progress{width:84px;height:84px;display:flex;align-items:center;justify-content:center}
.skill-progress .circle{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:conic-gradient(var(--brand) 0deg, rgba(255,255,255,0.06) 0deg);box-shadow:inset 0 -6px 18px rgba(0,0,0,0.2);position:relative}
.skill-progress .circle::after{content:"";position:absolute;width:58px;height:58px;background:var(--card);border-radius:50%;box-shadow:inset 0 2px 8px rgba(0,0,0,0.25)}
.skill-progress .pct{position:relative;z-index:2;font-weight:700;color:var(--text)}

/* make grid responsive */
@media (max-width:1100px){.skills-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:760px){.skills-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.skills-grid{grid-template-columns:1fr}}

@media (max-width:980px){.projects-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:640px){.projects-grid{grid-template-columns:1fr}}


/* Enhanced Contact Section */
.contact-inner{display:grid;grid-template-columns:1fr 420px;gap:12px;align-items:start}
/* Make heading and intro span both columns to avoid large empty space */
.contact-inner > h2,
.contact-inner > .contact-lead{grid-column:1 / -1}
/* Tighten vertical spacing specifically for contact section */
.contact h2{margin:0 0 8px;font-size:1.8rem;color:var(--text)}
.contact .contact-lead{margin:0 0 12px;color:var(--muted);font-size:1.1rem;line-height:1.5}

/* Contact grid and fields */
.contact-grid{display:grid;grid-template-columns:360px 1fr;gap:24px;align-items:start}
.contact-info{background:var(--card);padding:20px;border-radius:12px;border:1px solid var(--glass)}
.contact-info .info-lead{color:var(--muted);margin-bottom:20px;font-size:0.95rem}
.contact-info .contact-card{padding:16px;border-radius:10px;background:linear-gradient(180deg,rgba(255,255,255,0.01),transparent);margin-bottom:16px;border:1px solid rgba(255,255,255,0.02)}
.contact-info .contact-card:last-child{margin-bottom:0}
.contact-info .contact-card strong{color:var(--text);font-size:0.9rem;display:block;margin-bottom:8px}
.contact-info .contact-row{color:var(--muted);display:flex;flex-direction:column;gap:4px;align-items:flex-start}
.contact-info .contact-row a{color:var(--brand);text-decoration:none;font-weight:600}
.contact-info .contact-row a:hover{text-decoration:underline}

/* Enhanced social links */
.social-links{display:flex;gap:12px;flex-direction:row !important}
.social-link{display:inline-flex;align-items:center;gap:6px;color:var(--brand);text-decoration:none;font-weight:600;padding:6px 10px;border-radius:6px;background:rgba(6,182,212,0.05);transition:background .2s ease}
.social-link:hover{background:rgba(6,182,212,0.1);text-decoration:none}
.social-link svg{flex-shrink:0}

/* Copy email enhancements */
.copy-email{background:transparent;border:0;color:var(--brand);font-weight:700;cursor:pointer;padding:6px;border-radius:4px;transition:background .2s ease}
.copy-email:hover{background:rgba(6,182,212,0.1);text-decoration:none}
.copy-hint{font-size:0.8rem;color:var(--muted);font-style:italic}
.availability,.timezone{font-size:0.85rem;color:var(--muted);font-style:italic}

/* Fixed Form Layout */
.contact-form{display:flex;flex-direction:column;gap:20px}
.form-header{margin-bottom:8px}
.form-header h3{margin:0 0 4px;color:var(--text);font-size:1.2rem}
.form-header p{margin:0;color:var(--muted);font-size:0.9rem}

/* Fixed Field Layout - No Floating Labels */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:0}
.field label{position:static;color:var(--text);font-size:0.9rem;font-weight:600;margin-bottom:6px}
.field input,.field textarea,.field select{
  padding:12px 16px;
  border-radius:10px;
  background:var(--card);
  border:1px solid var(--glass);
  width:100%;
  color:var(--text);
  font-family:inherit;
  font-size:0.95rem;
  box-sizing:border-box;
  transition:border-color .2s ease,box-shadow .2s ease;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;
  border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(6,182,212,0.1);
}
.field select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}
.field textarea{resize:vertical;min-height:120px;line-height:1.5}
.field input::placeholder,.field textarea::placeholder{color:rgba(148,163,184,0.6)}

.form-actions{display:flex;gap:12px;align-items:center;margin-top:8px}
.form-note{font-size:0.85rem;color:var(--muted);margin:12px 0 0;font-style:italic}

/* Response time card highlight */
.response-time{border-color:rgba(6,182,212,0.2) !important;background:linear-gradient(180deg,rgba(6,182,212,0.03),transparent) !important}

/* small screens: stack */
@media (max-width:880px){
  .contact-grid{grid-template-columns:1fr}
  .contact-info{order:2;margin-top:20px}
}

/* send button spinner and states */
.send-btn{position:relative;overflow:hidden}
.send-btn .spinner{display:inline-block;width:18px;height:18px;border-radius:50%;border:2px solid transparent;border-top-color:rgba(255,255,255,0.9);margin-left:10px;opacity:0;transform:scale(.8);transition:opacity .18s ease,transform .2s ease}
.send-btn.sending .spinner{opacity:1;transform:none;animation:spin .8s linear infinite}
.send-btn.sent{background:linear-gradient(90deg,#22c55e,#16a34a);color:#021124}
.send-btn.sent .btn-text{margin-right:6px}
@keyframes spin{to{transform:rotate(360deg)}}

/* small screens: stack */
@media (max-width:880px){
  .contact-grid{grid-template-columns:1fr}
  .contact-info{order:2}
}

/* copy email button */
.copy-email{background:transparent;border:0;color:var(--brand);font-weight:700;cursor:pointer;padding:6px}
.copy-email:hover{text-decoration:underline}

.contact-lead{margin-bottom:14px;color:var(--muted)}

/* Technologies section with full-width grid */
.technologies .tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:20px}
.tech-card{background:var(--card);padding:18px;border-radius:12px;display:flex;align-items:center;gap:15px;border:1px solid rgba(255,255,255,0.03);transition:transform .22s ease,box-shadow .22s ease}
.tech-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(2,6,23,0.4)}
.tech-card img{width:38px;height:38px;object-fit:contain;flex-shrink:0}
.tech-card h4{margin:0;font-size:15px;color:var(--text);font-weight:700}
.tech-card p{margin:4px 0 0;font-size:13px;color:var(--muted);line-height:1.4}

/* Technologies responsive breakpoints */
@media (max-width:980px){.technologies .tech-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.technologies .tech-grid{grid-template-columns:1fr}}

/* reveal-on-scroll (consolidated above) */

/* header scrolled shadow */
.site-header.scrolled{box-shadow:0 6px 24px rgba(3,7,18,0.6)}

/* toast */
.toast{position:fixed;right:20px;bottom:20px;background:var(--card);color:var(--text);padding:12px 16px;border-radius:10px;border:1px solid var(--glass);box-shadow:0 8px 30px rgba(2,6,23,0.45);opacity:0;transform:translateY(10px);transition:opacity .25s ease,transform .25s ease;z-index:60}
.toast.show{opacity:1;transform:none}



.site-footer{border-top:1px solid rgba(255,255,255,0.02);padding:22px 0;color:var(--muted);text-align:center}

@media (max-width:980px){
  .projects-grid{grid-template-columns:repeat(2,1fr)}
  .contact-inner{grid-template-columns:1fr}
  .hero-inner{flex-direction:column;text-align:center}
  .hero-visual{order:-1}
  .skills-detailed-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .projects-grid{grid-template-columns:1fr}
  .hero h1{font-size:1.6rem}
  .container{padding:0 16px}
  .hero{padding:60px 0}
  .hero-ctas{flex-direction:column;gap:12px;align-items:center}
  .hero-ctas .btn{width:100%;max-width:280px;justify-content:center}
}

@media (max-width:520px){
  .skill-grid{grid-template-columns:1fr}
  .hero-inner{gap:18px}
  .header-actions{display:none}
  .contact h2{font-size:1.4rem}
  .contact .contact-lead{font-size:1rem}
  .tech-stack{justify-content:center}
  .project-links{flex-direction:column;gap:8px}
  .project-links .github-link, .project-links .details-link{width:100%;text-align:center;justify-content:center}
}
/* Enhanced Mobile Responsiveness */
@media (max-width:768px){
  /* Prevent horizontal scrolling */
  html, body{overflow-x:hidden;max-width:100vw}
  .container{padding:0 16px;max-width:100%;box-sizing:border-box}
  
  /* Stack all grids vertically */
  .projects-grid{grid-template-columns:1fr !important;gap:20px}
  .skills-detailed-grid{grid-template-columns:1fr !important;gap:18px}
  .technologies .tech-grid{grid-template-columns:1fr !important;gap:16px}
  .about-grid{grid-template-columns:1fr !important;gap:16px}
  .contact-grid{grid-template-columns:1fr !important;gap:20px}
  
  /* Contact form improvements */
  .contact-form{gap:16px}
  .field input, .field textarea, .field select{font-size:16px} /* Prevents zoom on iOS */
  .btn{min-height:44px} /* Better touch targets */
  .copy-email{min-height:44px;padding:8px 12px}
  .social-link{min-height:44px;padding:8px 12px}
  
  /* Hero section mobile optimization */
  .hero{padding:40px 0}
  .hero-inner{flex-direction:column;text-align:center;gap:24px}
  .hero-visual{order:-1;width:140px}
  .hero-ctas{flex-direction:column;gap:12px;align-items:center;width:100%}
  .hero-ctas .btn{width:100%;max-width:280px;justify-content:center}
  
  /* Typography adjustments */
  .hero h1{font-size:1.5rem;line-height:1.2}
  .hero h3{font-size:0.95rem}
  .contact h2{font-size:1.4rem}
  .contact .contact-lead{font-size:1rem}
  .form-header h3{font-size:1.1rem}
  
  /* Card optimizations */
  .card{padding:18px;margin-bottom:0}
  .skill-detailed-card{padding:16px}
  .tech-card{padding:14px;gap:12px}
  .contact-card{padding:14px}
  
  /* Project cards mobile specific */
  .tech-stack{justify-content:flex-start;flex-wrap:wrap}
  .project-links{flex-direction:column;gap:10px;width:100%}
  .project-links .github-link, .project-links .details-link{width:100%;text-align:center;justify-content:center}
  
  /* Navigation mobile */
  .header-inner{padding:12px 0}
  
  /* Contact info reorder */
  .contact-info{order:2;margin-top:20px}
}

@media (max-width:480px){
  /* Extra small screens */
  .container{padding:0 12px}
  
  /* Further typography reduction */
  .hero h1{font-size:1.3rem;line-height:1.1}
  .about-text{font-size:0.9rem}
  h2{font-size:0.95rem}
  
  /* Tighter spacing */
  .hero{padding:30px 0}
  .hero-inner{gap:20px}
  section{padding:40px 0}
  
  /* Card adjustments */
  .card{padding:16px}
  .skill-detailed-card{padding:14px}
  .tech-card{padding:12px;gap:10px}
  .contact-card{padding:12px}
  
  /* Profile image smaller */
  .profile-image{width:100px;height:100px}
  .profile-image-wrap{padding:4px}
  
  /* Tech tags smaller */
  .tech-tag{font-size:0.7rem;padding:3px 6px}
  
  /* Highlights full width */
  .highlights{flex-direction:column;gap:8px}
  .highlights li{width:100%;min-width:unset}
}
/* Project Modal Styles - FIXED */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1000;
  display: none !important; /* Force hide by default */
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.modal.open {
  display: flex !important; /* Only show when explicitly opened */
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.modal-backdrop {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.8);
  backdrop-filter: blur(4px);
}

.modal-panel {
  position: relative;
  margin: auto;
  background: var(--card);
  border-radius: 12px;
  border: 1px solid var(--glass);
  max-width: 90vw;
  max-height: 90vh;
  overflow-y: auto;
  padding: 24px;
  box-shadow: 0 20px 60px rgba(2, 6, 23, 0.8);
  z-index: 1001;
}

.modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: transparent;
  border: 0;
  color: var(--muted);
  font-size: 24px;
  cursor: pointer;
  padding: 8px;
  border-radius: 6px;
  transition: color 0.2s ease, background 0.2s ease;
  z-index: 1002;
  display: none; /* Hide close button completely for now */
}

.modal-close:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.1);
}

.modal-content {
  color: var(--text);
  line-height: 1.6;
}

.modal-content h3 {
  color: var(--text);
  margin-bottom: 16px;
}

/* Hide modal by default and prevent body scroll when open */
body.modal-open {
  overflow: hidden;
}

/* Mobile modal adjustments */
@media (max-width: 768px) {
  .modal-panel {
    margin: 20px;
    max-width: calc(100vw - 40px);
    max-height: calc(100vh - 40px);
    padding: 20px;
  }
  
  .modal-close {
    top: 12px;
    right: 12px;
    font-size: 20px;
    display: none; /* Ensure hidden on mobile too */
  }
}