/* CODEPRYME Shared Styles */
:root{
  --bg:#f8faff; /* Lighter, subtle background */
  --surface:#ffffff;
  --text:#0a101f; /* Near black for better contrast */
  --muted:#5c6b8a; /* Soft blue-grey for secondary text */
  --primary:#134e7a; /* A deeper, more professional blue */
  --primary-600:#0f172a;
  --accent:#22d3ee; /* Slightly cooler cyan for accents */
  --gold:#FFD700;
  --card:#ffffff;
  --border:rgba(19,78,122,.1); /* Border color linked to primary color */
  --success:#16a34a;
  --warning:#f59e0b;
  --danger:#ef4444;
  --radius:16px; /* Slightly larger radius */
  --shadow: 0 12px 36px rgba(19, 78, 122, .08); /* Shadow linked to primary color */
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Oxygen, Ubuntu, Cantarell, 'Fira Sans', 'Droid Sans', 'Helvetica Neue', Arial, sans-serif;
  /* Subtler background gradient for elegance */
  background:
    radial-gradient(1200px 800px at 15% -15%, rgba(19,78,122,.08), transparent),
    radial-gradient(1200px 800px at 85% -10%, rgba(34,211,238,.06), transparent),
    var(--bg);
  color:var(--text);
}
h2{font-size: clamp(28px, 4vw, 42px); font-family: 'Plus Jakarta Sans', sans-serif; font-weight: 800; margin-bottom: 24px}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1140px, 92vw); margin:0 auto}
.container.narrow{width:min(840px,92vw)}
.grid-2{display:grid;grid-template-columns:1.2fr .8fr;gap:50px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.section{padding:120px 0}
.section.alt{background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));}
.eyebrow{letter-spacing:.22em;text-transform:uppercase;color:var(--primary);font-weight:700;font-size:.78rem}
.display{font-family: 'Plus Jakarta Sans', Inter, sans-serif; font-size: clamp(36px, 7vw, 76px); line-height: .95; margin:.4em 0 .3em; font-weight:900; letter-spacing:-.03em}
.lead{color:var(--muted);font-size:1.1rem; line-height:1.7}
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:999px;padding:14px 24px;background:transparent;color:var(--text);transition:transform .2s ease, box-shadow .2s ease, color .2s ease, border-color .2s ease;box-shadow:none;font-weight:600}
.btn:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-3px)}
.btn-primary{background:linear-gradient(135deg, var(--primary), #1e5a88);border:none;color:white;box-shadow:0 14px 28px rgba(19,78,122,.28)}
.btn-primary:hover{filter:brightness(1.05); box-shadow:0 18px 36px rgba(19,78,122,.35); transform:translateY(-4px)}
.btn-link{opacity:.9}

/* Header */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.9);backdrop-filter: blur(12px);border-bottom:1px solid rgba(2,8,23,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.brand{font-weight:800;letter-spacing:.02em;font-size:1.2rem;color:var(--primary)}
.nav-links{display:flex;gap:20px;align-items:center;font-weight:500}
.nav-links a{opacity:.85;transition:color .2s ease, opacity .2s ease}
.nav-links a:hover{opacity:1;color:var(--primary)}
.nav-toggle{display:none;background:transparent;border:none;color:var(--text);font-size:24px}

/* Hero */
.hero{padding-top:160px;padding-bottom:100px;position:relative;overflow:hidden}
.hero .hero-text .display{letter-spacing:.02em}
.hero .hero-contacts{margin-top:16px;display:flex;flex-wrap:wrap;gap:12px;color:var(--muted);font-size:.95rem}
.hero-quick{margin-top:30px;display:flex;gap:16px}
.hero::before{content:"";position:absolute;inset:-20% -10%; background: linear-gradient(135deg, rgba(19,78,122,.2), rgba(34,211,238,.15)); filter: blur(70px); transform: rotate(12deg); animation: heroWave 20s ease-in-out infinite alternate; z-index:-1}
@keyframes heroWave { from { transform: translateY(-15px) rotate(10deg) } to { transform: translateY(15px) rotate(16deg) } }
.hero-card{background:rgba(255,255,255,.7); backdrop-filter: blur(18px); border:1px solid var(--border); border-radius:var(--radius); padding:30px; box-shadow:var(--shadow)}
.hero-card .info{display:grid;gap:10px;color:var(--muted)}
.scroll-indicator{margin-top:60px;text-align:center;color:var(--muted);opacity:.7;letter-spacing:.1em;font-weight:600}

/* Avatar */
.avatar{width:180px;height:180px;border-radius:50%;overflow:hidden;border:6px solid rgba(255,255,255,1);box-shadow:0 15px 35px rgba(2,8,23,.15);transition: transform .35s ease, box-shadow .35s ease}
.avatar:hover{transform:translateY(-5px); box-shadow:0 24px 50px rgba(2,8,23,.25)}
.avatar img{width:100%;height:100%;object-fit:cover;display:block}

/* Content blocks */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);
  transition: transform .35s ease, box-shadow .35s ease, background-color .3s ease, border-color .3s ease;
  position:relative; /* For before/after effects */
}
.card::before{content:""; position:absolute; inset:0; border-radius:inherit; background:rgba(19,78,122,.03); opacity:0; transition:opacity .3s ease}
.card:hover{transform:translateY(-5px); box-shadow:0 18px 40px rgba(2,8,23,.18)}
.card:hover::before{opacity:1}
.cards .card h3{margin-top:0;font-size:1.2rem}
.card .meta{color:var(--muted);font-size:.9rem;margin-bottom:12px}
.card ul{padding-left:18px; line-height:1.6}
.timeline{display:grid;gap:24px}
.skills{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.skills h4{font-weight:700;margin-bottom:12px;color:var(--primary)}
.tags{display:flex;flex-wrap:wrap;gap:10px;padding:0;margin:0;list-style:none}
.tags li{background:var(--surface);border:1px solid var(--border);padding:8px 12px;border-radius:999px;color:var(--text);font-size:.85rem;font-weight:500;box-shadow:0 2px 8px rgba(0,0,0,.03)}
.contact-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}

/* Project cards hover zoom */
.project{position:relative; overflow:hidden; padding:0; background:none; border:none; box-shadow:none;}
.project h3{font-size:1.3rem; margin-top:10px; margin-bottom:6px}
.project p{color:var(--muted)}
.project:hover{transform:translateY(-6px); box-shadow:var(--shadow)}
.project img{width:100%;height:180px;object-fit:cover;border-radius:var(--radius); margin-bottom:0; filter:grayscale(.1); transition: filter .3s ease, transform .3s ease, box-shadow .3s ease; border:1px solid var(--border); box-shadow: 0 8px 20px rgba(2,8,23,.08)}
.project:hover img{filter:grayscale(0); transform:scale(1.01); box-shadow: 0 12px 28px rgba(2,8,23,.12)}
.project-tags{margin-top:10px; font-size:.8rem; color:var(--primary); font-weight:500}
.tag-meta{background:rgba(19,78,122,.1); padding:4px 8px; border-radius:4px}

/* Testimonial card emphasis */
.testimonial-card{background:var(--primary); color:white; border-color:var(--primary); border:none; padding:32px}
.testimonial-card strong{display:block; margin-top:14px; color:var(--accent); font-weight:700}
.testimonial-card p{font-size:1rem; line-height:1.6; margin-bottom:0}
.testimonial-card:hover{background:var(--primary-600); transform:translateY(-4px); box-shadow:0 18px 40px rgba(19,78,122,.4)}

/* Footer */
.site-footer{border-top:1px solid rgba(2,8,23,.06);padding:32px 0;background:rgba(255,255,255,.7); backdrop-filter: blur(4px)}
.site-footer .container{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:.9rem;color:var(--muted)}
.footer-nav{display:flex;gap:20px}
.footer-nav a:hover{color:var(--primary)}

/* Clients */
.clients{display:flex;flex-wrap:wrap;gap:24px;align-items:center}
.clients img{height:45px;filter:grayscale(1) contrast(.9);opacity:.8;transition:filter .3s ease, opacity .3s ease, transform .3s ease}
.clients img:hover{filter:grayscale(0) contrast(1.1);opacity:1;transform:translateY(-3px)}

/* Animations */
.animate-in{opacity:0;transform:translateY(30px);}
.animate-in.is-visible{opacity:1;transform:none;transition:opacity .8s cubic-bezier(.22,.61,.36,1), transform .8s cubic-bezier(.22,.61,.36,1)}
.delay-1{transition-delay:.2s}

/* Stagger utility: apply to containers to reveal children in sequence */
.stagger > *{opacity:0;transform:translateY(16px)}
.stagger.is-visible > *{opacity:1;transform:none;transition:opacity .7s ease, transform .7s ease}
.stagger.is-visible > *{transition-delay: calc(0.06s * var(--i, 1))}

/* Responsive */
@media (max-width: 900px){
  .grid-2{grid-template-columns:1fr;gap:40px}
  .grid-3{grid-template-columns:1fr 1fr}
  .skills{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .grid-3{grid-template-columns:1fr}
  .skills{grid-template-columns:1fr}
  .nav-links{position:fixed;inset:68px 16px auto 16px;display:none;flex-direction:column;background:rgba(255,255,255,.98);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
  .nav-links.is-open{display:flex}
  .nav-toggle{display:inline-block}
  .site-footer .container{flex-direction:column}
  .footer-nav{gap:12px;margin-top:10px}
}

/* Forms */
form{display:grid;gap:18px}
.input, input[type="text"], input[type="email"], textarea{padding:14px 18px;border-radius:14px;border:1px solid var(--border);background:rgba(255,255,255,.95);color:var(--text);outline:none;transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;font-size:1rem}
.input:focus, input:focus, textarea:focus{border-color:var(--primary); box-shadow:0 0 0 4px rgba(19,78,122,.1); background:white}
textarea{min-height:140px; resize:vertical}