/*
Theme Name:        Mcafan
Theme URI:         https://mcafan.com
Author:            Mcafan
Author URI:        https://mcafan.com
Description:       The official Mcafan brand consultancy theme. World-class design inspired by Apple.com and Jack Morton — cinematic full-bleed sections, editorial Fraunces typography, photo-realistic stock imagery, professional SVG diagrams, deep case studies, and a complete brand system. Includes 5 custom page templates, 3 Custom Post Types (Work, Team, Services), native WordPress meta boxes (no plugins required), Elementor compatibility, a settings page, and a built-in contact form.
Version:           3.0.0
Requires at least: 6.2
Tested up to:      6.6
Requires PHP:      8.0
License:           Proprietary
Text Domain:       mcafan
Tags:              full-width-template, custom-menu, featured-images, custom-background, editor-style, custom-logo, threaded-comments, responsive-layout, accessibility-ready
*/

/* ================================================================
   MCAFAN DESIGN SYSTEM v3.0
   Palette: #9DE016 Lime · #00A859 Green · #292D2B Near-Black
   Type:    Fraunces (display) + DM Sans (body)
   ================================================================ */

/* ── 1. TOKENS ─────────────────────────────────────────────────*/
:root{
  --c-lime:#9DE016;--c-lime-d:#7eb010;
  --c-green:#00A859;--c-green-d:#007a41;
  --c-black:#292D2B;--c-white:#FFFFFF;
  --c-cream:#F6F5F0;--c-gray-50:#FAFAF8;
  --c-gray-100:#F0EFEA;--c-gray-200:#E0DFD8;
  --c-gray-300:#CCCCC4;--c-gray-400:#9C9C95;
  --c-gray-500:#78786F;--c-gray-600:#6A6A64;
  --f-d:'Fraunces',Georgia,'Times New Roman',serif;
  --f-b:'DM Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --nav-h:72px;--max-w:1440px;--pad:80px;
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-in:cubic-bezier(.4,0,1,1);
  --dur:.7s;
}

/* ── 2. RESET ──────────────────────────────────────────────────*/
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--f-b);color:var(--c-black);background:#fff;line-height:1.6;
     -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%;height:auto}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea,select{font-family:inherit}
:focus-visible{outline:2px solid var(--c-green);outline-offset:3px;border-radius:4px}

/* ── 3. LAYOUT ─────────────────────────────────────────────────*/
.mc-wrap{max-width:var(--max-w);margin:0 auto;padding:0 var(--pad)}
.mc-wrap-sm{max-width:920px;margin:0 auto;padding:0 var(--pad)}
.mc-sect{padding:120px 0}
.mc-sect-lg{padding:160px 0}
.mc-sect-sm{padding:72px 0}

/* ── 4. TYPE ───────────────────────────────────────────────────*/
.mc-hero-t{font-family:var(--f-d);font-size:clamp(52px,8.5vw,120px);font-weight:200;line-height:.96;letter-spacing:-.04em}
.mc-display{font-family:var(--f-d);font-size:clamp(38px,5.5vw,78px);font-weight:300;line-height:1.06;letter-spacing:-.03em}
.mc-title{font-family:var(--f-d);font-size:clamp(28px,3.5vw,50px);font-weight:300;line-height:1.16;letter-spacing:-.02em}
.mc-body-xl{font-size:clamp(17px,1.8vw,21px);font-weight:300;line-height:1.75;color:var(--c-gray-600)}
.mc-body-lg{font-size:18px;font-weight:300;line-height:1.78;color:var(--c-gray-600)}
.mc-body{font-size:16px;font-weight:400;line-height:1.72;color:var(--c-gray-600)}
.mc-small{font-size:13px;font-weight:500;color:var(--c-gray-400)}
.mc-label{font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase}
.mc-eyebrow{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.2em;
             text-transform:uppercase;color:var(--c-green);margin-bottom:22px}
.mc-eyebrow.lt{color:var(--c-lime)}
.mc-eyebrow.dim{color:var(--c-gray-400)}
em.hi{font-style:italic;color:var(--c-green)}
em.hil{font-style:italic;color:var(--c-lime)}

/* ── 5. BUTTONS ────────────────────────────────────────────────*/
.mc-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;
        border-radius:100px;font-family:var(--f-b);font-size:14px;font-weight:500;
        letter-spacing:.01em;white-space:nowrap;border:none;
        transition:all .24s var(--ease);cursor:pointer}
.mc-btn-icon{display:inline-block;transition:transform .22s var(--ease)}
.mc-btn:hover .mc-btn-icon{transform:translateX(4px)}
.mc-btn-blk{background:var(--c-black);color:#fff}
.mc-btn-blk:hover{background:#1a1d1a}
.mc-btn-lime{background:var(--c-lime);color:var(--c-black)}
.mc-btn-lime:hover{background:var(--c-lime-d)}
.mc-btn-grn{background:var(--c-green);color:#fff}
.mc-btn-grn:hover{background:var(--c-green-d)}
.mc-btn-out{background:transparent;color:var(--c-black);border:1.5px solid rgba(41,45,43,.2)}
.mc-btn-out:hover{border-color:var(--c-black)}
.mc-btn-outw{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.28)}
.mc-btn-outw:hover{border-color:rgba(255,255,255,.7)}
.mc-btn-sm{padding:10px 22px;font-size:13px}
.mc-btn-lg{padding:17px 42px;font-size:16px}

/* ── 6. NAV ────────────────────────────────────────────────────*/
#mc-nav{position:fixed;top:0;left:0;right:0;z-index:9000;height:var(--nav-h);
        display:flex;align-items:center;justify-content:space-between;padding:0 52px;
        transition:background .4s,border-color .4s}
#mc-nav.nav-transparent{background:transparent}
#mc-nav.nav-dark{background:rgba(41,45,43,.94);backdrop-filter:blur(28px) saturate(160%);
                 -webkit-backdrop-filter:blur(28px) saturate(160%);
                 border-bottom:1px solid rgba(255,255,255,.07)}
#mc-nav.nav-light{background:rgba(255,255,255,.96);backdrop-filter:blur(28px) saturate(160%);
                  -webkit-backdrop-filter:blur(28px) saturate(160%);
                  border-bottom:1px solid rgba(41,45,43,.07);
                  box-shadow:0 1px 0 rgba(41,45,43,.04)}
.mc-logo{display:flex;align-items:center;gap:0;text-decoration:none}
.mc-logo-mark{width:30px;height:30px;flex-shrink:0}

/* Real logo images — transparent background, no filter tricks needed */
.mc-logo-img{
  height:28px;width:auto;display:block;flex-shrink:0;
  transition:opacity .2s ease;
}
.mc-logo-img:hover{opacity:.85}
.mc-nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.mc-nav-links a{font-size:13.5px;font-weight:400;padding:7px 15px;border-radius:100px;
                color:var(--c-black);opacity:.68;transition:opacity .2s,background .2s}
.mc-nav-links a:hover,.mc-nav-links a.mc-active{opacity:1}
.mc-nav-links a:hover{background:rgba(0,0,0,.05)}
.nav-dark .mc-nav-links a,.nav-transparent .mc-nav-links a{color:#fff}
.nav-dark .mc-nav-links a:hover,.nav-transparent .mc-nav-links a:hover{background:rgba(255,255,255,.1)}
.mc-nav-cta{background:var(--c-black)!important;color:#fff!important;opacity:1!important;
            font-weight:500!important;padding:9px 24px;border-radius:100px}
.mc-nav-cta:hover{background:var(--c-green)!important}
.nav-dark .mc-nav-cta{background:var(--c-lime)!important;color:var(--c-black)!important}
.mc-hamburger{display:none;flex-direction:column;gap:5px;padding:8px;border-radius:6px}
.mc-hamburger span{display:block;width:22px;height:1.5px;background:var(--c-black);
                   border-radius:2px;transition:all .3s}
.nav-dark .mc-hamburger span,.nav-transparent .mc-hamburger span{background:#fff}
.mc-mob-nav{display:none;position:fixed;top:var(--nav-h);left:0;right:0;
            background:#fff;border-bottom:1px solid var(--c-gray-200);
            padding:20px 24px 32px;z-index:8999;flex-direction:column;gap:2px}
.mc-mob-nav.open{display:flex}
.mc-mob-nav a{font-size:17px;color:var(--c-black);padding:13px 16px;
              border-radius:12px;transition:background .15s}
.mc-mob-nav a:hover{background:var(--c-cream)}

/* ── 7. FOOTER ─────────────────────────────────────────────────*/
#mc-footer{background:var(--c-black);padding:96px 0 52px}
.mc-footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:64px;
                padding-bottom:64px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:40px}
.mc-footer-wordmark{font-family:var(--f-d);font-size:30px;font-weight:300;color:#fff;letter-spacing:-.02em;margin-bottom:16px}
.mc-footer-tagline{font-size:14px;font-weight:300;line-height:1.72;
                   color:rgba(255,255,255,.38);max-width:300px;margin-bottom:28px}
.mc-footer-loc{font-size:12px;color:rgba(255,255,255,.24);letter-spacing:.04em}
.mc-footer-col h5{font-size:10.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
                  color:rgba(255,255,255,.26);margin-bottom:22px}
.mc-footer-col li{margin-bottom:12px}
.mc-footer-col a{font-size:14px;color:rgba(255,255,255,.46);transition:color .2s}
.mc-footer-col a:hover{color:#fff}
.mc-footer-btm{display:flex;justify-content:space-between;align-items:center;
               font-size:12px;color:rgba(255,255,255,.24)}
.mc-footer-badge{display:inline-flex;align-items:center;gap:8px}
.mc-footer-badge::before{content:'';width:6px;height:6px;border-radius:50%;
                          background:var(--c-lime);
                          animation:pulse-dot 3s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:.4}50%{opacity:1}}

/* ── 8. ANIMATIONS ─────────────────────────────────────────────*/
.mc-up{opacity:0;transform:translateY(40px);
       transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease)}
.mc-up.vis{opacity:1;transform:none}
.mc-in{opacity:0;transition:opacity .6s var(--ease)}
.mc-in.vis{opacity:1}
/* stagger via sibling selectors */
.mc-stag>.mc-up:nth-child(1){transition-delay:0s}
.mc-stag>.mc-up:nth-child(2){transition-delay:.1s}
.mc-stag>.mc-up:nth-child(3){transition-delay:.2s}
.mc-stag>.mc-up:nth-child(4){transition-delay:.3s}
.mc-stag>.mc-up:nth-child(5){transition-delay:.4s}
.mc-stag>.mc-up:nth-child(6){transition-delay:.5s}

/* ── 9. HERO ───────────────────────────────────────────────────*/
.mc-hero{height:100svh;min-height:700px;background:var(--c-black);
         display:flex;align-items:center;justify-content:center;
         text-align:center;position:relative;overflow:hidden}
.mc-hero-media{position:absolute;inset:0;z-index:0}
.mc-hero-media img,.mc-hero-media video{width:100%;height:100%;object-fit:cover;
                                         opacity:.2;filter:saturate(.7)}
.mc-hero-media::after{content:'';position:absolute;inset:0;
                       background:linear-gradient(180deg,rgba(41,45,43,.5),rgba(41,45,43,.92))}
/* orbs */
.mc-orbs{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.mc-orb{position:absolute;border-radius:50%;filter:blur(110px);opacity:.14}
.mc-orb-1{width:640px;height:640px;background:var(--c-green);top:-160px;left:-160px;animation:orb-f 14s ease-in-out infinite}
.mc-orb-2{width:480px;height:480px;background:var(--c-lime);bottom:-100px;right:-80px;animation:orb-f 11s ease-in-out 4s infinite}
.mc-orb-3{width:360px;height:360px;background:var(--c-green);top:40%;right:18%;animation:orb-f 9s ease-in-out 8s infinite}
@keyframes orb-f{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(28px,-20px) scale(1.04)}66%{transform:translate(-20px,28px) scale(.97)}}
.mc-hero-inner{position:relative;z-index:1;max-width:1000px;padding:0 var(--pad)}
.mc-hero-ey{display:inline-flex;align-items:center;gap:12px;font-size:11px;font-weight:600;
            letter-spacing:.2em;text-transform:uppercase;color:var(--c-lime);margin-bottom:36px;
            opacity:0;animation:fade-rise .9s var(--ease) .5s forwards}
.mc-hero-ey::before{content:'';width:32px;height:1px;background:var(--c-lime)}
.mc-hero-h1{font-family:var(--f-d);font-size:clamp(52px,9vw,120px);font-weight:200;
            line-height:.96;letter-spacing:-.04em;color:#fff;margin-bottom:36px;
            opacity:0;animation:fade-rise 1s var(--ease) .7s forwards}
.mc-hero-h1 em{font-style:italic;color:var(--c-lime)}
.mc-hero-sub{font-size:clamp(16px,2vw,21px);font-weight:300;color:rgba(255,255,255,.5);
             line-height:1.72;max-width:600px;margin:0 auto 52px;
             opacity:0;animation:fade-rise 1s var(--ease) .9s forwards}
.mc-hero-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;
              opacity:0;animation:fade-rise 1s var(--ease) 1.1s forwards}
.mc-hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
                display:flex;flex-direction:column;align-items:center;gap:10px;z-index:1;
                opacity:0;animation:fade-rise 1s var(--ease) 1.6s forwards}
.mc-hero-scroll span{font-size:10px;font-weight:600;letter-spacing:.22em;
                     text-transform:uppercase;color:rgba(255,255,255,.28)}
.mc-scroll-line{width:1px;height:48px;
                background:linear-gradient(to bottom,rgba(255,255,255,.32),transparent);
                animation:scroll-pulse 2.4s ease-in-out infinite}
@keyframes scroll-pulse{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.1)}}
@keyframes fade-rise{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:none}}

/* ── 10. MARQUEE ───────────────────────────────────────────────*/
.mc-client-band{overflow:hidden;background:var(--c-cream);padding:52px 0;
                border-top:1px solid var(--c-gray-200);border-bottom:1px solid var(--c-gray-200)}
.mc-mq-outer{display:flex;overflow:hidden}
.mc-mq-track{display:flex;gap:24px;flex-shrink:0;animation:mq 34s linear infinite}
.mc-mq-track:hover{animation-play-state:paused}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.mc-mq-logo{display:flex;align-items:center;justify-content:center;
            width:160px;height:68px;border-radius:12px;
            border:1px solid rgba(0,0,0,.06);flex-shrink:0;overflow:hidden;
            transition:border-color .2s}
.mc-mq-logo:hover{border-color:var(--c-green)}
.mc-mq-logo img{max-width:128px;max-height:50px;width:auto;height:auto;object-fit:contain}
.mc-mq-logo span{font-size:11px;font-weight:700;text-align:center;padding:0 10px;
                 line-height:1.3;color:#555}

/* ── 11. SERVICE TILES ─────────────────────────────────────────*/
.mc-svc-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.mc-svc-tile{position:relative;overflow:hidden;min-height:520px;padding:52px 44px;
             display:flex;flex-direction:column;justify-content:flex-end;
             text-decoration:none;color:#fff;
             transition:transform .4s var(--ease)}
.mc-svc-tile:hover{transform:scale(1.012)}
.mc-svc-tile-bg{position:absolute;inset:0}
.mc-svc-tile-bg img{width:100%;height:100%;object-fit:cover;
                    transition:transform .7s var(--ease);filter:saturate(.7)}
.mc-svc-tile:hover .mc-svc-tile-bg img{transform:scale(1.06)}
.mc-svc-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(41,45,43,.94) 0%,rgba(41,45,43,.28) 60%,transparent 100%);transition:background .4s}
.mc-svc-tile:hover .mc-svc-overlay{background:linear-gradient(to top,rgba(0,168,89,.9) 0%,rgba(0,168,89,.4) 55%,transparent 100%)}
.mc-svc-body{position:relative;z-index:1}
.mc-svc-n{font-size:11px;font-weight:600;letter-spacing:.18em;opacity:.38;display:block;margin-bottom:20px}
.mc-svc-name{font-family:var(--f-d);font-size:30px;font-weight:300;letter-spacing:-.02em;line-height:1.2;margin-bottom:14px}
.mc-svc-desc{font-size:14px;line-height:1.7;opacity:.65;margin-bottom:28px;max-width:340px}
.mc-svc-link{font-size:13px;font-weight:500;color:var(--c-lime);display:inline-flex;align-items:center;gap:8px}
.mc-svc-arr{display:inline-block;transition:transform .2s}
.mc-svc-tile:hover .mc-svc-arr{transform:translateX(6px)}

/* ── 12. WORK LIST ─────────────────────────────────────────────*/
.mc-work-list{display:flex;flex-direction:column}
.mc-work-row{display:grid;grid-template-columns:72px 2.5fr 1.6fr 1fr 36px;
             align-items:center;gap:28px;padding:24px 0;
             border-top:1px solid var(--c-gray-200);text-decoration:none;
             color:var(--c-black);transition:padding-left .25s var(--ease),background .2s;
             cursor:pointer}
.mc-work-row:last-child{border-bottom:1px solid var(--c-gray-200)}
.mc-work-row:hover{padding-left:16px;background:rgba(0,168,89,.025)}
.mc-wr-n{font-size:12px;color:var(--c-gray-400);font-weight:600;letter-spacing:.04em}
.mc-wr-name{font-family:var(--f-d);font-size:24px;font-weight:300;letter-spacing:-.02em}
.mc-wr-type{font-size:14px;color:var(--c-gray-600)}
.mc-wr-arr{font-size:20px;color:var(--c-gray-400);transition:color .2s,transform .2s}
.mc-work-row:hover .mc-wr-arr{color:var(--c-green);transform:translateX(5px)}

/* ── 13. CASE STUDY ────────────────────────────────────────────*/
.mc-cs-sect{padding:100px 0;border-bottom:1px solid var(--c-gray-200);
            scroll-margin-top:var(--nav-h)}
.mc-cs-grid{display:grid;grid-template-columns:1fr 1fr;gap:84px;align-items:start}
.mc-cs-grid.flip{direction:rtl}
.mc-cs-grid.flip>*{direction:ltr}
.mc-cs-visual{border-radius:24px;overflow:hidden;aspect-ratio:1/1;position:relative;
              display:flex;align-items:flex-end}
.mc-cs-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
           opacity:.3;transition:opacity .4s}
.mc-cs-visual:hover .mc-cs-img{opacity:.44}
.mc-cs-overlay{position:absolute;inset:0}
.mc-cs-logo{position:absolute;bottom:22px;left:22px;border-radius:14px;padding:13px 18px;
            display:flex;align-items:center;justify-content:center;
            max-width:190px;min-width:120px;min-height:58px;
            box-shadow:0 8px 32px rgba(0,0,0,.5)}
.mc-cs-logo img{max-width:150px;max-height:52px;width:auto;height:auto;object-fit:contain}
.mc-cs-logo span{font-size:13px;font-weight:700;text-align:center;line-height:1.3}
.mc-cs-badge{position:absolute;top:20px;right:20px;background:rgba(157,224,22,.92);
             color:var(--c-black);font-size:11px;font-weight:700;padding:7px 16px;
             border-radius:100px;letter-spacing:.04em}
.mc-cs-meta{display:flex;align-items:center;gap:12px;margin-bottom:22px}
.mc-cs-num{font-size:12px;color:var(--c-gray-400);font-weight:600}
.mc-tag{display:inline-block;border-radius:100px;padding:5px 13px;font-size:11px;
        font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.mc-tag-d{background:var(--c-gray-100);color:var(--c-gray-600)}
.mc-tag-g{background:rgba(0,168,89,.1);color:var(--c-green)}
.mc-tag-l{background:rgba(157,224,22,.14);color:#5a8000}
.mc-cs-title{font-family:var(--f-d);font-size:clamp(24px,3vw,42px);font-weight:300;
             letter-spacing:-.025em;line-height:1.18;margin-bottom:28px}
.mc-cs-blk{margin-bottom:24px}
.mc-cs-blk h4{font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
              color:var(--c-gray-400);margin-bottom:10px}
.mc-cs-blk p{font-size:15.5px;font-weight:300;color:var(--c-gray-600);line-height:1.78}
.mc-cs-blk ul{margin-top:8px;display:flex;flex-direction:column;gap:8px}
.mc-cs-blk li{font-size:15px;font-weight:300;color:var(--c-gray-600);
              padding-left:18px;position:relative}
.mc-cs-blk li::before{content:'–';position:absolute;left:0;color:var(--c-green)}
.mc-result{display:flex;gap:18px;align-items:flex-start;
           background:var(--c-black);border-radius:18px;padding:26px 30px;margin-top:32px}
.mc-result-arr{font-size:22px;color:var(--c-lime);flex-shrink:0;margin-top:2px}
.mc-result p{font-size:15px;color:#fff;line-height:1.65}

/* ── 14. STATS ─────────────────────────────────────────────────*/
.mc-stats{display:grid;grid-template-columns:repeat(4,1fr);
          gap:2px;background:var(--c-gray-200);border-radius:20px;overflow:hidden}
.mc-stat{background:#fff;padding:36px 28px;transition:background .2s}
.mc-stat:hover{background:var(--c-cream)}
.mc-stat-n{font-family:var(--f-d);font-size:52px;font-weight:200;letter-spacing:-.04em;
           line-height:1;color:var(--c-black);margin-bottom:10px}
.mc-stat-n.g{color:var(--c-green)}
.mc-stat-l{font-size:11.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--c-gray-400)}
/* Dark variant */
.mc-stats-dk .mc-stat{background:rgba(255,255,255,.04);border-right:1px solid rgba(255,255,255,.05)}
.mc-stats-dk .mc-stat:last-child{border-right:none}
.mc-stats-dk .mc-stat:hover{background:rgba(255,255,255,.07)}
.mc-stats-dk .mc-stat-n{color:#fff}
.mc-stats-dk .mc-stat-n.g{color:var(--c-lime)}
.mc-stats-dk .mc-stat-l{color:rgba(255,255,255,.35)}

/* ── 15. MISSION ───────────────────────────────────────────────*/
.mc-mission{background:var(--c-green);padding:120px 0;text-align:center;position:relative;overflow:hidden}
.mc-mission blockquote{font-family:var(--f-d);font-size:clamp(22px,4vw,50px);font-weight:300;
                       font-style:italic;color:#fff;line-height:1.32;letter-spacing:-.02em;
                       max-width:920px;margin:0 auto 28px}
.mc-mission cite{font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
                 color:rgba(255,255,255,.44);font-style:normal;display:block}

/* ── 16. CTA BAND ──────────────────────────────────────────────*/
.mc-cta{padding:140px 0;text-align:center;position:relative;overflow:hidden}
.mc-cta-dk{background:var(--c-black)}
.mc-cta-cr{background:var(--c-cream)}
.mc-cta h2{margin:0 auto 18px;max-width:720px}
.mc-cta p{font-size:18px;max-width:480px;margin:0 auto 44px;line-height:1.72;color:rgba(255,255,255,.44)}
.mc-cta-cr p{color:var(--c-gray-600)}
.mc-cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ── 17. DIAGRAMS ──────────────────────────────────────────────*/
/* Process circle */
.mc-diag-wrap{position:relative;width:480px;height:480px;margin:0 auto}
/* Pillars */
.mc-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.mc-pillar{background:var(--c-black);padding:52px 40px;position:relative;overflow:hidden;transition:background .3s}
.mc-pillar:hover{background:var(--c-green)}
.mc-pillar-n{font-family:var(--f-d);font-size:96px;font-weight:200;
             color:rgba(255,255,255,.05);line-height:1;position:absolute;top:16px;right:20px}
.mc-pillar-icon{font-size:38px;margin-bottom:24px;display:block}
.mc-pillar-name{font-family:var(--f-d);font-size:28px;font-weight:300;color:#fff;margin-bottom:14px}
.mc-pillar-desc{font-size:14px;color:rgba(255,255,255,.48);line-height:1.72}
.mc-pillar:hover .mc-pillar-desc{color:rgba(255,255,255,.8)}
/* Timeline */
.mc-tl-row{display:flex;align-items:flex-start;justify-content:center;position:relative}
.mc-tl-row::before{content:'';position:absolute;top:24px;left:calc(10% + 24px);
                   right:calc(10% + 24px);height:2px;background:var(--c-gray-200);z-index:0}
.mc-tl-item{display:flex;flex-direction:column;align-items:center;flex:1;max-width:160px;position:relative;z-index:1}
.mc-tl-dot{width:48px;height:48px;border-radius:50%;background:var(--c-green);color:#fff;
           display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;
           margin-bottom:16px;transition:transform .2s;box-shadow:0 0 0 6px rgba(0,168,89,.12)}
.mc-tl-item:hover .mc-tl-dot{transform:scale(1.15)}
.mc-tl-label{font-size:13px;font-weight:600;color:var(--c-black);text-align:center}

/* ── 18. VALUES ────────────────────────────────────────────────*/
.mc-values-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.mc-val-card{background:#fff;border-radius:22px;padding:48px 44px;
             border:1px solid var(--c-gray-200);transition:transform .3s var(--ease),box-shadow .3s}
.mc-val-card:hover{transform:translateY(-4px);box-shadow:0 20px 52px rgba(41,45,43,.07)}
.mc-val-n{font-family:var(--f-d);font-size:76px;font-weight:200;color:var(--c-gray-200);line-height:1;margin-bottom:20px}
.mc-val-name{font-family:var(--f-d);font-size:30px;font-weight:400;letter-spacing:-.02em;margin-bottom:14px}
.mc-val-desc{font-size:15px;color:var(--c-gray-600);line-height:1.75}

/* ── 19. PEOPLE ────────────────────────────────────────────────*/
.mc-person{display:grid;grid-template-columns:260px 1fr;gap:80px;align-items:start;
           padding:72px 0;border-top:1px solid var(--c-gray-200)}
.mc-person:last-of-type{border-bottom:1px solid var(--c-gray-200)}
.mc-avatar{width:100%;aspect-ratio:1/1;border-radius:22px;display:flex;align-items:center;
           justify-content:center;font-family:var(--f-d);font-size:60px;font-weight:300;
           color:#fff;letter-spacing:-2px;overflow:hidden}
.mc-av-g{background:linear-gradient(135deg,var(--c-green),#00d070)}
.mc-av-bk{background:linear-gradient(135deg,var(--c-black),#404040)}
.mc-person-name{font-family:var(--f-d);font-size:38px;font-weight:300;letter-spacing:-.02em;margin-bottom:7px}
.mc-person-role{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--c-green);margin-bottom:28px}
.mc-person-bio p{font-size:16px;font-weight:300;color:var(--c-gray-600);line-height:1.8;margin-bottom:16px}
.mc-person-clients{padding:22px;background:var(--c-cream);border-radius:14px;margin:24px 0 20px}
.mc-person-clients h5{font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--c-gray-400);margin-bottom:10px}
.mc-person-clients p{font-size:14px;color:var(--c-gray-600);line-height:1.65}
.mc-person-creds{display:flex;gap:8px;flex-wrap:wrap}
.mc-cred{background:var(--c-gray-100);border-radius:100px;padding:6px 14px;font-size:11.5px;font-weight:500;color:var(--c-gray-600)}

/* ── 20. PROCESS STEPS ─────────────────────────────────────────*/
.mc-step{display:grid;grid-template-columns:140px 1fr 1fr;gap:56px;align-items:start;
         padding:64px 0;border-top:1px solid var(--c-gray-200)}
.mc-step:last-child{border-bottom:1px solid var(--c-gray-200)}
.mc-step-n{font-family:var(--f-d);font-size:84px;font-weight:200;color:var(--c-gray-200);line-height:1}
.mc-step-sub{font-size:10.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--c-green);margin-bottom:10px}
.mc-step-name{font-family:var(--f-d);font-size:38px;font-weight:300;letter-spacing:-.02em}
.mc-step-body{font-size:16px;font-weight:300;color:var(--c-gray-600);line-height:1.78;padding-top:8px}

/* ── 21. PRINCIPLES ────────────────────────────────────────────*/
.mc-principles{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.07)}
.mc-principle{background:var(--c-black);padding:48px 40px;transition:background .2s}
.mc-principle:hover{background:rgba(255,255,255,.04)}
.mc-pr-icon{font-size:34px;margin-bottom:20px;display:block}
.mc-pr-name{font-family:var(--f-d);font-size:26px;font-weight:300;color:#fff;margin-bottom:12px}
.mc-pr-desc{font-size:14px;color:rgba(255,255,255,.42);line-height:1.72}

/* ── 22. SERVICES LAYOUT ───────────────────────────────────────*/
.mc-svc-sect{padding:120px 0;border-top:1px solid var(--c-gray-200);scroll-margin-top:var(--nav-h)}
.mc-svc-layout{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:start}
.mc-svc-layout.rev{direction:rtl}
.mc-svc-layout.rev>*{direction:ltr}
.mc-svc-n-bg{font-family:var(--f-d);font-size:120px;font-weight:200;letter-spacing:-.06em;color:var(--c-gray-200);line-height:1}
.mc-svc-name{font-family:var(--f-d);font-size:clamp(28px,3.5vw,46px);font-weight:300;letter-spacing:-.025em;line-height:1.15;margin-top:-20px;margin-bottom:22px}
.mc-svc-intro{font-size:17px;font-weight:300;color:var(--c-gray-600);line-height:1.78;margin-bottom:32px}
.mc-cap{display:flex;align-items:center;gap:15px;padding:14px 0;
        border-bottom:1px solid var(--c-gray-200);font-size:15px;color:var(--c-black);transition:color .15s}
.mc-cap:hover{color:var(--c-green)}
.mc-cap-dot{width:7px;height:7px;border-radius:50%;background:var(--c-green);flex-shrink:0}
.mc-svc-vis{border-radius:24px;overflow:hidden;aspect-ratio:4/5;position:relative;
            display:flex;align-items:center;justify-content:center}
.mc-svc-vis-img{position:absolute;inset:0}
.mc-svc-vis-img img{width:100%;height:100%;object-fit:cover;opacity:.22}
.mc-svc-vis-inner{text-align:center;padding:52px;position:relative;z-index:1}
.mc-svc-vis-quote{font-family:var(--f-d);font-size:28px;font-weight:300;font-style:italic;line-height:1.3}

/* ── 23. WURD / ARTICLES ───────────────────────────────────────*/
.mc-feat-card{display:grid;grid-template-columns:1fr 1fr;border-radius:24px;overflow:hidden;
              border:1px solid var(--c-gray-200);text-decoration:none;color:inherit;
              transition:transform .35s var(--ease),box-shadow .35s}
.mc-feat-card:hover{transform:translateY(-5px);box-shadow:0 28px 64px rgba(41,45,43,.1)}
.mc-feat-img{position:relative;overflow:hidden;min-height:400px}
.mc-feat-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.mc-feat-card:hover .mc-feat-img img{transform:scale(1.04)}
.mc-feat-badge{position:absolute;bottom:22px;left:22px;background:var(--c-lime);color:var(--c-black);
               font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
               padding:6px 14px;border-radius:100px}
.mc-feat-rt{position:absolute;top:18px;right:18px;background:rgba(41,45,43,.7);
            color:rgba(255,255,255,.85);font-size:11px;font-weight:500;padding:5px 12px;border-radius:100px}
.mc-feat-body{background:#fff;padding:52px 48px;display:flex;flex-direction:column;justify-content:center}
.mc-feat-meta{font-size:12px;color:var(--c-gray-400);margin-bottom:18px;font-weight:500}
.mc-feat-title{font-family:var(--f-d);font-size:clamp(22px,2.8vw,36px);font-weight:300;letter-spacing:-.02em;line-height:1.22;margin-bottom:18px}
.mc-feat-exc{font-size:16px;font-weight:300;color:var(--c-gray-600);line-height:1.78;flex:1;margin-bottom:32px}
.mc-feat-read{font-size:14px;font-weight:500;color:var(--c-green);display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.mc-feat-card:hover .mc-feat-read{gap:12px}
.mc-art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.mc-art-card{background:#fff;border-radius:18px;overflow:hidden;border:1px solid var(--c-gray-200);
             text-decoration:none;color:inherit;display:flex;flex-direction:column;
             transition:transform .28s var(--ease),box-shadow .28s}
.mc-art-card:hover{transform:translateY(-5px);box-shadow:0 18px 44px rgba(41,45,43,.08)}
.mc-art-thumb{height:220px;overflow:hidden;position:relative}
.mc-art-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .42s var(--ease)}
.mc-art-card:hover .mc-art-thumb img{transform:scale(1.07)}
.mc-art-thumb-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(41,45,43,.48),transparent)}
.mc-art-cat{position:absolute;bottom:14px;left:14px;background:rgba(41,45,43,.7);
            color:rgba(255,255,255,.9);font-size:10px;font-weight:700;letter-spacing:.12em;
            text-transform:uppercase;padding:4px 10px;border-radius:100px}
.mc-art-body{padding:26px 24px;display:flex;flex-direction:column;flex:1}
.mc-art-title{font-family:var(--f-d);font-size:20px;font-weight:300;letter-spacing:-.02em;line-height:1.35;margin-bottom:10px;flex:1}
.mc-art-exc{font-size:14px;color:var(--c-gray-600);line-height:1.65;margin-bottom:18px}
.mc-art-foot{display:flex;justify-content:space-between;border-top:1px solid var(--c-gray-200);padding-top:14px}
.mc-art-read{font-size:12px;color:var(--c-gray-400);font-weight:500}
.mc-art-arr{color:var(--c-green);transition:transform .2s}
.mc-art-card:hover .mc-art-arr{transform:translateX(5px)}

/* ── 24. CONTACT / FORM ────────────────────────────────────────*/
.mc-contact-split{display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - var(--nav-h))}
.mc-contact-left{background:var(--c-black);padding:96px 88px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.mc-contact-right{background:var(--c-cream);padding:96px 88px;display:flex;flex-direction:column;justify-content:center}
.mc-field{margin-bottom:18px}
.mc-field label{display:block;font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--c-gray-600);margin-bottom:9px}
.mc-field input,.mc-field textarea,.mc-field select{width:100%;background:#fff;border:1.5px solid var(--c-gray-200);border-radius:14px;padding:14px 20px;font-family:var(--f-b);font-size:15px;color:var(--c-black);outline:none;transition:border-color .22s,box-shadow .22s;-webkit-appearance:none;appearance:none}
.mc-field input:focus,.mc-field textarea:focus,.mc-field select:focus{border-color:var(--c-green);box-shadow:0 0 0 3px rgba(0,168,89,.12)}
.mc-field textarea{resize:vertical;min-height:120px}
.mc-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.mc-cd{margin-bottom:36px}
.mc-cd-lbl{font-size:10.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-bottom:6px}
.mc-cd-val{font-size:18px;font-weight:300;color:#fff}
.mc-cd-val a{color:var(--c-lime);transition:opacity .2s}
.mc-cd-val a:hover{opacity:.7}

/* ── 25. SITEMAP ───────────────────────────────────────────────*/
.mc-sm-tree{display:flex;flex-direction:column;align-items:center;gap:0}
.mc-sm-root{background:var(--c-black);color:#fff;border-radius:16px;padding:22px 40px;
            font-family:var(--f-d);font-size:22px;font-weight:300;display:inline-flex;align-items:center;gap:10px}
.mc-sm-v{width:2px;height:40px;background:var(--c-green);margin:0 auto}
.mc-sm-hline{position:absolute;top:0;left:8%;right:8%;height:2px;background:var(--c-green)}
.mc-sm-l1{display:flex;justify-content:center;position:relative;width:100%}
.mc-sm-col{display:flex;flex-direction:column;align-items:center;flex:1;max-width:170px;position:relative}
.mc-sm-tick{width:2px;height:32px;background:var(--c-green);margin:0 auto}
.mc-sm-page{background:#fff;border:2px solid var(--c-green);border-radius:12px;padding:13px 16px;width:100%;max-width:158px;text-align:center;transition:all .22s;text-decoration:none;display:block}
.mc-sm-page:hover{background:var(--c-green)}
.mc-sm-page:hover .mc-smp-l,.mc-sm-page:hover .mc-smp-u{color:#fff}
.mc-smp-l{font-weight:700;font-size:14px;color:var(--c-black);display:block}
.mc-smp-u{font-size:11px;color:var(--c-gray-400);margin-top:3px;display:block;font-family:monospace}
.mc-sm-sub{width:1.5px;height:22px;background:var(--c-gray-200);margin:0 auto}
.mc-sm-sub-n{background:var(--c-gray-100);border-radius:8px;padding:8px 12px;width:calc(100% - 14px);max-width:144px;text-align:center;font-size:11.5px;font-weight:500;color:var(--c-gray-600);border:1px solid var(--c-gray-200);transition:all .2s;margin-bottom:5px;display:block}
.mc-sm-sub-n:hover{background:rgba(0,168,89,.08);border-color:var(--c-green);color:var(--c-green)}
.mc-sm-table{width:100%;border-collapse:collapse}
.mc-sm-table thead tr{background:var(--c-black)}
.mc-sm-table thead th{font-size:10.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.44);padding:14px 18px;text-align:left}
.mc-sm-table tbody tr{border-bottom:1px solid var(--c-gray-200);transition:background .15s}
.mc-sm-table tbody tr:hover{background:var(--c-cream)}
.mc-sm-table td{padding:15px 18px;font-size:14px;vertical-align:top}
.mc-sm-table td:first-child{font-weight:600;white-space:nowrap}
.mc-sm-table td:nth-child(2){color:var(--c-gray-400);font-family:monospace;font-size:13px}
.mc-sm-table td:nth-child(3){color:var(--c-gray-600)}
.mc-pri-hi{background:rgba(0,168,89,.1);color:var(--c-green);padding:3px 11px;border-radius:100px;font-size:11px;font-weight:700}
.mc-pri-md{background:rgba(157,224,22,.12);color:#5a8000;padding:3px 11px;border-radius:100px;font-size:11px;font-weight:700}
.mc-pri-lo{background:var(--c-gray-100);color:var(--c-gray-500);padding:3px 11px;border-radius:100px;font-size:11px;font-weight:700}

/* ── 26. FILTER TABS ───────────────────────────────────────────*/
.mc-filter-band{background:var(--c-black);padding:0 0 48px;border-bottom:1px solid rgba(255,255,255,.06)}
.mc-filter-tabs{display:flex;gap:8px;flex-wrap:wrap}
.mc-ftab{padding:9px 22px;border-radius:100px;font-size:13px;font-weight:500;
         border:1.5px solid rgba(255,255,255,.16);color:rgba(255,255,255,.46);
         background:transparent;cursor:pointer;transition:all .22s;font-family:var(--f-b)}
.mc-ftab:hover,.mc-ftab.active{background:var(--c-lime);border-color:var(--c-lime);color:var(--c-black)}
.mc-cat-tab{padding:9px 22px;border-radius:100px;font-size:13px;font-weight:500;
            border:1.5px solid rgba(255,255,255,.16);color:rgba(255,255,255,.46);
            background:transparent;cursor:pointer;transition:all .22s;font-family:var(--f-b)}
.mc-cat-tab:hover,.mc-cat-tab.active{background:var(--c-lime);border-color:var(--c-lime);color:var(--c-black)}

/* ── 27. SUBSCRIBE ─────────────────────────────────────────────*/
.mc-subscribe{background:var(--c-green);padding:100px 0;text-align:center;position:relative;overflow:hidden}
.mc-subscribe h2{font-family:var(--f-d);font-size:clamp(28px,4vw,54px);font-weight:300;color:#fff;letter-spacing:-.025em;line-height:1.2;margin-bottom:14px}
.mc-subscribe p{font-size:18px;color:rgba(255,255,255,.62);margin-bottom:40px;max-width:480px;margin-left:auto;margin-right:auto}
.mc-sub-form{display:flex;gap:12px;max-width:500px;margin:0 auto}
.mc-sub-form input{flex:1;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.28);border-radius:100px;padding:15px 24px;font-family:var(--f-b);font-size:15px;color:#fff;outline:none;transition:border-color .2s}
.mc-sub-form input::placeholder{color:rgba(255,255,255,.48)}
.mc-sub-form input:focus{border-color:#fff}
.mc-sub-note{font-size:13px;color:rgba(255,255,255,.4);margin-top:14px}

/* ── 28. RESPONSIVE ────────────────────────────────────────────*/
@media(max-width:1200px){
  :root{--pad:52px}
  .mc-footer-grid{grid-template-columns:1fr 1fr;gap:48px}
  .mc-stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:1024px){
  :root{--pad:36px}
  .mc-cs-grid,.mc-svc-layout{grid-template-columns:1fr;gap:48px}
  .mc-cs-grid.flip,.mc-svc-layout.rev{direction:ltr}
  .mc-person{grid-template-columns:1fr;gap:40px}
  .mc-avatar{max-width:200px}
  .mc-step{grid-template-columns:1fr;gap:16px}
  .mc-step>*:last-child{grid-column:1}
  .mc-principles{grid-template-columns:1fr}
  .mc-feat-card{grid-template-columns:1fr}
  .mc-contact-split{grid-template-columns:1fr}
  .mc-contact-left,.mc-contact-right{padding:64px 40px}
  .mc-values-grid{grid-template-columns:1fr}
  .mc-art-grid{grid-template-columns:1fr 1fr}
  .mc-work-row{grid-template-columns:60px 1fr 36px}
  .mc-wr-type,.mc-wr-tag{display:none}
  .mc-pillars{grid-template-columns:1fr}
  .mc-svc-tiles{grid-template-columns:1fr}
}
@media(max-width:768px){
  :root{--pad:20px;--nav-h:62px}
  #mc-nav{padding:0 20px}
  .mc-nav-links{display:none}
  .mc-hamburger{display:flex}
  .mc-footer-grid{grid-template-columns:1fr;gap:32px}
  .mc-footer-btm{flex-direction:column;gap:12px;text-align:center}
  .mc-form-row{grid-template-columns:1fr}
  .mc-art-grid{grid-template-columns:1fr}
  .mc-sm-l1{flex-wrap:wrap;gap:32px;justify-content:center}
  .mc-sm-hline{display:none}
  .mc-diag-wrap{width:320px;height:320px}
}
