/*
Theme Name:        CloudSprout
Theme URI:         https://cloudsprout.ca
Description:       CloudSprout custom theme — Modern editorial. Cream + green. Child of Hello Elementor.
Author:            CloudSprout
Author URI:        https://cloudsprout.ca
Template:          hello-elementor
Version:           5.3.0
Text Domain:       cloudsprout
*/

/* ════════════════════════════════════════════════════════════════
   CLOUDSPROUT v4 — Clean editorial. Single cs- prefix.
   ════════════════════════════════════════════════════════════════ */

:root{
  --cs-cream:#f3efe6;
  --cs-cream-2:#ebe6da;
  --cs-paper:#fbf8ef;
  --cs-paper-2:#f7f3e8;
  --cs-white:#ffffff;
  --cs-ink:#15170f;
  --cs-ink-2:#3d4135;
  --cs-ink-3:#666b58;
  --cs-ink-4:#8d9182;
  --cs-green:#2f5a3b;
  --cs-green-2:#4d8a5c;
  --cs-green-3:#7ecf8f;
  --cs-green-glow:#a7dba0;
  --cs-green-ink:#1a3622;
  --cs-marker:#c4e6b8;
  --cs-line:rgba(21,23,15,.12);
  --cs-line-2:rgba(21,23,15,.22);
  --cs-shadow-stamp:3px 3px 0 var(--cs-ink);
  --cs-shadow-stamp-lg:5px 5px 0 var(--cs-ink);
  --cs-font:'Surgena',Georgia,'Times New Roman',serif;
  --cs-mono:'SF Mono','Menlo','JetBrains Mono',ui-monospace,monospace;
  --cs-ease:cubic-bezier(.22,1,.36,1);
  --cs-pad-x:clamp(1.1rem,4vw,3rem);
}

/* ─── Reset within .cs-page ─── */
.cs-page,
.cs-page *,
.cs-page *::before,
.cs-page *::after{box-sizing:border-box}
.cs-page h1,.cs-page h2,.cs-page h3,.cs-page h4,
.cs-page p,.cs-page ul,.cs-page ol,.cs-page figure{margin:0;padding:0}
.cs-page ul,.cs-page ol{list-style:none}
.cs-page img,.cs-page video,.cs-page svg{max-width:100%;display:block}
.cs-page a{color:inherit;text-decoration:none}
.cs-page button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}

html{scroll-behavior:smooth}

/* Hide host theme chrome on CS pages — aggressive */
body.cs-active .site-header,
body.cs-active .site-footer,
body.cs-active .elementor-location-header,
body.cs-active .elementor-location-footer,
body.cs-active .ehf-header,
body.cs-active .ehf-footer,
body.cs-active #ast-mobile-header,
body.cs-active .site-content > .ast-container,
body.cs-active main.site-main > .entry-header{display:none!important}

body.cs-active{
  font-family:var(--cs-font)!important;
  background:var(--cs-cream)!important;
  color:var(--cs-ink)!important;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-weight:300;
}
body.admin-bar.cs-active #cs-nav{top:32px}
@media (max-width:782px){body.admin-bar.cs-active #cs-nav{top:46px}}

/* Override Elementor / Astra inherited styles on CS pages */
body.cs-active .cs-page button,
body.cs-active .cs-page .button,
body.cs-active .cs-page .wp-block-button__link,
body.cs-active .cs-page input[type="submit"]{
  background-image:none!important;
  text-transform:none!important;
}
/* Kill any pink/magenta from category chips, GeneratePress, ACF, etc. */
body.cs-active .cs-page .cat-links,
body.cs-active .cs-page .post-categories a,
body.cs-active .cs-page .tags-links a,
body.cs-active .cs-page .wp-block-categories,
body.cs-active .cs-page .entry-meta a,
body.cs-active .cs-page [class*="wpcf7"]{
  color:var(--cs-ink)!important;
  background:transparent!important;
}

/* Reveal */
.cs-r{opacity:0;transform:translateY(28px);transition:opacity .9s var(--cs-ease),transform .9s var(--cs-ease)}
.cs-r.cs-v{opacity:1;transform:none}
.cs-r-d2{transition-delay:.08s}
.cs-r-d3{transition-delay:.16s}
.cs-r-d4{transition-delay:.24s}
.cs-r-d5{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.cs-r{opacity:1;transform:none;transition:none}}

/* Paper grain */
body.cs-active::before{
  content:"";position:fixed;inset:-50%;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .4 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity:.06;mix-blend-mode:multiply;
}

/* Cursor blob */
.cs-blob{
  position:fixed;top:0;left:0;width:480px;height:480px;
  pointer-events:none;z-index:2;
  background:radial-gradient(circle at center,rgba(126,207,143,.28),transparent 65%);
  transform:translate(-50%,-50%);
  transition:opacity .6s var(--cs-ease);
  will-change:transform;opacity:0;
}
.cs-blob.cs-on{opacity:1}
@media (hover:none),(max-width:900px){.cs-blob{display:none}}

/* ════════════════════════════════════════════════════════════════
   NAV
   ════════════════════════════════════════════════════════════════ */
#cs-nav{
  position:fixed;top:0;left:0;right:0;z-index:9999;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem var(--cs-pad-x);
  background:rgba(243,239,230,.78);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid var(--cs-line);
  transition:padding .35s var(--cs-ease),background .35s var(--cs-ease),box-shadow .35s var(--cs-ease);
}
#cs-nav.cs-nav-sc{padding:.7rem var(--cs-pad-x);background:rgba(243,239,230,.94);box-shadow:0 2px 28px rgba(21,23,15,.06)}
.cs-logo{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.cs-logo img{height:34px;width:auto}
.cs-logo-name{font-family:var(--cs-font);font-size:1.08rem;letter-spacing:.002em;color:var(--cs-ink)}
.cs-nav-links{display:flex;gap:2.2rem;position:absolute;left:50%;transform:translateX(-50%)}
.cs-nav-links a{
  position:relative;font-family:var(--cs-font);font-size:.94rem;
  color:var(--cs-ink-2);transition:color .25s var(--cs-ease);
  padding:.3rem 0;
}
.cs-nav-links a::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:8px;
  background:var(--cs-marker);border-radius:50%;
  transform:scaleX(0);transform-origin:left center;opacity:0;
  transition:transform .35s var(--cs-ease),opacity .35s var(--cs-ease);
  z-index:-1;
}
.cs-nav-links a:hover,.cs-nav-links a.cs-active{color:var(--cs-ink)}
.cs-nav-links a:hover::after,.cs-nav-links a.cs-active::after{transform:scaleX(1);opacity:.85}

/* Nav CTA — stamp */
.cs-nav-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--cs-font);font-size:.9rem;
  background:var(--cs-ink);color:var(--cs-cream)!important;
  padding:.78rem 1.45rem;border-radius:2px;
  border:1.5px solid var(--cs-ink);
  box-shadow:var(--cs-shadow-stamp);
  transition:transform .25s var(--cs-ease),box-shadow .25s var(--cs-ease),background .25s var(--cs-ease);
  flex-shrink:0;
}
.cs-nav-cta:hover{transform:translate(-2px,-2px);box-shadow:var(--cs-shadow-stamp-lg);background:var(--cs-green)}
.cs-nav-cta .cs-arr{display:inline-block;transition:transform .3s var(--cs-ease)}
.cs-nav-cta:hover .cs-arr{transform:translateX(3px)}

.cs-burger{display:none;flex-direction:column;gap:5px;padding:6px}
.cs-burger span{display:block;width:22px;height:1.5px;background:var(--cs-ink);transition:transform .3s var(--cs-ease)}

/* Mobile-only compact Contact button next to burger */
.cs-nav-cta-mob{
  display:none;align-items:center;
  font-family:var(--cs-font);font-size:.86rem;letter-spacing:.005em;
  background:var(--cs-ink);color:var(--cs-cream)!important;
  padding:.55rem 1rem;border-radius:2px;
  border:1.5px solid var(--cs-ink);
  box-shadow:2px 2px 0 var(--cs-ink);
  margin-right:.6rem;flex-shrink:0;
  transition:transform .25s var(--cs-ease),background .25s var(--cs-ease);
}
.cs-nav-cta-mob:hover,.cs-nav-cta-mob:active{background:var(--cs-green);transform:translate(-1px,-1px)}

@media (max-width:980px){
  .cs-nav-links{display:none}
  .cs-burger{display:flex}
  .cs-nav-cta{display:none}
  .cs-nav-cta-mob{display:inline-flex}
}

#cs-mob{
  display:none;position:fixed;inset:0;z-index:10000;
  background:var(--cs-cream);
  flex-direction:column;align-items:flex-start;justify-content:center;gap:1.2rem;
  padding:5rem 2rem 2rem;
}
#cs-mob.cs-on{display:flex}
.cs-mob-x{position:absolute;top:1.2rem;right:1.5rem;font-size:2rem;color:var(--cs-ink);line-height:1}
#cs-mob a{font-family:var(--cs-font);font-size:clamp(1.9rem,7vw,2.8rem);letter-spacing:-.02em;color:var(--cs-ink);position:relative;line-height:1.05}
#cs-mob a:not(.cs-nav-cta)::after{
  content:"";position:absolute;left:0;right:0;bottom:6px;height:12px;background:var(--cs-marker);border-radius:50%;
  transform:scaleX(0);transform-origin:left;transition:transform .35s var(--cs-ease);z-index:-1;
}
#cs-mob a:hover::after{transform:scaleX(1)}
#cs-mob .cs-nav-cta{display:inline-flex;font-size:1.05rem;padding:1rem 2rem;margin-top:.8rem}

/* ════════════════════════════════════════════════════════════════
   BUTTONS — stamp style
   ════════════════════════════════════════════════════════════════ */
.cs-btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--cs-font);font-size:1rem;letter-spacing:.005em;
  padding:.95rem 1.65rem;border-radius:2px;
  border:1.5px solid var(--cs-ink);
  background:var(--cs-ink);color:var(--cs-cream)!important;
  box-shadow:var(--cs-shadow-stamp);
  transition:transform .3s var(--cs-ease),box-shadow .3s var(--cs-ease),background .3s var(--cs-ease),color .3s var(--cs-ease),border-color .3s var(--cs-ease);
  cursor:pointer;will-change:transform;
}
.cs-btn:hover{transform:translate(-3px,-3px);box-shadow:var(--cs-shadow-stamp-lg)}
.cs-btn .cs-arr{transition:transform .3s var(--cs-ease)}
.cs-btn:hover .cs-arr{transform:translateX(4px)}

.cs-btn-green{background:var(--cs-green);border-color:var(--cs-green);color:var(--cs-cream)!important;box-shadow:3px 3px 0 var(--cs-green-ink)}
.cs-btn-green:hover{background:var(--cs-green-ink);border-color:var(--cs-green-ink);box-shadow:5px 5px 0 var(--cs-green-ink)}

.cs-btn-cream{background:var(--cs-cream);color:var(--cs-ink)!important;border-color:var(--cs-ink)}
.cs-btn-cream:hover{background:var(--cs-marker);color:var(--cs-ink)!important}

.cs-btn-ghost{background:transparent;color:var(--cs-ink)!important;border-color:var(--cs-ink)}
.cs-btn-ghost:hover{background:var(--cs-ink);color:var(--cs-cream)!important}

/* On dark/green background — guaranteed text contrast */
.cs-btn-on-dark{
  background:var(--cs-green-3)!important;border-color:var(--cs-green-3)!important;
  color:var(--cs-ink)!important;
  box-shadow:3px 3px 0 var(--cs-cream)!important;
}
.cs-btn-on-dark:hover{
  background:var(--cs-cream)!important;border-color:var(--cs-cream)!important;
  color:var(--cs-ink)!important;
  box-shadow:5px 5px 0 var(--cs-green-3)!important;
}
.cs-btn-on-dark-ghost{
  background:transparent!important;
  color:var(--cs-cream)!important;
  border-color:var(--cs-cream)!important;
  box-shadow:3px 3px 0 rgba(243,239,230,.35)!important;
}
.cs-btn-on-dark-ghost:hover{
  background:var(--cs-cream)!important;
  color:var(--cs-ink)!important;
  border-color:var(--cs-cream)!important;
  box-shadow:5px 5px 0 var(--cs-green-3)!important;
}

.cs-mag{transition:transform .5s var(--cs-ease)}

/* Inline link */
.cs-link{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:var(--cs-font);color:var(--cs-ink);
  position:relative;padding:.2rem 0;
  background:linear-gradient(to right,var(--cs-green) 100%,var(--cs-green) 100%) 0 100% / 100% 1.5px no-repeat;
  transition:background-size .35s var(--cs-ease);
}
.cs-link:hover{background-size:100% 8px;background-image:linear-gradient(to right,var(--cs-marker),var(--cs-marker))}
.cs-link .cs-arr{transition:transform .3s var(--cs-ease)}
.cs-link:hover .cs-arr{transform:translateX(4px)}

/* ════════════════════════════════════════════════════════════════
   TYPE
   ════════════════════════════════════════════════════════════════ */
.cs-eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--cs-mono);font-size:.74rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--cs-green);font-weight:500;
}
.cs-eyebrow::before{
  content:"";display:inline-block;width:20px;height:1.5px;background:var(--cs-green);
}

.cs-h1{font-family:var(--cs-font);font-size:clamp(2.6rem,8vw,7.5rem);font-weight:300;line-height:1;letter-spacing:-.03em;color:var(--cs-ink)}
.cs-h2{font-family:var(--cs-font);font-size:clamp(2.1rem,5.8vw,4.6rem);font-weight:300;line-height:1.02;letter-spacing:-.025em;color:var(--cs-ink)}
.cs-h3{font-family:var(--cs-font);font-size:clamp(1.45rem,2.8vw,2.2rem);font-weight:300;line-height:1.12;letter-spacing:-.015em;color:var(--cs-ink)}
.cs-h4{font-family:var(--cs-font);font-size:clamp(1.15rem,1.8vw,1.4rem);font-weight:300;line-height:1.2;color:var(--cs-ink)}
.cs-lede{font-family:var(--cs-font);font-size:clamp(1.02rem,1.3vw,1.18rem);line-height:1.65;color:var(--cs-ink-2);max-width:58ch}
.cs-italic{font-style:italic;color:var(--cs-green)}

/* Marker highlight */
.cs-mark{
  display:inline;
  background:linear-gradient(transparent 62%,var(--cs-marker) 62%,var(--cs-marker) 92%,transparent 92%);
  padding:0 .1em;
}

/* ════════════════════════════════════════════════════════════════
   SECTIONS / CONTAINERS
   ════════════════════════════════════════════════════════════════ */
.cs-section{padding:clamp(4rem,9vw,7rem) var(--cs-pad-x);position:relative;z-index:3}
.cs-section-tight{padding:clamp(2.5rem,5vw,4rem) var(--cs-pad-x);position:relative;z-index:3}
.cs-container{max-width:1320px;margin:0 auto;width:100%}
.cs-container-narrow{max-width:960px;margin:0 auto;width:100%}
.cs-container-prose{max-width:720px;margin:0 auto;width:100%}
.cs-bg-cream{background:var(--cs-cream)}
.cs-bg-paper{background:var(--cs-paper)}
.cs-bg-ink{background:var(--cs-ink);color:var(--cs-cream)}
.cs-bg-green-deep{background:var(--cs-green-ink);color:var(--cs-cream)}

.cs-head-2col{
  display:grid;grid-template-columns:1.1fr 1fr;gap:3rem;
  align-items:end;margin-bottom:clamp(2.5rem,5vw,4rem);
}
.cs-head-2col p{font-size:clamp(1rem,1.2vw,1.15rem);line-height:1.65;color:var(--cs-ink-2);max-width:46ch}
@media(max-width:820px){.cs-head-2col{grid-template-columns:1fr;gap:1.2rem;align-items:start}}

/* ════════════════════════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════════════════════════ */
.cs-hero{
  position:relative;min-height:100vh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:120px var(--cs-pad-x) 4rem;
  border-bottom:1.5px solid var(--cs-ink);
  overflow:hidden;background:var(--cs-cream);
}
.cs-hero.cs-hero-short{min-height:76vh}
.cs-hero.cs-hero-mini{min-height:44vh;justify-content:center;padding-top:140px;padding-bottom:3rem}

.cs-hero-video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
  z-index:1;opacity:0;transition:opacity 1.2s var(--cs-ease);pointer-events:none;
}
.cs-hero-video.cs-vid-ready{opacity:1}
.cs-hero-video::-webkit-media-controls,
.cs-hero-video::-webkit-media-controls-enclosure,
.cs-hero-video::-webkit-media-controls-panel,
.cs-hero-video::-webkit-media-controls-overlay-play-button,
.cs-hero-video::-webkit-media-controls-start-playback-button{display:none!important;opacity:0!important}
.cs-hero-overlay{
  position:absolute;inset:0;z-index:2;
  background:linear-gradient(to bottom,rgba(243,239,230,.2) 0%,rgba(243,239,230,.06) 35%,rgba(243,239,230,.55) 72%,rgba(243,239,230,.96) 100%);
}

.cs-hero-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:auto;padding-bottom:2rem;position:relative;z-index:3;gap:1rem;flex-wrap:wrap}
.cs-badge{
  display:inline-flex;align-items:center;gap:.55rem;
  background:var(--cs-cream);border:1.5px solid var(--cs-ink);
  padding:.55rem 1rem;border-radius:2px;
  font-family:var(--cs-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cs-ink);
  box-shadow:2px 2px 0 var(--cs-ink);
  font-weight:500;
}
.cs-dot{width:7px;height:7px;background:var(--cs-green);border-radius:50%;animation:cs-pulse 2s infinite;flex-shrink:0}
.cs-hero-body{position:relative;z-index:3}
.cs-hero-foot{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:2rem;margin-top:2.6rem}
.cs-hero-desc{max-width:480px;font-size:1.05rem;line-height:1.65;color:var(--cs-ink-2)}
.cs-hero-acts{display:flex;flex-direction:column;align-items:flex-end;gap:.7rem}
.cs-hero-note{font-family:var(--cs-mono);font-size:.74rem;color:var(--cs-ink-3);letter-spacing:.04em}

/* New cohesive headline — single inline run with italic */
.cs-h1 .cs-italic{display:inline}

@media (max-width:760px){
  .cs-hero-foot{flex-direction:column;align-items:flex-start;margin-top:1.8rem;gap:1.4rem}
  .cs-hero-acts{align-items:flex-start;width:100%}
  .cs-hero{padding:110px var(--cs-pad-x) 2.4rem}
  .cs-hero.cs-hero-short{min-height:auto;padding-bottom:3rem}
}

.cs-hero-mini .cs-h1{font-size:clamp(2.4rem,6vw,4.2rem)}
.cs-hero-mini .cs-hero-meta{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:1.6rem;font-family:var(--cs-mono);font-size:.76rem;color:var(--cs-ink-3);letter-spacing:.04em}
.cs-hero-mini .cs-hero-meta b{color:var(--cs-ink);font-weight:500}

/* ════════════════════════════════════════════════════════════════
   HERO FALLBACK — brand photo behind the video.
   Video fades in on top (cs-vid-ready) for devices that autoplay.
   Devices that can't autoplay (or fail) see the PNG underneath.
   ════════════════════════════════════════════════════════════════ */
.cs-hero-fallback{
  position:absolute;inset:0;z-index:0;overflow:hidden;
  background:
    url("https://cloudsprout.ca/wp-content/uploads/2026/05/cloudsprout-mobile-hero-scaled.png") center/cover no-repeat,
    var(--cs-cream);
}
.cs-hero-fallback-logo{display:none}

/* ════════════════════════════════════════════════════════════════
   MARQUEE
   ════════════════════════════════════════════════════════════════ */
.cs-marquee{overflow:hidden;border-bottom:1.5px solid var(--cs-ink);padding:1rem 0;background:var(--cs-cream);position:relative;z-index:3}
.cs-mtrack{display:inline-flex;animation:cs-marquee 38s linear infinite;white-space:nowrap;will-change:transform;align-items:center}
.cs-marquee:hover .cs-mtrack{animation-play-state:paused}
.cs-mitem{font-family:var(--cs-font);font-size:clamp(1.15rem,2.4vw,1.7rem);color:var(--cs-ink);padding:0 1.4rem;display:inline-flex;align-items:center;gap:1.4rem;letter-spacing:-.005em;font-style:italic}
.cs-mitem:nth-child(odd){color:var(--cs-green);font-style:normal}
.cs-mdot{width:6px;height:6px;background:var(--cs-ink);border-radius:50%;display:inline-block}
@keyframes cs-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes cs-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(1.18)}}

/* ════════════════════════════════════════════════════════════════
   SERVICE CARDS
   ════════════════════════════════════════════════════════════════ */
.cs-gif-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border:1.5px solid var(--cs-ink);background:var(--cs-ink);
}
@media(max-width:1080px){.cs-gif-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cs-gif-grid{grid-template-columns:1fr}}
.cs-gif-card{
  position:relative;background:var(--cs-cream);
  padding:2rem 1.6rem;
  display:flex;flex-direction:column;gap:1rem;
  transition:background .4s var(--cs-ease);
  border-right:1.5px solid var(--cs-ink);
  overflow:hidden;color:var(--cs-ink);
}
.cs-gif-card:last-child{border-right:0}
@media(max-width:1080px){
  .cs-gif-card:nth-child(even){border-right:0}
  .cs-gif-card{border-bottom:1.5px solid var(--cs-ink)}
  .cs-gif-card:nth-last-child(-n+2){border-bottom:0}
}
@media(max-width:560px){
  .cs-gif-card{border-right:0;border-bottom:1.5px solid var(--cs-ink)}
  .cs-gif-card:nth-last-child(-n+2){border-bottom:1.5px solid var(--cs-ink)}
  .cs-gif-card:last-child{border-bottom:0}
}
.cs-gif-card > *{position:relative;z-index:1}
.cs-gif-card::after{
  content:"→";position:absolute;top:1.4rem;right:1.4rem;
  font-size:1.2rem;color:var(--cs-ink);z-index:2;
  transition:transform .35s var(--cs-ease);
}
.cs-gif-card:hover::after{transform:translate(4px,-4px) rotate(-20deg)}
.cs-gif-wrap{
  width:72px;height:72px;
  background:var(--cs-white);
  border:1.5px solid var(--cs-ink);
  display:flex;align-items:center;justify-content:center;
  box-shadow:2px 2px 0 var(--cs-ink);
  transition:transform .3s var(--cs-ease);
}
.cs-gif-card:hover .cs-gif-wrap{transform:scale(1.04) rotate(-3deg)}
.cs-gif-wrap img,.cs-gif-wrap svg{width:50px;height:50px;object-fit:contain}
.cs-gif-title{font-family:var(--cs-font);font-size:1.3rem;line-height:1.15;letter-spacing:-.012em;color:var(--cs-ink)}
.cs-gif-desc{font-size:.92rem;line-height:1.55;color:var(--cs-ink-2)}
.cs-gif-card .cs-tag-num{
  align-self:flex-start;font-family:var(--cs-mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cs-ink-3);
}

/* ════════════════════════════════════════════════════════════════
   NUMBERED GRID
   ════════════════════════════════════════════════════════════════ */
.cs-num-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1.5px solid var(--cs-ink)}
@media(max-width:820px){.cs-num-grid{grid-template-columns:1fr}}
.cs-num-item{
  display:grid;grid-template-columns:auto 1fr;gap:1.4rem;align-items:start;
  padding:1.8rem 1rem 1.8rem 0;
  border-bottom:1.5px solid var(--cs-ink);
  position:relative;color:var(--cs-ink);
}
.cs-num-item:nth-child(odd){padding-right:2rem}
.cs-num-item:nth-child(even){padding-left:2rem;border-left:1.5px solid var(--cs-ink)}
@media(max-width:820px){
  .cs-num-item:nth-child(even){padding-left:0;border-left:0}
  .cs-num-item:nth-child(odd){padding-right:0}
}
.cs-num-n{
  font-family:var(--cs-mono);font-size:.9rem;letter-spacing:.12em;
  color:var(--cs-cream);background:var(--cs-ink);
  width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  font-weight:500;flex-shrink:0;
  transition:background .3s var(--cs-ease),transform .3s var(--cs-ease);
}
.cs-num-item:hover .cs-num-n{background:var(--cs-green);transform:rotate(-6deg)}

/* SVG icon variant (replaces emoji) */
.cs-num-icon{
  width:42px;height:42px;flex-shrink:0;
  background:var(--cs-paper);border:1.5px solid var(--cs-ink);
  display:flex;align-items:center;justify-content:center;
  color:var(--cs-green);
  transition:background .3s var(--cs-ease),transform .3s var(--cs-ease);
}
.cs-num-icon svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.cs-num-item:hover .cs-num-icon{background:var(--cs-marker);transform:rotate(-6deg)}

.cs-num-t{font-family:var(--cs-font);font-size:1.3rem;line-height:1.2;letter-spacing:-.01em;color:var(--cs-ink);margin-bottom:.5rem}
.cs-num-d{font-size:.94rem;line-height:1.6;color:var(--cs-ink-2)}

/* ════════════════════════════════════════════════════════════════
   STATS
   ════════════════════════════════════════════════════════════════ */
.cs-stat-row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border:1.5px solid var(--cs-ink);background:var(--cs-paper);
}
@media(max-width:820px){.cs-stat-row{grid-template-columns:repeat(2,1fr)}}
.cs-stat{padding:1.8rem 1.5rem;display:flex;flex-direction:column;gap:.5rem;border-right:1.5px solid var(--cs-ink);position:relative}
.cs-stat:last-child{border-right:0}
@media(max-width:820px){
  .cs-stat:nth-child(even){border-right:0}
  .cs-stat{border-bottom:1.5px solid var(--cs-ink)}
  .cs-stat:nth-last-child(-n+2){border-bottom:0}
}
.cs-stat-n{font-family:var(--cs-font);font-size:clamp(2.4rem,4vw,3.2rem);line-height:1;letter-spacing:-.02em;color:var(--cs-ink)}
.cs-stat-l{font-family:var(--cs-mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cs-ink-3)}

/* ════════════════════════════════════════════════════════════════
   CTA BAND
   ════════════════════════════════════════════════════════════════ */
.cs-cta{
  position:relative;overflow:hidden;
  padding:clamp(4rem,9vw,7rem) var(--cs-pad-x);
  background:var(--cs-green-ink);color:var(--cs-cream);
  border-top:1.5px solid var(--cs-ink);
}
.cs-cta::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 50% 40% at 78% 20%,rgba(126,207,143,.22),transparent 60%),
    radial-gradient(ellipse 60% 50% at 8% 90%,rgba(126,207,143,.12),transparent 65%);
  pointer-events:none;
}
.cs-cta-inner{position:relative;z-index:1;max-width:1100px;margin:0 auto;display:flex;flex-direction:column;align-items:flex-start;text-align:left;gap:1.4rem}
.cs-cta h2{font-family:var(--cs-font);font-size:clamp(2.4rem,7vw,5rem);font-weight:300;letter-spacing:-.025em;line-height:1;color:var(--cs-cream)}
.cs-cta h2 em{font-style:italic;color:var(--cs-green-3)}
.cs-cta p{max-width:580px;color:rgba(243,239,230,.78);font-size:1.05rem;line-height:1.65;margin-bottom:1rem}
.cs-cta-acts{display:flex;gap:1rem;flex-wrap:wrap}

/* ════════════════════════════════════════════════════════════════
   FOOTER — clean professional
   ════════════════════════════════════════════════════════════════ */
#cs-footer{
  position:relative;z-index:3;
  background:var(--cs-ink);color:var(--cs-cream);
  padding:clamp(3rem,6vw,4.5rem) var(--cs-pad-x) 1.6rem;
}
.cs-ft-grid{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.6rem;
}
@media(max-width:980px){.cs-ft-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:560px){.cs-ft-grid{grid-template-columns:1fr}}
.cs-ft-brand .cs-logo img{height:38px;filter:brightness(1.15)}
.cs-ft-brand .cs-logo-name{font-size:1.15rem;color:var(--cs-cream)}
.cs-ft-tag{margin-top:1rem;color:rgba(243,239,230,.72);font-size:.95rem;line-height:1.6;max-width:32ch}
.cs-ft-col h5{font-family:var(--cs-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cs-green-3);margin-bottom:1.1rem;font-weight:500}
.cs-ft-col li{margin-bottom:.55rem}
.cs-ft-col a{color:rgba(243,239,230,.78);font-size:.96rem;transition:color .25s var(--cs-ease);position:relative;display:inline-block}
.cs-ft-col a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1px;background:var(--cs-green-3);
  transition:right .35s var(--cs-ease);
}
.cs-ft-col a:hover{color:var(--cs-cream)}
.cs-ft-col a:hover::after{right:0}
.cs-ft-bottom{
  max-width:1320px;margin:3rem auto 0;padding-top:1.4rem;
  border-top:1px solid rgba(243,239,230,.16);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  font-family:var(--cs-mono);font-size:.74rem;color:rgba(243,239,230,.52);letter-spacing:.06em;
}
.cs-ft-bottom a{color:rgba(243,239,230,.56)}
.cs-ft-bottom a:hover{color:var(--cs-cream)}
.cs-ft-legal{display:flex;gap:1.4rem}

/* ════════════════════════════════════════════════════════════════
   FORMS
   ════════════════════════════════════════════════════════════════ */
.cs-form{display:grid;gap:1.3rem}
.cs-field{display:flex;flex-direction:column;gap:.45rem}
.cs-field label{font-family:var(--cs-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cs-ink-2)}
.cs-field input,.cs-field textarea,.cs-field select{
  font:inherit;font-family:var(--cs-font);font-size:1.02rem;color:var(--cs-ink);
  background:transparent;
  border:0;border-bottom:1.5px solid var(--cs-line-2);
  padding:.85rem 0;outline:none;border-radius:0;
  transition:border-color .3s var(--cs-ease);
}
.cs-field input:focus,.cs-field textarea:focus,.cs-field select:focus{border-bottom-color:var(--cs-green)}
.cs-field textarea{min-height:120px;resize:vertical}
.cs-form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
@media(max-width:640px){.cs-form-row{grid-template-columns:1fr}}

.cs-ghl-form{
  background:var(--cs-paper);border:1.5px solid var(--cs-ink);
  padding:1.4rem;box-shadow:5px 5px 0 var(--cs-ink);
  min-height:680px;
}
.cs-ghl-form iframe{display:block;width:100%;min-height:640px;border:0;background:transparent}
@media(max-width:640px){.cs-ghl-form{padding:.9rem;min-height:760px}.cs-ghl-form iframe{min-height:720px}}

/* ════════════════════════════════════════════════════════════════
   PROSE
   ════════════════════════════════════════════════════════════════ */
.cs-prose{font-size:1.02rem;line-height:1.75;color:var(--cs-ink-2)}
.cs-prose h2{font-family:var(--cs-font);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:300;color:var(--cs-ink);margin:2.4rem 0 1rem;letter-spacing:-.02em}
.cs-prose h3{font-family:var(--cs-font);font-size:1.25rem;font-weight:300;color:var(--cs-ink);margin:1.5rem 0 .6rem}
.cs-prose p,.cs-prose ul,.cs-prose ol{margin-bottom:1rem}
.cs-prose ul,.cs-prose ol{padding-left:1.2rem}
.cs-prose ul li{list-style:disc}
.cs-prose ol li{list-style:decimal}
.cs-prose li{margin-bottom:.4rem;padding-left:.3rem}
.cs-prose a{color:var(--cs-green);text-decoration:underline;text-underline-offset:3px}
.cs-prose strong{color:var(--cs-ink);font-weight:400}

.cs-toc{position:sticky;top:120px;align-self:start;padding:1.4rem;border:1.5px solid var(--cs-ink);background:var(--cs-paper);box-shadow:4px 4px 0 var(--cs-ink)}
.cs-toc h5{font-family:var(--cs-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cs-green);margin-bottom:1rem;font-weight:500}
.cs-toc a{display:block;font-size:.9rem;color:var(--cs-ink-2);padding:.4rem 0;border-bottom:1px solid var(--cs-line);transition:color .25s var(--cs-ease)}
.cs-toc a:last-child{border-bottom:0}
.cs-toc a:hover,.cs-toc a.cs-active{color:var(--cs-ink)}
.cs-doc-grid{display:grid;grid-template-columns:260px 1fr;gap:3rem}
@media(max-width:900px){.cs-doc-grid{grid-template-columns:1fr}.cs-toc{position:relative;top:0}}

/* ════════════════════════════════════════════════════════════════
   PROJECT CARDS
   ════════════════════════════════════════════════════════════════ */
.cs-proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
@media(max-width:1080px){.cs-proj-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.cs-proj-grid{grid-template-columns:1fr}}
.cs-proj{
  position:relative;background:var(--cs-paper);
  border:1.5px solid var(--cs-ink);
  display:flex;flex-direction:column;
  box-shadow:5px 5px 0 var(--cs-ink);
  transition:transform .5s var(--cs-ease),box-shadow .5s var(--cs-ease);
}
.cs-proj:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--cs-green)}
.cs-proj-img{aspect-ratio:4/3;background:var(--cs-cream);overflow:hidden;position:relative;border-bottom:1.5px solid var(--cs-ink)}
.cs-proj-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--cs-ease)}
.cs-proj:hover .cs-proj-img img{transform:scale(1.05)}
.cs-proj-body{padding:1.3rem 1.5rem 1.6rem;display:flex;flex-direction:column;gap:.65rem;flex:1}
.cs-proj-tags{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.2rem}
.cs-tag{font-family:var(--cs-mono)!important;font-size:.66rem!important;letter-spacing:.12em!important;text-transform:uppercase!important;color:var(--cs-ink)!important;padding:.25rem .55rem!important;border:1px solid var(--cs-ink)!important;background:var(--cs-marker)!important;font-weight:500!important;border-radius:0!important;display:inline-block}
.cs-proj-title{font-family:var(--cs-font);font-size:1.3rem;color:var(--cs-ink);line-height:1.15;letter-spacing:-.012em}
.cs-proj-desc{font-size:.92rem;color:var(--cs-ink-2);line-height:1.55;flex:1}
.cs-proj-links{display:flex;gap:.6rem;margin-top:.4rem;align-items:center;flex-wrap:wrap}
.cs-cl{
  font-family:var(--cs-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;
  padding:.5rem .9rem;border:1.5px solid var(--cs-ink);
  transition:background .25s var(--cs-ease),color .25s var(--cs-ease),transform .25s var(--cs-ease);
  font-weight:500;border-radius:0;
}
.cs-cl-p{background:var(--cs-ink);color:var(--cs-cream)!important}
.cs-cl-p:hover{background:var(--cs-green);border-color:var(--cs-green);transform:translateY(-2px)}
.cs-cl-s{color:var(--cs-ink)!important;background:transparent}
.cs-cl-s:hover{background:var(--cs-ink);color:var(--cs-cream)!important;transform:translateY(-2px)}

/* ════════════════════════════════════════════════════════════════
   FILTER BAR — override Elementor pink
   ════════════════════════════════════════════════════════════════ */
.cs-filter{
  position:sticky;top:74px;z-index:50;
  background:rgba(243,239,230,.92);backdrop-filter:blur(10px);
  border-top:1.5px solid var(--cs-ink);border-bottom:1.5px solid var(--cs-ink);
  padding:.9rem var(--cs-pad-x);
}
.cs-filter-inner{max-width:1320px;margin:0 auto;display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}
.cs-filter-btn{
  font-family:var(--cs-mono)!important;font-size:.74rem!important;letter-spacing:.1em!important;text-transform:uppercase!important;
  padding:.45rem .9rem!important;border:1.5px solid var(--cs-ink)!important;
  color:var(--cs-ink)!important;background:transparent!important;font-weight:500!important;
  border-radius:0!important;
  transition:all .25s var(--cs-ease)!important;
  text-decoration:none!important;
}
.cs-filter-btn:hover{background:var(--cs-marker)!important;color:var(--cs-ink)!important}
.cs-filter-btn.cs-on{background:var(--cs-ink)!important;color:var(--cs-cream)!important;border-color:var(--cs-ink)!important}
.cs-filter-count{font-family:var(--cs-mono);font-size:.72rem;color:var(--cs-ink-3);letter-spacing:.1em;text-transform:uppercase;margin-left:auto}

/* ════════════════════════════════════════════════════════════════
   CLIENT LOGO STRIP
   ════════════════════════════════════════════════════════════════ */
.cs-logos{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border:1.5px solid var(--cs-ink);background:var(--cs-paper);
}
@media(max-width:980px){.cs-logos{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.cs-logos{grid-template-columns:repeat(2,1fr)}}
.cs-logo-cell{
  padding:1.6rem;display:flex;align-items:center;justify-content:center;
  min-height:130px;
  border-right:1.5px solid var(--cs-ink);border-bottom:1.5px solid var(--cs-ink);
  background:var(--cs-paper);transition:background .3s var(--cs-ease);
}
.cs-logo-cell:hover{background:var(--cs-cream)}
.cs-logo-cell img{max-height:56px;max-width:80%;width:auto;object-fit:contain;filter:grayscale(1) brightness(.45) contrast(1.4);opacity:.7;transition:filter .35s var(--cs-ease),opacity .35s var(--cs-ease),transform .35s var(--cs-ease)}
.cs-logo-cell:hover img{filter:none;opacity:1;transform:scale(1.04)}
.cs-logos > .cs-logo-cell:nth-child(4n){border-right:0}
.cs-logos > .cs-logo-cell:nth-last-child(-n+4){border-bottom:0}
@media(max-width:980px){
  .cs-logos > .cs-logo-cell{border-right:1.5px solid var(--cs-ink);border-bottom:1.5px solid var(--cs-ink)}
  .cs-logos > .cs-logo-cell:nth-child(3n){border-right:0}
  .cs-logos > .cs-logo-cell:nth-last-child(-n+3){border-bottom:0}
}
@media(max-width:560px){
  .cs-logos > .cs-logo-cell{border-right:1.5px solid var(--cs-ink);border-bottom:1.5px solid var(--cs-ink)}
  .cs-logos > .cs-logo-cell:nth-child(3n){border-right:1.5px solid var(--cs-ink)}
  .cs-logos > .cs-logo-cell:nth-last-child(-n+3){border-bottom:1.5px solid var(--cs-ink)}
  .cs-logos > .cs-logo-cell:nth-child(2n){border-right:0}
  .cs-logos > .cs-logo-cell:nth-last-child(-n+2){border-bottom:0}
}

/* ════════════════════════════════════════════════════════════════
   FAQ
   ════════════════════════════════════════════════════════════════ */
.cs-faqs{display:flex;flex-direction:column;border-top:1.5px solid var(--cs-ink)}
.cs-faq{border-bottom:1.5px solid var(--cs-ink);background:transparent;transition:background .3s var(--cs-ease)}
.cs-faq:hover{background:var(--cs-paper)}
.cs-faq[open]{background:var(--cs-paper)}
.cs-faq summary{cursor:pointer;font-family:var(--cs-font);font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--cs-ink);list-style:none;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.4rem .5rem;letter-spacing:-.005em}
.cs-faq summary::-webkit-details-marker{display:none}
.cs-faq summary::marker{display:none;content:""}
.cs-faq-plus{font-family:var(--cs-mono);color:var(--cs-green);font-size:1.5rem;line-height:1;transition:transform .35s var(--cs-ease);flex-shrink:0}
.cs-faq[open] .cs-faq-plus{transform:rotate(45deg)}
.cs-faq-body{padding:0 .5rem 1.6rem;color:var(--cs-ink-2);line-height:1.65;font-size:.98rem;max-width:62ch}

/* ════════════════════════════════════════════════════════════════
   SINGLE / 404
   ════════════════════════════════════════════════════════════════ */
.cs-single{padding:140px var(--cs-pad-x) clamp(3rem,6vw,5rem);position:relative;z-index:3}
.cs-single-meta{display:flex;gap:1.4rem;font-family:var(--cs-mono);font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cs-ink-3);margin-bottom:1.4rem;flex-wrap:wrap}
.cs-single-meta b{color:var(--cs-ink);font-weight:500}
.cs-single-img{margin:2.4rem 0;border:1.5px solid var(--cs-ink);box-shadow:5px 5px 0 var(--cs-ink)}
.cs-single-img img{width:100%;display:block}
.cs-single-content{font-size:1.05rem;line-height:1.75;color:var(--cs-ink-2);max-width:780px}
.cs-single-content h2,.cs-single-content h3{font-family:var(--cs-font);font-weight:300;color:var(--cs-ink);margin:2rem 0 .8rem;letter-spacing:-.02em}
.cs-single-content h2{font-size:clamp(1.7rem,3vw,2.4rem)}
.cs-single-content h3{font-size:1.3rem}
.cs-single-content p{margin-bottom:1rem}
.cs-single-content a{color:var(--cs-green);text-decoration:underline}
.cs-single-content img{margin:1.4rem 0;border:1.5px solid var(--cs-ink)}

.cs-404{min-height:80vh;display:flex;flex-direction:column;justify-content:center;padding:140px var(--cs-pad-x) 6rem;text-align:center}
.cs-404-big{font-family:var(--cs-font);font-size:clamp(7rem,18vw,18rem);line-height:.9;letter-spacing:-.05em;color:transparent;-webkit-text-stroke:1.5px var(--cs-ink);text-stroke:1.5px var(--cs-ink)}
.cs-404 h1{font-family:var(--cs-font);font-size:clamp(2rem,5vw,3.6rem);font-weight:300;letter-spacing:-.02em;color:var(--cs-ink);margin-top:1rem}
.cs-404 p{margin-top:1rem;color:var(--cs-ink-2);font-size:1.05rem;line-height:1.65;max-width:520px;margin-inline:auto}
.cs-404-acts{margin-top:2rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ════════════════════════════════════════════════════════════════
   UTILITY
   ════════════════════════════════════════════════════════════════ */
.cs-text-center{text-align:center}
.cs-text-right{text-align:right}
