@import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap');
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
img{-webkit-user-drag:none;-moz-user-drag:none}
:root{
  --bg:#060b14;
  --accent:#3BCABF;
  --accent2:#5BD9CF;
  --accent3:#7BE8DF;
  --text:#e2e8f0;
  --text-muted:#8899aa;
  --glass:rgba(15,25,40,.55);
  --glass-border:rgba(100,200,255,.1);
  --glass-blur:24px;
}
/* ========== LIGHT THEME ========== */
[data-theme="light"]{
  --bg:#eaf0f6;
  --text:#1a2332;
  --text-muted:#556677;
  --glass:rgba(255,255,255,.72);
  --glass-border:rgba(0,50,120,.08);
  --glass-blur:20px;
}

/* Background layers */
[data-theme="light"] body{background:#eaf0f6}
[data-theme="light"] canvas#bg{opacity:1}
[data-theme="light"] .vignette{background:radial-gradient(ellipse at 30% 20%,rgba(100,255,218,.04) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(72,177,255,.04) 0%,transparent 50%),radial-gradient(ellipse at center,transparent 50%,rgba(234,240,246,.5) 100%)}
[data-theme="light"] .noise{opacity:.015}
[data-theme="light"] .blob{opacity:.5}
[data-theme="light"] .blob-1{background:rgba(100,255,218,.15)}
[data-theme="light"] .blob-2{background:rgba(72,177,255,.12)}
[data-theme="light"] .blob-3{background:rgba(167,139,250,.1)}

/* Nav */
[data-theme="light"] .top-nav.scrolled{background:rgba(234,240,246,.88);border-bottom-color:rgba(0,50,120,.06)}
[data-theme="light"] .top-nav__link:hover,[data-theme="light"] .top-nav__link.active{background:rgba(0,80,120,.06)}
[data-theme="light"] .top-nav__settings:hover{background:rgba(0,80,120,.06)}
[data-theme="light"] .bottom-nav{background:rgba(255,255,255,.82);border-color:rgba(0,50,120,.08);box-shadow:0 4px 24px rgba(0,40,80,.1)}
[data-theme="light"] .bottom-nav__link:hover,[data-theme="light"] .bottom-nav__link.active{background:rgba(0,80,120,.06)}

/* Hero text */
[data-theme="light"] .display-name{background:linear-gradient(135deg,#0a3d50 0%,#0d6b4c 35%,#1a5a8a 65%,#5b4a9a 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:none}
[data-theme="light"] .greeting{color:#0d6b4c;opacity:1}
[data-theme="light"] .subtitle{color:#4a5a6a}
[data-theme="light"] .uname{color:#1a5a8a}
[data-theme="light"] .guild-chip{color:#556677;background:rgba(0,50,100,.04);border-color:rgba(0,50,100,.1)}
[data-theme="light"] a.guild-chip:hover{color:#0d6b4c;background:rgba(0,80,120,.06);border-color:rgba(0,80,120,.15)}

/* Avatar & status */
[data-theme="light"] .avatar-frame{border-color:rgba(0,80,120,.15);box-shadow:0 8px 30px rgba(0,40,80,.12),0 0 40px rgba(100,255,218,.08)}
[data-theme="light"] .avatar-frame--link:hover{border-color:rgba(0,80,120,.3);box-shadow:0 8px 30px rgba(0,40,80,.18),0 0 50px rgba(100,255,218,.12)}
[data-theme="light"] .avatar-glow{background:radial-gradient(circle,rgba(100,255,218,.08) 0%,transparent 70%)}
[data-theme="light"] .status-badge{background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-color:rgba(0,0,0,.1);color:#666}
[data-theme="light"] .status-badge.is-online{color:#1a8a3e;border-color:rgba(26,138,62,.3)}
[data-theme="light"] .status-badge.is-idle{color:#b87a08;border-color:rgba(184,122,8,.3)}
[data-theme="light"] .status-badge.is-dnd{color:#c43c3c;border-color:rgba(196,60,60,.3)}
[data-theme="light"] .status-badge.is-offline{color:#888;border-color:rgba(0,0,0,.1)}

/* Glass cards */
[data-theme="light"] .glass-card{background:rgba(255,255,255,.72);border-color:rgba(0,50,120,.07);box-shadow:0 2px 16px rgba(0,40,80,.06)}
[data-theme="light"] .glass-card::before{background:linear-gradient(90deg,transparent,rgba(0,80,120,.06),transparent)}
[data-theme="light"] .glass-card h3{color:#0d6b4c}
[data-theme="light"] .glass-card h3::before{background:linear-gradient(180deg,#0d6b4c,#1a5a8a)}
[data-theme="light"] .glass-card p{color:#2a3a4a;line-height:1.85}
[data-theme="light"] .glass-card p strong{color:#0d6b4c}
[data-theme="light"] .divider{background:linear-gradient(90deg,#0d6b4c,transparent)}

/* Skills */
[data-theme="light"] .skill{color:#1a5a8a;background:rgba(26,90,138,.06);border-color:rgba(26,90,138,.12)}
[data-theme="light"] .skill:hover{background:rgba(26,90,138,.12);border-color:rgba(26,90,138,.2)}

/* Activity */
[data-theme="light"] .discord-activity-text{color:#2a3a4a}
[data-theme="light"] .activity-card .meta{color:#556677}

/* Scroll hint */
[data-theme="light"] .scroll-hint span{color:#667788}
[data-theme="light"] .scroll-hint svg{stroke:#667788}

/* Road section */
[data-theme="light"] .road-section-title h2{background:linear-gradient(135deg,#0a8a5a,#0d6b4c,#1a5a8a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
[data-theme="light"] .road-timeline::before{background:rgba(0,80,120,.1)}
[data-theme="light"] .road-timeline::after{background:rgba(0,40,80,.03);border-color:rgba(0,50,100,.04)}
[data-theme="light"] .road-post::after{background:var(--accent);border-color:#eaf0f6}
[data-theme="light"] .road-card{background:rgba(255,255,255,.72);border-color:rgba(0,50,120,.07);box-shadow:0 2px 12px rgba(0,40,80,.06)}
[data-theme="light"] .road-card:hover{border-color:rgba(0,80,120,.15);box-shadow:0 8px 30px rgba(0,40,80,.1)}
[data-theme="light"] .road-card::before{background:linear-gradient(90deg,transparent,rgba(0,80,120,.06),transparent)}
[data-theme="light"] .road-card__img{filter:brightness(.95) contrast(1.02)}
[data-theme="light"] .road-card__title{color:#1a2332}
[data-theme="light"] .road-card__excerpt{color:#556677}
[data-theme="light"] .road-card__tag{color:#0d6b4c;background:rgba(13,107,76,.06);border-color:rgba(13,107,76,.12)}
[data-theme="light"] .road-card__more{color:#1a5a8a}

/* Contact section */
[data-theme="light"] .contact-section-title h2{background:linear-gradient(135deg,#0a3d50,#0d6b4c,#1a5a8a);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
[data-theme="light"] .contact-card{background:rgba(255,255,255,.72);border-color:rgba(0,50,120,.07);box-shadow:0 2px 12px rgba(0,40,80,.06)}
[data-theme="light"] .contact-card:hover{border-color:rgba(0,80,120,.15);box-shadow:0 8px 30px rgba(0,40,80,.1)}
[data-theme="light"] .contact-card::before{background:linear-gradient(90deg,transparent,rgba(0,80,120,.06),transparent)}
[data-theme="light"] .contact-card__icon--x{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.08);color:#1a2332}
[data-theme="light"] .contact-card__icon--discord{background:rgba(88,101,242,.08);border-color:rgba(88,101,242,.15)}
[data-theme="light"] .contact-card__icon--email{background:rgba(13,107,76,.06);border-color:rgba(13,107,76,.12)}
[data-theme="light"] .contact-card__label{color:#667788}
[data-theme="light"] .contact-card__value{color:#1a2332}
[data-theme="light"] .contact-card__value span{color:#1a5a8a}

/* Settings popup */
[data-theme="light"] .settings-popup__backdrop{background:rgba(0,0,0,.25)}
[data-theme="light"] .settings-popup__panel{background:rgba(255,255,255,.88);border-color:rgba(0,50,120,.08);box-shadow:0 20px 50px rgba(0,40,80,.12)}
[data-theme="light"] .settings-popup__title{color:#0d6b4c}
[data-theme="light"] .settings-label{color:#556677}
[data-theme="light"] .settings-option{color:#556677;background:rgba(0,50,100,.03);border-color:rgba(0,50,120,.1)}
[data-theme="light"] .settings-option:hover{color:#0d6b4c;border-color:rgba(13,107,76,.2);background:rgba(13,107,76,.05)}
[data-theme="light"] .settings-option.active{color:#0d6b4c;background:rgba(13,107,76,.08);border-color:rgba(13,107,76,.25)}
[data-theme="light"] .settings-accent-btn.active .settings-accent-swatch{border-color:#1a2332;box-shadow:0 0 0 1px rgba(255,255,255,.5)}

/* Back to top */
[data-theme="light"] .back-to-top{background:rgba(255,255,255,.82);border-color:rgba(0,50,120,.08)}
[data-theme="light"] .back-to-top:hover{background:rgba(13,107,76,.12);border-color:rgba(13,107,76,.2);color:#0d6b4c}

/* Loader */
[data-theme="light"] .road-loader{color:#556677}
[data-theme="light"] .road-loader .spinner{border-color:rgba(0,80,120,.1);border-top-color:var(--accent)}
body{background:var(--bg);color:var(--text);font-family:'Sora',sans-serif;overflow-x:hidden}
canvas#bg{position:fixed;top:0;left:0;z-index:0}

.vignette{position:fixed;inset:0;pointer-events:none;z-index:1;background:
  radial-gradient(ellipse at 30% 20%,rgba(100,255,218,.04) 0%,transparent 50%),
  radial-gradient(ellipse at 70% 80%,rgba(72,177,255,.03) 0%,transparent 50%),
  radial-gradient(ellipse at center,transparent 40%,rgba(6,11,20,.85) 100%)}
.noise{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ========== TOP NAV ========== */
.top-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:.8rem 2.5rem;transition:background .3s,backdrop-filter .3s}
.top-nav.scrolled{background:rgba(6,11,20,.75);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(100,200,255,.06)}
.top-nav__settings{position:absolute;top:50%;right:2.5rem;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem;border-radius:10px;transition:color .2s,background .2s}
.top-nav__settings:hover{color:var(--accent);background:rgba(100,255,218,.06)}
.top-nav__settings svg{width:20px;height:20px;display:block}
.top-nav__brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--text)}
.top-nav__avatar{width:32px;height:32px;border-radius:8px;object-fit:cover;border:1.5px solid rgba(100,255,218,.2)}
.top-nav__name{font-family:'Space Grotesk',sans-serif;font-size:.95rem;font-weight:600;background:linear-gradient(135deg,#e2f0ff,#64ffda);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.top-nav__links{display:flex;align-items:center;gap:.3rem}
.top-nav__link{color:var(--text-muted);text-decoration:none;font-size:.78rem;font-weight:500;letter-spacing:.5px;padding:.45rem .9rem;border-radius:8px;transition:color .2s,background .2s}
.top-nav__link:hover,.top-nav__link.active{color:var(--accent);background:rgba(100,255,218,.06)}
.top-nav__burger{display:none;background:none;border:none;color:var(--text);cursor:pointer;padding:.4rem}
.top-nav__burger svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2}

/* ========== SETTINGS POPUP ========== */
.settings-popup{position:fixed;inset:0;z-index:1000;pointer-events:none;opacity:0;transition:opacity .25s}
.settings-popup.is-open{pointer-events:auto;opacity:1}
.settings-popup__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);cursor:pointer}
.settings-popup__panel{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--glass);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:18px;padding:1.8rem 2rem;min-width:280px;max-width:90vw;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.settings-popup__title{font-family:'Space Grotesk',sans-serif;font-size:.9rem;font-weight:600;color:var(--accent);letter-spacing:2px;text-transform:uppercase;margin-bottom:1.5rem}
.settings-group{margin-bottom:1.4rem}
.settings-group:last-child{margin-bottom:0}
.settings-label{display:block;font-size:.7rem;color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:.5rem}
.settings-options{display:flex;flex-wrap:wrap;gap:.4rem}
.settings-option{padding:.45rem .9rem;font-size:.78rem;font-weight:500;color:var(--text-muted);background:rgba(255,255,255,.04);border:1px solid var(--glass-border);border-radius:8px;cursor:pointer;transition:all .2s}
.settings-option:hover{color:var(--accent);border-color:rgba(100,255,218,.2)}
.settings-option.active{color:var(--accent);background:rgba(100,255,218,.1);border-color:rgba(100,255,218,.25)}
.settings-accent{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-start}
.settings-accent-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:0;border:none;background:transparent;cursor:pointer;transition:transform .2s}
.settings-accent-btn:hover{transform:scale(1.05)}
.settings-accent-swatch{width:36px;height:36px;border-radius:50%;background:var(--swatch);border:2px solid transparent;transition:border-color .2s,box-shadow .2s}
.settings-accent-btn.active .settings-accent-swatch{border-color:#fff;box-shadow:0 0 0 1px rgba(0,0,0,.3)}
.settings-accent-label{font-size:.75rem;font-weight:500;color:var(--text-muted)}

/* ========== BOTTOM NAV (mobile) ========== */
.bottom-nav{display:none;position:fixed;bottom:1.2rem;left:50%;transform:translateX(-50%);z-index:99;background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:999px;padding:.4rem .6rem;gap:.2rem;box-shadow:0 8px 32px rgba(0,0,0,.3)}
.bottom-nav__link{color:var(--text-muted);text-decoration:none;font-size:.78rem;font-weight:500;padding:.5rem 1rem;border-radius:999px;transition:color .2s,background .2s}
.bottom-nav__link:hover,.bottom-nav__link.active{color:var(--accent);background:rgba(100,255,218,.08)}

@media(max-width:767px){
  .top-nav__links{display:none}
  .top-nav__burger{display:none}
  .top-nav__settings{right:1rem}
  .bottom-nav{display:flex;align-items:center;justify-content:center}
  .contact-cards{grid-template-columns:1fr}
  .contact-section{padding-bottom:calc(8rem + 70px)}
  .back-to-top{bottom:calc(1.2rem + 56px);right:1rem}
}
@media(max-width:900px){
  .top-nav__settings{right:1.5rem}
}
@media(max-width:1023px){
  .top-nav__settings{right:2rem}
}

/* ========== HERO (first viewport) ========== */
.hero-section{position:relative;z-index:2;display:flex;min-height:100vh;padding:3rem 5%;gap:3rem;align-items:center;max-width:1300px;margin:0 auto}
.col-left{flex:1.1;display:flex;flex-direction:column;align-items:flex-start}
.col-right{flex:1;display:flex;flex-direction:column;gap:1.5rem;align-items:stretch}

.avatar-wrap{position:relative;margin-bottom:2rem}
.avatar-glow{position:absolute;inset:-20px;border-radius:30px;background:radial-gradient(circle,rgba(100,255,218,.12) 0%,transparent 70%);filter:blur(20px);z-index:-1}
.avatar-frame{width:150px;height:150px;border-radius:22px;overflow:hidden;border:2px solid rgba(100,255,218,.2);box-shadow:0 8px 40px rgba(0,0,0,.5),0 0 60px rgba(100,255,218,.07)}
.avatar-frame--link{display:block;text-decoration:none;transition:border-color .2s,box-shadow .2s}
.avatar-frame--link:hover{border-color:rgba(100,255,218,.5);box-shadow:0 8px 40px rgba(0,0,0,.5),0 0 80px rgba(100,255,218,.2)}
.avatar-frame img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) saturate(1.1)}
.status-badge{position:absolute;bottom:-6px;right:-6px;background:rgba(6,11,20,.9);backdrop-filter:blur(12px);border:1.5px solid rgba(128,128,128,.5);border-radius:8px;padding:3px 10px;font-size:.62rem;color:#888;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;transition:color .3s,border-color .3s}
.status-badge.is-online{color:#3ba55d;border-color:rgba(59,165,93,.5)}
.status-badge.is-idle{color:#faa61a;border-color:rgba(250,166,26,.5)}
.status-badge.is-dnd{color:#ff6b6b;border-color:rgba(240,71,71,.5)}
.status-badge.is-offline{color:#888;border-color:rgba(128,128,128,.5)}

.greeting{font-size:.85rem;color:var(--accent);font-weight:500;margin-bottom:.5rem;letter-spacing:2px;text-transform:uppercase;opacity:.8}
.display-name{font-family:'Space Grotesk',sans-serif;font-size:3.8rem;font-weight:700;line-height:1.05;margin-bottom:.4rem;background:linear-gradient(135deg,#e2f0ff 0%,#64ffda 40%,#48b1ff 70%,#a78bfa 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 20px rgba(100,255,218,.15))}
.subtitle{font-size:1.15rem;color:var(--text-muted);margin-bottom:1.5rem;font-weight:400;letter-spacing:.5px}
.username-row{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}
.uname{color:var(--accent2);font-size:.85rem;font-weight:500;opacity:.9}
.guild-chip{color:var(--text-muted);font-size:.75rem;background:rgba(255,255,255,.04);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:3px 10px;font-weight:500;text-decoration:none;transition:color .2s,border-color .2s,background .2s}
a.guild-chip:hover{color:var(--accent);border-color:rgba(100,255,218,.3);background:rgba(100,255,218,.08)}

.glass-card{background:var(--glass);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:18px;padding:1.8rem 2rem;position:relative;overflow:hidden}
.glass-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(100,255,218,.15),rgba(72,177,255,.1),transparent)}
.glass-card h3{font-family:'Space Grotesk',sans-serif;font-size:.82rem;font-weight:600;color:var(--accent);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:1.1rem;display:flex;align-items:center;gap:.6rem}
.glass-card h3::before{content:'';display:inline-block;width:3px;height:16px;background:linear-gradient(180deg,var(--accent),var(--accent2));border-radius:2px}
.glass-card p{color:rgba(226,232,240,.7);line-height:1.85;font-size:.9rem}
.glass-card p strong{color:var(--accent);font-weight:600}

.divider{width:60px;height:2px;background:linear-gradient(90deg,var(--accent),transparent);margin:1.1rem 0;border-radius:2px;opacity:.5}

.skills{display:flex;flex-wrap:wrap;gap:.45rem}
.skill{font-size:.7rem;color:var(--accent2);background:rgba(72,177,255,.06);backdrop-filter:blur(8px);border:1px solid rgba(72,177,255,.12);border-radius:8px;padding:4px 12px;font-weight:500;transition:all .3s}
.skill:hover{background:rgba(72,177,255,.12);border-color:rgba(72,177,255,.25)}

.activity-card{display:flex;align-items:center;gap:.8rem}
.activity-card__body{min-width:0;flex:1}
.activity-card .pulse{width:8px;height:8px;border-radius:50%;background:#888;flex-shrink:0;box-shadow:0 0 12px rgba(128,128,128,.4);animation:pulse 2s ease-in-out infinite;transition:background .3s,box-shadow .3s}
.activity-card .pulse[data-status="online"]{background:#3ba55d;box-shadow:0 0 12px rgba(59,165,93,.4)}
.activity-card .pulse[data-status="idle"]{background:#faa61a;box-shadow:0 0 12px rgba(250,166,26,.4)}
.activity-card .pulse[data-status="dnd"]{background:#f04747;box-shadow:0 0 12px rgba(240,71,71,.4)}
.activity-card .pulse[data-status="offline"]{background:#888;box-shadow:0 0 12px rgba(128,128,128,.3)}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,.2)}50%{box-shadow:0 0 0 7px rgba(255,255,255,0)}}
.activity-card .meta{font-size:.65rem;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:3px}

.discord-activity-text{font-size:.82rem;color:rgba(255,255,255,.8);font-weight:500}
.discord-activity-line{position:relative;overflow:hidden;white-space:nowrap;max-width:100%}
.discord-activity-text-inner{display:inline-block}
.discord-activity-line.is-marquee .discord-activity-text-inner{animation:marquee 12s linear infinite}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

.blob{position:fixed;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:0;opacity:.35}
.blob-1{width:400px;height:400px;background:rgba(100,255,218,.08);top:10%;left:-5%}
.blob-2{width:350px;height:350px;background:rgba(72,177,255,.06);bottom:10%;right:-5%}
.blob-3{width:300px;height:300px;background:rgba(167,139,250,.05);top:50%;left:40%}

/* ========== SCROLL HINT ========== */
.scroll-hint{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:.5;animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}
.scroll-hint span{font-size:.7rem;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase}
.scroll-hint svg{width:20px;height:20px;stroke:var(--text-muted);fill:none;stroke-width:2}

/* ========== TRANSITION SPACER ========== */
.transition-spacer{height:100vh;position:relative;z-index:2}

/* ========== ROAD SECTION ========== */
.road-section{position:relative;z-index:2;padding:2rem 0 6rem}

.road-section-title{text-align:center;margin-bottom:3rem}
.road-section-title h2{font-family:'Space Grotesk',sans-serif;font-size:1.8rem;font-weight:700;background:linear-gradient(135deg,#c8f7e8,#64ffda,#48b1ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.5rem}
.road-section-title p{color:var(--text-muted);font-size:.85rem}

/* Timeline / road layout */
.road-timeline{position:relative;max-width:1000px;margin:0 auto;padding:0 2rem}
.road-timeline::before{content:'';position:absolute;left:50%;top:0;bottom:0;width:6px;background:rgba(100,255,218,.12);transform:translateX(-50%);border-radius:3px}
.road-timeline::after{content:'';position:absolute;left:50%;top:0;bottom:0;width:50px;background:rgba(15,15,30,.3);transform:translateX(-50%);border-left:1px solid rgba(255,255,255,.04);border-right:1px solid rgba(255,255,255,.04);z-index:-1;pointer-events:none}

.road-post{display:flex;align-items:flex-start;margin-bottom:3rem;position:relative;opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.road-post.visible{opacity:1;transform:translateY(0)}

.road-post:nth-child(odd){flex-direction:row;padding-right:calc(50% + 2rem)}
.road-post:nth-child(even){flex-direction:row-reverse;padding-left:calc(50% + 2rem)}

.road-post::after{content:'';position:absolute;left:50%;top:1.5rem;width:12px;height:12px;background:var(--accent);border:3px solid var(--bg);border-radius:50%;transform:translateX(-50%);box-shadow:0 0 15px rgba(100,255,218,.3);z-index:1}

.road-card{background:var(--glass);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:16px;overflow:hidden;transition:all .35s cubic-bezier(.4,0,.2,1);cursor:pointer;text-decoration:none;color:var(--text);display:block;width:100%}
.road-card:hover{border-color:rgba(100,255,218,.25);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.4)}
.road-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(100,255,218,.12),transparent)}

.road-card__img{width:100%;height:160px;object-fit:cover;display:block;filter:brightness(.85) contrast(1.05)}
.road-card__body{padding:1.2rem 1.4rem}
.road-card__title{font-family:'Space Grotesk',sans-serif;font-size:1rem;font-weight:600;color:#fff;margin-bottom:.5rem;line-height:1.3}
.road-card__excerpt{font-size:.8rem;color:var(--text-muted);line-height:1.6;margin-bottom:.8rem;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.road-card__tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.6rem}
.road-card__tag{font-size:.6rem;color:var(--accent);background:rgba(100,255,218,.06);border:1px solid rgba(100,255,218,.12);border-radius:6px;padding:2px 8px;font-weight:500}
.road-card__more{font-size:.72rem;color:var(--accent2);font-weight:600;letter-spacing:1px}

/* Loader */
.road-loader{text-align:center;padding:3rem;color:var(--text-muted);font-size:.85rem;letter-spacing:1px}
.road-loader .spinner{width:24px;height:24px;border:2px solid rgba(100,255,218,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}
@keyframes spin{to{transform:rotate(360deg)}}

/* ========== EDUCATION → PROJECTS TRANSITION ========== */
.education-projects-spacer{height:80vh;position:relative;z-index:2;min-height:400px}

/* ========== PROJECTS SECTION (index) ========== */
.projects-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;max-width:1100px;margin:0 auto;padding:0 2rem}
.projects-col{min-width:0;display:flex;flex-direction:column;gap:1rem}
.road-timeline--compact{max-width:100%;padding:0}
.road-timeline--compact::before,.road-timeline--compact::after{display:none}
.road-timeline--compact .road-post:nth-child(odd),
.road-timeline--compact .road-post:nth-child(even){flex-direction:row;padding-left:0;padding-right:0}
.road-timeline--compact .road-post::after{display:none}
.road-timeline--compact .road-card__img{height:140px}
@media(max-width:1023px){
  .projects-grid{grid-template-columns:1fr}
}

/* ========== BACK TO TOP ========== */
.back-to-top{position:fixed;bottom:2rem;right:2rem;z-index:90;width:52px;height:52px;border-radius:50%;background:var(--glass);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(12px) scale(0.9);transition:opacity .4s cubic-bezier(.4,0,.2,1),transform .4s cubic-bezier(.4,0,.2,1),visibility .4s,color .2s,background .2s,border-color .2s}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0) scale(1)}
.back-to-top:hover{color:var(--text);background:rgba(100,255,218,.15);border-color:rgba(100,255,218,.3)}
.back-to-top svg{width:24px;height:24px}

/* ========== CONTACT SECTION ========== */
.contact-spacer{height:100vh;position:relative;z-index:2}
.contact-section{position:relative;z-index:2;padding:4rem 2rem 8rem;display:flex;flex-direction:column;align-items:center}
.contact-section-title{text-align:center;margin-bottom:3rem}
.contact-section-title h2{font-family:'Space Grotesk',sans-serif;font-size:1.8rem;font-weight:700;background:linear-gradient(135deg,#e2f0ff,#64ffda,#48b1ff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.5rem}
.contact-section-title p{color:var(--text-muted);font-size:.85rem}
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:900px;width:100%}
.contact-card{min-width:0;background:var(--glass);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:18px;padding:2rem 1.8rem;position:relative;overflow:hidden;text-decoration:none;color:var(--text);transition:all .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;align-items:center;text-align:center;gap:.8rem}
.contact-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(100,255,218,.15),rgba(72,177,255,.1),transparent)}
.contact-card:hover{border-color:rgba(100,255,218,.25);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.4)}
.contact-card__icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.contact-card__icon--x{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:#fff}
.contact-card__icon--discord{background:rgba(88,101,242,.1);border:1px solid rgba(88,101,242,.2);color:#5865f2}
.contact-card__icon--email{background:rgba(100,255,218,.08);border:1px solid rgba(100,255,218,.15);color:var(--accent)}
.contact-card__label{font-size:.7rem;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;font-weight:500}
.contact-card__value{font-family:'Space Grotesk',sans-serif;font-size:1rem;font-weight:600;color:#fff}
.contact-card__value span{color:var(--accent2);font-weight:400;font-size:.85rem}

@media(max-width:1023px){
  .contact-cards{grid-template-columns:repeat(2,1fr)}
  .education-projects-spacer{height:60vh;min-height:300px}
}
@media(max-width:900px){
  .hero-section{flex-direction:column;padding:2rem;gap:2rem;text-align:center}
  .col-left{align-items:center}
  .col-right{align-items:center}
  .display-name{font-size:2.6rem}
  .avatar-frame{width:130px;height:130px}
  .road-post:nth-child(odd),.road-post:nth-child(even){flex-direction:row;padding-left:2.5rem;padding-right:0}
  .road-timeline::before{left:1rem}
  .road-post::after{left:1rem}
  .contact-cards{grid-template-columns:1fr;max-width:320px;margin:0 auto}
  .contact-card{min-height:140px}
  .contact-spacer{height:80vh}
}
