/* M5 PRODUCTION v4 — Full stylesheet */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Inter:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,700;1,400&display=swap');

:root{
  --green:#39b54a;--green-d:#2a8f37;
  --bg:#080808;--bg2:#0d0d0d;--card:#111;--card2:#1a1a1a;
  --border:rgba(255,255,255,.07);--border2:rgba(255,255,255,.12);
  --text:#ddd;--muted:#4e4e4e;--white:#fff;
  --ease:cubic-bezier(.16,1,.3,1);--ease2:cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;line-height:1.7;overflow-x:hidden;}
a{color:inherit;text-decoration:none;} img{max-width:100%;display:block;} ul{list-style:none;} button{cursor:pointer;}

/* ══════════════════════════════════════════════════════════
   PRELOADER — Cinematic letter reveal
   ══════════════════════════════════════════════════════════ */


@keyframes preloaderExit{
  to{transform:translateY(-100%);opacity:0;}
}

/* Top + bottom curtain lines */
.pl-line-top,.pl-line-bot{
  position:absolute;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(57,181,74,.6),transparent);
}
.pl-line-top{top:50%;animation:lineSweepUp .8s .4s var(--ease) forwards;opacity:0;}
.pl-line-bot{bottom:50%;animation:lineSweepDown .8s .4s var(--ease) forwards;opacity:0;}
@keyframes lineSweepUp{from{top:50%;opacity:1;}to{top:0;opacity:0;}}
@keyframes lineSweepDown{from{bottom:50%;opacity:1;}to{bottom:0;opacity:0;}}

/* Logo image reveal */
.pl-logo{
  width:140px;opacity:0;
  filter:brightness(0) invert(1);
  animation:plLogoIn .9s .1s var(--ease) forwards;
  margin-bottom:32px;
}
@keyframes plLogoIn{
  0%{opacity:0;transform:scale(.8);}
  60%{opacity:1;transform:scale(1.04);}
  100%{opacity:1;transform:scale(1);}
}

/* "M5 PRODUCTION" letters stagger */
.pl-letters{
  display:flex;gap:2px;
  font-family:'Bebas Neue',sans-serif;
  font-size:.95rem;letter-spacing:.5em;
  text-transform:uppercase;color:rgba(255,255,255,.3);
  overflow:hidden;margin-bottom:40px;
}
.pl-letters span{
  display:inline-block;
  animation:letterIn .6s var(--ease) both;
}
.pl-letters span:nth-child(1){animation-delay:.2s}
.pl-letters span:nth-child(2){animation-delay:.24s}
.pl-letters span:nth-child(3){animation-delay:.28s}
.pl-letters span:nth-child(4){animation-delay:.32s}
.pl-letters span:nth-child(5){animation-delay:.36s}
.pl-letters span:nth-child(6){animation-delay:.40s}
.pl-letters span:nth-child(7){animation-delay:.44s}
.pl-letters span:nth-child(8){animation-delay:.48s}
.pl-letters span:nth-child(9){animation-delay:.52s}
.pl-letters span:nth-child(10){animation-delay:.56s}
.pl-letters span:nth-child(11){animation-delay:.60s}
.pl-letters span:nth-child(12){animation-delay:.64s}
.pl-letters span:nth-child(13){animation-delay:.68s}
@keyframes letterIn{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}

/* Thin progress line */
.pl-progress{
  width:120px;height:1px;
  background:rgba(255,255,255,.08);
  border-radius:1px;overflow:hidden;
  position:relative;
}
.pl-progress::after{
  content:'';
  position:absolute;top:0;left:-100%;
  width:100%;height:100%;
  background:linear-gradient(90deg,transparent,var(--green),transparent);
  animation:plProgress 1.4s .2s ease-in-out forwards;
}
@keyframes plProgress{
  0%{left:-100%;}
  100%{left:100%;}
}

/* Counter number */
.pl-count{
  position:absolute;bottom:32px;right:36px;
  font-family:'Bebas Neue',sans-serif;
  font-size:1rem;letter-spacing:.1em;
  color:rgba(255,255,255,.12);
}

/* ══════════════════════════════════════════════════════════
   PAGE TRANSITION CURTAIN
   ══════════════════════════════════════════════════════════ */
.pt{position:fixed;inset:0;z-index:99999;pointer-events:none;display:flex;flex-direction:column;}
.pt-s{flex:1;background:var(--bg);transform:scaleY(0);transform-origin:bottom;}
.pt-s:nth-child(1){transition:transform .42s .0s var(--ease);}
.pt-s:nth-child(2){background:#0a0a0a;transition:transform .42s .04s var(--ease);}
.pt-s:nth-child(3){background:#0d0d0d;transition:transform .42s .08s var(--ease);}
.pt.in .pt-s{transform:scaleY(1);}
.pt.out .pt-s{transform:scaleY(0);transform-origin:top;}

/* ══════════════════════════════════════════════════════════
   CURSOR
   ══════════════════════════════════════════════════════════ */
.cursor-dot,.cursor-ring{position:fixed;border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);}
.cursor-dot{width:5px;height:5px;background:var(--green);top:0;left:0;}
.cursor-ring{width:34px;height:34px;border:1px solid rgba(57,181,74,.4);top:0;left:0;transition:width .3s var(--ease),height .3s var(--ease),border-color .3s;}
.cursor-ring.hovered{width:50px;height:50px;border-color:var(--green);background:rgba(57,181,74,.04);}
@media(hover:none){.cursor-dot,.cursor-ring{display:none;}}

/* ══════════════════════════════════════════════════════════
   LAYOUT
   ══════════════════════════════════════════════════════════ */
.container{max-width:1240px;margin:0 auto;padding:0 40px;}
@media(max-width:768px){.container{padding:0 22px;}}

/* ══════════════════════════════════════════════════════════
   HEADER
   ══════════════════════════════════════════════════════════ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:800;padding:22px 0;transition:padding .4s var(--ease),background .4s,border-color .4s;border-bottom:1px solid transparent;}
.site-header.scrolled{background:rgba(8,8,8,.94);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding:13px 0;border-color:var(--border);}
.header-wrap{max-width:1240px;margin:0 auto;padding:0 40px;display:flex;align-items:center;justify-content:space-between;gap:32px;}
.header-logo img{height:52px;width:auto;object-fit:contain;background:transparent;transition:opacity .3s;}
.header-logo:hover img{opacity:.8;}
.header-nav ul{display:flex;align-items:center;gap:28px;}
.header-nav ul a{font-size:.73rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);position:relative;padding-bottom:2px;transition:color .25s;}
.header-nav ul a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--green);transition:width .3s var(--ease);}
.header-nav ul a:hover,.header-nav ul a.current{color:var(--white);}
.header-nav ul a:hover::after,.header-nav ul a.current::after{width:100%;}
.header-admin-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 15px;border:1px solid rgba(57,181,74,.35);border-radius:6px;background:rgba(57,181,74,.06);color:var(--green)!important;font-size:.7rem!important;font-weight:700!important;letter-spacing:.1em;text-transform:uppercase;transition:background .25s!important;margin-left:8px;}
.header-admin-btn:hover{background:rgba(57,181,74,.14)!important;}
.header-admin-btn::after{display:none!important;}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:4px;z-index:900;}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--white);transition:transform .35s var(--ease),opacity .25s,width .3s;transform-origin:center;}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;width:0;}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}
@media(max-width:900px){
  .hamburger{display:flex;}.header-wrap{padding:0 22px;}
  .header-nav{position:fixed;inset:0;background:rgba(8,8,8,.98);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;transform:translateX(100%);transition:transform .5s var(--ease);z-index:799;}
  .header-nav.open{transform:translateX(0);}
  .header-nav ul{flex-direction:column;gap:28px;text-align:center;}
  .header-nav ul a{font-size:.95rem;}.header-admin-btn{margin:20px 0 0;}
}

/* ══════════════════════════════════════════════════════════
   SECTION BASE
   ══════════════════════════════════════════════════════════ */
.section{padding:120px 0;}
.section-label{font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--green);margin-bottom:12px;display:block;}
.section-heading{font-family:'Bebas Neue',sans-serif;font-size:clamp(2.6rem,5vw,4.2rem);letter-spacing:.02em;color:var(--white);line-height:1.06;margin-bottom:36px;}
.section-heading em{font-family:'Playfair Display',serif;font-style:italic;color:var(--green);font-size:.95em;}
.section-header{text-align:center;margin-bottom:56px;}
.section-header .section-heading{margin-bottom:12px;}
.section-header p{color:var(--muted);max-width:480px;margin:0 auto;}

/* ══════════════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:7px;font-family:'Inter',sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;transition:all .3s var(--ease);position:relative;overflow:hidden;border:none;}
.btn::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,.08);transform:translateX(-100%);transition:transform .35s var(--ease);}
.btn:hover::before{transform:translateX(0);}
.btn-primary{background:var(--green);color:#000;box-shadow:0 4px 20px rgba(57,181,74,.22);}
.btn-primary:hover{background:var(--green-d);box-shadow:0 8px 30px rgba(57,181,74,.38);transform:translateY(-2px);}
.btn-ghost{background:transparent;color:var(--white);border:1.5px solid var(--border2);}
.btn-ghost:hover{border-color:var(--green);color:var(--green);transform:translateY(-2px);}
.btn-outline{background:transparent;color:var(--green);border:1.5px solid rgba(57,181,74,.4);}
.btn-outline:hover{background:rgba(57,181,74,.1);transform:translateY(-2px);}
.btn-full{width:100%;justify-content:center;}

/* ══════════════════════════════════════════════════════════
   HERO
   ══════════════════════════════════════════════════════════ */
.s-hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding:120px 40px 80px;}
.hero-bg{position:absolute;inset:0;z-index:0;background:var(--bg);}
.hero-bg::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.022) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.022) 1px,transparent 1px);background-size:72px 72px;animation:gridF 16s ease-in-out infinite alternate;}
@keyframes gridF{to{transform:translate(5px,8px);}}
.hero-bg::after{content:'';position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(57,181,74,.09) 0%,transparent 70%);top:-200px;right:-120px;animation:orbF 14s ease-in-out infinite alternate;}
.hero-orb2{position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(57,181,74,.05) 0%,transparent 70%);bottom:-80px;left:8%;animation:orbF 18s ease-in-out infinite alternate-reverse;}
@keyframes orbF{to{transform:translate(-40px,60px) scale(1.1);}}
.hero-content{position:relative;z-index:1;max-width:880px;}
.hero-tag{display:inline-flex;align-items:center;gap:9px;font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--green);border:1px solid rgba(57,181,74,.28);background:rgba(57,181,74,.05);padding:6px 14px;border-radius:100px;margin-bottom:26px;opacity:0;animation:fadeUp .8s .2s var(--ease) forwards;}
.hero-tag::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--green);animation:blink 1.5s ease-in-out infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.hero-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(4rem,10vw,9rem);letter-spacing:.02em;line-height:.93;color:var(--white);margin-bottom:22px;opacity:0;animation:fadeUp .9s .4s var(--ease) forwards;}
.hero-title em{font-family:'Playfair Display',serif;font-style:italic;color:var(--green);font-size:.9em;}
.hero-sub{font-size:.95rem;color:var(--muted);margin-bottom:40px;letter-spacing:.04em;opacity:0;animation:fadeUp .9s .6s var(--ease) forwards;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:fadeUp .9s .8s var(--ease) forwards;}
.hero-location{position:absolute;bottom:34px;right:40px;display:flex;align-items:center;gap:7px;font-size:.7rem;color:var(--muted);letter-spacing:.08em;opacity:0;animation:fadeIn 1s 1.1s forwards;}
.hero-location i{color:var(--green);}
.hero-scroll{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:7px;font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);opacity:0;animation:fadeIn 1s 1.3s forwards;}
.hero-scroll i{animation:bounceD 1.5s ease-in-out infinite;}
@keyframes bounceD{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
@keyframes fadeIn{to{opacity:1}}

/* ══════════════════════════════════════════════════════════
   ABOUT
   ══════════════════════════════════════════════════════════ */
.s-about{background:var(--bg2);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:44px;}}
.about-text{color:#777;margin-bottom:18px;line-height:1.8;font-size:.95rem;}
.about-contact-line{display:flex;flex-wrap:wrap;gap:18px;margin-bottom:28px;}
.about-contact-line a{display:flex;align-items:center;gap:7px;font-size:.84rem;color:var(--muted);transition:color .25s;}
.about-contact-line a i{color:var(--green);}
.about-contact-line a:hover{color:var(--green);}
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px;}
.stat{text-align:center;padding:20px 10px;background:var(--card);border:1px solid var(--border);border-radius:12px;position:relative;overflow:hidden;transition:border-color .3s,transform .3s;}
.stat:hover{border-color:rgba(57,181,74,.3);transform:translateY(-4px);}
.stat::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);}
.stat:hover::after{transform:scaleX(1);}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:2.6rem;color:var(--white);display:block;line-height:1;}
.stat-sym{color:var(--green);font-size:1.3rem;}
.stat-desc{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;display:block;margin-top:5px;}
.skills{display:flex;flex-direction:column;gap:13px;}
.skill-row{display:grid;grid-template-columns:120px 1fr 36px;align-items:center;gap:12px;font-size:.77rem;color:var(--muted);}
.skill-track{height:2px;background:var(--card2);border-radius:2px;overflow:hidden;}
.skill-bar{height:100%;width:0;background:linear-gradient(90deg,var(--green-d),var(--green));border-radius:2px;transition:width 1.4s var(--ease);}

/* ══════════════════════════════════════════════════════════
   SERVICES
   ══════════════════════════════════════════════════════════ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
@media(max-width:900px){.services-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:540px){.services-grid{grid-template-columns:1fr;}}
.service-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:28px 22px;position:relative;overflow:hidden;transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;}
.service-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--green),transparent);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);}
.service-card:hover{transform:translateY(-6px);border-color:rgba(57,181,74,.22);box-shadow:0 20px 60px rgba(0,0,0,.4);}
.service-card:hover::before{transform:scaleX(1);}
.service-icon{width:44px;height:44px;border-radius:10px;background:rgba(57,181,74,.09);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--green);margin-bottom:16px;transition:transform .3s;}
.service-card:hover .service-icon{transform:scale(1.1);}
.service-card h3{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:.04em;color:var(--white);margin-bottom:9px;}
.service-card p{font-size:.83rem;color:var(--muted);line-height:1.75;}

/* ══════════════════════════════════════════════════════════
   WORKS PREVIEW
   ══════════════════════════════════════════════════════════ */
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:40px;}
@media(max-width:900px){.works-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:520px){.works-grid{grid-template-columns:1fr;}}
.work-card{border-radius:12px;overflow:hidden;background:var(--card);border:1px solid var(--border);transition:transform .35s var(--ease),box-shadow .35s,border-color .35s;cursor:pointer;}
.work-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.5);border-color:rgba(57,181,74,.28);}
.work-thumb{aspect-ratio:16/9;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#0e0e0e;}
.work-thumb iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none;pointer-events:none;}
.work-placeholder{font-size:2rem;color:rgba(255,255,255,.05);}
.work-overlay{position:absolute;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;}
.work-card:hover .work-overlay{opacity:1;}
.work-overlay-icon{width:46px;height:46px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;color:#000;font-size:.9rem;transform:scale(.7);transition:transform .3s var(--ease);}
.work-card:hover .work-overlay-icon{transform:scale(1);}
.work-info{padding:14px 15px;}
.work-cat{display:none;}
.work-info h4{font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:.03em;color:var(--white);margin:0;}
.works-cta{text-align:center;}

/* ══════════════════════════════════════════════════════════
   BEHANCE SECTION
   ══════════════════════════════════════════════════════════ */
.s-dribbble{background:var(--bg2);}
.dribbble-embed-wrap{border-radius:18px;overflow:hidden;border:1px solid var(--border);background:var(--card);box-shadow:0 40px 80px rgba(0,0,0,.4);}
.dribbble-embed-inner{position:relative;height:560px;}
.dribbble-frame{width:100%;height:100%;border:none;}
.dribbble-fallback-card{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:44px;background:var(--card);}
.dribbble-fallback-card h3{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:.04em;color:var(--white);}
.dribbble-fallback-card p{color:var(--muted);max-width:340px;font-size:.88rem;}

/* ══════════════════════════════════════════════════════════
   CONTACT
   ══════════════════════════════════════════════════════════ */
.s-contact{background:var(--bg);}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start;}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:44px;}}
.contact-details{display:flex;flex-direction:column;gap:12px;margin-bottom:28px;}
.contact-detail-item{display:flex;align-items:flex-start;gap:11px;font-size:.85rem;color:var(--muted);}
.contact-detail-item i{color:var(--green);margin-top:3px;width:15px;text-align:center;}
.contact-detail-item a:hover{color:var(--green);}
.contact-socials{display:flex;gap:8px;flex-wrap:wrap;}
.contact-socials a{width:37px;height:37px;border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.88rem;transition:all .25s var(--ease);}
.contact-socials a:hover{border-color:var(--green);color:var(--green);background:rgba(57,181,74,.07);transform:translateY(-3px);}
.contact-form{display:flex;flex-direction:column;gap:11px;}
.form-field input,.form-field textarea{width:100%;padding:11px 14px;background:var(--card);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:'Inter',sans-serif;font-size:.88rem;outline:none;transition:border-color .25s,box-shadow .25s;resize:vertical;}
.form-field input:focus,.form-field textarea:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(57,181,74,.09);}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--muted);}
.form-msg{font-size:.76rem;margin-top:5px;min-height:16px;}
.form-msg.ok{color:var(--green);}.form-msg.err{color:#f87171;}

/* ══════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════ */
.site-footer{background:var(--card);border-top:1px solid var(--border);padding:36px 0 24px;}
.footer-top{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;margin-bottom:28px;}
.footer-logo img{height:32px;object-fit:contain;opacity:.7;background:transparent;transition:opacity .25s;}
.footer-logo:hover img{opacity:1;}
.footer-nav{display:flex;gap:20px;flex-wrap:wrap;}
.footer-nav a{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);transition:color .25s;}
.footer-nav a:hover{color:var(--green);}
.footer-social{display:flex;gap:8px;}
.footer-social a{width:33px;height:33px;border:1px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.84rem;transition:all .25s;}
.footer-social a:hover{border-color:var(--green);color:var(--green);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;border-top:1px solid var(--border);padding-top:16px;font-size:.68rem;color:var(--muted);}

/* ══════════════════════════════════════════════════════════
   GO TOP
   ══════════════════════════════════════════════════════════ */
.go-top{position:fixed;bottom:24px;right:24px;width:40px;height:40px;background:var(--green);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#000;font-size:.85rem;opacity:0;visibility:hidden;transition:all .3s var(--ease);z-index:700;box-shadow:0 4px 18px rgba(57,181,74,.28);}
.go-top.visible{opacity:1;visibility:visible;}
.go-top:hover{transform:translateY(-4px);box-shadow:0 8px 26px rgba(57,181,74,.38);}

/* ══════════════════════════════════════════════════════════
   REVEAL
   ══════════════════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in-view{opacity:1;transform:none;}
.rd1{transition-delay:.07s}.rd2{transition-delay:.14s}.rd3{transition-delay:.21s}.rd4{transition-delay:.28s}.rd5{transition-delay:.35s}

/* NOISE */
.noise-overlay{position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:.018;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
.m5-hidden{display:none!important;}

@media(max-width:768px){.section{padding:80px 0;}.s-hero{padding:110px 22px 70px;}.stats-row{grid-template-columns:1fr 1fr;}.footer-top{flex-direction:column;text-align:center;}.footer-bottom{justify-content:center;}}
@media(max-width:480px){.stats-row{grid-template-columns:1fr;}.hero-cta{flex-direction:column;}}

/* ══════════════════════════════════════════════════════════
   MOBILE RESPONSIVE — Full overhaul
   ══════════════════════════════════════════════════════════ */

/* Tablet (≤900px) */
@media (max-width: 900px) {
  .section { padding: 80px 0; }
  .s-hero { padding: 100px 24px 70px; }

  /* About */
  .about-grid { grid-template-columns: 1fr; gap: 44px; }
  .stats-row  { grid-template-columns: repeat(3,1fr); gap: 12px; }

  /* Services */
  .services-grid { grid-template-columns: repeat(2,1fr); gap: 16px; }

  /* Works */
  .works-grid { grid-template-columns: repeat(2,1fr); gap: 14px; }

  /* Contact */
  .contact-grid { grid-template-columns: 1fr; gap: 44px; }

  /* Footer */
  .footer-top { flex-direction: column; align-items: flex-start; gap: 20px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 6px; }
}

/* Mobile (≤600px) */
@media (max-width: 600px) {
  html { font-size: 15px; }
  .container { padding: 0 18px; }

  /* Header */
  .header-wrap { padding: 0 18px; }
  .header-logo img { height: 32px; }

  /* Hero */
  .s-hero { padding: 88px 18px 64px; min-height: 100svh; }
  .hero-title { font-size: clamp(3.2rem, 14vw, 5.5rem); }
  .hero-sub { font-size: .88rem; }
  .hero-cta { flex-direction: column; gap: 10px; }
  .hero-cta .btn { width: 100%; justify-content: center; }
  .hero-location { right: 18px; font-size: .65rem; }
  .hero-scroll { display: none; }

  /* Sections */
  .section { padding: 60px 0; }
  .section-heading { font-size: clamp(2.2rem, 8vw, 3rem); margin-bottom: 24px; }
  .section-header { margin-bottom: 36px; }

  /* About */
  .stats-row { grid-template-columns: repeat(3,1fr); gap: 10px; }
  .stat { padding: 16px 6px; }
  .stat-num { font-size: 2rem; }
  .stat-sym { font-size: 1rem; }
  .stat-desc { font-size: .6rem; }
  .skill-row { grid-template-columns: 90px 1fr 30px; gap: 8px; font-size: .72rem; }
  .about-contact-line { flex-direction: column; gap: 10px; }

  /* Services */
  .services-grid { grid-template-columns: 1fr; gap: 12px; }
  .service-card { padding: 22px 18px; }

  /* Works */
  .works-grid { grid-template-columns: 1fr; gap: 14px; }

  /* Behance embed */
  .dribbble-embed-inner { height: 340px; }

  /* Contact */
  .contact-form { gap: 10px; }
  .form-field input, .form-field textarea { padding: 11px 12px; font-size: .85rem; }

  /* Footer */
  .footer-top { padding-bottom: 4px; }
  .footer-nav { gap: 14px; flex-wrap: wrap; }
  .footer-nav a { font-size: .68rem; }
  .footer-bottom { font-size: .65rem; }

  /* Buttons */
  .btn { padding: 11px 22px; font-size: .75rem; }
  .go-top { bottom: 16px; right: 16px; width: 36px; height: 36px; font-size: .8rem; }

  /* Nav mobile full screen */
  .header-nav ul a { font-size: 1.4rem; letter-spacing: .06em; }
  .header-admin-btn { font-size: .8rem !important; padding: 10px 20px !important; }
}

/* Small mobile (≤380px) */
@media (max-width: 380px) {
  .stats-row { grid-template-columns: 1fr 1fr; }
  .stat:last-child { grid-column: 1 / -1; }
  .hero-title { font-size: clamp(2.8rem, 15vw, 4rem); }
  .section-heading { font-size: clamp(2rem, 9vw, 2.6rem); }
}

/* Links page mobile */
@media (max-width: 480px) {
  .link-btn { padding: 13px 14px; gap: 12px; }
  .btn-icon-wrap { width: 38px; height: 38px; font-size: 1rem; }
  .brand-name { font-size: 2rem; }
  .logo-circle { width: 96px; height: 96px; }
}

/* Portfolio page mobile */
@media (max-width: 480px) {
  .port-hero { padding: 110px 18px 50px; }
  .port-hero h1 { font-size: clamp(3.5rem, 16vw, 6rem); }
  .behance-grid { grid-template-columns: 1fr; gap: 16px; }
  .behance-info { padding: 14px 14px; }
}

/* Login page mobile */
@media (max-width: 480px) {
  .login-card { padding: 32px 22px 28px; margin: 16px; border-radius: 18px; }
  .brand-name { font-size: 1.4rem; }
  .attempt-row { margin-bottom: 14px; }
}

/* Touch: remove hover effects that feel wrong on mobile */
@media (hover: none) {
  .service-card:hover,
  .work-card:hover,
  .stat:hover { transform: none !important; box-shadow: none !important; }
  .btn:hover { transform: none !important; }
  .contact-socials a:hover { transform: none !important; }
}
