/* ================================================
   DALEYORK — Premium Software Company Website
   Ultra Dark Luxury Theme with 3D Animations
================================================ */

:root {
  --black: #050508;
  --dark: #0a0a12;
  --dark2: #0f0f1a;
  --dark3: #141421;
  --glass: rgba(255,255,255,0.04);
  --glass-border: rgba(255,255,255,0.08);
  --orange: #ff6b00;
  --orange-light: #ff9500;
  --orange-glow: rgba(255,107,0,0.3);
  --blue: #3b82f6;
  --blue-light: #60a5fa;
  --blue-glow: rgba(59,130,246,0.3);
  --white: #ffffff;
  --gray: #a0a0b0;
  --gray2: #6b6b80;
  --font: 'Sora', sans-serif;
  --mono: 'Space Mono', monospace;
  --shadow: 0 25px 80px rgba(0,0,0,0.6);
  --shadow-orange: 0 0 40px rgba(255,107,0,0.2);
  --radius: 16px;
  --radius-lg: 24px;
  --transition: all 0.4s cubic-bezier(0.23, 1, 0.32, 1);
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);background:var(--black);color:var(--white);overflow-x:hidden;line-height:1.6}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}
button{cursor:pointer;border:none;background:none;font-family:var(--font)}
input,select,textarea{font-family:var(--font)}

/* SCROLLBAR */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--dark)}
::-webkit-scrollbar-thumb{background:var(--orange);border-radius:2px}

/* SELECTION */
::selection{background:var(--orange);color:white}

/* PARTICLES CANVAS */
#particleCanvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:0.6}

/* CURSOR */
.cursor{width:12px;height:12px;background:var(--orange);border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width 0.3s,height 0.3s,background 0.3s;mix-blend-mode:screen}
.cursor-follower{width:36px;height:36px;border:1px solid rgba(255,107,0,0.5);border-radius:50%;position:fixed;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all 0.12s linear}

/* PAGE LOADER */
.page-loader{position:fixed;inset:0;z-index:10000;background:var(--black);display:flex;align-items:center;justify-content:center;flex-direction:column;transition:opacity 0.8s ease,visibility 0.8s ease}
.page-loader.hidden{opacity:0;visibility:hidden}
.loader-logo{display:flex;flex-direction:column;align-items:center;gap:32px}
.loader-bar{width:200px;height:2px;background:rgba(255,255,255,0.1);border-radius:2px;overflow:hidden}
.loader-progress{height:100%;width:0;background:linear-gradient(90deg,var(--orange),var(--blue));border-radius:2px;animation:loadProgress 1.8s ease forwards}
@keyframes loadProgress{to{width:100%}}

/* CONTAINER */
.container{max-width:1280px;margin:0 auto;padding:0 24px;position:relative;z-index:2}

/* SECTION */
.section{padding:120px 0;position:relative;overflow:hidden}

/* SECTION LABELS */
.section-label{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:16px;display:inline-block}
.section-title{font-size:clamp(2rem,4vw,3rem);font-weight:800;line-height:1.15;letter-spacing:-0.03em;margin-bottom:20px}
.section-sub{font-size:1.1rem;color:var(--gray);max-width:600px;margin-bottom:60px}
.text-center{text-align:center}
.text-center .section-sub,.text-center .section-label{margin-left:auto;margin-right:auto;display:block}

/* GRADIENT TEXT */
.gradient-text{background:linear-gradient(135deg,var(--orange),var(--orange-light),var(--blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* GLASS CARDS */
.glass-card{background:var(--glass);border:1px solid var(--glass-border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-lg);padding:32px;transition:var(--transition)}
.glass-card:hover{border-color:rgba(255,107,0,0.2);box-shadow:0 20px 60px rgba(0,0,0,0.5),0 0 30px rgba(255,107,0,0.05);transform:translateY(-4px)}

/* REVEAL ANIMATIONS */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.8s cubic-bezier(0.23,1,0.32,1),transform 0.8s cubic-bezier(0.23,1,0.32,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* BUTTONS */
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--orange),var(--orange-light));color:white;padding:16px 32px;border-radius:50px;font-weight:700;font-size:1rem;transition:var(--transition);position:relative;overflow:hidden}
.btn-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--blue),#60a5fa);opacity:0;transition:opacity 0.4s}
.btn-primary:hover::before{opacity:1}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 50px rgba(255,107,0,0.4)}
.btn-primary span,.btn-primary svg{position:relative;z-index:1}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;background:transparent;color:white;padding:15px 32px;border-radius:50px;font-weight:600;font-size:1rem;border:1px solid var(--glass-border);transition:var(--transition)}
.btn-ghost:hover{border-color:var(--orange);background:rgba(255,107,0,0.1);transform:translateY(-2px)}

/* ================================
   NAVBAR
================================ */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0;transition:var(--transition)}
.navbar.scrolled{background:rgba(5,5,8,0.95);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-bottom:1px solid var(--glass-border);padding:14px 0}
.nav-container{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;align-items:center;gap:40px}
.nav-logo{flex-shrink:0}
.logo-svg svg{height:36px;width:auto}
.nav-links{display:flex;align-items:center;gap:4px;margin-left:auto}
.nav-link{padding:8px 16px;border-radius:8px;font-size:0.9rem;font-weight:500;color:var(--gray);transition:var(--transition)}
.nav-link:hover,.nav-link.active{color:white;background:rgba(255,255,255,0.06)}
.nav-cta{background:linear-gradient(135deg,var(--orange),var(--orange-light));color:white;padding:10px 24px;border-radius:50px;font-weight:700;font-size:0.9rem;transition:var(--transition);flex-shrink:0}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,107,0,0.4)}
.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;border-radius:8px;background:var(--glass);border:1px solid var(--glass-border)}
.hamburger span{display:block;width:22px;height:2px;background:white;border-radius:2px;transition:var(--transition)}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ================================
   HERO SECTION
================================ */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:stretch;justify-content:center;position:relative;overflow:hidden;padding:120px 0 80px}
.hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,107,0,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,107,0,0.04) 1px,transparent 1px);background-size:60px 60px;z-index:0;mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black,transparent)}
.hero-orb{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none}
.orb1{width:600px;height:600px;background:radial-gradient(circle,rgba(255,107,0,0.15),transparent);top:-100px;right:-100px;animation:orbFloat1 8s ease-in-out infinite}
.orb2{width:400px;height:400px;background:radial-gradient(circle,rgba(59,130,246,0.12),transparent);bottom:-100px;left:-100px;animation:orbFloat2 10s ease-in-out infinite}
.orb3{width:300px;height:300px;background:radial-gradient(circle,rgba(255,107,0,0.08),transparent);top:50%;left:40%;animation:orbFloat3 12s ease-in-out infinite}
@keyframes orbFloat1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-30px,40px) scale(1.05)}}
@keyframes orbFloat2{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-30px)}}
@keyframes orbFloat3{0%,100%{transform:translate(0,0)}50%{transform:translate(-20px,20px)}}
.hero-container{max-width:1280px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,107,0,0.1);border:1px solid rgba(255,107,0,0.3);border-radius:50px;padding:6px 16px;font-size:0.85rem;font-weight:600;color:var(--orange-light);margin-bottom:24px}
.badge-dot{width:8px;height:8px;background:var(--orange);border-radius:50%;animation:pulseDot 2s ease-in-out infinite}
@keyframes pulseDot{0%,100%{box-shadow:0 0 0 0 rgba(255,107,0,0.6)}50%{box-shadow:0 0 0 6px rgba(255,107,0,0)}}
.hero-title{font-size:clamp(2.5rem,5.5vw,4.2rem);font-weight:800;line-height:1.1;letter-spacing:-0.04em;margin-bottom:24px}
.hero-sub{font-size:1.15rem;color:var(--gray);line-height:1.8;margin-bottom:40px;max-width:520px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:60px}
.hero-stats{display:flex;align-items:center;gap:32px}
.stat{text-align:left}
.stat-num{font-size:2rem;font-weight:800;color:var(--orange)}
.stat span:last-of-type{font-size:1.5rem;font-weight:700;color:var(--orange)}
.stat p{font-size:0.8rem;color:var(--gray);margin-top:2px;font-family:var(--mono)}
.stat-divider{width:1px;height:40px;background:var(--glass-border)}

/* HERO 3D SCENE */
.hero-visual{display:flex;align-items:center;justify-content:center}
.hero-3d-scene{width:480px;height:480px;position:relative;display:flex;align-items:center;justify-content:center}
.hero-glow-center{position:absolute;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(255,107,0,0.3),transparent);animation:glowPulse 3s ease-in-out infinite}
@keyframes glowPulse{0%,100%{transform:scale(1);opacity:0.7}50%{transform:scale(1.3);opacity:1}}

/* CUBE */
.cube-wrapper{width:120px;height:120px;perspective:800px;position:relative;z-index:3}
.cube{width:100%;height:100%;position:relative;transform-style:preserve-3d;animation:rotateCube 10s linear infinite}
@keyframes rotateCube{from{transform:rotateX(25deg) rotateY(0deg)}to{transform:rotateX(25deg) rotateY(360deg)}}
.cube-face{position:absolute;width:120px;height:120px;border:2px solid rgba(255,107,0,0.4);background:rgba(255,107,0,0.05);display:flex;align-items:center;justify-content:center}
.cube-face.front {transform:translateZ(60px);border-color:rgba(255,107,0,0.6);background:rgba(255,107,0,0.08)}
.cube-face.back  {transform:rotateY(180deg) translateZ(60px)}
.cube-face.left  {transform:rotateY(-90deg) translateZ(60px);border-color:rgba(59,130,246,0.4)}
.cube-face.right {transform:rotateY(90deg) translateZ(60px);border-color:rgba(59,130,246,0.4)}
.cube-face.top   {transform:rotateX(90deg) translateZ(60px)}
.cube-face.bottom{transform:rotateX(-90deg) translateZ(60px)}
.cube-face::after{content:'';position:absolute;inset:6px;border:1px solid rgba(255,255,255,0.1)}

/* ORBIT RINGS */
.orbit-ring{position:absolute;border-radius:50%;border:1px solid;display:flex;align-items:flex-start;justify-content:center}
.ring1{width:240px;height:240px;border-color:rgba(255,107,0,0.2);animation:orbitRing 6s linear infinite}
.ring2{width:340px;height:340px;border-color:rgba(59,130,246,0.15);animation:orbitRing 10s linear infinite reverse}
.ring3{width:430px;height:430px;border-color:rgba(255,107,0,0.08);animation:orbitRing 15s linear infinite}
@keyframes orbitRing{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.orbit-dot{width:12px;height:12px;border-radius:50%;margin-top:-6px}
.dot1{background:var(--orange);box-shadow:0 0 15px var(--orange)}
.dot2{background:var(--blue);box-shadow:0 0 15px var(--blue)}
.dot3{background:var(--orange-light);box-shadow:0 0 10px var(--orange-light)}

/* FLOATING CHIPS */
.floating-chip{position:absolute;background:var(--glass);border:1px solid var(--glass-border);border-radius:30px;padding:8px 16px;font-size:0.8rem;font-weight:700;font-family:var(--mono);color:var(--white);backdrop-filter:blur(10px)}
.chip1{top:60px;left:20px;animation:chipFloat 4s ease-in-out infinite;color:var(--orange);border-color:rgba(255,107,0,0.3)}
.chip2{top:80px;right:30px;animation:chipFloat 5s ease-in-out infinite 1s;color:var(--blue-light);border-color:rgba(59,130,246,0.3)}
.chip3{bottom:80px;left:30px;animation:chipFloat 4.5s ease-in-out infinite 0.5s}
.chip4{bottom:60px;right:20px;animation:chipFloat 6s ease-in-out infinite 1.5s;color:var(--orange-light);border-color:rgba(255,149,0,0.3)}
@keyframes chipFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* SCROLL HINT */
.hero-scroll-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,var(--orange),transparent);animation:scrollLine 2s ease-in-out infinite}
@keyframes scrollLine{0%,100%{opacity:1;height:50px}50%{opacity:0.4;height:30px}}
.hero-scroll-hint span{font-size:0.7rem;font-family:var(--mono);letter-spacing:2px;color:var(--gray2);text-transform:uppercase}

/* ================================
   TICKER
================================ */
.ticker-wrap{background:rgba(255,107,0,0.06);border-top:1px solid rgba(255,107,0,0.15);border-bottom:1px solid rgba(255,107,0,0.15);overflow:hidden;padding:16px 0;position:relative;z-index:2}
.ticker{display:flex;gap:0;animation:ticker 30s linear infinite;width:max-content}
.ticker span{white-space:nowrap;padding:0 24px;font-family:var(--mono);font-size:0.8rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--gray)}
.ticker-dot{color:var(--orange) !important;padding:0 8px !important}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ================================
   ABOUT SECTION
================================ */
.about{background:var(--dark)}
.about-orb{position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(59,130,246,0.06),transparent);border-radius:50%;top:-100px;right:-100px;pointer-events:none}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;margin-bottom:80px}
.about-text{color:var(--gray);line-height:1.9;margin-bottom:24px;font-size:1.05rem}
.about-pillars{display:flex;flex-direction:column;gap:20px;margin-top:32px}
.pillar{display:flex;gap:16px;align-items:flex-start;padding:20px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius)}
.pillar-icon{font-size:1.5rem;flex-shrink:0}
.pillar strong{display:block;font-size:1rem;font-weight:700;margin-bottom:4px;color:white}
.pillar p{font-size:0.9rem;color:var(--gray);line-height:1.6}
.about-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.about-card{padding:24px;text-align:center}
.about-card-icon{font-size:2rem;margin-bottom:12px}
.about-card h3{font-size:1rem;font-weight:700;margin-bottom:8px}
.about-card p{font-size:0.85rem;color:var(--gray);line-height:1.6}
.accent-border{border-color:rgba(255,107,0,0.2) !important}

/* TIMELINE */
.timeline-wrap{text-align:center}
.timeline-heading{font-size:1.5rem;font-weight:700;margin-bottom:48px;color:var(--gray)}
.timeline{display:flex;align-items:flex-start;gap:0;position:relative;overflow-x:auto;padding-bottom:16px}
.timeline::before{content:'';position:absolute;top:24px;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,rgba(255,107,0,0.4),rgba(59,130,246,0.4),transparent)}
.timeline-item{flex:1;min-width:180px;display:flex;flex-direction:column;align-items:center;gap:16px;padding:0 12px}
.timeline-year{font-family:var(--mono);font-size:0.85rem;font-weight:700;color:var(--orange)}
.timeline-dot{width:14px;height:14px;border-radius:50%;background:var(--dark2);border:2px solid rgba(255,107,0,0.4);position:relative;z-index:1;flex-shrink:0}
.active-dot{background:var(--orange);border-color:var(--orange);box-shadow:0 0 20px var(--orange)}
.timeline-content{padding:20px;text-align:left}
.timeline-content h4{font-size:0.95rem;font-weight:700;margin-bottom:6px}
.timeline-content p{font-size:0.8rem;color:var(--gray);line-height:1.6}
.active-card{border-color:rgba(255,107,0,0.3) !important}

/* ================================
   SERVICES
================================ */
.services{background:var(--dark2)}
.services-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 40% at 50% 0%,rgba(255,107,0,0.04),transparent)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}
.service-card{position:relative;cursor:pointer;overflow:hidden;transition:var(--transition)}
.service-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,107,0,0.06),transparent);opacity:0;transition:opacity 0.4s;border-radius:var(--radius-lg)}
.service-card:hover::before{opacity:1}
.service-card:hover{transform:translateY(-8px);border-color:rgba(255,107,0,0.25);box-shadow:0 30px 80px rgba(0,0,0,0.5),0 0 50px rgba(255,107,0,0.08)}
.service-icon-wrap{width:56px;height:56px;background:linear-gradient(135deg,rgba(255,107,0,0.15),rgba(59,130,246,0.1));border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:var(--transition)}
.service-card:hover .service-icon-wrap{transform:scale(1.1) rotate(-5deg)}
.service-icon{font-size:1.6rem}
.service-card h3{font-size:1.1rem;font-weight:700;margin-bottom:10px}
.service-card p{font-size:0.88rem;color:var(--gray);line-height:1.7;margin-bottom:20px}
.service-tags{display:flex;flex-wrap:wrap;gap:6px}
.service-tags span{font-size:0.72rem;font-family:var(--mono);background:rgba(255,255,255,0.06);border:1px solid var(--glass-border);border-radius:20px;padding:3px 10px;color:var(--gray)}
.service-arrow{position:absolute;top:28px;right:28px;font-size:1.2rem;color:var(--orange);opacity:0;transform:translateX(-8px);transition:var(--transition)}
.service-card:hover .service-arrow{opacity:1;transform:translateX(0)}
.service-badge{position:absolute;top:-1px;right:20px;background:linear-gradient(135deg,var(--orange),var(--orange-light));color:white;font-size:0.7rem;font-weight:700;padding:4px 12px;border-radius:0 0 8px 8px;font-family:var(--mono);letter-spacing:1px}
.featured-service{border-color:rgba(255,107,0,0.2) !important}

/* ================================
   WHY CHOOSE US
================================ */
.why{background:var(--dark)}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.why-card{text-align:center;padding:32px 24px}
.why-icon{font-size:2.2rem;margin-bottom:16px;display:block}
.why-card h3{font-size:1rem;font-weight:700;margin-bottom:8px}
.why-card p{font-size:0.85rem;color:var(--gray);line-height:1.7}
.why-card:hover .why-icon{animation:bounce 0.6s ease}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* ================================
   TECH STACK
================================ */
.tech{background:var(--dark2)}
.tech-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(59,130,246,0.04),transparent)}
.tech-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.tech-item{display:flex;flex-direction:column;align-items:center;gap:12px;padding:28px 16px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);cursor:default;transition:var(--transition);position:relative;overflow:hidden}
.tech-item::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 100%,color-mix(in srgb,var(--glow,#ff6b00) 15%,transparent),transparent);opacity:0;transition:opacity 0.4s}
.tech-item:hover::before{opacity:1}
.tech-item:hover{border-color:var(--glow,rgba(255,107,0,0.3));transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,0.4),0 0 20px color-mix(in srgb,var(--glow,#ff6b00) 20%,transparent)}
.tech-logo{font-size:2rem}
.tech-item span{font-size:0.8rem;font-family:var(--mono);font-weight:700;color:var(--gray);transition:color 0.3s}
.tech-item:hover span{color:white}

/* ================================
   PORTFOLIO
================================ */
.portfolio{background:var(--dark)}
.portfolio-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:48px}
.filter-btn{background:var(--glass);border:1px solid var(--glass-border);color:var(--gray);padding:8px 20px;border-radius:30px;font-size:0.85rem;font-weight:600;transition:var(--transition);font-family:var(--font)}
.filter-btn.active,.filter-btn:hover{background:linear-gradient(135deg,var(--orange),var(--orange-light));color:white;border-color:transparent}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.portfolio-card{overflow:hidden;padding:0;transition:var(--transition)}
.portfolio-card:hover{transform:translateY(-8px);border-color:rgba(255,107,0,0.2);box-shadow:var(--shadow)}
.portfolio-thumb{height:220px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.portfolio-info{padding:24px}
.portfolio-cat{font-size:0.72rem;font-family:var(--mono);font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px}
.web-cat{color:#3b82f6}
.mobile-cat{color:var(--orange)}
.ai-cat{color:#10b981}
.erp-cat{color:#8b5cf6}
.portfolio-info h3{font-size:1.1rem;font-weight:700;margin-bottom:8px}
.portfolio-info p{font-size:0.85rem;color:var(--gray);line-height:1.6;margin-bottom:16px}
.portfolio-tags{display:flex;gap:6px;flex-wrap:wrap}
.portfolio-tags span{font-size:0.72rem;font-family:var(--mono);background:rgba(255,255,255,0.05);border:1px solid var(--glass-border);border-radius:20px;padding:3px 10px;color:var(--gray)}
.featured-card{grid-row:span 2}
.featured-card .portfolio-thumb{height:100%;min-height:300px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}

/* PORTFOLIO PREVIEWS */
.portfolio-3d-preview{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}
.browser-bar{display:flex;gap:6px;position:absolute;top:16px;left:16px}
.browser-bar span{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.3)}
.browser-bar span:first-child{background:#ff5f57}
.browser-bar span:nth-child(2){background:#ffbd2e}
.browser-bar span:nth-child(3){background:#28c840}
.browser-content{width:80%;height:70%;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:10px;margin-top:20px}
.bc-line{height:8px;border-radius:4px;background:rgba(255,255,255,0.08)}
.l1{width:70%}
.l2{width:50%}
.bc-grid{display:flex;gap:8px;margin-top:6px}
.bc-block{flex:1;height:50px;background:rgba(255,107,0,0.08);border:1px solid rgba(255,107,0,0.15);border-radius:6px}
.phone-frame{width:80px;height:150px;border:2px solid rgba(255,255,255,0.15);border-radius:20px;padding:8px;display:flex;flex-direction:column;background:rgba(255,255,255,0.02)}
.phone-screen{flex:1;background:rgba(255,107,0,0.05);border-radius:12px;padding:8px;display:flex;flex-direction:column;gap:6px}
.ps-bar{height:6px;background:rgba(255,107,0,0.3);border-radius:3px}
.ps-card{flex:1;background:rgba(255,107,0,0.08);border-radius:6px;border:1px solid rgba(255,107,0,0.15)}
.ps-stats{display:flex;gap:4px}
.ps-stats div{flex:1;height:20px;background:rgba(59,130,246,0.1);border-radius:4px}
.ai-nodes{width:200px;height:150px;position:relative}
.ai-node{position:absolute;width:18px;height:18px;border-radius:50%;animation:aiPulse 2s ease-in-out infinite}
.n1{top:20px;left:30px;background:var(--orange);animation-delay:0s;box-shadow:0 0 15px var(--orange)}
.n2{top:20px;right:30px;background:var(--blue);animation-delay:0.5s;box-shadow:0 0 15px var(--blue)}
.n3{bottom:20px;left:50%;transform:translateX(-50%);background:var(--orange-light);animation-delay:1s;box-shadow:0 0 15px var(--orange-light)}
.ai-lines{position:absolute;inset:0}
@keyframes aiPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.4)}}
.erp-bars{display:flex;align-items:flex-end;gap:8px;height:120px;padding:0 20px}
.erp-bar{width:28px;border-radius:4px 4px 0 0;background:linear-gradient(to top,var(--orange),rgba(255,107,0,0.3));animation:erp-grow 2s ease-in-out infinite alternate}
.b1{height:40%;animation-delay:0s}
.b2{height:70%;animation-delay:0.2s}
.b3{height:55%;animation-delay:0.4s}
.b4{height:90%;animation-delay:0.6s}
.b5{height:65%;animation-delay:0.8s}
@keyframes erp-grow{from{opacity:0.5}to{opacity:1}}
.ecom-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:16px}
.ecom-item{height:60px;border-radius:8px;background:rgba(255,107,0,0.08);border:1px solid rgba(255,107,0,0.12);transition:all 0.3s}
.ei1{animation:ecomShimmer 3s ease-in-out infinite}
.ei2{animation:ecomShimmer 3s ease-in-out infinite 0.5s}
.ei3{animation:ecomShimmer 3s ease-in-out infinite 1s}
.ei4{animation:ecomShimmer 3s ease-in-out infinite 1.5s}
@keyframes ecomShimmer{0%,100%{opacity:0.5}50%{opacity:1;border-color:rgba(255,107,0,0.4)}}
.map-dots{width:200px;height:150px;position:relative}
.map-dot{position:absolute;width:14px;height:14px;border-radius:50%;animation:mapPing 2s ease-in-out infinite}
.md1{top:40%;left:25%;background:var(--orange);animation-delay:0s}
.md2{top:60%;left:50%;background:var(--blue);animation-delay:0.7s}
.md3{top:33%;left:75%;background:var(--orange-light);animation-delay:1.4s}
.map-lines{position:absolute;inset:0}
@keyframes mapPing{0%,100%{box-shadow:0 0 0 0 currentColor;opacity:1}70%{box-shadow:0 0 0 10px transparent;opacity:0.7}}

/* ================================
   STATS
================================ */
.stats{background:var(--dark2);text-align:center}
.stats-orb{position:absolute;width:600px;height:300px;background:radial-gradient(ellipse,rgba(255,107,0,0.06),transparent);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.stat-block{display:flex;flex-direction:column;align-items:center;gap:16px}
.stat-circle{position:relative;width:120px;height:120px}
.stat-circle svg{position:absolute;inset:0;transform:rotate(-90deg)}
.stat-ring{transition:stroke-dashoffset 2s cubic-bezier(0.23,1,0.32,1)}
.stat-inner{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.count-num{font-size:2.2rem;font-weight:800;color:var(--white)}
.stat-plus{font-size:1.4rem;font-weight:700;color:var(--orange)}
.stat-block h3{font-size:1rem;font-weight:700}
.stat-block p{font-size:0.85rem;color:var(--gray)}

/* ================================
   TESTIMONIALS
================================ */
.testimonials{background:var(--dark);overflow:hidden}
.testimonials-slider{overflow:hidden;margin:0 -24px;padding:0 24px}
.testimonials-track{display:flex;gap:20px;transition:transform 0.6s cubic-bezier(0.23,1,0.32,1)}
.testi-card{min-width:380px;flex-shrink:0;padding:36px}
.testi-stars{color:var(--orange);font-size:1.1rem;margin-bottom:16px;letter-spacing:2px}
.testi-card p{color:var(--gray);line-height:1.8;margin-bottom:28px;font-size:0.95rem;font-style:italic}
.testi-author{display:flex;align-items:center;gap:14px}
.testi-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.85rem;flex-shrink:0}
.testi-author strong{display:block;font-size:0.95rem}
.testi-author span{font-size:0.8rem;color:var(--gray)}
.testi-controls{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:40px}
.testi-btn{width:44px;height:44px;border-radius:50%;background:var(--glass);border:1px solid var(--glass-border);color:white;font-size:1.1rem;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.testi-btn:hover{background:var(--orange);border-color:var(--orange)}
.testi-dots{display:flex;gap:8px}
.testi-dot{width:8px;height:8px;border-radius:50%;background:var(--glass-border);transition:var(--transition);cursor:pointer}
.testi-dot.active{background:var(--orange);width:24px;border-radius:4px}

/* ================================
   PRICING
================================ */
.pricing{background:var(--dark2)}
.pricing-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(255,107,0,0.03),transparent)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.pricing-card{padding:40px 32px;position:relative;transition:var(--transition)}
.pricing-card:hover{transform:translateY(-8px)}
.pricing-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.plan-name{font-size:1.1rem;font-weight:700}
.plan-badge{font-size:0.7rem;font-family:var(--mono);font-weight:700;padding:4px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:1px}
.starter-badge{background:rgba(59,130,246,0.1);color:var(--blue-light);border:1px solid rgba(59,130,246,0.2)}
.pro-badge{background:rgba(255,107,0,0.1);color:var(--orange-light);border:1px solid rgba(255,107,0,0.2)}
.enterprise-badge{background:rgba(139,92,246,0.1);color:#a78bfa;border:1px solid rgba(139,92,246,0.2)}
.plan-price{margin-bottom:16px}
.price-currency{font-size:1.4rem;font-weight:700;color:var(--orange);vertical-align:top;line-height:1.5}
.price-num{font-size:3rem;font-weight:800;color:white}
.price-period{font-size:0.9rem;color:var(--gray);margin-left:4px}
.plan-desc{font-size:0.88rem;color:var(--gray);line-height:1.7;margin-bottom:28px}
.plan-features{display:flex;flex-direction:column;gap:10px;margin-bottom:32px}
.plan-features li{font-size:0.88rem;color:var(--gray)}
.plan-cta{display:block;text-align:center;padding:14px 24px;border-radius:50px;font-weight:700;font-size:0.95rem;transition:var(--transition)}
.starter-cta{background:var(--glass);border:1px solid var(--glass-border);color:white}
.starter-cta:hover{border-color:var(--blue);background:rgba(59,130,246,0.1)}
.pro-cta{background:linear-gradient(135deg,var(--orange),var(--orange-light));color:white}
.pro-cta:hover{box-shadow:0 15px 40px rgba(255,107,0,0.4);transform:scale(1.02)}
.enterprise-cta{background:linear-gradient(135deg,#7c3aed,#a78bfa);color:white}
.enterprise-cta:hover{box-shadow:0 15px 40px rgba(124,58,237,0.4)}
.popular-plan{border-color:rgba(255,107,0,0.3) !important;background:rgba(255,107,0,0.03) !important;transform:scale(1.03)}
.popular-plan:hover{transform:scale(1.05) translateY(-4px)}
.popular-badge{position:absolute;top:-1px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--orange),var(--orange-light));color:white;font-size:0.75rem;font-weight:700;padding:6px 20px;border-radius:0 0 12px 12px;font-family:var(--mono);letter-spacing:1px;white-space:nowrap}

/* ================================
   CONTACT
================================ */
.contact{background:var(--dark)}
.contact-orb{position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(255,107,0,0.05),transparent);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:40px;align-items:start}
.contact-info-block{margin-bottom:20px}
.contact-info-block h3{font-size:1.2rem;font-weight:700;margin-bottom:24px}
.contact-item{display:flex;gap:16px;margin-bottom:20px;align-items:flex-start}
.contact-icon{font-size:1.2rem;flex-shrink:0;margin-top:2px}
.contact-item strong{display:block;font-size:0.85rem;font-weight:700;margin-bottom:4px;color:var(--gray2)}
.contact-item a,.contact-item span{font-size:0.9rem;color:var(--gray);line-height:1.6}
.contact-item a:hover{color:var(--orange)}
.social-links{display:flex;gap:10px;margin-top:28px}
.social-link{width:40px;height:40px;background:var(--glass);border:1px solid var(--glass-border);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:0.85rem;font-weight:700;transition:var(--transition)}
.social-link:hover{background:var(--orange);border-color:var(--orange);transform:translateY(-3px)}
.whatsapp-link{background:rgba(37,211,102,0.1);border-color:rgba(37,211,102,0.3);color:#25d366}
.whatsapp-link:hover{background:#25d366;color:white}
.map-container{padding:0;overflow:hidden}
.contact-form h3{font-size:1.2rem;font-weight:700;margin-bottom:28px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.form-group label{font-size:0.82rem;font-weight:600;color:var(--gray);font-family:var(--mono);letter-spacing:0.5px;text-transform:uppercase}
.form-group input,.form-group select,.form-group textarea{background:rgba(255,255,255,0.04);border:1px solid var(--glass-border);border-radius:10px;padding:12px 16px;color:white;font-size:0.9rem;transition:var(--transition);outline:none;resize:vertical}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--gray2)}
.form-group select option{background:var(--dark2);color:white}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,107,0,0.1)}
.form-submit{width:100%;justify-content:center;border-radius:12px;padding:16px;font-size:1rem}
.form-success{display:none;margin-top:16px;padding:12px 16px;background:rgba(16,185,129,0.1);border:1px solid rgba(16,185,129,0.3);border-radius:10px;color:#34d399;font-size:0.9rem;text-align:center}
.form-success.show{display:block;animation:fadeIn 0.5s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* WHATSAPP FLOAT */
.whatsapp-float{position:fixed;bottom:100px;right:28px;z-index:900;width:56px;height:56px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 30px rgba(37,211,102,0.4);transition:var(--transition);animation:whatsappBounce 3s ease-in-out infinite}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 12px 40px rgba(37,211,102,0.6)}
@keyframes whatsappBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* ================================
   FOOTER
================================ */
.footer{background:#030306;border-top:1px solid var(--glass-border)}
.footer-top{padding:80px 0 48px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:48px}
.footer-brand p{font-size:0.9rem;color:var(--gray);line-height:1.8;margin-top:16px;margin-bottom:24px}
.footer-logo svg{height:36px;width:auto}
.footer-social{display:flex;gap:10px}
.fs-link{width:38px;height:38px;background:var(--glass);border:1px solid var(--glass-border);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:0.85rem;font-weight:700;transition:var(--transition)}
.fs-link:hover{background:var(--orange);border-color:var(--orange);transform:translateY(-2px)}
.footer-col h4{font-size:0.95rem;font-weight:700;margin-bottom:20px;color:white}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul li a{font-size:0.88rem;color:var(--gray);transition:color 0.3s}
.footer-col ul li a:hover{color:var(--orange)}
.footer-col p{font-size:0.88rem;color:var(--gray);line-height:1.7;margin-bottom:16px}
.newsletter-form{display:flex;gap:8px;margin-bottom:24px}
.newsletter-form input{flex:1;background:var(--glass);border:1px solid var(--glass-border);border-radius:8px;padding:10px 14px;color:white;font-size:0.88rem;outline:none}
.newsletter-form input:focus{border-color:var(--orange)}
.newsletter-btn{background:var(--orange);color:white;border-radius:8px;padding:10px 16px;font-size:1rem;transition:var(--transition)}
.newsletter-btn:hover{background:var(--orange-light);transform:scale(1.05)}
.footer-contact p{font-size:0.85rem;color:var(--gray);margin-bottom:6px}
.footer-bottom{border-top:1px solid var(--glass-border);padding:20px 0}
.footer-bottom .container{display:flex;align-items:center;justify-content:space-between}
.footer-bottom p{font-size:0.82rem;color:var(--gray2)}
.footer-bottom-links{display:flex;gap:24px}
.footer-bottom-links a{font-size:0.82rem;color:var(--gray2);transition:color 0.3s}
.footer-bottom-links a:hover{color:var(--orange)}

/* SCROLL TO TOP */
.scroll-top{position:fixed;bottom:28px;right:28px;z-index:900;width:48px;height:48px;background:linear-gradient(135deg,var(--orange),var(--orange-light));color:white;border-radius:50%;font-size:1.2rem;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 30px rgba(255,107,0,0.4);opacity:0;transform:translateY(20px);transition:var(--transition)}
.scroll-top.visible{opacity:1;transform:translateY(0)}
.scroll-top:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(255,107,0,0.6)}

/* ================================================
   RESPONSIVE DESIGN
================================================ */
@media(max-width:1100px){
  .tech-grid{grid-template-columns:repeat(4,1fr)}
  .portfolio-grid{grid-template-columns:repeat(2,1fr)}
  .featured-card{grid-row:span 1}
  .why-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:900px){
  .hero-container{grid-template-columns:1fr;text-align:center}
  .hero-visual{display:none}
  .hero-actions{justify-content:center}
  .hero-stats{justify-content:center}
  .about-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:32px}
  .pricing-grid{grid-template-columns:1fr}
  .popular-plan{transform:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .services-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:768px){
  .nav-links,.nav-cta{display:none}
  .nav-links.open{display:flex;flex-direction:column;position:fixed;top:70px;left:0;right:0;background:rgba(5,5,8,0.98);backdrop-filter:blur(30px);padding:24px;gap:0;border-bottom:1px solid var(--glass-border);z-index:999}
  .nav-links.open .nav-link{padding:14px 16px;border-bottom:1px solid var(--glass-border)}
  .hamburger{display:flex}
  .section{padding:80px 0}
  .tech-grid{grid-template-columns:repeat(3,1fr)}
  .about-cards{grid-template-columns:1fr}
  .portfolio-grid{grid-template-columns:1fr}
  .timeline{flex-direction:column}
  .timeline::before{display:none}
  .why-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-bottom .container{flex-direction:column;gap:12px;text-align:center}
}

@media(max-width:480px){
  .tech-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr}
  .testi-card{min-width:300px}
  .stats-grid{grid-template-columns:1fr 1fr}
  .hero-3d-scene{width:300px;height:300px}
}

/* ================================================
   VISITOR COUNTER SECTION — NEW FEATURE
================================================ */
.visitor-section {
  background: var(--dark2);
  position: relative;
  overflow: hidden;
}
.visitor-bg-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(100px);
  pointer-events: none;
}
.visitor-orb1 {
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(255,107,0,0.07), transparent);
  top: -150px;
  left: -100px;
}
.visitor-orb2 {
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, rgba(59,130,246,0.07), transparent);
  bottom: -100px;
  right: -80px;
}

.visitor-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 40px;
}

.visitor-card {
  position: relative;
  padding: 36px 32px 28px;
  overflow: hidden;
  transition: var(--transition);
}
.visitor-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 30px 80px rgba(0,0,0,0.5), 0 0 40px rgba(255,107,0,0.07);
}
.visitor-card--featured {
  border-color: rgba(16,185,129,0.25) !important;
  background: rgba(16,185,129,0.03) !important;
}
.visitor-card--featured:hover {
  box-shadow: 0 30px 80px rgba(0,0,0,0.5), 0 0 40px rgba(16,185,129,0.1);
}

.visitor-card-inner {
  display: flex;
  gap: 24px;
  align-items: flex-start;
}

/* Icon Rings */
.visitor-icon-ring {
  width: 64px;
  height: 64px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
}
.visitor-icon-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
}
.total-ring {
  background: rgba(255,107,0,0.1);
  border: 1px solid rgba(255,107,0,0.2);
  box-shadow: 0 0 30px rgba(255,107,0,0.1);
}
.online-ring {
  background: rgba(16,185,129,0.1);
  border: 1px solid rgba(16,185,129,0.25);
  box-shadow: 0 0 30px rgba(16,185,129,0.15);
}
.today-ring {
  background: rgba(59,130,246,0.1);
  border: 1px solid rgba(59,130,246,0.2);
  box-shadow: 0 0 30px rgba(59,130,246,0.1);
}

/* Data */
.visitor-data {
  flex: 1;
  min-width: 0;
}
.visitor-count-wrap {
  display: flex;
  align-items: baseline;
  gap: 2px;
  margin-bottom: 6px;
}
.visitor-count {
  font-size: 2.8rem;
  font-weight: 800;
  color: var(--white);
  line-height: 1;
  font-family: var(--mono);
  letter-spacing: -2px;
}
.visitor-plus {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--orange);
  line-height: 1;
}
.visitor-label {
  font-size: 1rem;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 4px;
}
.visitor-desc {
  font-size: 0.82rem;
  color: var(--gray);
  margin-bottom: 16px;
  line-height: 1.5;
}

/* Progress Bar */
.visitor-bar {
  height: 4px;
  background: rgba(255,255,255,0.06);
  border-radius: 4px;
  overflow: hidden;
}
.visitor-bar-fill {
  height: 100%;
  border-radius: 4px;
  width: 0;
  transition: width 2s cubic-bezier(0.23,1,0.32,1);
}
.total-fill {
  background: linear-gradient(90deg, var(--orange), var(--orange-light));
  width: 85%;
}
.online-fill {
  background: linear-gradient(90deg, #10b981, #34d399);
  width: 45%;
}
.today-fill {
  background: linear-gradient(90deg, var(--blue), var(--blue-light));
  width: 62%;
}

/* Badges */
.visitor-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.72rem;
  font-family: var(--mono);
  font-weight: 700;
  letter-spacing: 0.5px;
  padding: 5px 12px;
  border-radius: 20px;
  margin-top: 20px;
}
.total-badge {
  background: rgba(255,107,0,0.08);
  color: var(--orange-light);
  border: 1px solid rgba(255,107,0,0.15);
}
.online-badge {
  background: rgba(16,185,129,0.08);
  color: #34d399;
  border: 1px solid rgba(16,185,129,0.2);
}
.today-badge {
  background: rgba(59,130,246,0.08);
  color: var(--blue-light);
  border: 1px solid rgba(59,130,246,0.15);
}
.vbadge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--orange);
  display: inline-block;
}
.online-dot {
  background: #10b981;
  animation: onlinePing 1.5s ease-in-out infinite;
}
.today-dot {
  background: var(--blue);
}
@keyframes onlinePing {
  0%, 100% { box-shadow: 0 0 0 0 rgba(16,185,129,0.6); }
  50% { box-shadow: 0 0 0 5px rgba(16,185,129,0); }
}

/* Pulse ring on online card */
.visitor-pulse-ring {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(16,185,129,0.3);
  animation: visitorPulse 2.5s ease-in-out infinite;
}
@keyframes visitorPulse {
  0% { transform: scale(0.8); opacity: 1; }
  100% { transform: scale(2); opacity: 0; }
}

/* Footer Strip */
.visitor-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius);
  padding: 20px 32px;
  flex-wrap: wrap;
  gap: 0;
}
.visitor-footer-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 8px 32px;
}
.vf-label {
  font-size: 0.72rem;
  font-family: var(--mono);
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--gray2);
}
.vf-value {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--white);
}
.vf-divider {
  width: 1px;
  height: 40px;
  background: var(--glass-border);
  flex-shrink: 0;
}

/* Responsive Visitor Counter */
@media (max-width: 900px) {
  .visitor-grid { grid-template-columns: 1fr; }
  .visitor-card--featured { order: -1; }
}
@media (max-width: 600px) {
  .visitor-card { padding: 24px 20px; }
  .visitor-count { font-size: 2.2rem; }
  .visitor-footer { flex-direction: column; gap: 16px; padding: 20px; }
  .vf-divider { width: 80%; height: 1px; }
  .visitor-footer-item { padding: 4px 0; }
}

/* ================================================
   AI CHATBOT WIDGET — NEW FEATURE
================================================ */

/* Floating Toggle Button */
.chatbot-toggle {
  position: fixed;
  bottom: 88px;
  right: 28px;
  z-index: 950;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--orange), var(--orange-light));
  box-shadow: 0 8px 32px rgba(255,107,0,0.45), 0 2px 8px rgba(0,0,0,0.3);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.4s cubic-bezier(0.23,1,0.32,1), box-shadow 0.4s;
  animation: chatBtnFloat 3.5s ease-in-out infinite;
}
.chatbot-toggle:hover {
  transform: scale(1.12) translateY(-3px);
  box-shadow: 0 14px 40px rgba(255,107,0,0.6);
}
.chatbot-toggle.active {
  animation: none;
  background: linear-gradient(135deg, #1e293b, #0f172a);
  box-shadow: 0 8px 28px rgba(0,0,0,0.5);
}
@keyframes chatBtnFloat {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-6px); }
}
.chatbot-toggle-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.3s, opacity 0.3s;
}

/* Notification dot */
.chatbot-notif-dot {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 12px;
  height: 12px;
  background: #10b981;
  border-radius: 50%;
  border: 2px solid var(--black);
  animation: notifPing 2s ease-in-out infinite;
}
@keyframes notifPing {
  0%, 100% { box-shadow: 0 0 0 0 rgba(16,185,129,0.6); }
  50%       { box-shadow: 0 0 0 6px rgba(16,185,129,0); }
}
.chatbot-notif-dot.hidden { display: none; }

/* Chat Window */
.chatbot-window {
  position: fixed;
  bottom: 160px;
  right: 28px;
  z-index: 949;
  width: 380px;
  max-height: 560px;
  background: rgba(10,10,20,0.92);
  backdrop-filter: blur(30px);
  -webkit-backdrop-filter: blur(30px);
  border: 1px solid rgba(255,107,0,0.18);
  border-radius: 24px;
  display: flex;
  flex-direction: column;
  box-shadow: 0 30px 80px rgba(0,0,0,0.7), 0 0 60px rgba(255,107,0,0.08);
  overflow: hidden;
  transform: translateY(24px) scale(0.95);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.45s cubic-bezier(0.23,1,0.32,1),
              opacity 0.4s cubic-bezier(0.23,1,0.32,1);
  transform-origin: bottom right;
}
.chatbot-window.open {
  transform: translateY(0) scale(1);
  opacity: 1;
  pointer-events: all;
}

/* Header */
.chatbot-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px;
  background: linear-gradient(135deg, rgba(255,107,0,0.15), rgba(59,130,246,0.08));
  border-bottom: 1px solid rgba(255,255,255,0.06);
  flex-shrink: 0;
}
.chatbot-header-left {
  display: flex;
  align-items: center;
  gap: 12px;
}
.chatbot-avatar {
  width: 42px;
  height: 42px;
  background: linear-gradient(135deg, var(--orange), var(--orange-light));
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(255,107,0,0.35);
}
.chatbot-header-info {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.chatbot-name {
  font-size: 0.95rem;
  font-weight: 700;
  color: white;
}
.chatbot-status {
  font-size: 0.72rem;
  color: #34d399;
  display: flex;
  align-items: center;
  gap: 5px;
  font-family: var(--mono);
}
.status-pulse {
  width: 7px;
  height: 7px;
  background: #10b981;
  border-radius: 50%;
  animation: onlinePing 1.5s ease-in-out infinite;
  flex-shrink: 0;
}
.chatbot-close-btn {
  width: 32px;
  height: 32px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.3s, transform 0.3s;
  color: var(--gray);
  flex-shrink: 0;
}
.chatbot-close-btn:hover {
  background: rgba(255,107,0,0.15);
  border-color: rgba(255,107,0,0.3);
  transform: scale(1.08);
}

/* Messages */
.chatbot-messages {
  flex: 1;
  overflow-y: auto;
  padding: 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  scroll-behavior: smooth;
}
.chatbot-messages::-webkit-scrollbar { width: 3px; }
.chatbot-messages::-webkit-scrollbar-track { background: transparent; }
.chatbot-messages::-webkit-scrollbar-thumb { background: rgba(255,107,0,0.3); border-radius: 2px; }

/* Message Bubbles */
.chat-msg {
  display: flex;
  flex-direction: column;
  gap: 4px;
  max-width: 82%;
  animation: msgIn 0.35s cubic-bezier(0.23,1,0.32,1) both;
}
@keyframes msgIn {
  from { opacity: 0; transform: translateY(10px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.chat-msg.bot { align-self: flex-start; }
.chat-msg.user { align-self: flex-end; }

.chat-bubble {
  padding: 12px 16px;
  border-radius: 18px;
  font-size: 0.88rem;
  line-height: 1.65;
  color: white;
  word-break: break-word;
}
.chat-msg.bot .chat-bubble {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  border-bottom-left-radius: 4px;
}
.chat-msg.user .chat-bubble {
  background: linear-gradient(135deg, var(--orange), var(--orange-light));
  border-bottom-right-radius: 4px;
  box-shadow: 0 4px 14px rgba(255,107,0,0.3);
}
.chat-time {
  font-size: 0.68rem;
  font-family: var(--mono);
  color: var(--gray2);
  padding: 0 4px;
}
.chat-msg.bot .chat-time { text-align: left; }
.chat-msg.user .chat-time { text-align: right; }

/* Typing Indicator */
.typing-indicator {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 12px 16px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 18px;
  border-bottom-left-radius: 4px;
  width: fit-content;
}
.typing-dot {
  width: 7px;
  height: 7px;
  background: var(--orange);
  border-radius: 50%;
  animation: typingBounce 1.2s ease-in-out infinite;
}
.typing-dot:nth-child(2) { animation-delay: 0.2s; background: var(--blue); }
.typing-dot:nth-child(3) { animation-delay: 0.4s; }
@keyframes typingBounce {
  0%, 80%, 100% { transform: translateY(0); opacity: 0.4; }
  40%           { transform: translateY(-6px); opacity: 1; }
}

/* Quick Replies */
.chatbot-quick-replies {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 10px 16px;
  border-top: 1px solid rgba(255,255,255,0.05);
  flex-shrink: 0;
}
.quick-reply-btn {
  background: rgba(255,107,0,0.08);
  border: 1px solid rgba(255,107,0,0.2);
  color: var(--orange-light);
  border-radius: 20px;
  padding: 6px 14px;
  font-size: 0.76rem;
  font-weight: 600;
  font-family: var(--font);
  cursor: pointer;
  transition: background 0.3s, transform 0.2s, border-color 0.3s;
  white-space: nowrap;
}
.quick-reply-btn:hover {
  background: rgba(255,107,0,0.18);
  border-color: rgba(255,107,0,0.4);
  transform: translateY(-1px);
}

/* Input Area */
.chatbot-input-area {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border-top: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.02);
  flex-shrink: 0;
}
.chatbot-input {
  flex: 1;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 10px 14px;
  color: white;
  font-size: 0.88rem;
  font-family: var(--font);
  outline: none;
  transition: border-color 0.3s, background 0.3s;
  min-width: 0;
}
.chatbot-input::placeholder { color: var(--gray2); }
.chatbot-input:focus {
  border-color: rgba(255,107,0,0.4);
  background: rgba(255,255,255,0.07);
}
.chatbot-send-btn {
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg, var(--orange), var(--orange-light));
  border-radius: 12px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform 0.25s, box-shadow 0.25s;
  box-shadow: 0 4px 12px rgba(255,107,0,0.3);
}
.chatbot-send-btn:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 18px rgba(255,107,0,0.5);
}

/* Footer Note */
.chatbot-footer-note {
  text-align: center;
  font-size: 0.68rem;
  color: var(--gray2);
  font-family: var(--mono);
  padding: 8px 16px 12px;
  border-top: 1px solid rgba(255,255,255,0.04);
  flex-shrink: 0;
}
.chatbot-footer-note a {
  color: var(--orange);
  text-decoration: underline;
  transition: color 0.3s;
}
.chatbot-footer-note a:hover { color: var(--orange-light); }

/* Adjust WhatsApp float position so they don't overlap */
.whatsapp-float {
  bottom: 160px !important;
}

/* Responsive Chatbot */
@media (max-width: 480px) {
  .chatbot-window {
    width: calc(100vw - 24px);
    right: 12px;
    bottom: 150px;
    max-height: 70vh;
    border-radius: 20px;
  }
  .chatbot-toggle {
    right: 16px;
    bottom: 80px;
  }
  .whatsapp-float {
    bottom: 148px !important;
    right: 16px;
  }
}

/* Scroll top stays at same position */
.scroll-top { bottom: 28px; right: 28px; }


/* ============================================================
   DALEYORK — Live Visitor Counter Widget
   Left-side floating panel, glassmorphism premium style
   ============================================================ */

#dyk-visitor-counter {
  position: fixed;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 950;
  display: flex;
  align-items: center;
  gap: 0;
  /* Entrance animation */
  animation: dykSlideIn 0.7s cubic-bezier(0.23, 1, 0.32, 1) 1.5s both;
}

@keyframes dykSlideIn {
  from { transform: translateY(-50%) translateX(-100%); opacity: 0; }
  to   { transform: translateY(-50%) translateX(0);     opacity: 1; }
}

/* ── Inner card ──────────────────────────────────────────── */
.dyk-vc-inner {
  background: rgba(10, 10, 18, 0.75);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 107, 0, 0.18);
  border-left: none;
  border-radius: 0 16px 16px 0;
  padding: 16px 14px 12px;
  width: 148px;
  box-shadow:
    4px 0 40px rgba(0,0,0,0.5),
    0 0 0 1px rgba(255,255,255,0.04) inset,
    0 0 30px rgba(255, 107, 0, 0.06);
  overflow: hidden;
  transition: all 0.45s cubic-bezier(0.23, 1, 0.32, 1);
  position: relative;
}

/* Subtle gradient shimmer on card */
.dyk-vc-inner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg,
    rgba(255, 107, 0, 0.04) 0%,
    transparent 50%,
    rgba(59, 130, 246, 0.03) 100%);
  pointer-events: none;
}

/* ── Collapsed state ─────────────────────────────────────── */
#dyk-visitor-counter.dyk-collapsed .dyk-vc-inner {
  width: 0;
  padding-left: 0;
  padding-right: 0;
  border-right-color: transparent;
  opacity: 0;
}

#dyk-visitor-counter.dyk-collapsed .dyk-vc-toggle svg {
  transform: rotate(180deg);
}

/* ── Toggle button ───────────────────────────────────────── */
.dyk-vc-toggle {
  width: 22px;
  min-width: 22px;
  height: 56px;
  background: rgba(255, 107, 0, 0.12);
  border: 1px solid rgba(255, 107, 0, 0.25);
  border-left: none;
  border-radius: 0 10px 10px 0;
  color: #ff9500;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.35s cubic-bezier(0.23, 1, 0.32, 1);
  flex-shrink: 0;
  padding: 0;
  font-family: inherit;
}

.dyk-vc-toggle:hover {
  background: rgba(255, 107, 0, 0.22);
  color: #ffffff;
}

.dyk-vc-toggle svg {
  transition: transform 0.4s cubic-bezier(0.23, 1, 0.32, 1);
  display: block;
}

/* ── Header ──────────────────────────────────────────────── */
.dyk-vc-header {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 12px;
  white-space: nowrap;
}

.dyk-vc-icon {
  color: #ff6b00;
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

.dyk-vc-title {
  font-family: 'Sora', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: #ffffff;
  flex: 1;
}

/* Pulsing live indicator dot */
.dyk-vc-live-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 8px rgba(34, 197, 94, 0.8);
  animation: dykPulse 2s ease-in-out infinite;
  flex-shrink: 0;
}

@keyframes dykPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.5; transform: scale(0.75); }
}

/* ── Stats ───────────────────────────────────────────────── */
.dyk-vc-stats {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.dyk-vc-divider {
  height: 1px;
  background: rgba(255, 255, 255, 0.06);
  margin: 8px 0;
}

.dyk-vc-stat {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* Icon circles */
.dyk-vc-stat-icon {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.dyk-vc-icon-total {
  background: rgba(255, 107, 0, 0.12);
  color: #ff9500;
  border: 1px solid rgba(255, 107, 0, 0.2);
}

.dyk-vc-icon-online {
  background: rgba(34, 197, 94, 0.12);
  color: #22c55e;
  border: 1px solid rgba(34, 197, 94, 0.2);
}

.dyk-vc-icon-today {
  background: rgba(59, 130, 246, 0.12);
  color: #60a5fa;
  border: 1px solid rgba(59, 130, 246, 0.2);
}

/* Stat text */
.dyk-vc-stat-info {
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
}

.dyk-vc-num {
  font-family: 'Space Mono', monospace;
  font-size: 14px;
  font-weight: 700;
  color: #ffffff;
  line-height: 1;
  white-space: nowrap;
  /* Number change flash */
  transition: color 0.3s ease;
}

.dyk-vc-num.dyk-updated {
  color: #ff9500;
}

.dyk-vc-label {
  font-family: 'Sora', sans-serif;
  font-size: 9px;
  font-weight: 500;
  color: #6b6b80;
  letter-spacing: 0.3px;
  white-space: nowrap;
}

/* ── Footer ──────────────────────────────────────────────── */
.dyk-vc-footer {
  margin-top: 12px;
  padding-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

.dyk-vc-powered {
  font-family: 'Space Mono', monospace;
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 1px;
  color: #22c55e;
  text-transform: uppercase;
  white-space: nowrap;
}

/* ── Mobile / Tablet responsive ─────────────────────────── */

/* Tablet (≤900px): make widget a bit smaller */
@media (max-width: 900px) {
  .dyk-vc-inner {
    width: 136px;
    padding: 13px 12px 10px;
  }
  .dyk-vc-title  { font-size: 9px; }
  .dyk-vc-num    { font-size: 13px; }
}

/* Mobile (≤640px): move to bottom-left, horizontal compact strip */
@media (max-width: 640px) {
  #dyk-visitor-counter {
    top: auto;
    bottom: 90px;       /* above scroll-to-top button */
    left: 0;
    transform: none;
    flex-direction: column-reverse;
    align-items: flex-start;
    animation: dykSlideInMobile 0.7s cubic-bezier(0.23, 1, 0.32, 1) 1.5s both;
  }

  @keyframes dykSlideInMobile {
    from { transform: translateX(-100%); opacity: 0; }
    to   { transform: translateX(0);     opacity: 1; }
  }

  .dyk-vc-inner {
    width: auto;
    padding: 10px 12px 8px;
    border-radius: 0 12px 12px 0;
  }

  .dyk-vc-stats {
    flex-direction: row;
    gap: 10px;
    align-items: center;
  }

  .dyk-vc-divider {
    width: 1px;
    height: 28px;
    margin: 0;
  }

  .dyk-vc-num   { font-size: 12px; }
  .dyk-vc-label { font-size: 8px; }

  .dyk-vc-stat-icon {
    display: none; /* hide icons on very small screens to save space */
  }

  .dyk-vc-toggle {
    width: 40px;
    height: 18px;
    border-radius: 0 0 8px 0;
    border: 1px solid rgba(255, 107, 0, 0.25);
    border-top: none;
    border-left: none;
    justify-content: center;
  }

  .dyk-vc-toggle svg {
    transform: rotate(-90deg) !important;
  }

  #dyk-visitor-counter.dyk-collapsed .dyk-vc-inner {
    width: 0;
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
  }

  #dyk-visitor-counter.dyk-collapsed .dyk-vc-toggle svg {
    transform: rotate(90deg) !important;
  }
}
