
/* ── FONT STRATEGY ──────────────────────────────────────────────────────────
   We use only system fonts so the site looks IDENTICAL whether opened via
   file://, http:// or inside Claude. No external requests needed.
   - Display (headings): "Barlow" is pre-installed on most Android devices.
     Fallback chain hits something bold & condensed on every platform.
   - Body: Roboto is the Android system font. Clean identical everywhere.
──────────────────────────────────────────────────────────────────────────── */
:root{
  --font-display: 'Barlow', 'Roboto Condensed', 'Arial Black', system-ui, sans-serif;
  --font-body:    'Roboto', 'Segoe UI', system-ui, -apple-system, sans-serif;
}

/* Compensate for system font metrics so sizes feel same as Syne */
h1,h2,h3,.hero-name,.section-title,.nav-logo,.stat-num,.project-name,.service-name,.footer-logo{
  font-stretch: normal;
  letter-spacing: -1.5px;
}

* { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

:root{
  --white:#FFFFFF;--blue-light:#5BB8F5;--blue-mid:#2E9CDB;--blue-dark:#0B72B9;
  --navy:#081828;--gray:#f0f6fc;--text-dark:#0d1b2a;--text-muted:#5a7a99;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);background:var(--white);color:var(--text-dark);overflow-x:hidden;}

/* CURSOR — desktop only */
.cursor,.cursor-ring{display:none;}
@media(pointer:fine){
  .cursor{display:block;width:10px;height:10px;background:var(--blue-light);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;mix-blend-mode:multiply;}
  .cursor-ring{display:block;width:36px;height:36px;border:1.5px solid var(--blue-mid);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transition:transform 0.18s ease;}
}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 32px;display:flex;justify-content:space-between;align-items:center;background:rgba(255,255,255,0.92);backdrop-filter:blur(14px);border-bottom:1px solid rgba(91,184,245,0.12);transition:padding 0.3s;}
nav.scrolled{padding:12px 32px;}
.nav-logo{font-family:var(--font-display);font-weight:900;font-size:1.25rem;color:var(--text-dark);text-decoration:none;letter-spacing:-0.5px;text-transform:uppercase;}
.nav-logo span{color:var(--blue-mid);}
.nav-links{display:flex;gap:28px;list-style:none;}
.nav-links a{font-size:0.88rem;font-weight:500;color:var(--text-muted);text-decoration:none;transition:color 0.2s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1.5px;background:var(--blue-light);transform:scaleX(0);transform-origin:left;transition:transform 0.25s;}
.nav-links a:hover{color:var(--blue-dark);}
.nav-links a:hover::after{transform:scaleX(1);}
.nav-lang{display:flex;gap:8px;}
.lang-btn{font-family:var(--font-body);font-size:0.78rem;font-weight:500;padding:5px 14px;border-radius:20px;border:1.5px solid rgba(91,184,245,0.3);background:transparent;color:var(--text-muted);cursor:pointer;transition:all 0.2s;}
.lang-btn.active,.lang-btn:hover{background:var(--blue-light);color:white;border-color:var(--blue-light);}
@media(max-width:700px){.nav-links{display:none;}nav{padding:16px 20px;}nav.scrolled{padding:11px 20px;}}

/* HERO */
#hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:100px 60px 60px;position:relative;overflow:hidden;gap:32px;}
.hero-bg-dots{position:absolute;inset:0;z-index:0;background-image:radial-gradient(circle,rgba(91,184,245,0.13) 1.5px,transparent 1.5px);background-size:36px 36px;animation:dotFloat 22s linear infinite;}
@keyframes dotFloat{0%{background-position:0 0;}100%{background-position:36px 36px;}}
.hero-glow{position:absolute;width:560px;height:560px;background:radial-gradient(circle,rgba(91,184,245,0.14) 0%,transparent 70%);right:-80px;top:50%;transform:translateY(-50%);pointer-events:none;}
.hero-text{position:relative;z-index:2;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(91,184,245,0.1);border:1px solid rgba(91,184,245,0.3);border-radius:30px;padding:6px 16px;font-family:var(--font-body);font-size:0.78rem;font-weight:500;color:var(--blue-dark);margin-bottom:24px;letter-spacing:0.4px;}
.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:var(--blue-light);flex-shrink:0;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1;}50%{transform:scale(1.5);opacity:0.5;}}
.hero-name{font-family:var(--font-display);font-weight:900;font-size:clamp(2.6rem,4.5vw,4.6rem);line-height:1.05;letter-spacing:-2.5px;color:var(--text-dark);margin-bottom:14px;text-transform:uppercase;}
.hero-name span{color:var(--blue-mid);}
.hero-subtitle{font-family:var(--font-display);font-weight:700;font-size:clamp(1.1rem,2vw,1.7rem);color:var(--text-muted);margin-bottom:20px;min-height:2rem;display:flex;align-items:center;gap:4px;letter-spacing:-0.5px;}
.typed-text{color:var(--blue-dark);}
.typed-cursor{display:inline-block;background:var(--blue-light);width:3px;height:1.3em;vertical-align:middle;animation:blink 1s step-end infinite;}
@keyframes blink{50%{opacity:0;}}
.hero-desc{font-family:var(--font-body);font-size:0.98rem;line-height:1.75;color:var(--text-muted);max-width:440px;margin-bottom:36px;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;}
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--blue-mid);color:white;padding:13px 30px;border-radius:50px;font-family:var(--font-body);font-weight:500;font-size:0.92rem;text-decoration:none;transition:all 0.25s;box-shadow:0 8px 26px rgba(46,156,219,0.3);border:none;cursor:pointer;}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-2px);box-shadow:0 12px 34px rgba(46,156,219,0.4);}
.btn-outline{display:inline-flex;align-items:center;gap:8px;border:1.5px solid rgba(91,184,245,0.4);color:var(--blue-dark);padding:13px 30px;border-radius:50px;font-family:var(--font-body);font-weight:500;font-size:0.92rem;text-decoration:none;transition:all 0.25s;background:transparent;cursor:pointer;}
.btn-outline:hover{background:rgba(91,184,245,0.08);border-color:var(--blue-mid);transform:translateY(-2px);}

/* 3D CANVAS */
.hero-3d{position:relative;z-index:2;height:500px;}
#heroCanvas{width:100%;height:100%;border-radius:20px;touch-action:none;}
.canvas-hint{position:absolute;bottom:16px;right:16px;font-family:var(--font-body);font-size:0.68rem;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;opacity:0.55;}
.scroll-ind{position:absolute;bottom:32px;left:60px;display:flex;align-items:center;gap:12px;z-index:2;}
.scroll-line{width:38px;height:1.5px;background:var(--blue-light);animation:slineAnim 2s ease infinite;}
@keyframes slineAnim{0%{width:18px;opacity:0.4;}50%{width:48px;opacity:1;}100%{width:18px;opacity:0.4;}}
.scroll-txt{font-family:var(--font-body);font-size:0.7rem;text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);}

@media(max-width:800px){
  #hero{grid-template-columns:1fr;padding:90px 22px 50px;gap:0;}
  .hero-3d{height:320px;margin-top:28px;}
  .scroll-ind{left:22px;bottom:18px;}
  .hero-glow{display:none;}
}

/* SECTIONS */
section{padding:90px 60px;}
@media(max-width:700px){section{padding:65px 22px;}}
.section-label{font-family:var(--font-body);font-size:0.72rem;font-weight:600;text-transform:uppercase;letter-spacing:3px;color:var(--blue-mid);margin-bottom:10px;}
.section-title{font-family:var(--font-display);font-weight:900;font-size:clamp(1.9rem,3.2vw,2.8rem);letter-spacing:-1.5px;color:var(--text-dark);margin-bottom:14px;line-height:1.1;text-transform:uppercase;}
.section-title span{color:var(--blue-mid);}
.section-line{width:44px;height:3px;background:var(--blue-light);border-radius:2px;margin-bottom:44px;}

/* ABOUT */
#about{background:var(--gray);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
@media(max-width:800px){.about-grid{grid-template-columns:1fr;gap:36px;}}
.about-desc{font-family:var(--font-body);font-size:0.97rem;line-height:1.85;color:var(--text-muted);margin-bottom:28px;}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.stat-card{background:white;border-radius:14px;padding:20px 22px;box-shadow:0 4px 18px rgba(91,184,245,0.07);border:1px solid rgba(91,184,245,0.12);transition:transform 0.25s,box-shadow 0.25s;}
.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(91,184,245,0.16);}
.stat-num{font-family:var(--font-display);font-weight:800;font-size:2.2rem;color:var(--blue-mid);line-height:1;margin-bottom:4px;}
.stat-label{font-family:var(--font-body);font-size:0.8rem;color:var(--text-muted);font-weight:500;}
.skills-list{display:flex;flex-wrap:wrap;gap:9px;margin-top:24px;}
.skill-tag{font-family:var(--font-body);padding:7px 15px;border-radius:30px;background:rgba(91,184,245,0.1);border:1px solid rgba(91,184,245,0.25);font-size:0.8rem;font-weight:500;color:var(--blue-dark);transition:all 0.2s;cursor:default;}
.skill-tag:hover{background:var(--blue-light);color:white;border-color:var(--blue-light);}

/* About 3D */
.about-3d-wrap{position:relative;border-radius:24px;overflow:hidden;box-shadow:0 18px 55px rgba(46,156,219,0.14);border:1px solid rgba(91,184,245,0.18);}
#aboutCanvas{width:100%;height:380px;display:block;}
.about-3d-labels{position:absolute;inset:0;pointer-events:none;}
.a3d-label{position:absolute;background:rgba(255,255,255,0.93);backdrop-filter:blur(8px);border:1px solid rgba(91,184,245,0.28);border-radius:10px;padding:6px 13px;font-family:var(--font-body);font-size:0.7rem;font-weight:600;color:var(--blue-dark);letter-spacing:0.4px;box-shadow:0 4px 14px rgba(91,184,245,0.1);animation:floatLbl 3s ease-in-out infinite;}
.a3d-label:nth-child(1){top:11%;left:5%;animation-delay:0s;}
.a3d-label:nth-child(2){top:9%;right:7%;animation-delay:0.6s;}
.a3d-label:nth-child(3){top:44%;left:3%;animation-delay:1.2s;}
.a3d-label:nth-child(4){bottom:17%;right:5%;animation-delay:0.9s;}
.a3d-label:nth-child(5){bottom:11%;left:9%;animation-delay:1.8s;}
@keyframes floatLbl{0%,100%{transform:translateY(0);}50%{transform:translateY(-6px);}}
.a3d-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--blue-light);margin-right:6px;vertical-align:middle;}

/* PROJECTS */
#projects{background:var(--white);}
.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:26px;margin-top:6px;}
.project-card{border-radius:18px;overflow:hidden;background:white;border:1px solid rgba(91,184,245,0.14);box-shadow:0 4px 22px rgba(11,114,185,0.06);transition:transform 0.3s,box-shadow 0.3s;}
.project-card:hover{transform:translateY(-7px);box-shadow:0 18px 44px rgba(46,156,219,0.14);}
.project-card.featured{grid-column:span 2;}
@media(max-width:700px){.project-card.featured{grid-column:span 1;}}
.project-visual{height:210px;overflow:hidden;position:relative;}
.project-card.featured .project-visual{height:260px;}
.project-visual svg{width:100%;height:100%;}
.project-badge{position:absolute;top:13px;right:13px;background:var(--blue-mid);color:white;font-family:var(--font-body);font-size:0.66rem;font-weight:600;padding:4px 11px;border-radius:20px;letter-spacing:0.4px;text-transform:uppercase;}
.project-body{padding:24px;}
.project-name{font-family:var(--font-display);font-weight:700;font-size:1.15rem;color:var(--text-dark);margin-bottom:7px;}
.project-desc{font-family:var(--font-body);font-size:0.86rem;line-height:1.65;color:var(--text-muted);margin-bottom:16px;}
.project-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px;}
.project-tag{font-family:var(--font-body);font-size:0.71rem;font-weight:500;padding:4px 10px;border-radius:20px;background:rgba(91,184,245,0.1);color:var(--blue-dark);}
.project-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.project-pdf-btn{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:0.8rem;font-weight:600;color:white;background:var(--blue-mid);padding:8px 18px;border-radius:20px;text-decoration:none;transition:all 0.2s;}
.project-pdf-btn:hover{background:var(--blue-dark);transform:translateY(-1px);box-shadow:0 6px 18px rgba(46,156,219,0.3);}
.project-link{font-family:var(--font-body);font-size:0.84rem;font-weight:500;color:var(--blue-mid);text-decoration:none;transition:gap 0.2s;display:inline-flex;align-items:center;gap:5px;}
.project-link:hover{gap:9px;}
.v2-chip{display:inline-block;margin-left:7px;background:linear-gradient(90deg,var(--blue-light),var(--blue-mid));color:white;font-size:0.58rem;font-weight:700;padding:2px 8px;border-radius:10px;vertical-align:middle;letter-spacing:0.4px;animation:shimmer 2.5s ease infinite;}
@keyframes shimmer{0%,100%{opacity:1;}50%{opacity:0.65;}}

/* SERVICES */
#services{background:var(--navy);}
#services .section-title{color:white;}
#services .section-label{color:var(--blue-light);}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:22px;}
.service-card{background:rgba(255,255,255,0.04);border:1px solid rgba(91,184,245,0.14);border-radius:18px;padding:32px 26px;transition:all 0.3s;position:relative;overflow:hidden;}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue-light),transparent);opacity:0;transition:opacity 0.3s;}
.service-card:hover{background:rgba(91,184,245,0.07);border-color:rgba(91,184,245,0.32);transform:translateY(-4px);}
.service-card:hover::before{opacity:1;}
.service-icon{font-size:2rem;margin-bottom:18px;}
.service-name{font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:white;margin-bottom:9px;}
.service-desc{font-family:var(--font-body);font-size:0.83rem;line-height:1.65;color:rgba(255,255,255,0.42);}

/* CONTACT */
#contact{background:var(--gray);}
.contact-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start;}
@media(max-width:800px){.contact-wrapper{grid-template-columns:1fr;gap:36px;}}
.contact-info p{font-family:var(--font-body);font-size:0.97rem;line-height:1.8;color:var(--text-muted);margin-bottom:36px;}
.contact-items{display:flex;flex-direction:column;gap:14px;}
.contact-item{display:flex;align-items:center;gap:14px;text-decoration:none;padding:14px 18px;border-radius:13px;border:1px solid rgba(91,184,245,0.16);background:white;transition:all 0.25s;}
.contact-item:hover{border-color:var(--blue-light);box-shadow:0 7px 25px rgba(91,184,245,0.13);transform:translateX(5px);}
.contact-icon{width:40px;height:40px;border-radius:11px;background:rgba(91,184,245,0.1);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.contact-item-label{font-family:var(--font-body);font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px;}
.contact-item-val{font-family:var(--font-body);font-weight:500;color:var(--text-dark);font-size:0.9rem;}
.contact-form{display:flex;flex-direction:column;gap:14px;}
.form-group{display:flex;flex-direction:column;gap:5px;}
.form-label{font-family:var(--font-body);font-size:0.78rem;font-weight:500;color:var(--text-muted);letter-spacing:0.3px;}
.form-input,.form-textarea{font-family:var(--font-body);padding:13px 16px;border:1.5px solid rgba(91,184,245,0.2);border-radius:11px;font-size:0.9rem;color:var(--text-dark);background:white;transition:border-color 0.2s,box-shadow 0.2s;outline:none;}
.form-input:focus,.form-textarea:focus{border-color:var(--blue-light);box-shadow:0 0 0 4px rgba(91,184,245,0.1);}
.form-textarea{min-height:125px;resize:vertical;}

/* FOOTER */
footer{background:var(--navy);padding:36px 60px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(91,184,245,0.1);}
@media(max-width:700px){footer{flex-direction:column;gap:18px;text-align:center;padding:28px 22px;}}
.footer-logo{font-family:var(--font-display);font-weight:800;font-size:1.05rem;color:white;text-decoration:none;}
.footer-logo span{color:var(--blue-light);}
.footer-copy{font-family:var(--font-body);font-size:0.77rem;color:rgba(255,255,255,0.32);}
.footer-socials{display:flex;gap:12px;}
.footer-social{width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,0.06);border:1px solid rgba(91,184,245,0.14);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.45);text-decoration:none;font-size:0.88rem;transition:all 0.2s;}
.footer-social:hover{background:var(--blue-mid);color:white;border-color:var(--blue-mid);}

/* FADE */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity 0.65s ease,transform 0.65s ease;}
.fade-up.visible{opacity:1;transform:translateY(0);}
.fade-up:nth-child(2){transition-delay:0.08s;}.fade-up:nth-child(3){transition-delay:0.16s;}.fade-up:nth-child(4){transition-delay:0.24s;}
