/* ============================================================
   ISTVAN EKES — style.css
   Design: #82FF1F neon-lime · Space Grotesk + Inter · QAVLAR-aligned
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600&display=swap');

:root {
  /* Core palette — QAVLAR brand */
  --bg:           #080c08;
  --bg-2:         #0d120d;
  --bg-card:      rgba(130,255,31,.03);
  --border:       rgba(130,255,31,.16);
  --border-soft:  rgba(130,255,31,.08);
  --border-dim:   rgba(255,255,255,.06);

  /* Accent family */
  --accent:       #82FF1F;
  --accent-dim:   rgba(130,255,31,.10);
  --accent-mid:   rgba(130,255,31,.22);
  --accent-glow:  rgba(130,255,31,.40);
  --accent-dark:  #5bcc00;
  --accent-2:     #b8ff6b;

  /* Text */
  --text:         #f0f5f0;
  --text-muted:   #7a9070;
  --text-dim:     #3d5038;

  /* Fonts */
  --font-display: 'Space Grotesk', sans-serif;
  --font-body:    'Inter', sans-serif;

  --radius:     10px;
  --radius-lg:  18px;
  --nav-h:      70px;
  --container:  1160px;
  --tr:         0.28s cubic-bezier(0.4,0,0.2,1);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

.container{max-width:var(--container);margin-inline:auto;padding-inline:clamp(1.25rem,5vw,3rem)}

/* ── Glass ── */
.glass{background:var(--bg-card);border:1px solid var(--border-soft);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}

/* ── Animate ── */
[data-animate]{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}
[data-animate].is-visible{opacity:1;transform:none}
[data-delay="100"]{transition-delay:.1s}
[data-delay="150"]{transition-delay:.15s}
[data-delay="200"]{transition-delay:.2s}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:7px;font-family:var(--font-display);font-size:.85rem;font-weight:600;letter-spacing:.01em;transition:var(--tr);white-space:nowrap}
.btn-primary{background:var(--accent);color:#080c08}
.btn-primary:hover{background:#9fff3f;box-shadow:0 0 28px var(--accent-glow);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border-dim)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn-accent{background:transparent;color:var(--accent);border:1px solid var(--accent)}
.btn-accent:hover{background:var(--accent);color:#080c08;box-shadow:0 0 22px var(--accent-glow);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--text-muted);border:1px solid var(--border-soft)}
.btn-outline:hover{color:var(--accent);border-color:var(--accent);transform:translateY(-2px)}
.btn-full{width:100%;justify-content:center}

/* ── Section helpers ── */
.section-label{font-family:var(--font-display);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:.6rem}
.section-title{font-family:var(--font-display);font-size:clamp(1.75rem,3.5vw,2.7rem);font-weight:700;line-height:1.12}
.section-header{margin-bottom:3.25rem}
.headline-accent{color:var(--accent)}
.inline-link{color:var(--accent);border-bottom:1px solid rgba(130,255,31,.25);transition:border-color var(--tr)}
.inline-link:hover{border-color:var(--accent)}

/* ═══════════════════════════════════════════════════════
   HEADER / NAV
════════════════════════════════════════════════════════ */
#header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);border-bottom:1px solid transparent;transition:background var(--tr),border-color var(--tr)}
#header.scrolled{background:rgba(8,12,8,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom-color:var(--border-soft)}
.nav{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h)}
.nav-brand{display:flex;align-items:center;gap:.75rem}
.nav-name{font-family:var(--font-display);font-weight:700;font-size:1.02rem}
.nav-badge{font-size:.65rem;color:var(--accent);background:var(--accent-dim);border:1px solid var(--border);padding:.18rem .58rem;border-radius:100px;letter-spacing:.05em}
.nav-links{display:flex;align-items:center;gap:.15rem}
.nav-link{padding:.42rem .8rem;font-size:.84rem;color:var(--text-muted);border-radius:6px;transition:var(--tr)}
.nav-link:hover{color:var(--text);background:rgba(130,255,31,.06)}
.nav-link.active{color:var(--accent);background:var(--accent-dim);position:relative}
.nav-link.active::after{content:'';position:absolute;bottom:-1px;left:.8rem;right:.8rem;height:2px;background:var(--accent);border-radius:2px;box-shadow:0 0 6px var(--accent)}
.nav-cta{display:flex;align-items:center;gap:.4rem;margin-left:.5rem;padding:.42rem .9rem;font-family:var(--font-display);font-size:.75rem;font-weight:600;color:var(--accent);border:1px solid var(--border);border-radius:7px;letter-spacing:.04em;transition:var(--tr)}
.nav-cta:hover{background:var(--accent);color:#080c08}

/* Language switcher */
.lang-switcher{display:flex;align-items:center;gap:.2rem;margin-left:.75rem;padding-left:.75rem;border-left:1px solid var(--border-soft)}
.lang-btn{display:inline-flex;align-items:center;padding:.28rem .52rem;font-family:var(--font-display);font-size:.66rem;font-weight:600;letter-spacing:.08em;color:var(--text-dim);border-radius:5px;transition:var(--tr);cursor:pointer;text-decoration:none;border:1px solid transparent}
.lang-btn:hover{color:var(--text);background:rgba(130,255,31,.07);text-decoration:none}
.lang-btn.active{color:var(--accent);background:var(--accent-dim);border-color:var(--border)}

.nav-toggle{display:none;flex-direction:column;gap:5px;padding:.5rem}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px;transition:var(--tr)}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ═══════════════════════════════════════════════════════
   COOKIE BANNER (centered modal)
════════════════════════════════════════════════════════ */
.cookie-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(4px);z-index:9998;opacity:0;pointer-events:none;transition:opacity .4s ease}
.cookie-banner{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.92);z-index:9999;width:min(460px,calc(100vw - 2rem));opacity:0;pointer-events:none;transition:opacity .4s ease,transform .4s ease}
.cookie-banner.show,.cookie-overlay.show{opacity:1;pointer-events:all}
.cookie-banner.show{transform:translate(-50%,-50%) scale(1)}
.cookie-box{border-radius:var(--radius-lg);padding:2rem 2rem 1.75rem;border-color:var(--border);text-align:center}
.cookie-icon{font-size:1.9rem;margin-bottom:.7rem;color:var(--accent)}
.cookie-box h3{font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin-bottom:.5rem}
.cookie-box p{font-size:.86rem;color:var(--text-muted);line-height:1.65;margin-bottom:.7rem}
.cookie-box a{color:var(--accent);font-size:.8rem;display:inline-block;margin-bottom:1.2rem}
.cookie-btns{display:flex;gap:.7rem;justify-content:center}
.btn-cookie-accept,.btn-cookie-decline{padding:.6rem 1.3rem;border-radius:7px;font-family:var(--font-display);font-size:.8rem;font-weight:700;cursor:pointer;transition:var(--tr)}
.btn-cookie-accept{background:var(--accent);color:#080c08}
.btn-cookie-accept:hover{background:#9fff3f;box-shadow:0 0 18px var(--accent-glow)}
.btn-cookie-decline{background:transparent;color:var(--text-muted);border:1px solid var(--border-dim)}
.btn-cookie-decline:hover{color:var(--text);border-color:rgba(255,255,255,.18)}

/* ═══════════════════════════════════════════════════════
   BACK TO TOP (bottom-left)
════════════════════════════════════════════════════════ */
.back-to-top{position:fixed;bottom:1.75rem;left:1.75rem;z-index:90;width:44px;height:44px;border-radius:50%;background:rgba(130,255,31,.08);border:1px solid var(--border);color:var(--accent);font-size:.88rem;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .32s,transform .32s,background var(--tr),box-shadow var(--tr)}
.back-to-top.visible{opacity:1;pointer-events:all;transform:none}
.back-to-top:hover{background:var(--accent);color:#080c08;box-shadow:0 0 18px var(--accent-glow)}

/* ═══════════════════════════════════════════════════════
   FLOATING CONTACT FAB (bottom-right)
════════════════════════════════════════════════════════ */
.fab-overlay{position:fixed;inset:0;z-index:88;opacity:0;pointer-events:none;transition:opacity .3s}
.fab-overlay.visible{opacity:1;pointer-events:all}
.fab-wrap{position:fixed;bottom:1.75rem;right:1.75rem;z-index:89;display:flex;flex-direction:column;align-items:flex-end;gap:.6rem}
.fab-menu{display:flex;flex-direction:column;align-items:flex-end;gap:.55rem;opacity:0;pointer-events:none;transform:translateY(14px);transition:opacity .28s ease,transform .28s ease}
.fab-menu.open{opacity:1;pointer-events:all;transform:none}
.fab-item{display:flex;align-items:center;gap:.6rem;text-decoration:none;transition:transform var(--tr)}
.fab-item:hover{transform:translateX(-4px)}
.fab-label{font-family:var(--font-display);font-size:.73rem;font-weight:600;background:rgba(8,12,8,.96);border:1px solid var(--border-dim);padding:.32rem .75rem;border-radius:100px;color:var(--text);white-space:nowrap;backdrop-filter:blur(12px)}
.fab-icon{width:40px;height:40px;border-radius:50%;background:var(--bg-2);border:1px solid var(--border-dim);display:flex;align-items:center;justify-content:center;font-size:.95rem;color:var(--accent);transition:var(--tr);flex-shrink:0}
.fab-item:hover .fab-icon{background:var(--accent);color:#080c08;border-color:var(--accent);box-shadow:0 0 14px var(--accent-glow)}
.fab-icon--wa{color:#25d366}.fab-item:hover .fab-icon--wa{background:#25d366;border-color:#25d366;box-shadow:0 0 14px rgba(37,211,102,.4);color:#fff}
.fab-icon--li{color:#0a66c2}.fab-item:hover .fab-icon--li{background:#0a66c2;border-color:#0a66c2;box-shadow:0 0 14px rgba(10,102,194,.4);color:#fff}
.fab-main{width:52px;height:52px;border-radius:50%;background:var(--accent);color:#080c08;font-size:1.15rem;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px var(--accent-glow);transition:var(--tr);flex-shrink:0}
.fab-main:hover{background:#9fff3f;transform:scale(1.07)}
.fab-main.open{background:#9fff3f}
.fab-icon-close{display:none}
.fab-main.open .fab-icon-open{display:none}
.fab-main.open .fab-icon-close{display:block}

/* ═══════════════════════════════════════════════════════
   HERO
════════════════════════════════════════════════════════ */
.hero{position:relative;min-height:100svh;padding-top:var(--nav-h);display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(130,255,31,.04) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(130,255,31,.04) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 0%,transparent 80%)}
.hero-glow{position:absolute;border-radius:50%;filter:blur(110px);pointer-events:none}
.glow-1{width:560px;height:560px;background:rgba(130,255,31,.07);top:-80px;right:-80px}
.glow-2{width:380px;height:380px;background:rgba(130,255,31,.04);bottom:0;left:5%}
.glow-3{width:650px;height:450px;background:rgba(130,255,31,.06);top:50%;left:50%;transform:translate(-50%,-50%)}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;padding-top:4rem;padding-bottom:5rem}
.hero-eyebrow{display:flex;align-items:center;gap:.55rem;font-size:.72rem;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.4rem}
.eyebrow-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:pulse 2s infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}
.hero-headline{font-family:var(--font-display);font-size:clamp(2.4rem,5.5vw,4.2rem);font-weight:700;line-height:1.06;letter-spacing:-.03em;margin-bottom:1.4rem}
.hero-sub{font-size:.97rem;color:var(--text-muted);max-width:500px;line-height:1.75;margin-bottom:2.2rem}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:2.4rem}
.hero-tags{display:flex;flex-wrap:wrap;gap:.45rem}
.tag{font-size:.68rem;font-family:var(--font-display);letter-spacing:.06em;color:var(--text-dim);border:1px solid var(--border-soft);padding:.2rem .62rem;border-radius:100px;transition:var(--tr)}
.tag:hover{color:var(--accent);border-color:var(--border)}
.hero-photo{position:relative;display:flex;justify-content:center}
.photo-frame{position:relative;width:100%;max-width:420px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);box-shadow:0 0 50px rgba(130,255,31,.07);min-height:520px;background:var(--bg-2)}
.photo-frame img{width:100%;height:100%;object-fit:cover;object-position:center top}
.photo-overlay{position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to top,var(--bg) 0%,transparent 100%)}
.photo-stat{position:absolute;background:rgba(8,12,8,.94);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);padding:.7rem 1rem;display:flex;flex-direction:column}
.stat-1{top:2rem;left:-2.5rem}
.stat-2{bottom:3rem;right:-2rem}
.stat-num{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--accent)}
.stat-label{font-size:.65rem;color:var(--text-muted);margin-top:.1rem}
.scroll-hint{position:absolute;bottom:2.25rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.45rem;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim)}
.scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,var(--accent),transparent);animation:scrollDown 1.8s ease-in-out infinite}
@keyframes scrollDown{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ═══════════════════════════════════════════════════════
   STATS BAR
════════════════════════════════════════════════════════ */
.stats-bar{padding:0;background:var(--bg-2);border-top:1px solid var(--border-soft);border-bottom:1px solid var(--border-soft)}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{padding:2.25rem 1rem;text-align:center;position:relative;transition:background var(--tr)}
.stat-item:not(:last-child)::after{content:'';position:absolute;top:20%;right:0;height:60%;width:1px;background:var(--border-soft)}
.stat-item:hover{background:rgba(130,255,31,.03)}
.stat-big{font-family:var(--font-display);font-size:clamp(1.9rem,3.8vw,2.9rem);font-weight:700;line-height:1;color:var(--accent);text-shadow:0 0 30px var(--accent-glow);margin-bottom:.38rem;display:block}
.stat-desc{font-size:.76rem;color:var(--text-muted);line-height:1.4;display:block;letter-spacing:.02em}

@media(max-width:640px){
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat-item:nth-child(2)::after,.stat-item:nth-child(3)::after{display:none}
  .stat-item:nth-child(even){border-left:1px solid var(--border-soft)}
  .stats-inner .stat-item:nth-child(3),.stats-inner .stat-item:nth-child(4){border-top:1px solid var(--border-soft)}
}

/* ═══════════════════════════════════════════════════════
   WHY
════════════════════════════════════════════════════════ */
.why{padding:6rem 0;background:var(--bg)}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.why-card{border-radius:var(--radius-lg);padding:1.9rem;transition:var(--tr)}
.why-card:hover{transform:translateY(-3px);border-color:var(--border)}
.why-icon{width:42px;height:42px;border-radius:9px;background:var(--accent-dim);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.05rem;color:var(--accent);margin-bottom:1.2rem}
.why-card h3{font-family:var(--font-display);font-size:1rem;font-weight:600;margin-bottom:.5rem}
.why-card p{font-size:.86rem;color:var(--text-muted);line-height:1.7}

/* ═══════════════════════════════════════════════════════
   SERVICES
════════════════════════════════════════════════════════ */
.services{padding:7rem 0;background:var(--bg-2)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.service-card{border-radius:var(--radius-lg);padding:1.9rem;transition:var(--tr);position:relative;overflow:hidden;display:flex;flex-direction:column}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(130,255,31,.25),transparent);opacity:0;transition:opacity var(--tr)}
.service-card:hover{transform:translateY(-3px);border-color:var(--border);box-shadow:0 16px 44px rgba(0,0,0,.35)}
.service-card:hover::before{opacity:1}
.service-card--cta{border-color:rgba(130,255,31,.14)}
.service-icon{width:42px;height:42px;border-radius:9px;background:var(--accent-dim);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.05rem;color:var(--accent);margin-bottom:1.2rem;flex-shrink:0}
.service-card h3{font-family:var(--font-display);font-size:.97rem;font-weight:600;margin-bottom:.65rem}
.service-card p{font-size:.84rem;color:var(--text-muted);line-height:1.7;margin-bottom:1rem;flex:1}
.service-list{padding-left:0;margin:0}
.service-list li{font-size:.77rem;color:var(--text-dim);padding:.26rem 0 .26rem 1rem;border-bottom:1px solid var(--border-soft);position:relative}
.service-list li::before{content:'→';position:absolute;left:0;color:var(--accent);font-size:.7rem}
.service-list li:last-child{border-bottom:none}

/* ═══════════════════════════════════════════════════════
   PORTFOLIO
════════════════════════════════════════════════════════ */
.work{padding:7rem 0;background:var(--bg)}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.work-card{border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-2);border:1px solid var(--border-dim);transition:var(--tr)}
.work-card:hover{transform:translateY(-5px);border-color:var(--border);box-shadow:0 20px 52px rgba(0,0,0,.4)}
.work-img-placeholder{width:100%;height:165px;display:flex;align-items:center;justify-content:center;font-size:2.3rem;color:rgba(130,255,31,.2)}
.work-body{padding:1.4rem}
.work-client{font-size:.66rem;font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:.42rem}
.work-card h3{font-family:var(--font-display);font-size:.93rem;font-weight:600;margin-bottom:.65rem;line-height:1.3}
.work-card p{font-size:.82rem;color:var(--text-muted);line-height:1.65;margin-bottom:.85rem}
.work-stack{display:flex;flex-wrap:wrap;gap:.38rem;margin-bottom:.85rem}
.work-stack span{font-size:.64rem;color:var(--text-muted);background:rgba(130,255,31,.05);border:1px solid var(--border-soft);border-radius:4px;padding:.13rem .46rem}
.work-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.76rem;font-family:var(--font-display);font-weight:600;color:var(--accent);transition:gap var(--tr)}
.work-link:hover{gap:.7rem}

/* ═══════════════════════════════════════════════════════
   ENGAGEMENT PATHS
════════════════════════════════════════════════════════ */
.engage{padding:7rem 0;background:var(--bg-2)}
.paths-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.path-card{border-radius:var(--radius-lg);padding:2.4rem;transition:var(--tr);position:relative;overflow:hidden;display:flex;flex-direction:column}
.path-card::after{content:'';position:absolute;inset:0;border-radius:var(--radius-lg);border:1px solid var(--border-soft);pointer-events:none;transition:border-color var(--tr)}
.path-card:hover::after{border-color:var(--border)}
.path-card:hover{transform:translateY(-3px);box-shadow:0 18px 50px rgba(0,0,0,.3)}
.path-card--personal{border-color:var(--border)}
.path-card--personal::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}
.path-card--qavlar::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent-dark),transparent)}
.path-icon{width:46px;height:46px;border-radius:10px;background:var(--accent-dim);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.15rem;color:var(--accent);margin-bottom:1.4rem}
.path-icon--accent{background:rgba(130,255,31,.15);border-color:var(--accent)}
.path-tag{display:inline-block;font-size:.62rem;font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);background:rgba(255,255,255,.04);border:1px solid var(--border-soft);border-radius:100px;padding:.18rem .65rem;margin-bottom:.65rem}
.path-tag--accent{color:var(--accent);background:var(--accent-dim);border-color:var(--border)}
.path-subtitle{font-size:.78rem;color:var(--text-muted);margin-bottom:.5rem;font-style:italic}
.path-card h3{font-family:var(--font-display);font-size:1.35rem;font-weight:700;margin-bottom:1rem}
.path-card>p{color:var(--text-muted);font-size:.88rem;line-height:1.72;margin-bottom:1.5rem}
.path-cap-label{font-size:.62rem;font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);margin-bottom:.65rem}
.path-list{margin-bottom:2rem;flex:1}
.path-list li{display:flex;align-items:flex-start;gap:.55rem;font-size:.86rem;color:var(--text-muted);padding:.32rem 0;border-bottom:1px solid var(--border-soft)}
.path-list li:last-child{border-bottom:none}
.path-list i{color:var(--accent);font-size:.66rem;margin-top:.35rem;flex-shrink:0}

/* ═══════════════════════════════════════════════════════
   ABOUT
════════════════════════════════════════════════════════ */
.about{padding:7rem 0;background:var(--bg)}
.about-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;margin-bottom:4rem}
.about-lead{font-size:1.02rem;color:var(--text);line-height:1.7;margin-bottom:1rem}
.about-content p{font-size:.88rem;color:var(--text-muted);line-height:1.75;margin-bottom:.85rem}
.about-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin:1.65rem 0 2.2rem}
.philosophy{margin-top:.5rem}
.philosophy-title{font-family:var(--font-display);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:1.2rem}
.philosophy-items{display:flex;flex-direction:column;gap:1.05rem}
.phil-item{display:flex;gap:.95rem;align-items:flex-start}
.phil-item>i{color:var(--accent);font-size:.8rem;margin-top:.28rem;flex-shrink:0;width:18px;text-align:center}
.phil-item strong{display:block;font-family:var(--font-display);font-size:.84rem;font-weight:600;margin-bottom:.2rem}
.phil-item p{font-size:.79rem;color:var(--text-muted);line-height:1.6;margin:0}
.about-right{display:flex;flex-direction:column}
.timeline-title{font-family:var(--font-display);font-size:.66rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:1.4rem}
.timeline{position:relative}
.timeline-item{display:grid;grid-template-columns:12px 1fr;gap:.95rem;margin-bottom:1.65rem;position:relative}
.timeline-item:not(:last-child)::after{content:'';position:absolute;left:5px;top:20px;bottom:-1.65rem;width:1px;background:linear-gradient(to bottom,rgba(130,255,31,.25),transparent)}
.timeline-dot{width:12px;height:12px;border-radius:50%;background:var(--accent);border:2px solid var(--bg);box-shadow:0 0 8px var(--accent-glow);margin-top:4px;flex-shrink:0}
.timeline-dot--edu{background:var(--accent-2);box-shadow:0 0 8px rgba(184,255,107,.4)}
.timeline-period{font-size:.66rem;color:var(--accent);font-family:var(--font-display);letter-spacing:.08em;display:block;margin-bottom:.28rem}
.timeline-body h4{font-family:var(--font-display);font-size:.9rem;font-weight:600;margin-bottom:.18rem}
.timeline-org{font-size:.74rem;color:var(--text-muted);margin-bottom:.5rem}
.timeline-list{padding-left:1rem;list-style:disc}
.timeline-list li{font-size:.76rem;color:var(--text-dim);line-height:1.6;margin-bottom:.18rem}
.timeline-note{font-size:.75rem;color:var(--text-dim);line-height:1.6;font-style:italic}

/* Skills */
.skills-section{border-top:1px solid var(--border-soft);padding-top:3rem}
.skills-title{font-family:var(--font-display);font-size:.66rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:1.4rem}
.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.95rem}
.skill-group{border-radius:var(--radius);padding:1.2rem;transition:var(--tr)}
.skill-group:hover{border-color:var(--border);transform:translateY(-2px)}
.skill-group-label{font-size:.65rem;font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:.7rem;display:flex;align-items:center;gap:.38rem}
.skill-group-label i{color:var(--accent)}
.skill-tags{display:flex;flex-wrap:wrap;gap:.38rem}
.skill-tags span{font-size:.68rem;color:var(--text-muted);border:1px solid var(--border-soft);border-radius:4px;padding:.18rem .5rem;transition:var(--tr)}
.skill-tags span:hover{color:var(--accent);border-color:var(--border)}

/* ═══════════════════════════════════════════════════════
   CONNECT
════════════════════════════════════════════════════════ */
.connect{padding:8rem 0;text-align:center;position:relative;overflow:hidden;background:var(--bg-2)}
.connect-bg{position:absolute;inset:0;pointer-events:none}
.connect-inner{position:relative}
.connect-headline{font-family:var(--font-display);font-size:clamp(1.9rem,4vw,3rem);font-weight:700;letter-spacing:-.03em;line-height:1.12;margin-bottom:1.1rem}
.connect-sub{max-width:520px;margin:0 auto 3.25rem;color:var(--text-muted);font-size:.95rem;line-height:1.75}
.connect-options{display:flex;flex-direction:column;gap:.9rem;max-width:580px;margin:0 auto;text-align:left}
.connect-option{display:flex;align-items:center;gap:1.2rem;padding:1.15rem 1.4rem;border-radius:var(--radius);transition:var(--tr)}
.connect-option:hover{border-color:var(--border);background:rgba(130,255,31,.04);transform:translateX(5px)}
.connect-option>i:first-child{font-size:1.25rem;color:var(--accent);width:26px;text-align:center;flex-shrink:0}
.connect-option>div{flex:1}
.connect-option strong{display:block;font-family:var(--font-display);font-weight:600;margin-bottom:.18rem;font-size:.92rem}
.connect-option span{font-size:.79rem;color:var(--text-muted)}
.connect-arrow{color:var(--text-dim);font-size:.8rem;transition:var(--tr)}
.connect-option:hover .connect-arrow{color:var(--accent)}

/* ═══════════════════════════════════════════════════════
   FOOTER
════════════════════════════════════════════════════════ */
.footer{border-top:1px solid var(--border-soft);background:var(--bg)}
.footer-inner{display:grid;grid-template-columns:1fr auto;align-items:start;gap:3rem;padding-top:3rem;padding-bottom:2.5rem}
.footer-brand .nav-name{font-size:1.1rem;display:block;margin-bottom:.4rem}
.footer-brand p{font-size:.77rem;color:var(--text-dim);margin-top:.3rem;max-width:360px;line-height:1.6}
.footer-nav-links{display:flex;flex-wrap:wrap;gap:1.1rem;margin-top:1.4rem}
.footer-nav-links a{font-size:.79rem;color:var(--text-muted);transition:color var(--tr)}
.footer-nav-links a:hover{color:var(--accent)}

/* Trust badges */
.footer-badges{display:grid;grid-template-columns:repeat(2,1fr);gap:.65rem;width:340px}
.badge{display:flex;align-items:center;gap:.65rem;padding:.7rem .85rem;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border-soft);transition:var(--tr)}
.badge:hover{border-color:var(--border);background:rgba(130,255,31,.04)}
.badge-icon{width:30px;height:30px;border-radius:7px;background:var(--accent-dim);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.82rem;color:var(--accent);flex-shrink:0}
.badge-text strong{display:block;font-family:var(--font-display);font-size:.72rem;font-weight:600;color:var(--text);line-height:1.2}
.badge-text span{display:block;font-size:.64rem;color:var(--text-muted);line-height:1.3}

.footer-bottom{border-top:1px solid var(--border-soft);padding:1.2rem 0;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-bottom p{font-size:.72rem;color:var(--text-dim)}
.footer-bottom-links{display:flex;gap:1.25rem}
.footer-bottom-links a{font-size:.72rem;color:var(--text-dim);transition:color var(--tr)}
.footer-bottom-links a:hover{color:var(--accent)}

/* ═══════════════════════════════════════════════════════
   404 PAGE
════════════════════════════════════════════════════════ */
.page-404{min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;position:relative;overflow:hidden}
.page-404 .hero-bg{position:absolute;inset:0;pointer-events:none}
.err-code{font-family:var(--font-display);font-size:clamp(8rem,20vw,14rem);font-weight:700;line-height:1;color:rgba(130,255,31,.12);letter-spacing:-.05em;margin-bottom:-.5rem;user-select:none}
.err-title{font-family:var(--font-display);font-size:clamp(1.4rem,3vw,2rem);font-weight:700;margin-bottom:1rem}
.err-sub{color:var(--text-muted);font-size:.93rem;max-width:400px;line-height:1.75;margin:0 auto 2.5rem}
.err-actions{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════════ */
@media(max-width:1100px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .work-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .skills-grid{grid-template-columns:repeat(2,1fr)}
  .footer-badges{grid-template-columns:repeat(2,1fr);width:auto}
}
@media(max-width:860px){
  .hero-inner{grid-template-columns:1fr;gap:3rem;text-align:center;padding-top:3rem}
  .hero-content{order:2}
  .hero-photo{order:1}
  .hero-sub{margin-inline:auto}
  .hero-actions,.hero-tags{justify-content:center}
  .photo-frame{max-width:280px;min-height:340px}
  .stat-1{left:-.5rem}
  .stat-2{right:-.5rem}
  .paths-grid{grid-template-columns:1fr}
  .about-inner{grid-template-columns:1fr;gap:3rem}
  .services-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .work-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .footer-badges{grid-template-columns:repeat(2,1fr);width:100%}
  .nav-toggle{display:flex}
  .nav-links{position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(8,12,8,.97);backdrop-filter:blur(20px);flex-direction:column;align-items:flex-start;padding:1.5rem;gap:.35rem;border-bottom:1px solid var(--border-soft);transform:translateY(-120%);transition:transform var(--tr);z-index:99}
  .nav-links.open{transform:translateY(0)}
  .nav-link{padding:.72rem 1rem;width:100%}
  .nav-cta{margin-left:0;width:100%;justify-content:center;margin-top:.25rem}
  .lang-switcher{margin-left:0;padding-left:0;border-left:none;padding-top:.7rem;border-top:1px solid var(--border-soft);width:100%;justify-content:flex-start}
}
@media(max-width:600px){
  .skills-grid{grid-template-columns:1fr}
  .about-actions{flex-direction:column}
  .hero-headline{font-size:1.9rem}
  .back-to-top{bottom:5.5rem}
  .fab-wrap{bottom:1.5rem;right:1.5rem}
  .footer-badges{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:.5rem}
}

/* ═══════════════════════════════════════════════════════
   ANIMATION SYSTEM — FANCY LAYER
════════════════════════════════════════════════════════ */

/* ── Scroll progress bar ── */
#scroll-progress {
  position: fixed; top: 0; left: 0; height: 2px; z-index: 999;
  background: linear-gradient(90deg, var(--accent), var(--accent-2), var(--accent));
  background-size: 200% 100%;
  width: 0%;
  transition: width .1s linear;
  box-shadow: 0 0 10px var(--accent-glow), 0 0 20px var(--accent-glow);
  animation: shimmer-bar 3s linear infinite;
}
@keyframes shimmer-bar {
  0%  { background-position: 0% 0% }
  100%{ background-position: 200% 0% }
}

/* ── Particle canvas ── */
#particle-canvas {
  position: fixed; inset: 0; z-index: 0;
  pointer-events: none; opacity: .55;
}

/* ── Custom cursor ── */
#cursor-dot {
  position: fixed; width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent); pointer-events: none; z-index: 9999;
  transform: translate(-50%,-50%);
  transition: transform .08s, background .2s, width .2s, height .2s;
  box-shadow: 0 0 10px var(--accent-glow);
}
#cursor-ring {
  position: fixed; width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid rgba(130,255,31,.5); pointer-events: none; z-index: 9998;
  transform: translate(-50%,-50%);
  transition: transform .18s cubic-bezier(.17,.67,.35,1.1), width .2s, height .2s, opacity .2s, border-color .2s;
}
body.cursor-hover #cursor-dot { width: 12px; height: 12px; }
body.cursor-hover #cursor-ring {
  width: 52px; height: 52px;
  border-color: var(--accent);
  box-shadow: 0 0 14px var(--accent-glow);
}
@media (hover: none) { #cursor-dot, #cursor-ring { display: none; } }

/* ── Hero headline scramble + reveal ── */
.hero-headline .char {
  display: inline-block;
  opacity: 0;
  transform: translateY(40px) rotate(4deg);
  transition: opacity .5s ease, transform .5s cubic-bezier(.17,.67,.35,1.2);
}
.hero-headline .char.revealed {
  opacity: 1;
  transform: none;
}
.hero-headline .line-accent .char { color: var(--accent); }

/* ── Glitch on nav name hover ── */
.nav-name {
  position: relative; cursor: default;
}
.nav-name::before,
.nav-name::after {
  content: attr(data-text);
  position: absolute; top: 0; left: 0;
  opacity: 0; pointer-events: none;
}
.nav-name:hover::before {
  opacity: .7; color: var(--accent);
  animation: glitch-a .35s steps(2) infinite;
  clip-path: polygon(0 0, 100% 0, 100% 45%, 0 45%);
}
.nav-name:hover::after {
  opacity: .5; color: #ff4f4f;
  animation: glitch-b .35s steps(2) infinite .05s;
  clip-path: polygon(0 55%, 100% 55%, 100% 100%, 0 100%);
}
@keyframes glitch-a { 0%,100%{transform:translate(0)} 33%{transform:translate(-3px,1px)} 66%{transform:translate(3px,-1px)} }
@keyframes glitch-b { 0%,100%{transform:translate(0)} 33%{transform:translate(3px,-1px)} 66%{transform:translate(-3px,1px)} }

/* ── Section entrance — stagger + blur ── */
[data-animate] {
  filter: blur(6px);
  transition: opacity .7s ease, transform .7s ease, filter .7s ease;
}
[data-animate].is-visible { filter: blur(0); }

/* ── Card magnetic tilt ── */
.why-card, .service-card, .work-card, .path-card, .badge {
  transform-style: preserve-3d;
  will-change: transform;
}
.card-shine {
  position: absolute; inset: 0; border-radius: inherit;
  background: radial-gradient(circle at var(--mx,50%) var(--my,50%),
    rgba(130,255,31,.08) 0%, transparent 60%);
  pointer-events: none; opacity: 0;
  transition: opacity .3s;
  z-index: 1;
}
.why-card:hover .card-shine,
.service-card:hover .card-shine,
.work-card:hover .card-shine,
.path-card:hover .card-shine,
.badge:hover .card-shine { opacity: 1; }

/* ── Stat numbers glow pulse ── */
.stat-big {
  animation: stat-glow 3s ease-in-out infinite;
}
@keyframes stat-glow {
  0%,100%{ text-shadow: 0 0 20px rgba(130,255,31,.3); }
  50%    { text-shadow: 0 0 40px rgba(130,255,31,.7), 0 0 80px rgba(130,255,31,.3); }
}

/* ── Skill tags wave on hover ── */
.skill-tags span {
  transition: color .2s, border-color .2s, transform .2s, box-shadow .2s;
}
.skill-tags span:hover {
  transform: translateY(-4px) scale(1.08);
  box-shadow: 0 6px 18px rgba(130,255,31,.2);
  border-color: var(--accent);
  color: var(--accent);
}

/* ── Timeline dots pulse ── */
.timeline-dot {
  animation: dot-pulse 2.5s ease-in-out infinite;
}
@keyframes dot-pulse {
  0%,100%{ box-shadow: 0 0 6px var(--accent-glow); }
  50%    { box-shadow: 0 0 16px var(--accent-glow), 0 0 32px rgba(130,255,31,.2); }
}

/* ── Hero eyebrow dot breathing ── */
.eyebrow-dot {
  animation: eyebrow-breathe 2.2s ease-in-out infinite;
}
@keyframes eyebrow-breathe {
  0%,100%{ transform:scale(1);   box-shadow: 0 0 8px var(--accent); }
  50%    { transform:scale(1.5); box-shadow: 0 0 18px var(--accent), 0 0 36px rgba(130,255,31,.3); }
}

/* ── Hero photo frame scan line ── */
.photo-frame::before {
  content: '';
  position: absolute; top: -100%; left: 0; right: 0; height: 30%;
  background: linear-gradient(to bottom, transparent, rgba(130,255,31,.04), transparent);
  z-index: 2; pointer-events: none;
  animation: scan 4s linear infinite;
}
@keyframes scan { 0%{top:-30%} 100%{top:130%} }

/* ── Floating hero tags drift ── */
.hero-tags .tag {
  animation: tag-float var(--dur,3s) ease-in-out infinite var(--delay,0s);
}
@keyframes tag-float {
  0%,100%{ transform: translateY(0); }
  50%    { transform: translateY(-5px); }
}

/* ── Section label shimmer ── */
.section-label {
  background: linear-gradient(90deg, var(--accent) 0%, var(--accent-2) 50%, var(--accent) 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: label-shimmer 3s linear infinite;
  display: inline-block;
}
@keyframes label-shimmer { to { background-position: 200% center; } }

/* ── Nav link underline slide ── */
.nav-link::before {
  content: '';
  position: absolute; bottom: 0; left: 50%; right: 50%;
  height: 1px; background: var(--accent);
  transition: left .25s ease, right .25s ease;
}
.nav-link:hover::before { left: .8rem; right: .8rem; }
.nav-link { position: relative; overflow: hidden; }

/* ── Connect options slide-in ── */
.connect-option {
  transition: transform .25s ease, border-color .25s, background .25s, box-shadow .25s;
}
.connect-option:hover {
  box-shadow: 4px 0 0 0 var(--accent) inset, 0 8px 32px rgba(130,255,31,.08);
}

/* ── Badge icon spin on hover ── */
.badge:hover .badge-icon i {
  animation: icon-spin .5s ease forwards;
}
@keyframes icon-spin {
  0%  { transform: rotate(0) scale(1); }
  50% { transform: rotate(15deg) scale(1.2); }
  100%{ transform: rotate(0) scale(1); }
}

/* ── Scroll hint pulse ── */
.scroll-line {
  animation: scrollDown 1.8s ease-in-out infinite, line-glow 2s ease-in-out infinite;
}
@keyframes line-glow {
  0%,100%{ box-shadow: none; }
  50%    { box-shadow: 0 0 8px var(--accent); }
}

/* ── Path card entrance stagger ── */
.path-card { transition: transform .28s, box-shadow .28s; }

/* ── Work cards image overlay animate ── */
.work-img-placeholder i {
  transition: transform .4s cubic-bezier(.17,.67,.35,1.3), color .3s;
}
.work-card:hover .work-img-placeholder i {
  transform: scale(1.3) rotate(-6deg);
  color: var(--accent);
}

/* ── Footer badge entrance ── */
.footer-badges .badge {
  opacity: 0; transform: translateY(16px);
  transition: opacity .5s ease, transform .5s ease;
}
.footer-badges .badge.badge-visible {
  opacity: 1; transform: none;
}

/* ── Hero glow orbs slow drift ── */
.glow-1 { animation: orb-drift-1 12s ease-in-out infinite; }
.glow-2 { animation: orb-drift-2 15s ease-in-out infinite; }
.glow-3 { animation: orb-drift-3 18s ease-in-out infinite; }
@keyframes orb-drift-1 {
  0%,100%{ transform: translate(0,0) scale(1); }
  33%    { transform: translate(-40px,30px) scale(1.05); }
  66%    { transform: translate(30px,-20px) scale(.95); }
}
@keyframes orb-drift-2 {
  0%,100%{ transform: translate(0,0) scale(1); }
  50%    { transform: translate(50px,-40px) scale(1.08); }
}
@keyframes orb-drift-3 {
  0%,100%{ transform: translate(-50%,-50%) scale(1); }
  40%    { transform: translate(calc(-50% + 30px), calc(-50% - 20px)) scale(1.04); }
  70%    { transform: translate(calc(-50% - 20px), calc(-50% + 15px)) scale(.97); }
}

/* ═══════════════════════════════════════════════════════
   ANIMATION POLISH — additions for animations.js v2
════════════════════════════════════════════════════════ */

/* Header smooth transition for auto-hide */
#header { transition: transform .35s cubic-bezier(.4,0,.2,1), background var(--tr), border-color var(--tr); }

/* Section background number */
.section-bg-num {
  position: absolute;
  top: 50%; right: -0.05em;
  transform: translateY(-50%);
  font-family: var(--font-display);
  font-size: clamp(8rem, 18vw, 16rem);
  font-weight: 700;
  line-height: 1;
  color: rgba(130,255,31,.03);
  pointer-events: none;
  user-select: none;
  z-index: 0;
  letter-spacing: -.05em;
}
section { position: relative; }

/* Card bg pulse (work cards) */
@keyframes card-bg-pulse {
  0%,100% { opacity: 1; }
  50%      { opacity: .5; }
}

/* Badge icon bounce */
@keyframes icon-bounce {
  0%,100% { transform: rotate(0) scale(1); }
  20%     { transform: rotate(-12deg) scale(1.2); }
  40%     { transform: rotate(8deg) scale(1.1); }
  60%     { transform: rotate(-5deg) scale(1.05); }
  80%     { transform: rotate(3deg) scale(1.02); }
}

/* Cursor dot — reset transform on load */
#cursor-dot { transform: translate(-50%,-50%); transition: transform .15s ease, width .2s, height .2s; }

/* Enhanced card-shine for tilt */
.card-shine {
  position: absolute; inset: 0; border-radius: inherit;
  background: radial-gradient(
    circle at var(--mx,50%) var(--my,50%),
    rgba(130,255,31,.10) 0%, transparent 55%
  );
  pointer-events: none; opacity: 0;
  transition: opacity .3s;
  z-index: 1;
}
.why-card:hover .card-shine,
.service-card:hover .card-shine,
.work-card:hover .card-shine,
.path-card:hover .card-shine { opacity: 1; }

/* Hero headline char — improved spring */
.hero-headline .char {
  display: inline-block;
  opacity: 0;
  transform: translateY(44px) rotate(5deg);
  transition: opacity .55s cubic-bezier(.22,1,.36,1),
              transform .55s cubic-bezier(.22,1,.36,1);
  will-change: opacity, transform;
}
.hero-headline .char.revealed { opacity: 1; transform: none; }
.hero-headline .line-accent.char { color: var(--accent); }

/* Scroll progress bar — brighter */
#scroll-progress {
  position: fixed; top: 0; left: 0; height: 3px; z-index: 9999;
  background: linear-gradient(90deg, #82FF1F 0%, #b8ff6b 50%, #82FF1F 100%);
  background-size: 200% 100%;
  width: 0%;
  box-shadow: 0 0 12px rgba(130,255,31,.7), 0 0 24px rgba(130,255,31,.3);
  animation: shimmer-bar 2.5s linear infinite;
}

/* Particle canvas z layering */
#particle-canvas { position: fixed; inset: 0; z-index: 0; pointer-events: none; opacity: .5; }

/* Cursor dot + ring — crisp positioning */
#cursor-dot {
  position: fixed; width: 8px; height: 8px; border-radius: 50%;
  background: #82FF1F; pointer-events: none; z-index: 9999;
  left: -20px; top: -20px;
  box-shadow: 0 0 10px rgba(130,255,31,.8);
  will-change: left, top;
}
#cursor-ring {
  position: fixed; width: 36px; height: 36px; border-radius: 50%;
  border: 1.5px solid rgba(130,255,31,.45); pointer-events: none; z-index: 9998;
  left: -20px; top: -20px;
  will-change: left, top;
}
body.cursor-hover #cursor-dot  { width: 14px; height: 14px; background: #b8ff6b; }
body.cursor-hover #cursor-ring { width: 54px; height: 54px; border-color: rgba(130,255,31,.8); box-shadow: 0 0 18px rgba(130,255,31,.25); }
@media (hover: none) { #cursor-dot, #cursor-ring { display: none; } }

/* Nav typewriter cursor */
.nav-name { display: inline-block; }

/* Why/service/work section z-index fix for bg-num */
.why-grid, .services-grid, .work-grid, .paths-grid,
.about-inner, .connect-inner, .footer-inner { position: relative; z-index: 1; }
