/*
Theme Name: Pixel Square
Theme URI: https://pixelsquare.ca
Author: Pixel Square
Author URI: https://pixelsquare.ca
Description: Custom WordPress theme for Pixel Square — a Winnipeg-based creative and automation studio offering graphic design, animation, 3D animation, and business automation services.
Version: 1.2.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: Private
Text Domain: pixelsquare
*/

:root {
  --bg-dark:#0e0f0c;--bg-dark-2:#131510;--bg-mid:#1a1d16;
  --bg-light:#f2f0eb;--bg-light-2:#e8e5de;--white:#ffffff;--black:#0a0b09;
  --green:#6dbf2f;--green-bright:#8edb4a;--green-dark:#3a7a10;
  --green-pale:#eaf5d8;--green-glow:rgba(109,191,47,0.12);
  --text-dark:#e8e4dc;--text-muted:#72756a;--text-light:#1c1e18;--text-light-m:#5a5d52;
  --border-dark:rgba(109,191,47,0.1);--border-light:rgba(28,30,24,0.12);
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'DM Sans',system-ui,sans-serif;
  --ease:cubic-bezier(0.16,1,0.3,1);--ease-back:cubic-bezier(0.34,1.56,0.64,1);--r:4px;--rl:10px;
  --shadow:0 8px 40px rgba(0,0,0,0.3);--shadow-g:0 8px 32px rgba(109,191,47,0.2);
  --shadow-card:0 2px 16px rgba(0,0,0,0.2);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{background:var(--bg-dark);color:var(--text-dark);font-family:var(--font-body);font-weight:300;line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased;}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:300;line-height:1.08;letter-spacing:-0.01em;}
h1{font-size:clamp(3rem,7.5vw,7rem);}
h2{font-size:clamp(2rem,4.5vw,3.8rem);}
h3{font-size:clamp(1.3rem,2.5vw,1.9rem);}
p{font-size:1rem;line-height:1.82;}
em{font-style:italic;color:var(--green);}
.container{max-width:1200px;margin:0 auto;padding:0 2.5rem;}
.section{padding:7rem 0;}
.section--dark{background:var(--bg-dark);}
.section--mid{background:var(--bg-mid);}
.section--alt{background:var(--bg-dark-2);}
.section--light{background:var(--bg-light);color:var(--text-light);}
.section--light p{color:var(--text-light-m);}
.section--light h2,.section--light h3,.section--light h4{color:var(--text-light);}
.section-label{display:inline-flex;align-items:center;gap:.75rem;font-size:.68rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--green);margin-bottom:1.2rem;}
.section-label::before{content:'';display:block;width:28px;height:1px;background:var(--green);}
.section-label.dark-label{color:var(--green-dark);}
.section-label.dark-label::before{background:var(--green-dark);}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:.9rem 2rem;border-radius:var(--r);transition:all .3s var(--ease);position:relative;overflow:hidden;}
.btn::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.07);opacity:0;transition:opacity .2s;}
.btn:hover::after{opacity:1;}
.btn-primary{background:var(--green);color:var(--black);}
.btn-primary:hover{background:var(--green-bright);transform:translateY(-2px);box-shadow:var(--shadow-g);}
.btn-outline{border:1px solid rgba(232,228,220,.2);color:var(--text-dark);background:transparent;}
.btn-outline:hover{border-color:var(--green);color:var(--green);transform:translateY(-2px);}
.btn-outline-light{border:1px solid rgba(232,228,220,.2);color:var(--text-dark);background:transparent;}
.btn-outline-light:hover{border-color:var(--green);color:var(--green);transform:translateY(-2px);}
.btn-outline-dark{border:1px solid rgba(28,30,24,.2);color:var(--text-light);}
.btn-outline-dark:hover{background:var(--text-light);color:var(--white);transform:translateY(-2px);}
.btn-ghost{color:var(--text-muted);font-size:.78rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;display:inline-flex;align-items:center;gap:.4rem;background:none;border:none;padding:0;}
.btn-ghost:hover{color:var(--green);}
.btn-ghost::after{content:'→';transition:transform .2s;background:none;}
.btn-ghost:hover::after{transform:translateX(4px);}

/* MOUSE CANVAS */
#ps-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;}

/* NAV */
#masthead{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background .4s,border-color .4s,box-shadow .4s;}
#masthead.scrolled{background:rgba(14,15,12,.92);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border-dark);box-shadow:0 4px 30px rgba(0,0,0,.3);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1.4rem 2.5rem;max-width:1440px;margin:0 auto;}
.nav-logo{display:flex;align-items:center;gap:10px;}
.nav-logo img{height:36px;width:auto;}
.nav-logo-text{font-family:var(--font-display);font-size:1.25rem;font-weight:500;color:var(--white);letter-spacing:.02em;}
.nav-menu{display:flex;align-items:center;gap:2.5rem;}
.nav-menu a{font-size:.76rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;color:rgba(232,228,220,.5);position:relative;transition:color .2s;}
.nav-menu a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--green);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease);}
.nav-menu a:hover,.nav-menu a.active{color:var(--white);}
.nav-menu a:hover::after,.nav-menu a.active::after{transform:scaleX(1);}
.nav-cta{background:var(--green)!important;color:var(--black)!important;padding:.5rem 1.4rem;border-radius:var(--r);font-weight:500!important;transition:all .25s var(--ease)!important;}
.nav-cta::after{display:none!important;}
.nav-cta:hover{background:var(--green-bright)!important;transform:translateY(-1px);}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:4px;}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--white);transition:all .3s;}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.nav-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:10rem 0 5rem;position:relative;overflow:hidden;background:var(--bg-dark);}
.hero-bg{position:absolute;inset:0;pointer-events:none;z-index:0;}
.hero-dots{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(109,191,47,.045) 1px,transparent 1px);background-size:48px 48px;animation:dotsPulse 8s ease-in-out infinite;}
.hero-glow{position:absolute;top:-20%;right:-10%;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(109,191,47,.07) 0%,transparent 65%);animation:glowPulse 6s ease-in-out infinite;}
.hero-glow-2{position:absolute;bottom:-20%;left:-10%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(109,191,47,.04) 0%,transparent 65%);animation:glowPulse 6s ease-in-out infinite 3s;}
.hero-content{position:relative;z-index:2;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.75rem;font-size:.68rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--green);margin-bottom:1.5rem;opacity:0;animation:fadeUp .8s .2s var(--ease) forwards;}
.hero-eyebrow::before{content:'';width:28px;height:1px;background:var(--green);}
.hero h1{color:var(--white);margin-bottom:1.5rem;opacity:0;animation:fadeUp .9s .4s var(--ease) forwards;max-width:900px;}
.hero-tagline{font-size:1.05rem;color:var(--text-muted);max-width:500px;margin-bottom:2.5rem;opacity:0;animation:fadeUp .9s .55s var(--ease) forwards;}
.hero-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;opacity:0;animation:fadeUp .9s .7s var(--ease) forwards;}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2;opacity:0;animation:fadeIn 1s 1.3s forwards;}
.hero-scroll-line{width:1px;height:40px;background:var(--green);animation:scrollLine 1.5s ease-in-out infinite;}
.hero-scroll-text{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);}
.hero-stats{display:flex;gap:3rem;margin-top:5rem;padding-top:2.5rem;border-top:1px solid var(--border-dark);flex-wrap:wrap;opacity:0;animation:fadeUp .9s .85s var(--ease) forwards;}
.stat-num{font-family:var(--font-display);font-size:2.8rem;font-weight:300;color:var(--green);line-height:1;}
.stat-label{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-top:.3rem;}

/* HERO FLOATING BADGE */
.hero-badge{position:absolute;right:5%;top:30%;z-index:3;background:rgba(20,23,17,.85);border:1px solid var(--border-dark);border-radius:var(--rl);padding:1rem 1.4rem;backdrop-filter:blur(12px);animation:float 5s ease-in-out infinite,fadeIn 1s .9s forwards;opacity:0;}
.hero-badge-label{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.4rem;}
.hero-badge-val{font-family:var(--font-display);font-size:1.5rem;color:var(--green);line-height:1;}
.hero-badge-sub{font-size:.65rem;color:var(--text-muted);margin-top:.2rem;}

/* MARQUEE */
.marquee-section{padding:1.1rem 0;background:var(--green);overflow:hidden;position:relative;z-index:2;}
.marquee-track{display:flex;gap:3rem;white-space:nowrap;animation:marquee 25s linear infinite;}
.marquee-track span{font-size:.68rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(10,11,9,.7);flex-shrink:0;}
.marquee-track .dot{color:rgba(10,11,9,.3);}

/* SERVICES INTRO (home) */
.services-intro{display:grid;grid-template-columns:1fr .9fr;gap:6rem;align-items:center;}
.services-intro-list{display:flex;flex-direction:column;gap:0;}
.service-item{display:grid;grid-template-columns:3rem 1fr auto;align-items:center;gap:1.2rem;padding:1.4rem 0;border-bottom:1px solid var(--border-dark);text-decoration:none;color:inherit;transition:all .25s var(--ease);cursor:pointer;}
.service-item:first-child{border-top:1px solid var(--border-dark);}
.service-item:hover{padding-left:.6rem;border-color:rgba(109,191,47,.3);}
.service-num{font-family:var(--font-display);font-size:1rem;font-weight:300;color:rgba(109,191,47,.35);line-height:1;transition:color .25s;}
.service-item:hover .service-num{color:var(--green);}
.service-item-title{font-family:var(--font-display);font-size:1.25rem;font-weight:400;color:var(--white);display:block;margin-bottom:.2rem;transition:color .25s;}
.service-item-desc{font-size:.82rem;color:var(--text-muted);line-height:1.6;}
.service-item-arrow{color:rgba(109,191,47,.3);font-size:1.1rem;transition:all .25s var(--ease);flex-shrink:0;}
.service-item:hover .service-item-arrow{color:var(--green);transform:translateX(4px);}
.services-intro-visual{display:flex;align-items:center;justify-content:center;position:relative;aspect-ratio:1;background:var(--bg-dark-2);border:1px solid var(--border-dark);border-radius:var(--rl);overflow:hidden;}
.services-intro-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 60% 40%,rgba(109,191,47,.08),transparent 65%);}
.services-intro-visual img{width:55%;object-fit:contain;position:relative;z-index:1;filter:drop-shadow(0 0 40px rgba(109,191,47,.2));animation:float 6s ease-in-out infinite;}
.services-intro-visual-rings{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;}
.ring{border:1px solid var(--border-dark);border-radius:50%;position:absolute;animation:ringPulse 3s ease-in-out infinite;}
.ring:nth-child(1){width:60%;height:60%;animation-delay:0s;}
.ring:nth-child(2){width:78%;height:78%;animation-delay:.8s;}
.ring:nth-child(3){width:95%;height:95%;animation-delay:1.6s;}

/* SERVICES HOME GRID */
.services-home-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border-dark);border:1px solid var(--border-dark);border-radius:var(--rl);overflow:hidden;}
.service-home-card{background:var(--bg-dark-2);padding:3rem 2.5rem;position:relative;overflow:hidden;transition:background .35s;}
.service-home-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--green),transparent);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);}
.service-home-card::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(109,191,47,.06),transparent 60%);opacity:0;transition:opacity .3s;}
.service-home-card:hover{background:var(--bg-mid);}
.service-home-card:hover::before{transform:scaleX(1);}
.service-home-card:hover::after{opacity:1;}
.s-num{font-family:var(--font-display);font-size:4.5rem;font-weight:300;color:rgba(109,191,47,.08);line-height:1;margin-bottom:1rem;transition:color .3s;}
.service-home-card:hover .s-num{color:rgba(109,191,47,.2);}
.s-name{font-family:var(--font-display);font-size:1.9rem;font-weight:400;color:var(--white);margin-bottom:.75rem;}
.s-desc{font-size:.88rem;color:var(--text-muted);line-height:1.8;margin-bottom:1.2rem;}
.s-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.5rem;}
.s-tag{font-size:.6rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.25rem .7rem;border:1px solid var(--border-dark);color:var(--text-muted);border-radius:20px;transition:all .2s;}
.service-home-card:hover .s-tag{border-color:rgba(109,191,47,.25);color:var(--green);}
.s-link{font-size:.68rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--green);display:inline-flex;align-items:center;gap:.4rem;transition:gap .2s;}
.service-home-card:hover .s-link{gap:.7rem;}

/* SERVICES PAGE */
.service-detail{display:grid;grid-template-columns:1fr 1fr;min-height:500px;}
.service-detail:nth-child(odd) .service-detail-visual{order:2;}
.service-detail-content{padding:4.5rem 3.5rem;display:flex;flex-direction:column;justify-content:center;}
.service-detail-content.dark{background:var(--bg-dark-2);}
.service-detail-content.light{background:var(--bg-light);color:var(--text-light);}
.service-detail-content.light p{color:var(--text-light-m);}
.service-detail-content.light h2,.service-detail-content.light h3{color:var(--text-light);}
.service-detail-visual{display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:var(--bg-mid);}
.service-detail-visual.light-vis{background:var(--bg-light-2);}
.service-vis-num{font-family:var(--font-display);font-size:clamp(8rem,16vw,15rem);font-weight:300;color:rgba(109,191,47,.06);position:absolute;line-height:1;user-select:none;}
.service-detail-visual.light-vis .service-vis-num{color:rgba(109,191,47,.12);}
.service-vis-icon{position:relative;z-index:1;font-size:4.5rem;animation:float 4s ease-in-out infinite;}
.service-features{display:flex;flex-direction:column;gap:.55rem;margin:1.5rem 0 2rem;}
.service-feature{display:flex;align-items:flex-start;gap:.75rem;font-size:.88rem;line-height:1.6;}
.service-feature::before{content:'→';color:var(--green);flex-shrink:0;}
.service-feature.on-light{color:var(--text-light-m);}

/* PORTFOLIO — MASONRY */
.portfolio-filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:3rem;}
.filter-btn{font-size:.68rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.5rem 1.2rem;border-radius:20px;border:1px solid var(--border-dark);color:var(--text-muted);cursor:pointer;transition:all .25s var(--ease);background:transparent;}
.filter-btn:hover{border-color:var(--green);color:var(--green);transform:translateY(-1px);}
.filter-btn.active{background:var(--green);border-color:var(--green);color:var(--black);}

/* Grid layout — works correctly with JS filtering */
.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
  align-items:start; /* rows size to content — gives masonry-like visual */
}
.portfolio-item{
  display:block;
  width:100%;
  background:var(--bg-dark-2);
  border:1px solid var(--border-dark);
  border-radius:var(--rl);
  overflow:hidden;
  transition:transform .4s var(--ease),box-shadow .4s,border-color .4s,opacity .35s;
}
.portfolio-item:hover{transform:translateY(-6px);box-shadow:0 12px 48px rgba(0,0,0,.35);border-color:rgba(109,191,47,.3);}
.portfolio-item.hidden{display:none;}

/* Vary thumbnail heights for masonry depth */
.portfolio-item:nth-child(3n+1) .p-thumb{aspect-ratio:4/3;}
.portfolio-item:nth-child(3n+2) .p-thumb{aspect-ratio:1/1;}
.portfolio-item:nth-child(3n)   .p-thumb{aspect-ratio:16/10;}

.p-thumb{overflow:hidden;position:relative;background:var(--bg-mid);}
.p-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);}
.portfolio-item:hover .p-thumb img{transform:scale(1.08);}
.p-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;min-height:200px;}
.p-cat-badge{position:absolute;top:1rem;left:1rem;font-size:.6rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;background:var(--green);color:var(--black);padding:.3rem .8rem;border-radius:20px;}
.p-body{padding:1.5rem;}
.p-title{font-family:var(--font-display);font-size:1.4rem;font-weight:400;color:var(--white);margin-bottom:.35rem;line-height:1.2;}
.p-client{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.6rem;}
.p-excerpt{font-size:.84rem;color:var(--text-muted);line-height:1.7;margin-bottom:1rem;}
.p-link{font-size:.65rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--green);display:inline-flex;align-items:center;gap:.4rem;transition:gap .2s;}
.portfolio-item:hover .p-link{gap:.7rem;}
.portfolio-item:hover .p-title{color:var(--green-bright);transition:color .2s;}

/* PROJECTS HOME — featured asymmetric grid */
.projects-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.5rem;}
.project-card{background:var(--bg-dark-2);border:1px solid var(--border-dark);border-radius:var(--rl);overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s,border-color .4s;}
.project-card:hover{transform:translateY(-8px);box-shadow:0 16px 52px rgba(0,0,0,.4);border-color:rgba(109,191,47,.3);}
.project-card:nth-child(1){grid-column:span 7;}
.project-card:nth-child(2){grid-column:span 5;}
.project-card:nth-child(3){grid-column:span 5;}
.project-card:nth-child(4){grid-column:span 7;}
.project-thumb{aspect-ratio:16/9;background:var(--bg-mid);overflow:hidden;position:relative;}
.project-card:nth-child(1) .project-thumb,.project-card:nth-child(4) .project-thumb{aspect-ratio:3/2;}
.project-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);}
.project-card:hover .project-thumb img{transform:scale(1.07);}
.project-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;}
.project-cat{position:absolute;top:1rem;left:1rem;font-size:.6rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;background:var(--green);color:var(--black);padding:.3rem .75rem;border-radius:20px;}
.project-body{padding:1.5rem;}
.project-title{font-family:var(--font-display);font-size:1.4rem;font-weight:400;color:var(--white);margin-bottom:.5rem;transition:color .2s;}
.project-card:hover .project-title{color:var(--green-bright);}
.project-excerpt{font-size:.84rem;color:var(--text-muted);line-height:1.7;margin-bottom:1rem;}
.project-link{font-size:.65rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--green);display:inline-flex;align-items:center;gap:.4rem;transition:gap .2s;}
.project-card:hover .project-link{gap:.7rem;}

/* PROJECT SINGLE */
.project-hero{padding:9rem 0 4rem;background:var(--bg-dark);border-bottom:1px solid var(--border-dark);}
.project-meta{display:flex;gap:3rem;flex-wrap:wrap;margin-top:2rem;}
.project-meta-item label{font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);display:block;margin-bottom:.3rem;}
.project-meta-item span{font-size:.9rem;color:var(--text-dark);}
.project-content{padding:5rem 0;background:var(--bg-dark);}
.project-content .container{display:grid;grid-template-columns:2fr 1fr;gap:5rem;align-items:start;}
.project-body p{color:var(--text-muted);margin-bottom:1rem;}
.project-body h2{color:var(--white);font-size:1.8rem;margin:2rem 0 .8rem;}
.project-sidebar{position:sticky;top:120px;}
.project-sidebar-card{background:var(--bg-dark-2);border:1px solid var(--border-dark);border-radius:var(--rl);padding:1.5rem;margin-bottom:1rem;}
.project-sidebar-title{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1rem;}
.project-gallery{padding:0 0 5rem;background:var(--bg-dark);}
.project-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:2px;}
.project-gallery-item{aspect-ratio:16/10;background:var(--bg-mid);overflow:hidden;}
.project-gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease);}
.project-gallery-item:hover img{transform:scale(1.05);}
.project-nav{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;padding:3rem 0;border-top:1px solid var(--border-dark);}
.project-nav-item{background:var(--bg-dark-2);border:1px solid var(--border-dark);border-radius:var(--rl);padding:1.5rem;transition:all .25s;}
.project-nav-item:hover{border-color:var(--green);transform:translateY(-3px);}
.project-nav-label{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.3rem;}
.project-nav-title{font-family:var(--font-display);font-size:1.1rem;color:var(--white);}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:6rem;align-items:center;}
.about-visual{position:relative;}
.about-img-wrap{aspect-ratio:3/4;background:var(--bg-mid);border:1px solid var(--border-dark);border-radius:var(--rl);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;}
.about-img-wrap::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 40% 50%,rgba(109,191,47,.08),transparent 60%);}
.about-img-wrap img{width:55%;object-fit:contain;position:relative;z-index:1;filter:drop-shadow(0 0 30px rgba(109,191,47,.15));}
.about-glow{position:absolute;width:300px;height:300px;border-radius:50%;background:var(--green-glow);filter:blur(60px);}
.about-corner-decoration{position:absolute;top:-1.5rem;left:-1.5rem;width:50px;height:50px;border-top:2px solid var(--green);border-left:2px solid var(--green);z-index:2;}
.about-accent,.float-badge{position:absolute;bottom:-1.5rem;right:-1.5rem;background:var(--green);color:var(--black);padding:1.4rem 1.8rem;border-radius:var(--rl);z-index:2;animation:float 5s ease-in-out infinite;}
.about-accent-num{font-family:var(--font-display);font-size:2.2rem;font-weight:300;line-height:1;}
.about-accent-label{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;opacity:.8;margin-top:.2rem;}
.about-visual-wrap{position:relative;aspect-ratio:3/4;background:var(--bg-mid);border:1px solid var(--border-dark);border-radius:var(--rl);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.about-visual-wrap img{width:55%;object-fit:contain;position:relative;z-index:1;}
.about-corner{position:absolute;top:-1.5rem;left:-1.5rem;width:50px;height:50px;border-top:2px solid var(--green);border-left:2px solid var(--green);}

/* PROCESS SECTION */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:3.5rem;}
.process-step{padding:2rem;background:var(--bg-dark-2);border:1px solid var(--border-dark);border-radius:var(--rl);position:relative;transition:border-color .3s,transform .3s var(--ease);}
.process-step:hover{border-color:rgba(109,191,47,.3);transform:translateY(-4px);}
.process-step::before{content:attr(data-step);position:absolute;top:1.5rem;right:1.5rem;font-family:var(--font-display);font-size:3rem;font-weight:300;color:rgba(109,191,47,.06);line-height:1;}
.process-step-icon{font-size:1.5rem;margin-bottom:1rem;}
.process-step-title{font-family:var(--font-display);font-size:1.15rem;font-weight:400;color:var(--white);margin-bottom:.5rem;}
.process-step-desc{font-size:.83rem;color:var(--text-muted);line-height:1.7;}
.process-connector{display:none;}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:6rem;align-items:start;}
.contact-info-item{display:flex;gap:1rem;align-items:flex-start;margin-bottom:2rem;}
.contact-icon{width:40px;height:40px;background:rgba(109,191,47,.1);border:1px solid rgba(109,191,47,.2);border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--green);font-size:1rem;}
.contact-info-label{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.2rem;}
.contact-info-val{font-size:.95rem;color:var(--text-dark);}
.contact-form-field{width:100%;background:var(--bg-dark-2);border:1px solid var(--border-dark);color:var(--text-dark);padding:.85rem 1rem;font-family:var(--font-body);font-size:.9rem;font-weight:300;border-radius:var(--r);transition:border-color .2s,box-shadow .2s;outline:none;}
.contact-form-field:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(109,191,47,.08);}
.contact-form-field::placeholder{color:var(--text-muted);}
select.contact-form-field option{background:var(--bg-dark-2);}
textarea.contact-form-field{min-height:140px;resize:vertical;}
.contact-form-submit{background:var(--green);color:var(--black);border:none;cursor:pointer;font-family:var(--font-body);font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;padding:.95rem 2.2rem;border-radius:var(--r);transition:all .25s var(--ease);margin-top:1.5rem;}
.contact-form-submit:hover{background:var(--green-bright);transform:translateY(-2px);box-shadow:var(--shadow-g);}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.form-label{font-size:.67rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);display:block;margin-bottom:.4rem;margin-top:1rem;}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:2rem;}
.blog-card{background:var(--bg-dark-2);border:1px solid var(--border-dark);border-radius:var(--rl);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;}
.blog-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:rgba(109,191,47,.2);}
.blog-thumb{aspect-ratio:16/9;background:var(--bg-mid);overflow:hidden;}
.blog-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease);}
.blog-card:hover .blog-thumb img{transform:scale(1.05);}
.blog-body{padding:1.5rem;}
.blog-cat{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:.5rem;display:block;}
.blog-title{font-family:var(--font-display);font-size:1.4rem;color:var(--white);margin-bottom:.5rem;line-height:1.2;}
.blog-excerpt{font-size:.85rem;color:var(--text-muted);line-height:1.7;margin-bottom:1rem;}
.blog-meta{font-size:.72rem;color:var(--text-muted);display:flex;gap:1rem;}

/* PAGE HERO */
.page-hero{padding:10rem 0 5rem;background:var(--bg-dark);border-bottom:1px solid var(--border-dark);position:relative;overflow:hidden;}
.page-hero-bg{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(109,191,47,.05) 1px,transparent 1px);background-size:44px 44px;pointer-events:none;}
.page-hero-content{position:relative;z-index:1;}
.breadcrumb{display:flex;gap:.5rem;align-items:center;margin-bottom:1.5rem;font-size:.74rem;color:var(--text-muted);}
.breadcrumb a{color:var(--green);}
.breadcrumb-sep{color:rgba(109,191,47,.2);}

/* CTA BAND */
.cta-band{padding:7rem 0;background:var(--bg-mid);position:relative;overflow:hidden;border-top:1px solid var(--border-dark);border-bottom:1px solid var(--border-dark);text-align:center;}
.cta-band::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(109,191,47,.07) 0%,transparent 65%);}
.cta-band::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(109,191,47,.03) 1px,transparent 1px);background-size:44px 44px;pointer-events:none;}
.cta-band h2{color:var(--white);position:relative;z-index:1;}
.cta-band p{color:var(--text-muted);position:relative;z-index:1;max-width:500px;margin:.8rem auto 0;}
.cta-band .section-label{justify-content:center;position:relative;z-index:1;}
.cta-band .btn{position:relative;z-index:1;}

/* FOOTER */
#colophon{background:var(--black);color:var(--white);padding:5rem 0 2rem;border-top:1px solid var(--border-dark);}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:3rem;margin-bottom:4rem;}
.footer-brand-logo{display:flex;align-items:center;gap:10px;margin-bottom:1rem;}
.footer-brand-logo img{height:32px;}
.footer-brand-name{font-family:var(--font-display);font-size:1.2rem;color:var(--white);}
.footer-tagline{font-size:.82rem;color:rgba(232,228,220,.3);line-height:1.7;margin-bottom:1.5rem;}
.footer-social{display:flex;gap:.75rem;}
.footer-social a{width:36px;height:36px;border-radius:var(--r);border:1px solid rgba(232,228,220,.08);display:flex;align-items:center;justify-content:center;font-size:.75rem;color:rgba(232,228,220,.35);transition:all .25s var(--ease);}
.footer-social a:hover{border-color:var(--green);color:var(--green);transform:translateY(-2px);}
.footer-col-title{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(232,228,220,.3);margin-bottom:1.2rem;}
.footer-links{display:flex;flex-direction:column;gap:.6rem;}
.footer-links a,.footer-links span{font-size:.85rem;color:rgba(232,228,220,.5);}
.footer-links a:hover{color:var(--green);}
.footer-bottom{border-top:1px solid rgba(232,228,220,.05);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;}
.footer-copy{font-size:.74rem;color:rgba(232,228,220,.2);}
.footer-legal{display:flex;gap:1.5rem;}
.footer-legal a{font-size:.74rem;color:rgba(232,228,220,.2);transition:color .2s;}
.footer-legal a:hover{color:var(--green);}

/* CURSOR */
.cursor{width:8px;height:8px;background:var(--green);border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s,height .3s,background .2s;}
.cursor-ring{width:32px;height:32px;border:1px solid rgba(109,191,47,.5);border-radius:50%;position:fixed;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s,opacity .3s;}
.cursor.hover{width:14px;height:14px;}
.cursor-ring.hover{width:52px;height:52px;opacity:.25;}
.cursor.clicking{transform:translate(-50%,-50%) scale(.85);}

/* SCROLL REVEAL */
[data-reveal]{opacity:0;transform:translateY(32px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
[data-reveal].revealed{opacity:1;transform:none;}
[data-reveal="left"]{transform:translateX(-32px);}[data-reveal="left"].revealed{transform:none;}
[data-reveal="right"]{transform:translateX(32px);}[data-reveal="right"].revealed{transform:none;}
[data-reveal="scale"]{transform:scale(.95);}[data-reveal="scale"].revealed{transform:none;}
[data-delay="1"]{transition-delay:.1s;}[data-delay="2"]{transition-delay:.2s;}
[data-delay="3"]{transition-delay:.3s;}[data-delay="4"]{transition-delay:.4s;}
[data-delay="5"]{transition-delay:.5s;}[data-delay="6"]{transition-delay:.6s;}

/* PROGRESS BAR */
#read-progress{position:fixed;top:0;left:0;height:2px;background:var(--green);z-index:2000;width:0%;transition:width .1s linear;box-shadow:0 0 8px rgba(109,191,47,.5);}

/* TILT CARD */
.tilt-card{transform-style:preserve-3d;will-change:transform;}

/* NOISE OVERLAY */
.noise-overlay{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-size:128px 128px;}

/* 404 */
.error-404{min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center;}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:none;}}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes marquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top;}50%{transform:scaleY(1);transform-origin:top;}50.01%{transform:scaleY(1);transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-14px);}}
@keyframes glowPulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.6;transform:scale(1.08);}}
@keyframes dotsPulse{0%,100%{opacity:1;}50%{opacity:.5;}}
@keyframes ringPulse{0%,100%{opacity:.3;transform:scale(1);}50%{opacity:.07;transform:scale(1.04);}}
@keyframes shimmer{0%{background-position:-200% 0;}100%{background-position:200% 0;}}
@keyframes gradientShift{0%{background-position:0% 50%;}50%{background-position:100% 50%;}100%{background-position:0% 50%;}}
@keyframes fadeSlideIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}

/* SERVICE OVERVIEW GRID (compact 2x2, page-services.php) */
.service-overview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;}
.service-overview-card{background:var(--bg-dark-2);border:1px solid var(--border-dark);border-radius:var(--rl);padding:2.5rem;position:relative;overflow:hidden;transition:border-color .35s,transform .35s var(--ease),box-shadow .35s;}
.service-overview-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--green),transparent);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);}
.service-overview-card:hover{border-color:rgba(109,191,47,.3);transform:translateY(-4px);box-shadow:0 16px 52px rgba(0,0,0,.35);}
.service-overview-card:hover::before{transform:scaleX(1);}
.service-overview-card-num{position:absolute;top:1.5rem;right:2rem;font-family:var(--font-display);font-size:5rem;font-weight:300;color:rgba(109,191,47,.05);line-height:1;user-select:none;transition:color .35s;}
.service-overview-card:hover .service-overview-card-num{color:rgba(109,191,47,.12);}
.service-overview-badge{display:inline-flex;align-items:center;gap:.5rem;font-size:.65rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--green);margin-bottom:.8rem;}
.service-overview-title{font-family:var(--font-display);font-size:1.7rem;font-weight:400;color:var(--white);margin-bottom:.8rem;line-height:1.15;}
.service-overview-title em{color:var(--green);}
.service-overview-desc{font-size:.88rem;color:var(--text-muted);line-height:1.8;margin-bottom:1.5rem;}
.service-overview-features{list-style:none;padding:0;margin:0 0 2rem;border-top:1px solid var(--border-dark);padding-top:1.2rem;display:flex;flex-direction:column;gap:.45rem;}
.service-overview-features li{font-size:.84rem;color:var(--text-muted);display:flex;align-items:flex-start;gap:.6rem;transition:color .2s;}
.service-overview-features li::before{content:'→';color:var(--green);flex-shrink:0;opacity:.7;}
.service-overview-card:hover .service-overview-features li{color:rgba(232,228,220,.65);}
.service-overview-cta{font-size:.72rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);display:inline-flex;align-items:center;gap:.4rem;transition:all .2s;}
.service-overview-cta:hover{color:var(--green);gap:.7rem;}
.service-overview-cta::after{content:'↗';}

/* SERVICE DEDICATED PAGES */
.service-page-hero{padding-bottom:6rem;}
.service-deliverables-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;}
.service-deliverable{background:var(--bg-dark-2);border:1px solid var(--border-dark);border-radius:var(--rl);padding:1.4rem 1.6rem;display:flex;align-items:flex-start;gap:.85rem;transition:border-color .25s,transform .25s var(--ease);}
.service-deliverable:hover{border-color:rgba(109,191,47,.25);transform:translateY(-2px);}
.service-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;position:relative;}
.service-steps::before{content:'';position:absolute;top:2rem;left:16%;right:16%;height:1px;background:linear-gradient(90deg,transparent,var(--border-dark) 20%,var(--border-dark) 80%,transparent);}
.service-step{text-align:center;position:relative;z-index:1;}
.service-outcomes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.service-outcome{background:var(--bg-dark-2);border:1px solid var(--border-dark);border-radius:var(--rl);padding:2rem;text-align:center;transition:border-color .25s,transform .25s var(--ease);}
.service-outcome:hover{border-color:rgba(109,191,47,.25);transform:translateY(-3px);}

/* FAQ ACCORDION */
.service-faq{max-width:700px;}
.faq-item{border-bottom:1px solid var(--border-dark);}
.faq-item:first-child{border-top:1px solid var(--border-dark);}
.faq-question{cursor:pointer;padding:1.3rem 0;font-family:var(--font-display);font-size:1.1rem;font-weight:400;color:var(--white);display:flex;justify-content:space-between;align-items:center;user-select:none;gap:1rem;transition:color .2s;}
.faq-question:hover{color:var(--green);}
.faq-question::after{content:'+';color:var(--green);font-size:1.5rem;font-weight:300;line-height:1;flex-shrink:0;transition:transform .3s var(--ease);}
.faq-item.open .faq-question::after{transform:rotate(45deg);}
.faq-answer{overflow:hidden;max-height:0;transition:max-height .4s ease,padding .3s ease;}
.faq-answer p{font-size:.88rem;color:var(--text-muted);line-height:1.8;}
.faq-item.open .faq-answer{max-height:300px;padding-bottom:1.3rem;}

/* LEGAL PAGES — Privacy Policy & Terms of Use */
.legal-body{display:flex;flex-direction:column;gap:0;}
.legal-section{padding:3rem 0;border-bottom:1px solid var(--border-dark);position:relative;}
.legal-section:last-child{border-bottom:none;}
.legal-num{font-family:var(--font-display);font-size:4rem;font-weight:300;color:rgba(109,191,47,.1);line-height:1;margin-bottom:.75rem;letter-spacing:-.02em;}
.legal-heading{font-family:var(--font-display);font-size:1.6rem;font-weight:400;color:var(--white);margin-bottom:1.25rem;line-height:1.25;}
.legal-subheading{font-family:var(--font-display);font-size:1.05rem;font-weight:400;color:var(--white);margin:1.75rem 0 .6rem;}
.legal-body p{font-size:.9rem;color:var(--text-muted);line-height:1.85;margin-bottom:1rem;}
.legal-body p:last-child{margin-bottom:0;}
.legal-list{list-style:none;padding:0;margin:.5rem 0 1rem;display:flex;flex-direction:column;gap:.75rem;}
.legal-list li{font-size:.88rem;color:var(--text-muted);line-height:1.8;padding-left:1.25rem;position:relative;}
.legal-list li::before{content:'—';position:absolute;left:0;color:var(--green);font-size:.8rem;top:.1em;}
.legal-list strong{color:var(--white);}

/* VALUE CARDS (about page) */
.value-card{background:var(--bg-dark-2);border:1px solid var(--border-dark);border-radius:var(--rl);padding:2rem;transition:border-color .25s,transform .25s var(--ease);}
.value-card:hover{border-color:rgba(109,191,47,.2);transform:translateY(-3px);}
.value-num{font-family:var(--font-display);font-size:3rem;font-weight:300;color:rgba(109,191,47,.18);line-height:1;margin-bottom:1rem;}
.value-title{font-family:var(--font-display);font-size:1.15rem;font-weight:400;color:var(--white);margin-bottom:.6rem;}
.value-desc{font-size:.88rem;color:var(--text-muted);line-height:1.8;}

/* RESPONSIVE */
@media(max-width:1200px){
  .process-grid{grid-template-columns:repeat(2,1fr);}
  .services-intro{grid-template-columns:1fr;gap:3rem;}
  .services-intro-visual{display:none;}
}
@media(max-width:1200px){
  .service-steps{grid-template-columns:repeat(3,1fr);}
  .service-outcomes{grid-template-columns:repeat(3,1fr);}
}
@media(max-width:1024px){
  .service-overview-grid{grid-template-columns:1fr;}
  .service-steps{grid-template-columns:1fr;}.service-steps::before{display:none;}
  .service-outcomes{grid-template-columns:1fr 1fr;}
  .service-detail{grid-template-columns:1fr;}
  .service-detail:nth-child(odd) .service-detail-visual{order:0;}
  .services-home-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .project-content .container{grid-template-columns:1fr;}
  .project-sidebar{position:static;}
  .about-grid{grid-template-columns:1fr;gap:3rem;}
  .about-img-wrap{max-width:400px;}
  .about-corner-decoration,.float-badge,.about-accent{display:none;}
  .portfolio-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px){
  .service-outcomes{grid-template-columns:1fr;}
  .service-deliverables-grid{grid-template-columns:1fr;}
  .section{padding:5rem 0;}.container{padding:0 1.5rem;}
  .nav-menu{display:none;flex-direction:column;position:fixed;inset:0;background:var(--bg-dark);padding:6rem 2rem 2rem;gap:1.5rem;z-index:999;}
  .nav-menu.open{display:flex;}.nav-menu a{font-size:1.2rem;}
  .nav-toggle{display:flex;}.nav-cta{display:none;}
  .projects-grid{grid-template-columns:1fr;}.project-card:nth-child(n){grid-column:span 1;}
  .contact-grid{grid-template-columns:1fr;gap:3rem;}.form-row-2{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}.hero-stats{gap:2rem;}
  .cursor,.cursor-ring{display:none;}#ps-canvas{display:none;}
  .service-detail-content{padding:2.5rem 1.5rem;}
  .project-nav{grid-template-columns:1fr;}
  .portfolio-grid{grid-template-columns:1fr;}
  .hero-badge{display:none;}
  .process-grid{grid-template-columns:1fr;}
}
