:root{
  --bg: linear-gradient(135deg,#0b1220 0%,#1c0f1f 40%,#0b1220 100%);
  --bg-soft: #131b2b;
  --card: #131c2e;
  --text: #e6eaf2;
  --muted: #9aa7bd;
  --brand: #6ea8fe;
  --brand-2: #7c5cff;
  --accent: #41d1b7;
  --ring: rgba(110,168,254,.45);
  --glass: rgba(255,255,255,.04);
  --shadow: 0 10px 30px rgba(0,0,0,.35);
}

::-webkit-scrollbar{width:5px;} 
::-webkit-scrollbar-track{background:#101828;} 
::-webkit-scrollbar-thumb{background:#027c6e;border-radius:4px;} 
::-webkit-scrollbar-thumb:hover{background:#026a59;}

*, *::before, *::after {
  box-sizing: border-box;
}

html,body{height:100%;}
/* body stays scrollable */
  body {
    cursor:none;
    margin: 0;
    padding: 0;
    width: 100%;
    min-height: 100%;
    align-items: center; 
    background: var(--bg);
    background-attachment: fixed;
    font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, "Helvetica Neue", Arial, "Noto Sans", sans-serif;
    color: var(--text);
    overflow-x: hidden; /* horizontal scroll hidden */
    overflow-y: auto;/* vertical scroll enabled */
  }
  canvas { z-index: -1; position: fixed; }
  .content, .nav, footer { z-index: 10; position: relative; }

  .content {
    position: relative;
    z-index: 10;
    top: 0vh;
  }

a{color:inherit; text-decoration:none;}
a, button, input, textarea{ cursor: none !important; }
img{max-width:100%; display:block;}


/* ===== CUSTOM CURSOR ===== */
.cursor{position:fixed;top:0;left:0;width:8px;height:8px;background:#7c5cff;border:2px solid rgba(124,92,255,.5);border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);z-index:9999;transition:transform .15s ease-out,width .15s ease-out,height .15s ease-out;box-shadow:0 0 8px rgba(124,92,255,.5); }
.cursor-follower{position:fixed;top:0;left:0;width:30px;height:30px;border:2px solid #7c5cff;border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);z-index:9998;transition:transform .3s ease-out; animation: blink 0.7s infinite;}
@keyframes blink {0%, 50% { opacity: 1; }51%, 100% { opacity: 0; }}
.cursor.link-hover{ transform: translate(-50%, -50%) scale(2); background:#ff5c7c; } 
.cursor-follower.link-hover{ transform: translate(-50%, -50%) scale(1.5); border-color:#ff5c7c; }


/* ===== PRELOADER ===== */
#preloader{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg);display:flex;justify-content:center;align-items:center;z-index:9999;color:var(--text);flex-direction:column}
.terminal{background:rgba(0,0,0,0.85);border-radius:8px;padding:20px;width:80%;max-width:600px;height:350px;overflow:hidden;font-family:'Fira Code','Source Code Pro','Courier New',monospace;color:#00ff00a8;position:relative;z-index:1;box-shadow:inset 0 0 10px rgba(0,255,0,0.2)}
.terminal::before{content:"";position:absolute;inset:0;border-radius:8px;padding:2px;background:linear-gradient(90deg,#00ff00,#00ffaa,#580237,#2602f5,#f8f6f8);background-size:400% 400%;animation:borderMove 6s linear infinite;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;z-index:-1}
@keyframes borderMove{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.line{display:block;white-space:pre;font-size:13px;line-height:1.5em;margin:2px 0;color:#00ff00;position:relative}


/* ===== COOKIES CONSCENT ===== */
#cookie-banner{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);width:90%;max-width:480px;background:var(--card);color:var(--text);border-radius:20px;padding:22px;box-shadow:0 8px 25px rgba(0,0,0,.25);animation:slideUp .6s ease forwards;z-index:1000;text-align:center;border: 1px solid var(--muted);transition:opacity .4s ease}
#cookie-banner p{margin:0 0 14px;font-size:15px;line-height:1.4}
#cookie-banner i{margin-right:6px;color:var(--brand)}
#cookie-banner .btns{display:flex;justify-content:center;gap:12px;margin-top:10px}
#cookie-banner button{background:var(--brand);color:#fff;border:none;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:.3s;display:flex;align-items:center;gap:6px}
#cookie-banner button:hover{background:#6a40d1}
#cookie-banner #decline-cookies{background:var(--muted);color:var(--text)}
#cookie-banner #decline-cookies:hover{background:#666}
#cookie-banner .policy-link{margin-top:12px;font-size:13px}
#cookie-banner .policy-link a{color:var(--brand);font-weight:600;text-decoration:none}
#cookie-banner .policy-link a:hover{text-decoration:underline}
@keyframes slideUp{from{transform:translate(-50%,100%);opacity:0}to{transform:translate(-50%,0);opacity:1}}
@media(max-width:600px){#cookie-banner{padding:18px}#cookie-banner .btns{flex-direction:column;gap:10px}#cookie-banner button{width:100%;justify-content:center}}


/* ===== NAVBAR ===== */
.nav-wrap{position: fixed; top: 18px; left: 0; right: 0; z-index: 50; display:flex; justify-content:center; transition: all .45s ease; pointer-events:none; }
.nav{ pointer-events:auto; display:flex; align-items:center; gap:10px; padding: 10px 14px; border-radius: 999px; background: var(--glass); backdrop-filter: blur(0px) saturate(140%); border: 1px solid rgba(255,255,255,.15); box-shadow: var(--shadow); width: min(980px, calc(100% - 24px)); margin: 0 auto; transition: all .45s ease; }
.brand{ display:flex; align-items:center; gap:10px; padding:8px 12px; border-radius: 999px; font-weight: 700; letter-spacing:.2px; background: linear-gradient(90deg, var(--brand), var(--brand-2)); color:white; box-shadow: inset 0 0 0 1px rgba(255,255,255,.18); }
.brand svg{ width:18px; height:18px }
.nav ul{ list-style:none; display:flex; gap: 6px; margin:0; padding:0; }
.nav a.link{ padding:8px 12px; border-radius:10px; color: var(--text); font-weight:600; font-size: 14px; opacity:.9; border:1px solid transparent; transition:.25s }
.nav a.link:hover{ background: rgba(255,255,255,.09); border-color: rgba(255,255,255,.14); }
.nav a.active{ background: rgba(110,168,254,.18); border-color: var(--ring); box-shadow: 0 0 0 4px var(--ring); }
.nav .spacer{ flex:1 }
.cta{ display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:12px; font-weight:700; background:linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%); color:#fff; border: 1px solid rgba(255,255,255,.25); box-shadow: var(--shadow); transition:.25s }
.cta:hover{ transform: translateY(-1px); }

/* Sticky state */
.is-sticky .nav-wrap{ top:0; }
.is-sticky .nav{ border-radius: 0; width: 100%; max-width:100%; margin:0; padding: 10px clamp(12px, 3vw, 24px); background: linear-gradient(180deg, rgba(16,24,40,.85), rgba(16,24,40,.75)); backdrop-filter: blur(0px); border-bottom: 1px solid rgba(255,255,255,.08); box-shadow: 0 5px 20px rgba(0,0,0,.12); }
@media (prefers-color-scheme: dark){ 
  .is-sticky .nav{ background: linear-gradient(180deg, rgba(16,24,40,.85), rgba(16,24,40,.75)); border-bottom: 1px solid rgba(255,255,255,.08);} }

/* Mobile menu */
.menu-btn{ display:none; }
@media (max-width: 980px){ .menu-btn{ display:inline-flex; } }
.mobile-menu{ position: fixed; top:64px; left: 12px; right: 12px; background: var(--card); border:1px solid rgba(255,255,255,.15); border-radius: 16px; box-shadow: var(--shadow); display:none; padding:8px }
.mobile-menu a{ display:block; padding:12px; border-radius:12px; font-weight:600 }
.mobile-menu a:hover{ background: rgba(255,255,255,.08) }
.mobile-show{ display:block }


/* ===== HERO ===== */
.hero{ position:relative; min-height: 88vh; display:grid; place-items:center; padding: 120px 20px 60px; }
.hero-inner{ max-width: 1100px; margin:auto; display:grid; grid-template-columns: 1.1fr .9fr; align-items:center; gap: clamp(24px, 6vw, 56px); }
.kicker{ display:inline-flex; align-items:center; gap:8px; font-weight:700; color:var(--accent); background: rgba(65,209,183,.14); border:1px solid rgba(65,209,183,.35); padding:6px 10px; border-radius:999px; }
h1{ font-size: clamp(36px, 6vw, 62px); line-height:1.05; margin: 12px 0; letter-spacing:-.02em }
.lead{ color: var(--muted); font-size: clamp(16px, 1.7vw, 20px); line-height:1.6; margin: 8px 0 22px }
.btns{ display:flex; gap:12px; flex-wrap:wrap }
.btn{ display:inline-flex; align-items:center; gap:10px; padding:12px 18px; border-radius:14px; font-weight:700; border:1px solid rgba(255,255,255,.2); background: var(--card); box-shadow: var(--shadow); }
.btn.primary{ background: linear-gradient(135deg, var(--brand) 0%, var(--brand-2) 100%); color:#fff; }
.btn.ghost{ background: transparent; border-color: rgba(255,255,255,.22); }
.hero-visual{position:relative;aspect-ratio:4/3;border-radius:24px;overflow:hidden;background:linear-gradient(145deg,rgba(110,168,254,.25),rgba(124,92,255,.2));border:1px solid rgba(255,255,255,.22);box-shadow:var(--shadow);}
.hero-visual::before{content:"";position:absolute;inset:0;padding:2px;border-radius:24px;background:linear-gradient(90deg,#e94ba9,#6048cc,#2dd436,#ffffff);background-size:300% 300%;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude;pointer-events:none;animation:borderMove 1s linear infinite;}
@keyframes borderMove{0%{background-position:0% 0%;}50%{background-position:100% 0%;}100%{background-position:0% 0%;}}
.hero-grid{ position:absolute; inset:0; display:grid; grid-template-columns: repeat(7, 1fr); gap:10px; padding: 10px; }
.card{background:var(--card);border:1px solid rgba(255,255,255,.14);border-radius:18px;display:flex;flex-direction:column;align-items:center;justify-content:space-evenly;padding:14px;box-shadow:var(--shadow);flex:1;}.card > *{width:100%;}


/* ===== SECTIONS ===== */
section{ padding: 90px 20px; align-items: center; }
.container{ max-width:1100px; margin:0 auto; }
.section-head{ display:flex; align-items:end; justify-content:space-between; gap:20px; margin-bottom: 28px; }
.section-head h2{ font-size: clamp(28px, 4vw, 40px); margin:0; letter-spacing:-.01em; }
.muted{ color: var(--muted); }

.about{ display:grid; grid-template-columns: 1.2fr .8fr; gap:32px; }
.about .card{ min-height: 220px; }

.skills-grid{ display:grid; grid-template-columns: repeat(6, 1fr); gap:14px; }
.skill{ display:flex; align-items:center; justify-content:center; padding:14px; border-radius:14px; border:1px solid rgba(255,255,255,.14); background:var(--card); font-weight:700; }
.skill i {margin-right: 8px; }

/* ===== PROJECTS ===== */
.stack-container { position: relative; }

.project_card {
  position: sticky;
  top: 75px;
  margin-bottom: 60px;
  background: transparent;
  border-radius: 20px;
  overflow: hidden;
  transform: translateY(40px);
  opacity: 0;
  transition: all .6s ease-out;
  box-shadow: 0 8px 20px rgba(0,0,0,.4);
}
.project_card.visible { transform: translateY(0); opacity: 1; }
.project_card:hover { transform: translateY(-8px); box-shadow: 0 16px 30px rgba(0,0,0,.6); }

.project_card-inner { position: relative; width: 100%; height: 600px; max-height: 75vh; overflow: hidden; }
.project_card img { position: absolute; width: 100%; height: 100%; object-fit: contain; transition: transform .3s ease; }

.info { position: absolute; top: 0; width: 100%; padding: 20px; color: #fff; font-weight: 600; text-shadow: 0 2px 8px rgba(0,0,0,0.9); transition: transform .3s ease; font-size: clamp(0.9rem, 2vw, 1rem); background: linear-gradient(to bottom, rgba(0,0,0,0.6) 80%, rgba(0,0,0,0) 100%); }
.info h3 { color: var(--brand); margin: 0 0 8px; font-size: clamp(1.2rem, 2.2vw, 1.3rem); }
.info p.muted { color: var(--muted); margin:0 0 12px; font-size: clamp(1rem, 1.8vw, 1rem); }

.tags { display:flex; flex-wrap: wrap; gap:8px; }
.tag{font-size:12px;padding:6px 10px;border:1px solid rgba(255,255,255,.16);border-radius:999px;color:var(--muted);transition:all .3s ease;}
.tag:hover{background:rgba(255,255,255,.08);color:var(--text);}

.details { position:absolute; inset:0; background:rgba(19,28,46,.95); padding:16px; opacity:0; transform:translateY(20px); transition:.4s ease; overflow-y:auto; color:var(--text); font-size:clamp(0.9rem,.9vw,.95rem); border-radius:12px; display:flex; flex-direction:column; justify-content:space-evenly; }
.project_card:hover .details { opacity:1; transform:translateY(0); box-shadow:0 6px 18px rgba(0,0,0,.35); }
.details h4 { color:var(--brand); font-size:clamp(1.2rem,1.1vw,1.05rem); letter-spacing:.3px; margin:0; }
.details h4:first-child { margin-top:0; }
.details ul { margin:0 0 14px 18px; line-height:1.5; padding-left:4px; }
.details .links a { color:var(--brand); text-decoration:none; font-weight:500; margin-top:10px; display:inline-block; font-size:clamp(.9rem,.9vw,.95rem); transition:.3s; }
.details .links a:hover { text-decoration:underline; color:var(--accent); }
.metrics { margin-top:14px; font-size:.8rem; opacity:.85; font-style:italic; }
.progress { width:100%; height:6px; background:rgba(255,255,255,.15); border-radius:4px; margin-top:8px; overflow:hidden; }
.bar { height:100%; background:linear-gradient(90deg,var(--brand),var(--accent)); width:0; transition:width .6s ease; }
.project_card:hover .bar { width:80%; }

/* ===== RESPONSIVE ===== */
@media (max-width: 992px) {
  .project_card-inner { height: 500px; }
  .project_card img { position: relative; width: 100%; height: auto; top: 100px; object-fit: contain; }
  .info { padding: 15px; }
  .tag { font-size:11px; padding:5px 8px; }
}

@media (max-width: 600px) {
  .project_card { margin-bottom:40px; top:100px; }
  .project_card-inner { height: auto; min-height: 250px; }
  .project_card img { position: relative; width: 100%; height: auto; top: 100px; object-fit: contain; }
  .info { padding:12px; }
  .info h3 { font-size:1rem; }
  .info p.muted { font-size:0.85rem; }
  .details { padding:15px; font-size:0.85rem; }
  .details h4 { font-size:1rem; }
  .details .links a { font-size:0.9rem; }
  .tag { font-size:10px; padding:4px 6px; }
}


/* ===== CONTACT FORM ===== */
#contact { padding: 60px 20px; background: transparent; color: var(--text, #e6eaf2); }
#contact .section-head { text-align: center; margin-bottom: 40px; }
#contact .section-head h2 { font-size: 2rem; margin-bottom: 8px; }
#contact .section-head .muted { color: var(--muted, #9aa7c7); font-size: 0.95rem; }

/* Grid Layout */
.contact-grid { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 10px; }
.card { background: var(--card, #131c2e); padding: 10px; border-radius: 16px; box-shadow: 0 4px 20px rgba(0,0,0,0.2); }

/* Form */
form { display: flex; flex-direction: column; gap: 16px; }
.field label { display: flex; flex-direction: column; font-size: 0.90rem; font-weight: 500; margin-bottom: 6px; }
input, textarea { margin-top: 6px; padding: 10px 12px; border: 1px solid #ccc; border-radius: 8px; font-size: 0.95rem; background: var(--bg-soft); color: #faf8f8; }
textarea { resize: vertical; min-height: 100px; }
.error { display: none; font-size: 0.8rem; color: #ff6b6b; margin-top: 4px; }
button#sendBtn{background:#6c63ff;color:#fff;padding:12px 24px;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .3s ease;width:auto;display:inline-block;}
button#sendBtn:hover { background: #5848d9; }

/* Contact Info */
.contact-info div { margin-bottom: 10px; }
.contact-info strong { display: block; margin-bottom: 6px; }
.social-links { display: flex; flex-wrap: wrap; gap: 10px; }
.social-links .btn { background: #222a44; color: #fff; padding: 8px 14px; border-radius: 6px; font-size: 0.9rem; text-decoration: none; display: inline-flex; align-items: center; gap: 6px; transition: background 0.3s; }
.social-links .btn:hover { background: #6c63ff; }

/* Responsive Breakpoints */
@media (max-width: 992px) { .contact-grid { grid-template-columns: 1fr; } }
@media (max-width: 480px) { #contact { padding: 40px 16px; } input, textarea { font-size: 0.9rem; } button#sendBtn { font-size: 0.9rem; padding: 10px; } }


/* ===== Testimonials ===== */
.testimonials{background:transparent;padding:20px 20px;text-align:center;}
.testimonials h2{font-size:2rem;margin-bottom:50px;font-weight:700;color:#f1f1f1;letter-spacing:.5px;}
.testimonial-grid{position:relative;max-width:80vw;margin:0 auto;height:250px;overflow:hidden;}
.testimonial-card{background:transparent;padding:20px;text-align:center;border-radius:20px;box-shadow:inset 0 0 15px rgba(255,255,255,.15),0 8px 25px transparent;border:1px solid rgba(255,255,255,.1);transition:opacity .5s ease,transform .35s ease,box-shadow .35s ease;position:absolute;top:0;left:0;width:100%;opacity:0;display:flex;flex-direction:column;height:100%;}
.testimonial-card:hover{box-shadow:inset 0 0 25px rgba(255,255,255,.25),0 8px 25px transparent;border:1px solid rgba(255,255,255,.35);}
.testimonial-card.active{opacity:1;position:relative;}
@import url('https://fonts.googleapis.com/css2?family=Dancing+Script:wght@400;600&display=swap');
.testimonial-card p { font-size:.95rem; line-height:1.7; margin-bottom:18px; color:#e8ecf5; font-style:italic; font-family:'Dancing Script', cursive; }
.testimonial-footer{margin-top:auto;padding-top:16px;text-align:center;}
.testimonial-footer h2{margin:0 0 4px;font-size:1.1rem;font-weight:600;color:#fff;}
.testimonial-footer span{font-size:.9rem;color:#bbb;}
@media(max-width:768px){.testimonials h2{font-size:1.6rem;margin-bottom:30px;}.testimonial-grid{height:auto;}.testimonial-card{margin-bottom:20px;box-shadow:inset 0 0 10px rgba(255,255,255,.1);}}
@media(max-width:480px){.testimonials h2{font-size:1.4rem;}.testimonial-card p{font-size:.85rem;line-height:1.5;}.testimonial-footer h2{font-size:1rem;}.testimonial-footer span{font-size:.8rem;}}


/* ===== FOOTER ===== */
.footer{padding:20px 20px;background:linear-gradient(180deg,#1e0b2069,#10182856);color:var(--muted);font-family:Inter,system-ui,sans-serif;font-size:14px;}
.footer-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:25px;align-items:start;}
.footer-about h3{margin-bottom:10px;color:var(--text);font-size:16px;}
.footer-about p{line-height:1.5;font-size:14px; text-align:justify;}
.footer-links h4,.footer-contact h4,.footer-newsletter h4{margin-bottom:10px;color:var(--text);font-size:14px;}
.footer-links ul{list-style:none;padding:0;margin:0;line-height:1.7;font-size:14px;}
.footer-links ul li a{color:var(--muted);text-decoration:none;transition:color .25s;font-size:14px;}
.footer-links ul li a:hover{color:var(--brand);}
.footer-contact p{margin:4px 0;font-size:14px;}
.footer-contact a{color:var(--brand);text-decoration:none;transition:color .25s;font-size:14px;}
.footer-contact a:hover{color:var(--accent);}
.footer-newsletter p{margin-bottom:6px;font-size:14px;}
.footer-newsletter form{display:flex;gap:6px;margin-top:6px;}
.footer-newsletter input{flex:1;padding:6px 10px;border-radius:6px;border:none;background:var(--bg-soft);color:var(--text);font-size:14px;}
.footer-newsletter button{padding:6px 10px;border:none;border-radius:6px;background:var(--brand);color:#fff;font-weight:600;cursor:pointer;font-size:14px;transition:background .25s,transform .25s;}
.footer-newsletter button:hover{background:var(--accent);transform:translateY(-2px);}
.footer-bottom{margin-top:20px;border-top:1px solid rgba(255,255,255,.12);padding-top:10px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;font-size:14px;}
.footer-social a{color:var(--muted);font-size:14px;margin-left:10px;text-decoration:none;transition:color .25s,transform .25s;}
.footer-social a:hover{color:var(--brand);transform:translateY(-2px);}

/* FAQ Modal */
.modal { display:none; position:fixed; z-index:1000; inset:0; background:rgba(0,0,0,0.6); justify-content:center; align-items:center; }
.modal-content { background:var(--card); padding:20px; max-width:700px; width:90%; border-radius:12px; box-shadow:0 5px 20px rgba(0,0,0,0.3); }
.modal-content h3 { margin-bottom:15px; font-size:1.1rem; }
.faq { margin-bottom:15px; }
.faq h4 { font-size:0.8rem; margin-bottom:5px; }
.close { float:right; font-size:22px; cursor:pointer; }
.footer-faq a, .footer-Tac a {color:var(--muted);font-size:14px;margin-left:10px;text-decoration:none;transition:color .25s,transform .25s;}


/* Active link underline */
.underline{ position:relative; }
.underline::after{ content:""; position:absolute; left:10px; right:10px; bottom:6px; height:2px; background:linear-gradient(90deg, var(--brand), var(--accent)); border-radius:2px; transform: scaleX(0); transform-origin:left; transition: transform .25s ease; }
a.active .underline::after{ transform: scaleX(1); }

/* ===== RESPONSIVE ===== */
@media (max-width: 980px){
  .hero-inner { grid-template-columns: 1fr; text-align:center; }
  .hero-visual{position:relative;width:100%;max-width:600px;aspect-ratio:4/3;border-radius:24px;overflow:hidden;background:linear-gradient(145deg,rgba(110,168,254,.25),rgba(124,92,255,.2));border:1px solid rgba(255,255,255,.22);box-shadow:var(--shadow);margin:0 auto;}
  .section-head { align-items: start; flex-direction: column; }
  .about { grid-template-columns: 1fr; }
  .skills-grid { grid-template-columns: repeat(3, 1fr); }
  /* .contact-grid { grid-template-columns: 1fr; } */
  .nav ul { display: none; }
  .menu-btn{ display:inline-flex; }
}

@media (max-width: 580px){
  .skills-grid { grid-template-columns: repeat(2,1fr); }
}

@media(max-width:780px){
  .footer-container{grid-template-columns:1fr;gap:15px;padding:20px;text-align:center;}
  .footer-bottom{flex-direction:column;align-items:center;gap:10px;padding:10px 0;text-align:center;}
}
