/*
Theme Name: Channon Agency Theme V2
Theme URI: https://channonagency.com
Author: Channon Agency
Description: Custom performance and creative agency theme for Channon Agency. Clean, fast, dependency free. Bespoke templates for Home, About, Performance Services, Creative Services, Case Studies and Contact.
Version: 2.0
Requires at least: 5.9
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: channon
*/

:root{
  --blue:#36A9E1; --blue-deep:#1E90C9; --blue-ink:#127ab0;
  --ink:#2B2B2A; --graphite:#575756; --white:#FFFFFF;
  --tint:#F4F8FB; --surface:#EAF5FC; --hair:#E2E8EC;
  --display:"Space Grotesk", sans-serif; --body:"Manrope", sans-serif; --mono:"JetBrains Mono", monospace;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--graphite);background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;height:auto}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--blue-ink);font-weight:600}
h1,h2,h3{font-family:var(--display);color:var(--ink);font-weight:700;line-height:1.04;letter-spacing:-.02em}

/* NAV */
header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.85);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid transparent;transition:border-color .25s, box-shadow .25s}
header.scrolled{border-color:var(--hair);box-shadow:0 6px 24px -18px rgba(43,43,42,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px;gap:18px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:700;color:var(--ink);font-size:1.1rem}
.brand .mark{width:36px;height:36px;flex:0 0 auto;object-fit:contain}
.navlinks{display:flex;align-items:center;gap:22px;list-style:none}
.navlinks a{font-size:.9rem;font-weight:600;color:var(--graphite);position:relative;padding:6px 0;white-space:nowrap}
.navlinks a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--blue);transition:width .22s}
.navlinks a:hover{color:var(--ink)} .navlinks a:hover::after,.navlinks a:focus-visible::after{width:100%}
.btn{font-family:var(--body);font-weight:700;font-size:.92rem;background:var(--blue);color:#fff;padding:11px 20px;border-radius:9px;border:0;cursor:pointer;transition:background .2s, transform .2s;display:inline-block;white-space:nowrap;flex:0 0 auto}
.navlinks .btn{padding:14px 30px;font-size:.98rem;border-radius:10px;color:#fff}
.navlinks .btn::after{display:none}
.navlinks .btn:hover{color:#fff}
.btn:hover{background:var(--blue-deep);transform:translateY(-1px);color:#fff}
.btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--hair)}
.btn.ghost:hover{border-color:var(--blue);color:var(--blue-ink)}
.menu-toggle{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.menu-toggle span{width:24px;height:2px;background:var(--ink);display:block}

/* HERO */
.hero{position:relative;overflow:hidden;padding:84px 0 60px}
.hero-lines{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;background-image:linear-gradient(90deg,var(--hair) 1px,transparent 1px);background-size:118px 100%;-webkit-mask-image:linear-gradient(180deg,#000,transparent 78%);mask-image:linear-gradient(180deg,#000,transparent 78%)}
.hero .wrap{position:relative;z-index:1}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.6rem);max-width:18ch;margin:18px 0 0}
.rotor{color:var(--blue);display:inline-block;min-height:1.05em;position:relative}
.rotor span{display:inline-block;opacity:0;transform:translateY(10px);position:absolute;left:0;top:0}
.rotor span.on{opacity:1;transform:none;position:relative;transition:opacity .5s, transform .5s}
.hero p.lede{font-size:clamp(1.04rem,1.6vw,1.24rem);max-width:62ch;margin:26px 0 34px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* PAGE HERO (inner pages) */
.page-hero{position:relative;overflow:hidden;padding:78px 0 34px}
.page-hero .hero-lines{opacity:.45}
.page-hero .wrap{position:relative;z-index:1}
.page-hero h1{font-size:clamp(2.3rem,5vw,4rem);max-width:20ch;margin-top:16px}
.page-hero p{font-size:clamp(1.04rem,1.6vw,1.2rem);max-width:60ch;margin-top:22px;color:var(--graphite)}

/* COUNTERS */
.ledger{margin-top:60px;border:1px solid var(--hair);border-radius:16px;background:var(--white);box-shadow:0 30px 60px -45px rgba(18,122,176,.6);overflow:hidden}
.ledger-head{display:flex;align-items:center;gap:9px;padding:13px 22px;border-bottom:1px solid var(--hair);background:var(--tint)}
.ledger-head .dot{width:8px;height:8px;border-radius:50%;background:var(--blue);box-shadow:0 0 0 4px var(--surface)}
.ledger-head .live{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--graphite)}
.ledger-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:30px 26px;border-right:1px solid var(--hair)}
.stat:last-child{border-right:0}
.stat .num{font-family:var(--display);font-weight:700;font-size:clamp(2.1rem,3.8vw,3.2rem);color:var(--blue);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-.03em}
.stat .num .unit{color:var(--blue)}
.stat .label{display:block;margin-top:12px;font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink)}

/* SECTIONS */
section{padding:92px 0}
.band{background:var(--tint);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.sec-head{max-width:64ch} .sec-head h2{font-size:clamp(1.9rem,3.4vw,3rem);margin:14px 0 0}
.sec-head p{margin-top:16px;font-size:1.08rem}
.sec-title{font-size:clamp(1.9rem,3.4vw,3rem);margin-top:12px;max-width:20ch}

/* PROSE */
.prose{max-width:64ch}
.prose p{font-size:1.12rem;color:var(--graphite)}
.prose p + p{margin-top:18px}

/* MARQUEE */
.marq-title{text-align:center;font-family:var(--display);font-weight:600;color:var(--ink);font-size:clamp(1.3rem,2.2vw,1.7rem);max-width:24ch;margin:0 auto 36px}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:60px;align-items:center;width:max-content;animation:scroll 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track img{height:42px;width:auto;opacity:.7;filter:grayscale(1);transition:opacity .2s, filter .2s}
.marquee-track img:hover{opacity:1;filter:none}
@keyframes scroll{to{transform:translateX(-50%)}}

/* SERVICES */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px}
.svc{border:1px solid var(--hair);border-radius:14px;padding:26px 24px;background:var(--white);transition:transform .25s, box-shadow .25s, border-color .25s}
.svc:hover{transform:translateY(-4px);box-shadow:0 26px 44px -36px rgba(18,122,176,.55);border-color:#cfe6f5}
.svc .ic{width:38px;height:38px;border-radius:10px;background:var(--surface);display:flex;align-items:center;justify-content:center;color:var(--blue-ink);margin-bottom:16px;font-family:var(--display);font-weight:700}
.svc h3{font-size:1.2rem;margin-bottom:8px}
.svc p{font-size:.95rem}
.svc a{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-ink);font-weight:600;margin-top:14px;display:inline-block}
.svc-more{display:none;margin:24px auto 0;font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--blue-ink);background:var(--white);border:1.5px solid var(--hair);border-radius:999px;padding:12px 24px;cursor:pointer;transition:.2s}
.svc-more:hover{border-color:var(--blue);color:var(--blue)}
.svc a:hover{color:var(--blue-deep)}

/* PROCESS (services pages) */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:46px}
.step{border-top:2px solid var(--blue);padding-top:18px}
.step .n{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;color:var(--blue-ink);font-weight:600}
.step h3{font-size:1.15rem;margin:10px 0 8px}
.step p{font-size:.95rem}

/* SELECTED WORK */
.work-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px}
.work-tab{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--graphite);background:var(--white);border:1.5px solid var(--hair);border-radius:999px;padding:9px 18px;cursor:pointer;transition:.2s}
.work-tab:hover{border-color:var(--blue);color:var(--blue-ink)}
.work-tab.active{background:var(--blue);border-color:var(--blue);color:#fff}
.work-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:28px}
.work-item{border:1px solid var(--hair);border-radius:14px;overflow:hidden;background:var(--white)}
.work-media{position:relative;aspect-ratio:9/16;background:linear-gradient(160deg,var(--surface),#dceefb);display:flex;align-items:center;justify-content:center;overflow:hidden}
.work-media img,.work-media iframe,.work-media video{width:100%;height:100%;object-fit:cover;border:0;display:block}
.work-media .play{position:absolute;width:54px;height:54px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.15rem;padding-left:3px;box-shadow:0 10px 30px -8px rgba(18,122,176,.7)}
.work-media .badge{position:absolute;top:10px;left:10px;font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;background:rgba(43,43,42,.82);color:#fff;padding:4px 9px;border-radius:999px}
.work-cap{padding:12px 14px;font-size:.86rem;color:var(--graphite)}
.work-item.hide{display:none}
/* VIDEO REEL */
.reel-row{display:flex;gap:26px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.reel-col{flex:0 0 320px;max-width:320px}
.reel-col.hide{display:none}
.reel{aspect-ratio:9/16;border-radius:18px;overflow:hidden;background:#000;box-shadow:0 30px 60px -34px rgba(18,122,176,.55)}
.reel iframe{width:100%;height:100%;border:0;display:block}
.reel-cap{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--graphite);text-align:center;margin-top:12px}
.reel-cap a{color:var(--blue-ink);display:block;margin-top:4px;text-transform:none;letter-spacing:0;font-size:.8rem}

/* CASE STUDIES */
.cases{display:flex;flex-direction:column;gap:18px;margin-top:46px}
.case{border:1px solid var(--hair);border-radius:16px;background:var(--white);overflow:hidden;transition:border-color .25s, box-shadow .25s}
.case.open{border-color:var(--blue);box-shadow:0 30px 60px -45px rgba(18,122,176,.6)}
.case-top{display:grid;grid-template-columns:120px 1fr auto;gap:26px;align-items:center;width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:22px 26px;font-family:var(--body)}
.case-thumb{width:120px;height:84px;border-radius:10px;object-fit:cover;background:var(--surface)}
.case-thumb.ph{display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;color:var(--blue-ink);font-size:1.1rem;letter-spacing:.04em}
.case-id{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-ink);margin-bottom:7px}
.case-top h3{font-size:1.3rem;color:var(--ink)}
.case-top .chal{font-size:.95rem;color:var(--graphite);margin-top:6px}
.case-toggle{width:42px;height:42px;border-radius:50%;border:1.5px solid var(--hair);display:flex;align-items:center;justify-content:center;color:var(--graphite);transition:.25s;flex:0 0 auto;font-size:1.4rem;line-height:1}
.case.open .case-toggle{background:var(--blue);border-color:var(--blue);color:#fff;transform:rotate(45deg)}
.case-panel{max-height:0;overflow:hidden;transition:max-height .4s ease}
.case-body{padding:4px 26px 32px;border-top:1px solid var(--hair)}
.case-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:24px}
.case-cols h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-ink);margin-bottom:9px;font-weight:600}
.case-cols p{font-size:.97rem}
.case-results{display:flex;gap:38px;flex-wrap:wrap;margin-top:26px;padding-top:22px;border-top:1px dashed var(--hair)}
.case-results .rn{font-family:var(--display);font-weight:700;font-size:1.7rem;color:var(--ink);font-variant-numeric:tabular-nums}
.case-results .rl{font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--graphite);margin-top:4px}
.case-link{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-ink);font-weight:600;margin-top:24px;display:inline-block}
.case-link:hover{color:var(--blue-deep)}
.cases-cta{margin-top:34px;text-align:center}

/* TEAM */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:46px}
.member{border:1px solid var(--hair);border-radius:16px;background:var(--white);padding:32px 24px;text-align:center}
.member img{width:122px;height:122px;border-radius:50%;object-fit:cover;object-position:center;background:var(--surface);margin:0 auto 16px}
.member .ph-av{width:122px;height:122px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;color:var(--blue-ink);font-size:2.1rem;margin:0 auto 16px}
.member .who{padding:0}
.member h3{font-size:1.2rem}
.member .role{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--blue-ink);margin:6px 0 12px;font-weight:600}
.member p{font-size:.93rem;text-align:left;line-height:1.6;margin-top:2px}
/* GOOGLE REVIEWS */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:46px}
.reviews-embed{margin-top:40px}
.review{background:var(--white);border:1px solid var(--hair);border-radius:16px;padding:28px 26px;display:flex;flex-direction:column;gap:14px}
.review .stars{color:#FBBC04;font-size:1.05rem;letter-spacing:2px}
.review p{font-size:.97rem;color:var(--ink);line-height:1.6;flex:1}
.review-by{display:flex;align-items:center;gap:12px}
.review-by .g{width:34px;height:34px;border-radius:50%;background:var(--surface);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;color:#4285F4;font-size:1.05rem;flex:0 0 auto}
.review-by strong{display:block;font-family:var(--display);font-size:.95rem;color:var(--ink)}
.review-by span{font-family:var(--mono);font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;color:var(--graphite)}
/* CASE VIDEO */
.case-video{position:relative;aspect-ratio:16/9;max-width:560px;border-radius:12px;overflow:hidden;margin:6px 0 6px;background:linear-gradient(160deg,var(--surface),#dceefb);display:flex;align-items:center;justify-content:center}
.case-video iframe{width:100%;height:100%;border:0}
.case-video .play{width:58px;height:58px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;padding-left:3px;box-shadow:0 10px 30px -8px rgba(18,122,176,.7)}
.case-video .badge{position:absolute;top:10px;left:10px;font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;background:rgba(43,43,42,.82);color:#fff;padding:4px 9px;border-radius:999px}

/* TESTIMONIAL VIDEOS */
.vid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:46px}
.vid{border:1px solid var(--hair);border-radius:16px;overflow:hidden;background:var(--white);transition:transform .25s, box-shadow .25s}
.vid:hover{transform:translateY(-4px);box-shadow:0 26px 44px -36px rgba(18,122,176,.55)}
.vid-frame{position:relative;aspect-ratio:16/9;background:linear-gradient(160deg,var(--surface),#dceefb);display:flex;align-items:center;justify-content:center}
.vid-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vid-frame .play{width:62px;height:62px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem;padding-left:4px;box-shadow:0 10px 30px -8px rgba(18,122,176,.7);transition:transform .2s}
.vid:hover .play{transform:scale(1.08)}
.vid-cap{padding:16px 18px;display:flex;flex-direction:column;gap:3px}
.vid-cap strong{font-family:var(--display);color:var(--ink);font-size:1rem}
.vid-cap span{font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-ink)}

/* CONTACT */
.contact-card{background:var(--ink);color:#fff;border-radius:22px;padding:60px 54px;display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center;position:relative;overflow:hidden}
.contact-card h2{color:#fff;font-size:clamp(2rem,3.6vw,3rem);position:relative}
.contact-card p{color:#cfd4d6;margin-top:16px;font-size:1.06rem;max-width:46ch;position:relative}
.contact-actions{position:relative;display:flex;flex-direction:column;gap:16px;align-items:center;text-align:center;justify-content:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:34px 28px}
.contact-actions .btn{font-size:1rem;padding:14px 24px}
.contact-actions .line{font-family:var(--mono);font-size:.85rem;color:#9fb6c2;letter-spacing:.03em}

/* CONTACT PAGE */
.contact-split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start;margin-top:6px}
.contact-info .line2{font-family:var(--mono);font-size:.92rem;color:var(--graphite);margin:6px 0 22px}
.contact-info h3{font-size:1.4rem;margin-bottom:6px}
.cform{display:grid;gap:16px;max-width:560px}
.cform label{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--graphite);display:block;margin-bottom:6px}
.cform input,.cform textarea{width:100%;padding:13px 14px;border:1.5px solid var(--hair);border-radius:10px;font-family:var(--body);font-size:1rem;color:var(--ink);background:var(--white)}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--blue)}
.cform textarea{min-height:140px;resize:vertical}
.cform button{justify-self:start}

/* FOOTER */
footer{padding:50px 0 56px;border-top:1px solid var(--hair)}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
.foot .brand{font-size:1.05rem;margin-bottom:12px}
.foot p{font-size:.92rem}
.foot h5{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);margin-bottom:14px;font-weight:600}
.foot ul{list-style:none} .foot li{margin-bottom:9px} .foot a{font-size:.92rem;color:var(--graphite);font-weight:500}
.foot a:hover{color:var(--blue-ink)}
.copy{font-family:var(--mono);font-size:.74rem;color:var(--graphite);letter-spacing:.03em;margin-top:34px;padding-top:22px;border-top:1px solid var(--hair)}

:focus-visible{outline:3px solid var(--blue);outline-offset:3px;border-radius:4px}

@media (max-width:1180px){
  .work-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:1120px){
  .menu-toggle{display:flex}
  .navlinks{position:absolute;top:76px;left:0;right:0;background:#fff;border-bottom:1px solid var(--hair);flex-direction:column;align-items:flex-start;gap:0;padding:8px 28px 18px;display:none;box-shadow:0 20px 30px -24px rgba(43,43,42,.5)}
  .navlinks.show{display:flex}
  .navlinks li{width:100%} .navlinks a{display:block;width:100%;padding:13px 0;border-bottom:1px solid var(--hair)} .navlinks .btn{margin-top:12px}
}
@media (max-width:980px){
  .svc-grid,.team-grid,.vid-grid,.reviews-grid,.steps{grid-template-columns:1fr 1fr}
  .foot{grid-template-columns:1fr 1fr}
}
@media (max-width:860px){
  .ledger-grid{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:0}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--hair)}
  .contact-card{grid-template-columns:1fr}
  .contact-split{grid-template-columns:1fr;gap:34px}
  .case-top{grid-template-columns:1fr auto;gap:16px}
  .case-thumb{display:none}
  .case-cols{grid-template-columns:1fr}
}
@media (max-width:760px){
  section{padding:62px 0}
  .svc-grid,.team-grid,.foot,.vid-grid,.reviews-grid,.steps{grid-template-columns:1fr}
  .svc-collapse .svc:nth-child(n+4){display:none}
  .svc-collapse.open .svc:nth-child(n+4){display:block}
  .svc-more{display:block;width:max-content}
  .work-grid{grid-template-columns:repeat(2,1fr)}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important;transition:none !important}
  .marquee-track{animation:none !important}
  .rotor span{position:relative;opacity:1;transform:none}
  .rotor span ~ span{display:none}
}
