/*
Theme Name: Walton Creative Group
Theme URI: https://waltoncreativegroup.com
Description: Custom theme for Walton Creative Group - Creative Production & Strategy.
Author: Walton Creative Group
Author URI: https://waltoncreativegroup.com
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: wcg-theme
*/

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --cream:#F5F0EB;--warm-white:#FAF8F5;--off-white:#EEEAE5;
  --black:#111;--dark:#1A1A1A;--charcoal:#2A2A2A;
  --gray-800:#333;--gray-600:#555;--gray-400:#888;--gray-200:#CCC;
  --purple:#7E679B;--purple-light:#9680B3;--purple-dark:#654F82;--purple-wash:rgba(126,103,155,0.06);
  --sans:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --serif:'DM Serif Display',Georgia,serif;
  --ease:cubic-bezier(.16,1,.3,1);--max-w:1400px
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--black);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}
button{cursor:pointer;border:none;background:none;font-family:inherit}
.container{max-width:var(--max-w);margin:0 auto;padding:0 clamp(1.5rem,4vw,3rem)}

/* Animations */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}.reveal-d4{transition-delay:.4s}

/* NAV */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.25rem 0;transition:background .4s var(--ease),padding .4s var(--ease)}
.site-nav.scrolled{background:rgba(245,240,235,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:.8rem 0;box-shadow:0 1px 0 rgba(0,0,0,.06)}
.site-nav .container{display:flex;justify-content:space-between;align-items:center}
.logo{font-family:var(--serif);font-size:1.5rem;color:var(--black);letter-spacing:-.03em}
.logo img{height:36px;width:auto}
.nav-links{display:flex;align-items:center;gap:2.2rem}
.nav-links a{font-size:.9rem;font-weight:400;color:var(--gray-600);transition:color .3s}
.nav-links a:hover{color:var(--black)}
.nav-links .cta-link{font-weight:500;color:var(--purple);padding:.5rem 1.25rem;border:1.5px solid var(--purple);border-radius:100px;transition:all .3s var(--ease)}
.nav-links .cta-link:hover{background:var(--purple);color:#fff}
.hamburger{display:none;width:28px;height:20px;position:relative}
.hamburger span{position:absolute;left:0;width:100%;height:2px;background:var(--black);transition:.3s}
.hamburger span:nth-child(1){top:0}.hamburger span:nth-child(2){top:9px}.hamburger span:nth-child(3){top:18px}
.nav-links.show{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:rgba(245,240,235,.98);backdrop-filter:blur(16px);padding:2rem;gap:1.5rem;box-shadow:0 4px 20px rgba(0,0,0,.08)}

/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:10rem 0 6rem}
.hero-eyebrow{font-size:.82rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--purple);margin-bottom:1.5rem}
.hero h1{font-family:var(--serif);font-size:clamp(3rem,7.5vw,7rem);font-weight:400;line-height:1.0;letter-spacing:-.04em;color:var(--black);margin-bottom:2rem;max-width:1000px}
.hero h1 em{font-style:italic;color:var(--purple)}
.hero-sub{font-size:clamp(1rem,1.4vw,1.15rem);color:var(--gray-600);max-width:560px;line-height:1.75;margin-bottom:2.5rem}
.hero-actions{display:flex;gap:1.25rem;align-items:center;flex-wrap:wrap}
.btn-fill{display:inline-flex;align-items:center;gap:.6rem;padding:1rem 2rem;background:var(--black);color:#fff;font-size:.9rem;font-weight:500;border-radius:100px;transition:all .35s var(--ease)}
.btn-fill:hover{background:var(--charcoal);transform:translateY(-1px)}
.btn-outline{display:inline-flex;align-items:center;gap:.6rem;padding:1rem 2rem;border:1.5px solid var(--gray-200);color:var(--black);font-size:.9rem;font-weight:500;border-radius:100px;transition:all .35s var(--ease)}
.btn-outline:hover{border-color:var(--black)}
.btn-purple{background:var(--purple)}.btn-purple:hover{background:var(--purple-light)}

/* REEL */
.reel-banner{background:var(--black);padding:6rem 0;position:relative;overflow:hidden}
.reel-inner{position:relative;aspect-ratio:2.35/1;border-radius:12px;overflow:hidden;background:var(--charcoal);cursor:pointer}
.reel-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(0,0,0,.35);transition:background .4s}
.reel-inner:hover .reel-overlay{background:rgba(0,0,0,.2)}
.play-circle{width:88px;height:88px;border:2px solid rgba(255,255,255,.7);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;transition:all .4s var(--ease)}
.reel-inner:hover .play-circle{transform:scale(1.1);border-color:#fff;background:rgba(126,103,155,.35)}
.play-circle svg{width:24px;height:24px;fill:#fff;margin-left:3px}
.reel-label{font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.7);font-weight:500}
.reel-bg-text{position:absolute;bottom:-2rem;left:-1rem;font-family:var(--serif);font-size:clamp(6rem,14vw,14rem);font-weight:400;color:rgba(255,255,255,.03);white-space:nowrap;pointer-events:none;letter-spacing:-.04em}

/* Section patterns */
.section-intro{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:end;margin-bottom:4rem}
.section-intro h2{font-family:var(--serif);font-size:clamp(2.2rem,4.5vw,3.8rem);font-weight:400;line-height:1.08;letter-spacing:-.03em}
.section-intro h2 em{font-style:italic;color:var(--purple)}
.section-intro p{font-size:1rem;color:var(--gray-600);line-height:1.7;max-width:440px;justify-self:end}
.section-eyebrow{font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--purple);margin-bottom:1rem}

/* WHAT WE DO */
.what-we-do{padding:8rem 0;background:var(--warm-white)}
.what-we-do .intro-body{font-size:1.05rem;color:var(--gray-600);max-width:640px;line-height:1.75;margin-bottom:3.5rem}
.service-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.tile{padding:2rem 1.75rem;background:var(--cream);border:1px solid rgba(0,0,0,.06);border-radius:8px;transition:all .35s var(--ease);position:relative;overflow:hidden}
.tile::before{content:'';position:absolute;top:0;left:0;right:0;height:2.5px;background:var(--purple);transform:scaleX(0);transition:transform .35s var(--ease)}
.tile:hover{border-color:rgba(126,103,155,.2);transform:translateY(-3px);box-shadow:0 8px 30px rgba(126,103,155,.08)}
.tile:hover::before{transform:scaleX(1)}
.tile h3{font-family:var(--serif);font-size:1.2rem;font-weight:400;margin-bottom:.5rem;letter-spacing:-.01em}
.tile p{font-size:.88rem;color:var(--gray-600);line-height:1.6}
.what-we-do .section-cta{margin-top:3rem}

/* PORTFOLIO */
.portfolio{padding:8rem 0;background:var(--cream)}
.portfolio-grid{display:grid;gap:1.5rem}
.portfolio-row{display:grid;gap:1.5rem}
.portfolio-row.two-col{grid-template-columns:1.2fr .8fr}
.portfolio-row.two-col-rev{grid-template-columns:.8fr 1.2fr}
.portfolio-row.full{grid-template-columns:1fr}
.project{position:relative;border-radius:8px;overflow:hidden;cursor:pointer;background:var(--off-white);transition:transform .5s var(--ease)}
.project:hover{transform:scale(.985)}
.project-img{aspect-ratio:16/10;background:linear-gradient(135deg,#2a2a2a,#3a3a3a);position:relative;overflow:hidden}
.project-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(0,0,0,.6) 100%);opacity:0;transition:opacity .4s}
.project:hover .project-img::after{opacity:1}
.project-meta{padding:1.5rem 1.75rem;display:flex;justify-content:space-between;align-items:flex-start}
.project-bg-video{position:absolute;inset:0;width:100%;height:100%;border:0;pointer-events:none;z-index:0;object-fit:cover}
.project-meta h3{font-family:var(--serif);font-size:1.3rem;font-weight:400;letter-spacing:-.01em;margin-bottom:.3rem}
.project-meta .cat{font-size:.75rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--gray-400)}
.project-meta .result{font-size:.82rem;color:var(--purple);font-weight:500;margin-top:.4rem}
.project-arrow{width:36px;height:36px;border:1.5px solid var(--gray-200);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .35s var(--ease);margin-top:.2rem}
.project:hover .project-arrow{background:var(--purple);border-color:var(--purple)}
.project-arrow svg{width:14px;height:14px;transition:.3s}
.project:hover .project-arrow svg{stroke:#fff;transform:translateX(2px)}
.portfolio-more{text-align:center;margin-top:3.5rem}

/* MARQUEE */
.marquee-section{padding:3rem 0;background:var(--off-white);overflow:hidden;border-top:1px solid rgba(0,0,0,.06);border-bottom:1px solid rgba(0,0,0,.06)}
.marquee-track{display:flex;gap:4rem;animation:marquee 35s linear infinite;width:max-content}
.marquee-track span{font-family:var(--serif);font-size:1rem;color:var(--gray-400);white-space:nowrap;display:flex;align-items:center;gap:4rem}
.marquee-track span::after{content:'\2022';color:var(--gray-200)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* WHY WCG */
.why-wcg{padding:8rem 0;background:var(--warm-white)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.why-card{padding:2.25rem 2rem;background:var(--cream);border:1px solid rgba(0,0,0,.06);border-radius:8px;transition:all .35s var(--ease)}
.why-card:hover{border-color:rgba(126,103,155,.2);box-shadow:0 4px 20px rgba(126,103,155,.06)}
.why-card h3{font-family:var(--serif);font-size:1.2rem;font-weight:400;margin-bottom:.5rem}
.why-card p{font-size:.9rem;color:var(--gray-600);line-height:1.65}

/* SERVICES LIST */
.services{padding:8rem 0;background:var(--cream)}
.services-list{border-top:1px solid rgba(0,0,0,.1)}
.service-row{display:grid;grid-template-columns:.15fr 1fr .35fr;gap:2rem;align-items:center;padding:2rem 0;border-bottom:1px solid rgba(0,0,0,.1);transition:all .35s var(--ease);cursor:pointer}
.service-row:hover{padding-left:1rem;background:var(--purple-wash)}
.service-num{font-family:var(--serif);font-size:1.1rem;color:var(--gray-400)}
.service-info h3{font-family:var(--serif);font-size:clamp(1.4rem,2.5vw,2rem);font-weight:400;letter-spacing:-.02em;margin-bottom:.4rem;transition:color .3s}
.service-row:hover .service-info h3{color:var(--purple)}
.service-info p{font-size:.9rem;color:var(--gray-600);line-height:1.6;max-width:520px}
.service-cta{justify-self:end;font-size:.82rem;font-weight:500;color:var(--gray-400);display:flex;align-items:center;gap:.4rem;transition:color .3s}
.service-row:hover .service-cta{color:var(--purple)}
.service-cta svg{width:14px;height:14px;transition:transform .3s}
.service-row:hover .service-cta svg{transform:translateX(4px)}

/* PROCESS */
.process{padding:8rem 0;background:var(--black);color:#fff}
.process .section-eyebrow{color:var(--purple-light)}
.process .section-intro h2{color:#fff}
.process .section-intro p{color:rgba(255,255,255,.5)}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px}
.process-card{padding:2.5rem 2rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:4px;transition:all .4s var(--ease)}
.process-card:hover{background:rgba(126,103,155,.1);transform:translateY(-4px)}
.process-card .num{font-family:var(--serif);font-size:3rem;color:rgba(126,103,155,.2);margin-bottom:1.5rem;line-height:1}
.process-card h4{font-family:var(--serif);font-size:1.3rem;font-weight:400;margin-bottom:.6rem}
.process-card p{font-size:.85rem;color:rgba(255,255,255,.45);line-height:1.65}

/* TESTIMONIAL CAROUSEL */
.testimonial{padding:8rem 0;background:var(--warm-white);overflow:hidden}
.testimonial-carousel{max-width:860px;margin:0 auto;text-align:center;position:relative}
.testimonial-track{display:flex;transition:transform .6s var(--ease)}
.testimonial-slide{min-width:100%;padding:0 1rem}
.testimonial-slide .quote-mark{font-family:var(--serif);font-size:5rem;line-height:1;color:var(--purple);opacity:.25;margin-bottom:-1rem}
.testimonial-slide blockquote{font-family:var(--serif);font-size:clamp(1.4rem,2.8vw,2rem);font-weight:400;line-height:1.45;color:var(--black);margin-bottom:2rem;font-style:italic;letter-spacing:-.02em}
.testimonial-author strong{display:block;font-family:var(--sans);font-size:.9rem;font-weight:600;color:var(--black)}
.testimonial-author span{font-size:.82rem;color:var(--gray-400)}
.carousel-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-top:2.5rem}
.carousel-btn{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--gray-200);display:flex;align-items:center;justify-content:center;transition:all .3s var(--ease);background:transparent}
.carousel-btn:hover{border-color:var(--purple);background:var(--purple-wash)}
.carousel-btn svg{width:16px;height:16px;stroke:var(--gray-600);transition:stroke .3s}
.carousel-btn:hover svg{stroke:var(--purple)}
.carousel-dots{display:flex;gap:.5rem}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:var(--gray-200);transition:all .3s var(--ease);cursor:pointer}
.carousel-dot.active{background:var(--purple);width:24px;border-radius:4px}

/* ABOUT */
.about{padding:8rem 0;background:var(--cream)}
.about-inner{max-width:800px}
.about-inner .section-eyebrow{margin-bottom:1rem}
.about-inner h2{font-family:var(--serif);font-size:clamp(2rem,3.5vw,3rem);font-weight:400;line-height:1.1;letter-spacing:-.03em;margin-bottom:1.5rem}
.about-inner h2 em{font-style:italic;color:var(--purple)}
.about-inner p{font-size:1.05rem;color:var(--gray-600);line-height:1.8;margin-bottom:1.2rem}
.about-inner p strong{color:var(--black);font-weight:600}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-top:2.5rem}
.about-value{padding:1.5rem;background:var(--warm-white);border:1px solid rgba(0,0,0,.06);border-radius:8px;transition:all .35s var(--ease)}
.about-value:hover{border-color:rgba(126,103,155,.2)}
.about-value h4{font-family:var(--serif);font-size:1.05rem;font-weight:400;margin-bottom:.35rem}
.about-value p{font-size:.88rem;color:var(--gray-600);line-height:1.6;margin-bottom:0}
.about-tags{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:2rem}
.about-tags span{font-size:.78rem;font-weight:500;letter-spacing:.04em;padding:.5rem 1rem;border:1px solid rgba(0,0,0,.12);border-radius:100px;color:var(--gray-600);transition:all .3s}
.about-tags span:hover{border-color:var(--purple);color:var(--purple)}

/* CTA */
.cta{padding:10rem 0;background:var(--black);text-align:center;position:relative;overflow:hidden}
.cta::before{content:"LET'S BUILD";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--serif);font-size:clamp(8rem,18vw,18rem);color:rgba(255,255,255,.02);white-space:nowrap;pointer-events:none}
.cta .container{position:relative;z-index:1}
.cta .section-eyebrow{color:var(--purple-light);margin-bottom:1.5rem}
.cta h2{font-family:var(--serif);font-size:clamp(2.5rem,5.5vw,4.5rem);font-weight:400;color:#fff;line-height:1.08;letter-spacing:-.03em;margin-bottom:1.2rem}
.cta h2 em{font-style:italic;color:var(--purple-light)}
.cta p{font-size:1.05rem;color:rgba(255,255,255,.5);max-width:500px;margin:0 auto 2.5rem;line-height:1.7}
.cta .btn-fill{background:var(--purple);font-size:.95rem;padding:1.1rem 2.5rem}
.cta .btn-fill:hover{background:var(--purple-light)}
.cta-sub{margin-top:2rem;font-size:.85rem;color:rgba(255,255,255,.3)}
.cta-sub a{color:rgba(255,255,255,.6);border-bottom:1px solid rgba(255,255,255,.15);transition:all .3s}
.cta-sub a:hover{color:#fff;border-color:rgba(255,255,255,.5)}

/* FOOTER */
.site-footer{background:var(--dark);padding:4rem 0 2rem;border-top:1px solid rgba(255,255,255,.06)}
.site-footer .container{max-width:1230px;margin:0 auto;padding:0 2rem}
.footer-main{display:grid;grid-template-columns:1.5fr 1fr 1.5fr;gap:3rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-section h4{font-family:var(--serif);font-size:.7rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:rgba(126,103,155,.6);margin-bottom:1.2rem}
.footer-nav-columns{display:flex;gap:2.5rem}
.footer-nav-col{display:flex;flex-direction:column;gap:.6rem}
.footer-nav-col a{font-size:.85rem;color:rgba(255,255,255,.5);text-decoration:none;transition:color .3s}
.footer-nav-col a:hover{color:var(--purple-light)}
.footer-find p{font-size:.85rem;color:rgba(255,255,255,.5);line-height:1.6}
.footer-contact a{font-size:.85rem;color:rgba(255,255,255,.5);text-decoration:none;transition:color .3s;display:block;line-height:1.8}
.footer-contact a:hover{color:var(--purple-light)}
.footer-social{display:flex;gap:1.2rem;padding:2rem 0;justify-content:center}
.footer-social a{color:rgba(255,255,255,.35);transition:color .3s}
.footer-social a:hover{color:var(--purple-light)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:.5rem}
.footer-bottom p{font-size:.75rem;color:rgba(255,255,255,.25);margin:0}
.footer-legal{display:flex;gap:.5rem;align-items:center}
.footer-legal a{font-size:.75rem;color:rgba(255,255,255,.25);text-decoration:none;transition:color .3s}
.footer-legal a:hover{color:var(--purple-light)}
.footer-legal .separator{color:rgba(255,255,255,.15);font-size:.7rem}

/* RESPONSIVE */
@media(max-width:1024px){
  .section-intro{grid-template-columns:1fr;gap:1rem}.section-intro p{justify-self:start}
  .service-tiles{grid-template-columns:repeat(2,1fr)}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .service-row{grid-template-columns:.15fr 1fr}.service-cta{display:none}
  .why-grid{grid-template-columns:1fr}
}
@media(max-width:768px){
  .nav-links{display:none}.hamburger{display:block}
  .hero{padding:8rem 0 4rem}
  .service-tiles{grid-template-columns:1fr}
  .portfolio-row.two-col,.portfolio-row.two-col-rev{grid-template-columns:1fr}
  .process-grid{grid-template-columns:1fr}
  .about-values{grid-template-columns:1fr}
  .service-row{grid-template-columns:1fr;gap:.5rem}.service-num{display:none}
  .footer-main{grid-template-columns:1fr;gap:2rem;text-align:center}.footer-nav-columns{justify-content:center}.footer-bottom{flex-direction:column;gap:.5rem;text-align:center}
}
