@import"https://fonts.googleapis.com/css2?family=General+Sans:wght@400;600;700&family=Inter:wght@400;600&display=swap";:root{--ink: #e9eef3;--muted: #9aa6b2;--panel: #0e1420;--panel2: #0b111a;--accent: #6EF3C5;--accent2: #32C39A;--glow: 0 0 0 1px rgba(110,243,197,.25), 0 20px 60px rgba(110,243,197,.08) inset;--border: #1a2433;--shadow: 0 30px 70px rgba(0,0,0,.35);--radius: 18px;--maxw: 1160px}:root[data-theme=light]{--ink: #0a0f18;--muted: #4b5563;--panel: #ffffff;--panel2: #f7fafc;--accent: #2F6B4F;--accent2: #4D8D70;--glow: 0 0 0 1px rgba(47,107,79,.18), 0 16px 44px rgba(47,107,79,.08) inset;--border: #e5e7eb;--shadow: 0 18px 50px rgba(2,6,23,.1)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:#060a12;color:var(--ink);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;line-height:1.65}.aurora-bg{position:relative;min-height:100dvh;background:radial-gradient(1200px 600px at -10% -10%,rgba(110,243,197,.12),transparent 60%),radial-gradient(900px 500px at 120% 10%,rgba(50,195,154,.12),transparent 60%),linear-gradient(180deg,#070b13,#0a1120 40%,#090e18);overflow-x:hidden}.shell{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:310px 1fr;gap:24px;padding:26px 20px 80px}.sidebar{position:sticky;top:20px;align-self:start}.content{min-width:0}.sidebar-card{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);position:relative;overflow:hidden}.sidebar-card:after{content:"";position:absolute;inset:0;background:radial-gradient(400px 120px at 20% -10%,rgba(110,243,197,.12),transparent 60%);pointer-events:none}.avatar img{display:block;width:92px;height:92px;object-fit:cover;border-radius:16px;border:1px solid var(--border);box-shadow:var(--shadow)}.brand{font-family:General Sans,Inter,sans-serif;font-size:28px;font-weight:700;letter-spacing:-.02em;margin:14px 0 4px}.role{margin:0 0 14px;color:var(--muted)}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.chips span{display:inline-block;padding:6px 10px;border-radius:999px;font-size:.9rem;font-weight:600;color:var(--ink);background:#ffffff0f;border:1px solid var(--border)}.menu{display:grid;gap:10px;margin-bottom:14px}.menu button,.menu .ghost{appearance:none;border:1px solid var(--border);background:var(--panel);color:var(--ink);border-radius:12px;padding:10px 12px;font-weight:700;cursor:pointer}.menu button:hover,.menu .ghost:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.menu .ghost{text-align:center;text-decoration:none}.links{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.links a{padding:8px 10px;border-radius:10px;border:1px solid var(--border);background:var(--panel);text-decoration:none;color:var(--ink);font-weight:600}.links a:hover{background:var(--accent);color:#091218;border-color:transparent}.toggle{width:100%;background:linear-gradient(120deg,var(--accent),#baf3df);color:#091218;border:none;border-radius:12px;padding:10px 12px;font-weight:800;cursor:pointer}.toggle:hover{filter:brightness(1.05)}.section{margin-bottom:26px}.panel{background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:26px}.hero{padding:0;background:transparent;border:none;box-shadow:none}.hero-inner{background:radial-gradient(800px 220px at 10% -10%,rgba(110,243,197,.12),transparent 60%),radial-gradient(900px 240px at 90% -20%,rgba(50,195,154,.1),transparent 60%),linear-gradient(180deg,var(--panel),transparent 30%);border:1px solid var(--border);border-radius:calc(var(--radius) + 6px);box-shadow:var(--shadow);padding:38px 28px 28px}.eyebrow{color:var(--muted);font-weight:600;margin-bottom:8px}.headline{font-family:General Sans,Inter,sans-serif;font-size:clamp(28px,5vw,44px);font-weight:800;letter-spacing:-.02em;margin:0 0 10px}.headline .gradient{background:linear-gradient(120deg,var(--accent),#baf3df);-webkit-background-clip:text;background-clip:text;color:transparent}.subtext{color:var(--muted);max-width:70ch;margin-bottom:16px}.cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}.btn{display:inline-block;padding:10px 14px;border-radius:12px;border:1px solid var(--border);background:var(--panel);color:var(--ink);text-decoration:none;font-weight:700}.btn:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.btn.primary{background:linear-gradient(120deg,var(--accent),#baf3df);color:#091218;border-color:transparent}.marquee{display:flex;gap:22px;overflow:hidden;position:relative}.marquee span{opacity:.85;color:var(--muted);white-space:nowrap;animation:marq 18s linear infinite}@keyframes marq{0%{transform:translate(0)}to{transform:translate(-50%)}}.page-section h2{font-family:General Sans,Inter,sans-serif;font-size:clamp(22px,3.5vw,32px);letter-spacing:-.02em;margin:0 0 14px}.page-section img{width:260px;height:260px;object-fit:cover;border-radius:16px;border:1px solid var(--border);margin:0 18px 12px 0;float:left}.grid-container{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}.grid-item{grid-column:span 4;min-height:220px;display:flex;align-items:flex-end;border-radius:18px;overflow:hidden;border:1px solid var(--border);background-size:cover;background-position:center;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;filter:saturate(1.05) contrast(1.05)}.grid-item:first-child{grid-column:span 8;min-height:320px}.grid-item:hover{transform:translateY(-4px) scale(1.01)}.grid-item div{margin:12px;padding:12px 14px;border-radius:12px;background:#080c12a6;color:#e9eef3;border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}:root[data-theme=light] .grid-item div{background:#ffffffe6;color:#0a0f18}.grid-item h3{margin:0 0 4px;font-weight:800}.grid-item span{opacity:.9}.date-night{background-image:url(/assets/images/project1.PNG)}.sports-blog-friends{background-image:url(/assets/images/project2.png)}.weather-dashboard{background-image:url(/assets/images/weather-dashboard.PNG)}.password-generator{background-image:url(/assets/images/password.PNG)}.git-it-done{background-image:url(/assets/images/git-it-done.PNG)}.contact address{display:flex;flex-wrap:wrap;gap:12px 16px;align-items:center;font-style:normal}.contact address span{display:inline-block;padding:10px 12px;border-radius:12px;background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--border)}.contact address a{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:10px;border:1px solid var(--border);background:var(--panel);color:var(--ink);font-weight:700;text-decoration:none}.contact address a:hover{background:var(--accent);color:#091218;border-color:transparent;transform:translateY(-1px)}footer{margin-top:26px;text-align:center;color:var(--muted);padding:32px 20px 60px}.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}.reveal.is-visible{opacity:1;transform:none}.backtotop{position:fixed;right:18px;bottom:18px;z-index:40;width:44px;height:44px;border-radius:12px;border:1px solid var(--border);background:var(--panel);color:var(--ink);font-weight:800;cursor:pointer;box-shadow:var(--shadow)}.backtotop:hover{background:var(--accent);color:#091218;border-color:transparent}@media(max-width:1080px){.shell{grid-template-columns:1fr}.sidebar{position:static}}@media(max-width:760px){.grid-item,.grid-item:first-child{grid-column:1 / -1;min-height:220px}}.contact-form{display:grid;gap:10px;width:100%;max-width:560px}.filter{display:flex;gap:8px;flex-wrap:wrap;margin:8px 0 14px}.chip{padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:var(--panel);color:var(--ink);font-weight:700;cursor:pointer}.chip:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.chip.active{background:var(--accent);color:#091218;border-color:transparent}.modal-backdrop{position:fixed;inset:0;background:#0000008c;display:grid;place-items:center;z-index:60;padding:20px}.modal{width:min(720px,96vw);background:linear-gradient(180deg,var(--panel),var(--panel2));border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:20px 20px 16px;position:relative}.modal-title{margin:0 0 10px;font-size:22px}.modal-close{position:absolute;right:10px;top:8px;width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--panel);color:var(--ink);cursor:pointer}.bullets{margin:10px 0 14px;padding-left:1.1rem}.modal-cta{display:flex;gap:8px;justify-content:flex-end}.typewriter{position:relative}.caret{display:inline-block;margin-left:2px;opacity:.85;animation:blink 1s steps(1,end) infinite}@keyframes blink{50%{opacity:0}}.grid-item:hover{transform:translateY(-4px) scale(1.01) rotate(-.2deg)}.contact-form{display:grid;gap:10px;width:100%;max-width:560px;margin-top:10px}.contact-form input,.contact-form textarea{border:1px solid var(--border);background:var(--panel);color:var(--ink);border-radius:12px;padding:10px 12px;font:inherit}.contact-form input:focus,.contact-form textarea:focus{outline:none;box-shadow:0 0 0 2px var(--accent)}
