*, ::before, ::after {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

::backdrop {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*//*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/

*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}

::before,
::after {
  --tw-content: '';
}

/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/

html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: Inter, sans-serif; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}

/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/

body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}

/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/

hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}

/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/

abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

/*
Remove the default font size and weight for headings.
*/

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}

/*
Reset links to optimize for opt-in styling instead of opt-out.
*/

a {
  color: inherit;
  text-decoration: inherit;
}

/*
Add the correct font weight in Edge and Safari.
*/

b,
strong {
  font-weight: bolder;
}

/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp,
pre {
  font-family: "JetBrains Mono", monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}

/*
Add the correct font size in all browsers.
*/

small {
  font-size: 80%;
}

/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/

table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}

/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  letter-spacing: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}

/*
Remove the inheritance of text transform in Edge and Firefox.
*/

button,
select {
  text-transform: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/

button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}

/*
Use the modern Firefox focus style for all focusable elements.
*/

:-moz-focusring {
  outline: auto;
}

/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

:-moz-ui-invalid {
  box-shadow: none;
}

/*
Add the correct vertical alignment in Chrome and Firefox.
*/

progress {
  vertical-align: baseline;
}

/*
Correct the cursor style of increment and decrement buttons in Safari.
*/

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/

[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/*
Remove the inner padding in Chrome and Safari on macOS.
*/

::-webkit-search-decoration {
  -webkit-appearance: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/*
Add the correct display in Chrome and Safari.
*/

summary {
  display: list-item;
}

/*
Removes the default spacing and border for appropriate elements.
*/

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
}

legend {
  padding: 0;
}

ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

/*
Reset default styling for dialogs.
*/
dialog {
  padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

textarea {
  resize: vertical;
}

/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/

input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

/*
Set the default cursor for buttons.
*/

button,
[role="button"] {
  cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/
:disabled {
  cursor: default;
}

/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}

/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

img,
video {
  max-width: 100%;
  height: auto;
}

/* Make elements with the HTML hidden attribute stay hidden by default */
[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}
  :root,
  [data-theme="light"] {
    --c-paper: #f1ede3;
    --c-surface: #fbf9f2;
    --c-ink: #15231e;
    --c-muted: #5a6961;
    --c-brand: #73c1b5;
    --c-onbrand: #f1ede3;
    --c-line: rgba(115, 193, 181, 0.14);
    --c-accent: #f35b2d;
    --c-onaccent: #fbf7f0;
  }

  [data-theme="dark"] {
    --c-paper: #0c1611;
    --c-surface: #11201a;
    --c-ink: #edf2ec;
    --c-muted: #8fa097;
    --c-brand: #73c1b5;
    --c-onbrand: #0c1611;
    --c-line: rgba(255, 255, 255, 0.10);
    --c-accent: #f35b2d;
    --c-onaccent: #160d07;
  }

  [data-theme="forest"] {
    --c-paper: #73c1b5;
    --c-surface: #62b4a8;
    --c-ink: #f1ede3;
    --c-muted: #bdd4cb;
    --c-brand: #f0e6d4;
    --c-onbrand: #73c1b5;
    --c-line: rgba(255, 255, 255, 0.18);
    --c-accent: #f35b2d;
    --c-onaccent: #fbf7f0;
  }

  body {
    background-color: var(--c-paper);
    color: var(--c-ink);
    -webkit-font-smoothing: antialiased;
  }
/* ---------- GLOBAL BASE ELEMENTS (index.html) ---------- */
html { scroll-behavior:auto; }
body {
    font-family:"Inter",sans-serif;
    overflow-x:clip;
    transition:background .5s ease, color .5s ease;
  }
::-moz-selection { background:var(--c-brand); color:var(--c-onbrand); }
::selection { background:var(--c-brand); color:var(--c-onbrand); }
/* inline icon */
.ico{ width:1em; height:1em; display:inline-block; vertical-align:-.1em; flex:0 0 auto; }
/* grain + soft vignette */
/* ---------- TEXT REVEAL (index.html) ---------- */
.rv-line{ display:block; }
.rv-w{ display:inline-block; overflow:hidden; vertical-align:top; padding-bottom:.12em; margin-bottom:-.12em; padding-right:.05em; }
.rv-wi{ display:inline-block; transform:translateY(112%); transition:transform .85s cubic-bezier(.19,1,.22,1); }
.is-in .rv-wi, [data-reveal='words'].is-in .rv-wi{ transform:translateY(0); }
[data-reveal='up']{ opacity:0; transform:translateY(34px); transition:opacity .9s ease, transform .9s cubic-bezier(.19,1,.22,1); }
[data-reveal='up'].is-in{ opacity:1; transform:none; }
[data-reveal='fade']{ opacity:0; transition:opacity 1s ease; }
[data-reveal='fade'].is-in{ opacity:1; }
[data-reveal='clip']{ clip-path:inset(0 100% 0 0); transition:clip-path 1s cubic-bezier(.7,0,.2,1); }
[data-reveal='clip'].is-in{ clip-path:inset(0 0 0 0); }
[style*="--d"]{ transition-delay:var(--d); }
/* hero rotating word */
.rot-host{ display:inline-block; overflow:hidden; vertical-align:top; color:var(--c-accent); }
.rot-stack{ display:flex; flex-direction:column; }
.rot-word{ display:block; line-height:0.92; white-space:nowrap; }
/* custom hover cursor — circular badge with rotating rim text */
.cursor-cta{ position:fixed; top:0; left:0; z-index:999; pointer-events:none; }
.cursor-cta-in{
    position:relative; width:122px; height:122px; border-radius:50%;
    display:grid; place-items:center;
    background:var(--c-brand); color:var(--c-onbrand);
    box-shadow:0 18px 38px -12px color-mix(in srgb, var(--c-brand) 60%, #000);
    opacity:0; transform:translate(-50%,-50%) scale(0);
    transition:transform .45s cubic-bezier(.34,1.45,.4,1), opacity .2s ease;
  }
.cursor-cta.on .cursor-cta-in{ opacity:1; transform:translate(-50%,-50%) scale(1); }
.cur-ring{ position:absolute; inset:5px; width:calc(100% - 10px); height:calc(100% - 10px); }
.cur-ring text{ font-family:"Inter",sans-serif; font-size:10.5px; font-weight:500; fill:currentColor; }
@media (prefers-reduced-motion: no-preference){ .cur-ring{ animation:spin-slow 12s linear infinite; } }
.cur-arrow{ width:30px; height:30px; }
.rot-cta{ cursor:none; }
/* ---------- NAV (index.html) ---------- */
[data-nav]{ transition:padding .4s ease; }
.theme-dot{ width:13px; height:13px; border-radius:99px; border:1.5px solid var(--c-line); transition:transform .25s, box-shadow .25s; }
.theme-dot[aria-pressed="true"]{ box-shadow:0 0 0 2px var(--c-paper),0 0 0 3.5px var(--c-brand); transform:scale(1.05); }
[data-magnetic]{ transition:transform .35s cubic-bezier(.19,1,.22,1), background .3s, color .3s; will-change:transform; }
/* ---------- HERO logo float (index.html) ---------- */
/* ---------- MARQUEE (index.html) ---------- */
.marquee{ display:flex; width:-moz-max-content; width:max-content; animation:marq var(--dur,38s) linear infinite; }
.marquee.rev{ animation-direction:reverse; }
.marquee-mask{ -webkit-mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent); mask-image:linear-gradient(90deg,transparent,#000 9%,#000 91%,transparent); }
.partner-chip{ display:inline-flex; align-items:center; white-space:nowrap; border:1.5px solid var(--c-line); border-radius:99px; padding:.72rem 1.6rem; font-family:"Bricolage Grotesque",sans-serif; font-weight:600; font-size:clamp(1.05rem,2vw,1.4rem); letter-spacing:-.01em; color:var(--c-ink); transition:background .35s ease, color .35s ease, border-color .35s ease; }
.partner-chip:hover{ background:var(--c-brand); color:var(--c-onbrand); border-color:transparent; }
/* ---------- media card (used by About) (index.html) ---------- */
/* ---------- SHOWCASE CAROUSEL (index.html) ---------- */
.car-stage{ position:relative; height:min(72vh,660px); min-height:420px; overflow:hidden; }
.car-card{
    position:absolute; top:50%; left:50%; margin:0;
    width:min(46vw,560px); height:100%;
    border-radius:26px; overflow:hidden; background:var(--c-surface);
    transform:translate(-50%,-50%);
    will-change:transform; cursor:pointer;
  }
.car-card.is-front{ cursor:none; }
.car-card img{ position:absolute; inset:0; width:100%; height:100%; -o-object-fit:cover; object-fit:cover; }
.car-card::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:36%; background:linear-gradient(to top, rgba(0,0,0,.5), transparent); pointer-events:none; }
.car-cap{
    position:absolute; left:1.25rem; right:1.25rem; bottom:1.1rem; z-index:2;
    display:flex; align-items:center; gap:.55rem;
    color:#fff; font-weight:600; font-size:clamp(.88rem,1.3vw,1.05rem); letter-spacing:-.01em;
    white-space:nowrap; overflow:hidden;
  }
.car-dot{ width:7px; height:7px; border-radius:99px; background:#fff; flex:0 0 auto; }
@media (max-width:1023px){
    .car-card{ width:min(76vw,560px); }
    .car-stage{ height:min(60vh,540px); min-height:380px; }
  }
/* ---------- SERVICES BENTO (index.html) ---------- */
/* reels thumb strip (index.html bento — NOTE: distinct from reels.html .reel-strip below) */
.reel-strip{ display:flex; align-items:center; gap:.7rem; }
.reel-strip .rs{ flex:1; aspect-ratio:3/4; border-radius:14px; overflow:hidden; }
.reel-strip .rs img{ width:100%; height:100%; -o-object-fit:cover; object-fit:cover; display:block; transition:transform .8s cubic-bezier(.19,1,.22,1); }
.reel-strip .rs--mid{ flex:1.3; border:1.5px solid var(--c-ink); padding:5px; background:var(--c-surface); border-radius:18px; }
.reel-strip .rs--mid img{ border-radius:12px; }
.bento-card:hover .reel-strip img{ transform:scale(1.06); }
/* roas mini panel (index.html) */
/* tilted chip field (index.html) */
.chip{ border:1px solid var(--c-line); background:var(--c-surface); border-radius:99px; padding:.5rem 1.05rem; font-family:"Inter",sans-serif; font-size:.66rem; text-transform:uppercase; letter-spacing:.13em; color:var(--c-muted); white-space:nowrap; }
/* footer big word (index.html) */
.bigword{ font-weight:700; line-height:.82; letter-spacing:-.03em; font-size:clamp(4.5rem,21vw,20rem); overflow:hidden; }
/* contact CTA — auto height on mobile (index.html) */
@media(max-width:767px){
    .cta-inner{ height:auto !important; max-height:none !important; grid-template-columns:1fr !important; }
    .cta-inner > div:first-child{ padding-top:2.5rem; padding-bottom:2.5rem; }
  }
.link-u{ position:relative; }
.link-u::after{ content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:100%; background:currentColor; transform:scaleX(0); transform-origin:right; transition:transform .45s cubic-bezier(.19,1,.22,1); }
.link-u:hover::after{ transform:scaleX(1); transform-origin:left; }
/* ---------- HERO STAT STRIP (index.html) ---------- */
.stat-strip{ display:grid; grid-template-columns:repeat(4,1fr); }
.stat{ padding:.35rem 1.6rem .15rem; border-left:1px solid var(--c-line); }
.stat:first-child{ border-left:0; padding-left:0; }
/* NOTE: .stat-num here is the homepage hero variant; work-project.html redefines
     .stat-num for case-study stat cells — see "WORK-PROJECT" section below. */
.stat-num{ display:flex; align-items:baseline; gap:.04em; font-weight:800; letter-spacing:-.03em; line-height:1; font-size:clamp(2.1rem,3.6vw,3.4rem); font-variant-numeric:tabular-nums; }
.stat-num .sfx{ color:var(--c-accent); }
.stat-star{ width:.62em; height:.62em; align-self:center; }
.stat-label{ font-family:"Inter",sans-serif; font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--c-muted); margin-top:.6rem; }
@media (max-width:767px){
    .stat-strip{ grid-template-columns:repeat(2,1fr); row-gap:1.5rem; }
    .stat{ padding:.2rem 1rem 0; }
    .stat:nth-child(odd){ border-left:0; padding-left:0; }
    .stat-num{ font-size:clamp(1.8rem,8vw,2.6rem); }
    .stat-label{ font-size:9px; letter-spacing:.07em; white-space:nowrap; }
  }
/* hero eyebrow — cut-paper accent tag with drifting sloped edges (index.html) */
.hero-tag{
    display:inline-flex; align-items:center;
    padding:.66rem 1.3rem .7rem;
    background:var(--c-accent); color:var(--c-onaccent);
    font-family:"Inter",sans-serif; line-height:1;
    font-size:clamp(.66rem,1.3vw,.74rem); text-transform:uppercase; letter-spacing:.18em;
    transform:rotate(-0.6deg);
    clip-path:polygon(0% 26%, 48% 7%, 100% 0%, 100% 74%, 52% 95%, 0% 100%);
    filter:drop-shadow(0 9px 18px color-mix(in srgb, var(--c-accent) 38%, transparent));
  }
/* hero entrance: whole badge slides up from below + fades in, gentle spring (index.html) */
[data-reveal='tag']{ overflow:visible; }
[data-reveal='tag'] .hero-tag{
    opacity:0;
    transform:rotate(-0.6deg) translateY(32px);
    transition:
      opacity  .7s cubic-bezier(.22,1,.36,1) .1s,
      transform .9s cubic-bezier(.22,1,.36,1) .1s;
  }
[data-reveal='tag'].is-in .hero-tag{
    opacity:1;
    transform:rotate(-0.6deg) translateY(0px);
  }
[data-reveal='tag'] .hero-tag-text{ display:inline-block; }
/* hero eyebrow — status pill + drawing divider (index.html) */
.hero-eyebrow.is-in .hero-eyebrow-line{ width:44px; }
/* ---------- PILL NAVBAR (index.html) ---------- */
.nav-bar{ background:color-mix(in srgb, var(--c-paper) 70%, transparent); backdrop-filter:blur(16px) saturate(1.3); border:1px solid var(--c-line); transition:box-shadow .4s ease, background .4s ease; }
[data-nav].nav-solid .nav-bar{ box-shadow:0 14px 40px -18px rgba(0,0,0,.28); background:color-mix(in srgb, var(--c-paper) 86%, transparent); }
.nav-pill{ border-radius:99px; padding:.5rem 1rem; font-weight:600; font-size:.92rem; color:var(--c-muted); transition:background .3s, color .3s; }
/* about.html / work.html add [data-active] as an active-state alias for :hover */
.nav-pill:hover, .nav-pill[data-active]{ background:color-mix(in srgb, var(--c-brand) 12%, transparent); color:var(--c-brand); }
.menu-icon-btn{ position:relative; display:inline-grid; place-items:center; width:40px; height:40px; border-radius:99px; border:1px solid var(--c-line); color:var(--c-ink); transition:background .3s, color .3s, border-color .3s; }
.menu-icon-btn:hover, .menu-icon-btn[aria-expanded="true"]{ background:var(--c-brand); color:var(--c-onbrand); border-color:transparent; }
.menu-icon-btn .mb-ico{ position:relative; width:16px; height:11px; }
.menu-icon-btn .mb-ico span{ position:absolute; left:0; right:0; height:2px; background:currentColor; border-radius:2px; transition:transform .35s cubic-bezier(.7,0,.2,1), opacity .25s; }
.menu-icon-btn .mb-ico span:nth-child(1){ top:0; }
.menu-icon-btn .mb-ico span:nth-child(2){ top:50%; transform:translateY(-50%); }
.menu-icon-btn .mb-ico span:nth-child(3){ bottom:0; }
.menu-icon-btn[aria-expanded="true"] .mb-ico span:nth-child(1){ top:50%; transform:translateY(-50%) rotate(45deg); }
.menu-icon-btn[aria-expanded="true"] .mb-ico span:nth-child(2){ opacity:0; }
.menu-icon-btn[aria-expanded="true"] .mb-ico span:nth-child(3){ bottom:50%; transform:translateY(50%) rotate(-45deg); }
.cta-pill{ display:inline-flex; align-items:center; gap:.4rem; border-radius:99px; background:var(--c-brand); color:var(--c-onbrand); font-weight:700; font-size:.92rem; padding:.5rem 1rem; transition:opacity .3s; }
.cta-pill:hover{ opacity:.9; }
/* ---------- EXPANDABLE MENU (dropdown under burger) (index.html) ---------- */
.su-menu{ position:absolute; z-index:60; top:calc(100% + 10px); right:0; width:min(340px,86vw); transform:translateY(-12px) scale(.95); transform-origin:top right; opacity:0; pointer-events:none; transition:opacity .3s ease, transform .5s cubic-bezier(.34,1.4,.5,1); }
.su-menu.open{ opacity:1; pointer-events:auto; transform:translateY(0) scale(1); }
.su-menu-inner{ background:var(--c-brand); border-radius:32px; padding:1.1rem 1rem 1.2rem; box-shadow:0 44px 90px -28px color-mix(in srgb, var(--c-brand) 55%, #000); }
.su-menu-list{ position:relative; }
.su-menu-pill{ position:absolute; left:.5rem; right:.5rem; top:0; height:0; background:var(--c-onbrand); border-radius:99px; transition:transform .5s cubic-bezier(.34,1.35,.4,1), height .35s ease; z-index:0; }
.menu-link{ position:relative; z-index:1; display:block; text-align:center; font-family:"Bricolage Grotesque",sans-serif; font-weight:800; letter-spacing:-.02em; font-size:clamp(1.55rem,5.5vw,1.95rem); line-height:1; padding:.62rem 1rem; color:var(--c-onbrand); transition:color .35s ease; }
.menu-link.on{ color:var(--c-brand); }
.su-menu-foot{ display:flex; align-items:center; justify-content:center; gap:.85rem; margin-top:1rem; padding-top:1rem; border-top:1px solid color-mix(in srgb, var(--c-onbrand) 24%, transparent); }
.su-menu-foot .fl{ font-family:"Inter",sans-serif; font-size:.66rem; text-transform:uppercase; letter-spacing:.18em; color:color-mix(in srgb, var(--c-onbrand) 70%, transparent); }
.su-menu-foot .theme-dot{ border-color:color-mix(in srgb, var(--c-onbrand) 40%, transparent); }
.su-menu-foot .theme-dot[aria-pressed="true"]{ box-shadow:0 0 0 2px var(--c-brand), 0 0 0 3.5px var(--c-onbrand); }
/* small-screen headline sizing (index.html) */
@media (max-width:640px){
    #top h1{ font-size:clamp(2rem,9.6vw,3.2rem); }
  }
/* ---------- PUSH-UP CTA BUTTONS (index.html) ---------- */
/* the button keeps its box; the label slides up while an identical copy pushes in from below */
.flip-3d{
    position:relative;
    display:inline-flex; align-items:center; justify-content:center;
    overflow:hidden;
  }
.flip-3d .flip-face{
    display:inline-flex; align-items:center; justify-content:center; gap:.45rem;
    white-space:nowrap;
    transition:transform .55s cubic-bezier(.76,0,.24,1);
    will-change:transform;
  }
.flip-3d .flip-face--a{ transform:translateY(0); }
.flip-3d .flip-face--b{ position:absolute; inset:0; transform:translateY(110%); }
.flip-btn:hover .flip-3d .flip-face--a,
  .flip-btn:focus-visible .flip-3d .flip-face--a{ transform:translateY(-110%); }
.flip-btn:hover .flip-3d .flip-face--b,
  .flip-btn:focus-visible .flip-3d .flip-face--b{ transform:translateY(0); }
/* =========================================================================
     SERVICES ACCORDION (index.html — inline section \3c style>)
     ========================================================================= */
.svc-tab { border-bottom:1px solid var(--c-line); overflow:hidden; }
.svc-tab:first-child { border-top:1px solid var(--c-line); }
.svc-tab-hd {
    display:flex; align-items:center; justify-content:space-between;
    padding:1.35rem 0; gap:1rem; cursor:pointer; -webkit-user-select:none; -moz-user-select:none; user-select:none;
  }
.svc-tab-num { font-family:"Inter",sans-serif; font-size:.68rem; color:var(--c-muted); flex-shrink:0; }
.svc-tab-name {
    font-family:"Bricolage Grotesque",sans-serif; font-weight:700;
    font-size:clamp(1.1rem,1.8vw,1.45rem); letter-spacing:-.02em;
    color:var(--c-ink); transition:color .3s ease; flex:1;
  }
.svc-tab.is-open .svc-tab-name { color:var(--c-brand); }
.svc-tab-ico {
    width:34px; height:34px; border-radius:50%; border:1.5px solid var(--c-line);
    display:flex; align-items:center; justify-content:center; flex-shrink:0;
    transition:transform .45s cubic-bezier(.22,1,.36,1), border-color .3s, background .3s;
  }
.svc-tab.is-open .svc-tab-ico { transform:rotate(180deg); border-color:var(--c-brand); background:var(--c-brand); }
.svc-tab-ico svg { width:13px; height:13px; stroke:var(--c-ink); fill:none; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round; transition:stroke .3s; }
.svc-tab.is-open .svc-tab-ico svg { stroke:var(--c-onbrand); }
.svc-tab-body { max-height:0; overflow:hidden; transition:max-height .5s cubic-bezier(.22,1,.36,1); }
.svc-tab.is-open .svc-tab-body { max-height:260px; }
.svc-tab-desc { font-size:.93rem; line-height:1.7; color:var(--c-muted); padding-bottom:.9rem; max-width:32rem; }
.svc-tab-cta {
    display:inline-flex; align-items:center; gap:.4rem;
    font-size:.85rem; font-weight:600; color:var(--c-brand);
    text-decoration:none; padding-bottom:1.4rem;
    transition:gap .25s;
  }
.svc-tab-cta:hover { gap:.7rem; }
.svc-tab-cta svg { width:13px; height:13px; stroke:currentColor; fill:none; stroke-width:2; stroke-linecap:round; }
/* services right panel (index.html) */
.svc-img-wrap {
    position:relative; border-radius:22px; overflow:hidden;
    background:var(--c-surface); border:1px solid var(--c-line);
    flex:1; min-height:0;
  }
.svc-img-wrap img {
    position:absolute; inset:0; width:100%; height:100%; -o-object-fit:cover; object-fit:cover;
    opacity:0; transform:scale(1.05);
    transition:opacity .6s cubic-bezier(.22,1,.36,1), transform .6s cubic-bezier(.22,1,.36,1);
  }
.svc-img-wrap img.is-active { opacity:1; transform:scale(1); }
/* services stat cards (index.html) */
.svc-card-brand {
    background:var(--c-brand); color:var(--c-onbrand);
    border-radius:18px; padding:1.25rem 1.4rem;
    flex:1; display:flex; flex-direction:column; gap:.5rem;
  }
.svc-card-ink {
    background:var(--c-ink); color:var(--c-onbrand);
    border-radius:18px; padding:1.25rem 1.4rem;
    flex:1; display:flex; flex-direction:column; gap:.5rem;
  }
.svc-card-val {
    font-family:"Bricolage Grotesque",sans-serif;
    font-weight:800; font-size:clamp(1.5rem,2.5vw,2rem); line-height:1;
    transition:opacity .25s ease, transform .35s cubic-bezier(.22,1,.36,1);
  }
.svc-card-lbl { font-family:"Inter",sans-serif; font-size:.68rem; text-transform:uppercase; letter-spacing:.12em; opacity:.65; }
.svc-bars b.hi { background:var(--c-onbrand); }
@media(max-width:900px){
    .svc-col-right{ position:relative !important; height:auto !important; top:auto !important; }
    .svc-img-wrap{ flex:none !important; aspect-ratio:4/3; width:100%; }
  }
.svc-col-left {
    opacity:0; transform:translateX(-56px);
    transition:opacity .85s cubic-bezier(.22,1,.36,1), transform .85s cubic-bezier(.22,1,.36,1);
  }
.svc-col-right {
    opacity:0; transform:translateX(56px);
    transition:opacity .85s cubic-bezier(.22,1,.36,1) .1s, transform .85s cubic-bezier(.22,1,.36,1) .1s;
  }
.svc-grid.svc-loaded .svc-col-left,
  .svc-grid.svc-loaded .svc-col-right { opacity:1; transform:translateX(0); }
/* =========================================================================
     HOME ABOUT SECTION (index.html — inline section \3c style>)
     ========================================================================= */
.about-grid {
    display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:stretch;
  }
@media(max-width:900px){
    .about-grid{ grid-template-columns:1fr; }
    .about-img-wrap{ min-height:300px; flex:none; }
    .about-left{ min-height:0; }
  }
.about-left {
    display:flex; flex-direction:column;
    opacity:0; transform:translateX(-60px);
    transition:opacity .9s cubic-bezier(.22,1,.36,1), transform .9s cubic-bezier(.22,1,.36,1);
  }
.about-grid.about-loaded .about-left { opacity:1; transform:translateX(0); }
.about-right {
    opacity:0; transform:translateX(60px);
    transition:opacity .9s cubic-bezier(.22,1,.36,1) .1s, transform .9s cubic-bezier(.22,1,.36,1) .1s;
  }
.about-grid.about-loaded .about-right { opacity:1; transform:translateX(0); }
.about-label {
    opacity:0; transform:rotate(-0.6deg) translateY(32px);
    transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
  }
#about.about-section-loaded .about-label { opacity:1; transform:rotate(-0.6deg) translateY(0); }
.about-img-wrap {
    flex:1; min-height:260px; margin-top:2rem;
    border-radius:20px; overflow:hidden; position:relative;
  }
.about-img-wrap img {
    width:100%; height:100%; -o-object-fit:cover; object-fit:cover; display:block;
    transition:transform .8s cubic-bezier(.22,1,.36,1);
  }
.about-img-wrap:hover img { transform:scale(1.04); }
.about-left .rv-wi {
    display:inline-block;
    opacity:0; transform:translateY(100%);
    transition:opacity .55s cubic-bezier(.22,1,.36,1), transform .55s cubic-bezier(.22,1,.36,1);
  }
.about-grid.about-loaded .about-left .rv-wi { opacity:1; transform:translateY(0); }
.process-step {
    display:flex; gap:1.2rem; align-items:flex-start;
    padding:1.5rem 0; border-bottom:1px solid var(--c-line);
    opacity:0; transform:translateX(28px);
    transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
  }
.process-step:last-child { border-bottom:none; }
.process-step.is-in { opacity:1; transform:translateX(0); }
.process-icon {
    width:44px; height:44px; border-radius:12px; flex-shrink:0;
    display:grid; place-items:center;
    background:var(--c-surface); border:1.5px solid var(--c-line);
    transition:background .35s, border-color .35s, transform .4s cubic-bezier(.22,1,.36,1);
  }
.process-step:hover .process-icon { background:var(--c-brand); border-color:var(--c-brand); transform:rotate(6deg) scale(1.08); }
.process-icon svg { width:20px; height:20px; stroke:var(--c-ink); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; transition:stroke .35s; }
.process-step:hover .process-icon svg { stroke:var(--c-onbrand); }
.process-body { flex:1; }
.process-num { font-family:"Inter",sans-serif; font-size:.68rem; text-transform:uppercase; letter-spacing:.14em; color:var(--c-muted); margin-bottom:.3rem; }
.process-title { font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:1.1rem; letter-spacing:-.01em; color:var(--c-ink); }
.process-desc { font-size:.88rem; color:var(--c-muted); line-height:1.65; margin-top:.3rem; }
.process-line {
    display:none;
    width:2px; background:var(--c-line); margin:0 auto;
    height:0; transition:height .6s cubic-bezier(.22,1,.36,1);
    border-radius:2px;
  }
.process-line.is-in { height:28px; }
/* =========================================================================
     BREADCRUMB (about.html / contact.html / work.html)
     ========================================================================= */
.breadcrumb{ display:flex; align-items:center; gap:.5rem; font-size:.78rem; color:var(--c-muted); font-family:"Inter",sans-serif; padding-bottom:2rem; flex-wrap:wrap; }
.breadcrumb a{ color:var(--c-muted); text-decoration:none; transition:color .2s; }
.breadcrumb a:hover{ color:var(--c-brand); }
.breadcrumb-sep{ opacity:.4; }
/* =========================================================================
     REELS PAGE — vertical reel hero slider (reels.html)
     ========================================================================= */
.rh-section{
    position:relative; overflow:hidden;
    background:var(--c-paper);
    display:flex; flex-direction:column;
    height:100svh; width:100%;
  }
.rh-split{
    flex:1; min-height:0;
    display:grid; grid-template-columns:1fr 1fr;
    overflow:hidden;
    width:100%;
  }
.rh-copy{
    display:flex; flex-direction:column; justify-content:center;
    padding:8rem 5% 5rem 5%;
  }
.rh-headline{
    font-family:"Bricolage Grotesque",sans-serif; font-weight:800;
    font-size:clamp(3rem,5.5vw,6rem); letter-spacing:-.04em; line-height:.92;
    color:var(--c-ink); margin:1.8rem 0 1.6rem;
  }
.rh-headline em{ font-style:normal; color:var(--c-accent); }
.rh-sub{
    font-size:clamp(.92rem,1.4vw,1.06rem); color:var(--c-muted);
    line-height:1.7; max-width:390px; margin-bottom:2.4rem;
  }
.rh-btn-primary{
    display:inline-flex; align-items:center; gap:.5rem;
    background:var(--c-brand); color:var(--c-onbrand);
    font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:1rem;
    border-radius:99px; padding:.9rem 2.2rem; width:-moz-fit-content; width:fit-content;
    transition:transform .35s cubic-bezier(.19,1,.22,1), box-shadow .35s;
    box-shadow:0 18px 40px -12px color-mix(in srgb,var(--c-brand) 32%,transparent);
  }
.rh-btn-primary:hover{ transform:translateY(-3px); box-shadow:0 26px 52px -12px color-mix(in srgb,var(--c-brand) 42%,transparent); }
.rh-slider-col{
    position:relative; overflow:hidden; height:100%;
    cursor:grab;
    -webkit-mask-image:linear-gradient(to bottom, transparent 0%, #000 10%, #000 72%, transparent 100%);
    mask-image:linear-gradient(to bottom, transparent 0%, #000 10%, #000 72%, transparent 100%);
  }
.rh-slider-col:active{ cursor:grabbing; }
.rh-slider-track{
    display:flex; flex-direction:column; gap:20px;
    padding:20px 8%;
    will-change:transform;
    align-items:center;
  }
.rh-card{
    width:min(100%, 560px); aspect-ratio:9/16;
    max-height:620px;
    border-radius:28px; overflow:hidden; flex-shrink:0;
    box-shadow:0 20px 60px -16px rgba(0,0,0,.18);
    position:relative;
    transition:box-shadow .4s, transform .4s;
  }
.rh-card img{ width:100%; height:100%; -o-object-fit:cover; object-fit:cover; display:block; }
.rh-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 50%); pointer-events:none; }
.rh-card-cap{
    position:absolute; bottom:1.1rem; left:1.1rem; right:1.1rem; z-index:2;
    font-size:.62rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
    color:rgba(255,255,255,.88);
    display:flex; align-items:center; gap:.5rem;
  }
.rh-card-dot{ width:6px; height:6px; border-radius:50%; background:var(--c-accent); flex-shrink:0; }
.rh-card.is-center{ box-shadow:0 28px 70px -14px rgba(0,0,0,.24); }
/* reels.html MARQUEE STRIP — CONFLICT: this .reel-strip is the accent ticker bar,
     distinct from index.html's .reel-strip flex thumb strip above. Both kept verbatim
     because they belong to different pages' markup (selectors share a name only). */
.reel-strip{ background:var(--c-accent); color:var(--c-onaccent); padding:.9rem 0; overflow:hidden; }
.rs-item{ display:inline-flex; align-items:center; gap:1.6rem; padding:0 1.6rem; font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:clamp(.88rem,1.7vw,1.1rem); letter-spacing:.02em; white-space:nowrap; }
.rs-dot{ width:5px; height:5px; border-radius:50%; background:rgba(251,247,240,.45); flex-shrink:0; }
/* reels.html PLATFORMS — split section */
.plat-grid{
    display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center;
  }
.plat-illo{ position:relative; display:flex; align-items:center; justify-content:center; height:500px; }
.plat-stack{ position:relative; width:260px; height:360px; }
.pc{
    position:absolute; inset:0;
    width:240px; height:320px;
    border-radius:26px; padding:1.3rem 1.4rem;
    display:flex; flex-direction:column; justify-content:space-between;
    box-shadow:0 28px 70px -16px rgba(0,0,0,.38);
    transform-origin:bottom center;
    transition:transform .4s cubic-bezier(.34,1.2,.5,1);
  }
.plat-stack:hover .pc{ --fan:1; }
.pc-head{ display:flex; align-items:center; justify-content:space-between; }
.pc-avatar{ width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,.25); border:2px solid rgba(255,255,255,.4); }
.pc-icon{ width:28px; height:28px; display:flex; align-items:center; justify-content:center; }
.pc-icon svg{ width:20px; height:20px; fill:#fff; }
.pc-bars{ display:flex; flex-direction:column; gap:8px; }
.pc-bar{ height:8px; border-radius:5px; background:rgba(255,255,255,.28); }
.pc-bar:first-child{ width:80%; }
.pc-bar:last-child{ width:55%; }
.pc-label{ font-size:.7rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.7); }
.pc:nth-child(1){ background:#1877F2; transform:rotate(14deg) translate(130px,-56px); z-index:1; }
.pc:nth-child(2){ background:#000; transform:rotate(9deg) translate(90px,-36px); z-index:2; }
.pc:nth-child(3){ background:linear-gradient(145deg,#f9a925 0%,#e8525a 45%,#c13584 100%); transform:rotate(5deg) translate(48px,-16px); z-index:3; }
.pc:nth-child(4){ background:#FF0000; transform:rotate(1deg) translate(12px,4px); z-index:4; }
.pc:nth-child(5){ background:#0d2820; border:1px solid rgba(255,255,255,.1); transform:rotate(-3deg) translate(-24px,20px); z-index:5; }
.plat-stack:hover .pc:nth-child(1){ transform:rotate(18deg) translate(160px,-72px); }
.plat-stack:hover .pc:nth-child(2){ transform:rotate(11deg) translate(110px,-44px); }
.plat-stack:hover .pc:nth-child(3){ transform:rotate(5deg) translate(56px,-14px); }
.plat-stack:hover .pc:nth-child(4){ transform:rotate(-1deg) translate(8px,8px); }
.plat-stack:hover .pc:nth-child(5){ transform:rotate(-6deg) translate(-36px,28px); }
@media(max-width:900px){
    .plat-grid{ grid-template-columns:1fr; }
    .plat-illo{ height:320px; }
    .plat-stack{ transform:scale(.85); }
  }
/* reels.html PROCESS — horizontal scroll timeline */
.proc-outer{ position:relative; }
.proc-sticky{
    position:sticky; top:0;
    height:100vh; overflow:hidden;
    display:flex; flex-direction:column;
    background:var(--c-surface);
  }
.proc-header{
    flex-shrink:0; text-align:center;
    padding:4.5rem 5vw 2.8rem;
  }
.proc-viewport{
    flex:1; min-height:0;
    overflow:hidden; position:relative;
    padding-top:12px; margin-top:-12px;
  }
.proc-track{
    display:flex; align-items:stretch; gap:24px;
    padding:12px 6vw 2rem;
    will-change:transform; width:-moz-max-content; width:max-content;
  }
.proc-line-wrap{
    position:absolute; left:0; right:0;
    top:40px; padding:0 6vw;
    pointer-events:none; z-index:0;
  }
.proc-line-bg{ height:2px; background:var(--c-line); border-radius:2px; position:relative; }
.proc-line-fill{
    position:absolute; left:0; top:0; height:100%;
    background:var(--c-brand); border-radius:2px;
    width:0%; transition:width .08s linear;
  }
.proc-card{
    flex-shrink:0; width:290px;
    background:var(--c-paper); border:1px solid var(--c-line);
    border-radius:24px; padding:2rem 1.8rem 1.8rem;
    position:relative; z-index:1; display:flex; flex-direction:column;
    transition:transform .4s cubic-bezier(.19,1,.22,1), box-shadow .4s;
  }
.proc-card:hover{ transform:translateY(-8px); box-shadow:0 28px 64px -16px color-mix(in srgb,var(--c-brand) 20%,transparent); }
.proc-dot{
    width:14px; height:14px; border-radius:50%;
    background:var(--c-paper); border:3px solid var(--c-line);
    margin-bottom:1.6rem; flex-shrink:0;
    transition:border-color .4s, background .4s;
  }
.proc-card.is-passed .proc-dot{ background:var(--c-brand); border-color:var(--c-brand); }
.proc-card-ico{
    display:inline-flex; align-items:center; justify-content:center;
    width:44px; height:44px; border-radius:12px;
    background:color-mix(in srgb,var(--c-brand) 10%,transparent);
    border:1px solid color-mix(in srgb,var(--c-brand) 16%,transparent);
    margin-bottom:1.2rem;
  }
.proc-card-ico svg{ width:22px; height:22px; stroke:var(--c-brand); fill:none; stroke-width:1.75; stroke-linecap:round; stroke-linejoin:round; }
.proc-num{ font-family:"Inter",sans-serif; font-size:.7rem; font-weight:600; color:var(--c-muted); letter-spacing:.08em; text-transform:uppercase; margin-bottom:.55rem; }
.proc-title{ font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:1.1rem; letter-spacing:-.015em; margin-bottom:.45rem; }
.proc-desc{ font-size:.86rem; color:var(--c-muted); line-height:1.65; flex:1; }
@media(max-width:960px){
    .proc-header{ padding-top:3.5rem; }
    .proc-card{ width:260px; }
  }
@media(max-width:600px){
    .proc-outer{ background:var(--c-surface); }
    .proc-sticky{ height:auto; }
    .proc-card{ width:220px; }
  }
/* TESTIMONIALS MARQUEE (reels.html — also used by about.html) */
.testi-section{
    padding:6rem 0;
    overflow:hidden;
    background:var(--c-paper);
  }
.testi-header{
    text-align:center;
    padding:0 5vw 3.5rem;
  }
.testi-row{
    overflow:hidden;
    padding-top:16px;
    margin-top:-16px;
    -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
    mask-image:linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
    margin-bottom:20px;
  }
.testi-row:last-child{ margin-bottom:0; }
.testi-track{
    display:flex;
    gap:20px;
    width:-moz-max-content;
    width:max-content;
    will-change:transform;
  }
.testi-card{
    flex-shrink:0;
    width:320px;
    background:var(--c-surface);
    border:1px solid var(--c-line);
    border-radius:20px;
    padding:1.6rem 1.8rem;
    display:flex;
    flex-direction:column;
    gap:.9rem;
    cursor:default;
    transition:box-shadow .35s, border-color .35s, transform .35s cubic-bezier(.19,1,.22,1);
  }
.testi-card:hover{
    box-shadow:0 20px 50px -12px color-mix(in srgb,var(--c-brand) 18%,transparent);
    border-color:color-mix(in srgb,var(--c-brand) 25%,transparent);
    transform:translateY(-4px);
  }
.testi-top{ display:flex; align-items:center; justify-content:space-between; }
.testi-stars{ display:flex; gap:3px; }
.testi-star{ width:14px; height:14px; fill:var(--c-accent); }
.testi-plat-icon{ width:22px; height:22px; flex-shrink:0; opacity:.55; }
.testi-quote{
    font-size:.9rem;
    line-height:1.7;
    color:var(--c-ink);
    flex:1;
  }
.testi-author{
    display:flex;
    align-items:center;
    gap:.75rem;
    margin-top:.2rem;
    padding-top:.9rem;
    border-top:1px solid var(--c-line);
  }
.testi-avatar{
    width:36px; height:36px; border-radius:50%;
    background:color-mix(in srgb,var(--c-brand) 12%,transparent);
    border:1px solid color-mix(in srgb,var(--c-brand) 18%,transparent);
    display:grid; place-items:center;
    font-family:"Bricolage Grotesque",sans-serif;
    font-weight:800; font-size:.82rem;
    color:var(--c-brand);
    flex-shrink:0;
  }
.testi-name{ font-weight:700; font-size:.85rem; line-height:1.2; }
.testi-role{ font-size:.76rem; color:var(--c-muted); margin-top:.1rem; }
@media(max-width:600px){
    .testi-card{ width:270px; }
    .testi-section{ padding:4rem 0; }
  }
/* reels.html — extended responsive overrides for hero/platforms/process */
@media(max-width:960px){
    .rh-section{ height:auto; min-height:100svh; }
    .rh-split{ grid-template-columns:1fr; }
    .rh-copy{ padding:7rem 5% 2rem; }
    .rh-slider-col{
      height:300px;
      -webkit-mask-image:linear-gradient(to right, transparent 0%, #000 10%, #000 90%, transparent 100%);
      mask-image:linear-gradient(to right, transparent 0%, #000 10%, #000 90%, transparent 100%);
    }
    .rh-slider-track{ flex-direction:row !important; padding:0 5% !important; height:100%; align-items:center; }
    .rh-card{ width:auto; height:260px; max-height:none; aspect-ratio:9/16; }
    .plat-grid{ grid-template-columns:1fr; gap:2rem; text-align:center; }
    .plat-grid > div:first-child{ display:flex; flex-direction:column; align-items:center; }
    .plat-illo{ height:320px; }
    .plat-stack{ transform:translateX(-37px) scale(.85); }
    .testi-card{ width:280px; }
  }
@media(max-width:600px){
    .rh-slider-col{ height:220px; }
    .rh-card{ height:190px; }
    .plat-grid{ gap:2rem; }
    .plat-illo{ height:260px; }
    .plat-stack{ transform:translateX(-31px) scale(.72); }
    .proc-line-wrap{ display:none; }
    .proc-header{ padding:2.5rem 5vw 1.8rem; }
    .proc-header h2{ font-size:clamp(1.8rem,6vw,2.8rem); }
    .testi-header{ padding:0 5vw 2.5rem; }
    .testi-card{ width:250px; }
    .cta-inner > div:first-child{ padding:2.5rem 1.5rem; }
  }
/* =========================================================================
     ABOUT PAGE (about.html)
     ========================================================================= */
.ab-hero-grid{
    display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center;
  }
.ab-ring.rev{ animation-direction:reverse; }
.ab-node.rev{ animation-direction:reverse; }
/* about.html SERVICES GRID — 3-col card grid (distinct from index.html .svc-tab accordion).
     NOTE: .svc-grid is declared inline on index.html's #svc-grid; here it is the about-page grid. */
.svc-grid{
    display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem;
  }
/* about.html FEATURES (VALUES) */
.feat-grid{
    display:grid; grid-template-columns:repeat(3,1fr); gap:2rem;
  }
.feat-card{
    padding:2.2rem 2rem; border-radius:28px;
    background:var(--c-surface); border:1px solid var(--c-line);
    transition:transform .45s cubic-bezier(.19,1,.22,1), box-shadow .35s;
  }
.feat-card:hover{ transform:translateY(-6px); box-shadow:0 28px 64px -16px color-mix(in srgb,var(--c-brand) 14%,transparent); }
.feat-num{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:3rem; letter-spacing:-.06em; line-height:1; color:color-mix(in srgb,var(--c-brand) 12%,transparent); margin-bottom:.5rem; }
.feat-title{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:1.3rem; letter-spacing:-.02em; margin-bottom:.7rem; }
.feat-desc{ font-size:.9rem; color:var(--c-muted); line-height:1.7; }
/* about.html TEAM STRIP */
.team-strip{ background:var(--c-accent); color:var(--c-onaccent); padding:.9rem 0; overflow:hidden; }
/* about.html responsive */
@media(max-width:1024px){
    .ab-hero-grid{ grid-template-columns:1fr; gap:3rem; }
    .ab-orbit{ max-width:400px; }
  }
@media(max-width:768px){
    .svc-grid{ grid-template-columns:1fr 1fr; }
    .feat-grid{ grid-template-columns:1fr; }
  }
@media(max-width:600px){
    .svc-grid{ grid-template-columns:1fr; }
    .ab-orbit{ max-width:300px; }
  }
/* =========================================================================
     CONTACT PAGE (contact.html)
     ========================================================================= */
.contact-left{
    opacity:0; transform:translateX(-40px);
    transition:opacity .9s cubic-bezier(.22,1,.36,1), transform .9s cubic-bezier(.22,1,.36,1);
  }
.contact-right{
    opacity:0; transform:translateX(40px);
    transition:opacity .9s cubic-bezier(.22,1,.36,1) .1s, transform .9s cubic-bezier(.22,1,.36,1) .1s;
  }
.contact-section-loaded .contact-left{ opacity:1; transform:translateX(0); }
.contact-section-loaded .contact-right{ opacity:1; transform:translateX(0); }
.form-field{
    opacity:0; transform:translateY(14px);
    transition:opacity .6s cubic-bezier(.22,1,.36,1), transform .6s cubic-bezier(.22,1,.36,1);
  }
.contact-section-loaded .form-field{ opacity:1; transform:translateY(0); }
.form-card{
    background:var(--c-surface);
    border:1.5px solid var(--c-line);
    border-radius:28px;
    padding:2.5rem 2.2rem;
  }
@media(max-width:600px){
    .form-card{ padding:1.6rem 1.2rem; border-radius:20px; }
  }
.submit-btn{
    display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
    border-radius:99px; background:var(--c-brand); color:var(--c-onbrand);
    font-family:"Inter",sans-serif; font-weight:700; font-size:1rem;
    padding:.95rem 2.2rem; border:none; cursor:pointer;
    transition:opacity .3s, transform .4s cubic-bezier(.22,1,.36,1);
    overflow:hidden; position:relative;
  }
.submit-btn:hover{ opacity:.9; }
.submit-btn:active{ transform:scale(.97); }
.submit-btn.loading{ pointer-events:none; opacity:.7; }
.cinfo-block{
    display:flex; flex-direction:column; gap:1.5rem;
  }
.cinfo-item{
    display:flex; align-items:flex-start; gap:1rem;
    padding:1.4rem 1.5rem;
    background:var(--c-surface); border:1.5px solid var(--c-line); border-radius:20px;
    transition:border-color .3s, transform .4s cubic-bezier(.22,1,.36,1);
  }
.cinfo-item:hover{ border-color:var(--c-brand); transform:translateY(-2px); }
.cinfo-icon{
    width:40px; height:40px; border-radius:12px; flex-shrink:0;
    display:grid; place-items:center;
    background:color-mix(in srgb,var(--c-brand) 10%,transparent);
    border:1.5px solid color-mix(in srgb,var(--c-brand) 16%,transparent);
  }
.cinfo-icon svg{ width:18px; height:18px; stroke:var(--c-brand); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.cinfo-label{ font-size:.7rem; text-transform:uppercase; letter-spacing:.12em; color:var(--c-muted); margin-bottom:.25rem; }
.cinfo-value{ font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:1.05rem; letter-spacing:-.01em; color:var(--c-ink); }
.cinfo-value a{ color:inherit; text-decoration:none; transition:color .2s; }
.cinfo-value a:hover{ color:var(--c-brand); }
.cinfo-sub{ font-size:.82rem; color:var(--c-muted); margin-top:.15rem; }
.copy-btn{
    display:inline-flex; align-items:center; gap:.4rem;
    font-size:.78rem; font-weight:500; color:var(--c-muted);
    background:none; border:none; cursor:pointer; padding:0; margin-top:.35rem;
    transition:color .25s;
  }
.copy-btn:hover, .copy-btn.copied{ color:var(--c-brand); }
.social-row{ display:flex; flex-wrap:wrap; gap:.55rem; }
.social-pill{
    display:inline-flex; align-items:center; gap:.5rem;
    border:1.5px solid var(--c-line); border-radius:99px;
    padding:.48rem 1rem; font-size:.82rem; font-weight:500; color:var(--c-ink);
    background:var(--c-surface); transition:background .25s, border-color .25s, color .25s;
    text-decoration:none;
  }
.social-pill:hover{ background:var(--c-brand); border-color:var(--c-brand); color:var(--c-onbrand); }
.social-pill svg{ width:14px; height:14px; stroke:currentColor; fill:none; stroke-width:1.9; stroke-linecap:round; flex-shrink:0; }
@media(max-width:900px){
    .contact-grid{ grid-template-columns:1fr !important; }
    .contact-right{ transform:none; opacity:0; transform:translateY(30px); }
    .contact-section-loaded .contact-right{ opacity:1; transform:translateY(0); }
  }
@media(max-width:480px){
    .cinfo-item{ flex-direction:column; gap:.75rem; }
  }
/* =========================================================================
     WORK INDEX PAGE — service cards (work.html)
     ========================================================================= */
.work-card{
    display:flex; flex-direction:column;
    background:var(--c-surface);
    border:1px solid var(--c-line);
    border-radius:24px;
    padding:2rem;
    text-decoration:none;
    color:var(--c-ink);
    transition:border-color .35s ease, transform .45s cubic-bezier(.19,1,.22,1);
    position:relative;
    overflow:hidden;
  }
.work-card:hover{ border-color:var(--c-brand); transform:translateY(-4px); }
.work-card-ico{ width:52px; height:52px; border-radius:14px; background:var(--c-paper); border:1px solid var(--c-line); display:grid; place-items:center; margin-bottom:1.4rem; transition:background .3s, border-color .3s; }
.work-card-ico svg{ width:22px; height:22px; stroke:var(--c-brand); fill:none; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.work-card:hover .work-card-ico{ background:var(--c-brand); border-color:var(--c-brand); }
.work-card:hover .work-card-ico svg{ stroke:var(--c-onbrand); }
.work-card-title{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:clamp(1.4rem,2.5vw,1.85rem); letter-spacing:-.03em; line-height:1.05; margin-bottom:.75rem; }
.work-card-desc{ font-family:"Inter",sans-serif; font-size:.9rem; color:var(--c-muted); line-height:1.65; margin-bottom:1.5rem; flex:1; }
.work-card-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:auto; }
.work-card-count{ font-family:"Inter",sans-serif; font-size:.75rem; color:var(--c-muted); letter-spacing:.05em; }
.work-card-arrow{ width:38px; height:38px; border-radius:99px; border:1px solid var(--c-line); display:grid; place-items:center; color:var(--c-ink); transition:background .3s, color .3s, border-color .3s, transform .4s cubic-bezier(.19,1,.22,1); }
.work-card:hover .work-card-arrow{ background:var(--c-brand); color:var(--c-onbrand); border-color:transparent; transform:rotate(45deg); }
.work-card-accent-line{ position:absolute; top:0; left:0; right:0; height:3px; background:var(--c-brand); transform:scaleX(0); transform-origin:left; transition:transform .45s cubic-bezier(.19,1,.22,1); }
.work-card:hover .work-card-accent-line{ transform:scaleX(1); }
/* =========================================================================
     WORK-SERVICE PAGE — project cards grid (work-service.html)
     ========================================================================= */
.proj-card{
    display:flex; flex-direction:column;
    background:var(--c-surface);
    border:1px solid var(--c-line);
    border-radius:20px;
    overflow:hidden;
    text-decoration:none;
    color:var(--c-ink);
    transition:border-color .35s ease, transform .45s cubic-bezier(.19,1,.22,1);
  }
.proj-card:hover{ border-color:var(--c-brand); transform:translateY(-5px); }
.proj-card-img{ aspect-ratio:4/3; overflow:hidden; position:relative; }
.proj-card-img-inner{
    width:100%; height:100%;
    transition:transform .7s cubic-bezier(.19,1,.22,1);
  }
.proj-card:hover .proj-card-img-inner{ transform:scale(1.05); }
.proj-card-body{ padding:1.5rem 1.75rem 1.75rem; }
.proj-card-name{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:clamp(1.2rem,2vw,1.5rem); letter-spacing:-.025em; margin-bottom:.35rem; }
.proj-card-meta{ display:flex; align-items:center; justify-content:space-between; margin-top:.75rem; }
.proj-card-tag{ font-family:"Inter",sans-serif; font-size:.72rem; color:var(--c-muted); }
.proj-card-arrow{ width:36px; height:36px; border-radius:99px; border:1px solid var(--c-line); display:grid; place-items:center; color:var(--c-ink); transition:background .3s, color .3s, border-color .3s, transform .4s cubic-bezier(.19,1,.22,1); }
.proj-card:hover .proj-card-arrow{ background:var(--c-brand); color:var(--c-onbrand); border-color:transparent; transform:rotate(45deg); }
/* =========================================================================
     WORK-PROJECT PAGE — case study detail (work-project.html)
     ========================================================================= */
.proj-hero{
    aspect-ratio:16/9;
    border-radius:24px;
    overflow:hidden;
    position:relative;
    background:linear-gradient(135deg,#73c1b5 0%,#3a8a80 100%);
    display:grid;
    place-items:center;
  }
.proj-hero-name{
    font-family:"Bricolage Grotesque",sans-serif;
    font-weight:800;
    font-size:clamp(2.5rem,8vw,7rem);
    color:#fff;
    letter-spacing:-.04em;
    text-align:center;
    line-height:.95;
    padding:1.5rem;
    position:relative;
    z-index:1;
  }
.proj-hero::after{
    content:""; position:absolute; inset:0;
    background:radial-gradient(ellipse at 60% 40%,color-mix(in srgb,#f35b2d 22%,transparent),transparent 65%);
    pointer-events:none;
  }
.meta-bar{
    display:flex; flex-wrap:wrap; gap:0;
    border:1px solid var(--c-line);
    border-radius:16px;
    overflow:hidden;
    background:var(--c-surface);
  }
.meta-item{
    flex:1; min-width:140px;
    padding:1.25rem 1.5rem;
    border-right:1px solid var(--c-line);
  }
.meta-item:last-child{ border-right:0; }
.meta-label{ font-family:"Inter",sans-serif; font-size:.65rem; text-transform:uppercase; letter-spacing:.16em; color:var(--c-muted); margin-bottom:.4rem; }
.meta-value{ font-family:"Bricolage Grotesque",sans-serif; font-weight:700; font-size:1rem; letter-spacing:-.01em; }
.content-section{ max-width:720px; margin-left:auto; margin-right:auto; text-align:center; }
.section-label{ font-family:"Inter",sans-serif; font-size:.68rem; text-transform:uppercase; letter-spacing:.18em; color:var(--c-accent); margin-bottom:.9rem; font-weight:600; }
.section-title{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:clamp(1.5rem,3vw,2.5rem); letter-spacing:-.03em; line-height:1.05; margin-bottom:1.25rem; }
.body-text{ font-family:"Inter",sans-serif; font-size:1.05rem; line-height:1.75; color:var(--c-muted); }
/* CONFLICT: .stat-num is also defined for the homepage hero strip above. This is the
     work-project case-study stat variant (single value, brand-coloured). Kept verbatim;
     scoped in markup by .stat-cell / .stat-row context. */
.stat-cell .stat-num{ font-family:"Bricolage Grotesque",sans-serif; font-weight:800; font-size:clamp(2rem,5vw,3.5rem); letter-spacing:-.04em; line-height:1; color:var(--c-brand); margin-bottom:.4rem; }
.img-placeholder{
    aspect-ratio:4/3;
    border-radius:18px;
    border:1px solid var(--c-line);
    overflow:hidden;
  }
.next-link{
    display:inline-flex; align-items:center; gap:.75rem;
    font-family:"Bricolage Grotesque",sans-serif; font-weight:800;
    font-size:clamp(1.1rem,2vw,1.5rem); letter-spacing:-.02em;
    color:var(--c-ink); text-decoration:none;
    transition:color .3s;
  }
.next-link:hover{ color:var(--c-brand); }
.next-link-arrow{
    width:48px; height:48px; border-radius:99px;
    border:1px solid var(--c-line);
    display:grid; place-items:center;
    color:var(--c-ink); font-size:1.2em;
    transition:background .3s, color .3s, border-color .3s, transform .4s cubic-bezier(.19,1,.22,1);
  }
.next-link:hover .next-link-arrow{ background:var(--c-brand); color:var(--c-onbrand); border-color:transparent; transform:rotate(45deg); }
@media (max-width:640px){
    .meta-item{ min-width:50%; border-bottom:1px solid var(--c-line); }
    .stat-row{ grid-template-columns:1fr; }
  }
/* =========================================================================
     WHATSAPP FLOATING ACTION BUTTON (all pages)
     ========================================================================= */
.wa-fab{ position:fixed; bottom:1.5rem; right:1.5rem; z-index:9999; width:58px; height:58px; border-radius:50%; background:#25d366; color:#fff; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 24px rgba(37,211,102,.45); transition:transform .35s cubic-bezier(.19,1,.22,1), box-shadow .35s; text-decoration:none; }
.wa-fab:hover{ transform:scale(1.13); box-shadow:0 8px 32px rgba(37,211,102,.6); }
.wa-fab svg{ width:30px; height:30px; }
.wpcf7 input[type="text"],
  .wpcf7 input[type="email"],
  .wpcf7 input[type="tel"],
  .wpcf7 select,
  .wpcf7 textarea{
    width:100%; margin-top:.4rem; padding:.8rem 1rem;
    border:1px solid var(--c-line); border-radius:14px;
    background:var(--c-surface); color:var(--c-ink);
    font-family:"Inter",sans-serif; font-size:.95rem;
    transition:border-color .25s ease, box-shadow .25s ease;
  }
.wpcf7 textarea{ min-height:140px; resize:vertical; }
.wpcf7 :is(input,select,textarea):focus{
    outline:none; border-color:var(--c-brand);
    box-shadow:0 0 0 3px color-mix(in srgb, var(--c-brand) 22%, transparent);
  }
.wpcf7 .cta-pill{ border:0; cursor:pointer; }
.wpcf7 .wpcf7-response-output{
    border-radius:12px; border:1px solid var(--c-line);
    padding:.8rem 1rem; margin:1rem 0 0; font-size:.85rem;
  }
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}
.pointer-events-none {
  pointer-events: none;
}
.invisible {
  visibility: hidden;
}
.static {
  position: static;
}
.fixed {
  position: fixed;
}
.absolute {
  position: absolute;
}
.relative {
  position: relative;
}
.\!sticky {
  position: sticky !important;
}
.sticky {
  position: sticky;
}
.inset-0 {
  inset: 0px;
}
.inset-x-0 {
  left: 0px;
  right: 0px;
}
.-bottom-2\.5 {
  bottom: -0.625rem;
}
.-bottom-7 {
  bottom: -1.75rem;
}
.-bottom-8 {
  bottom: -2rem;
}
.-left-8 {
  left: -2rem;
}
.-right-2\.5 {
  right: -0.625rem;
}
.-right-7 {
  right: -1.75rem;
}
.top-0 {
  top: 0px;
}
.top-\[90px\] {
  top: 90px;
}
.z-10 {
  z-index: 10;
}
.z-\[200\] {
  z-index: 200;
}
.col-span-1 {
  grid-column: span 1 / span 1;
}
.col-span-2 {
  grid-column: span 2 / span 2;
}
.mx-auto {
  margin-left: auto;
  margin-right: auto;
}
.-mt-20 {
  margin-top: -5rem;
}
.-mt-8 {
  margin-top: -2rem;
}
.mb-10 {
  margin-bottom: 2.5rem;
}
.mb-12 {
  margin-bottom: 3rem;
}
.mb-14 {
  margin-bottom: 3.5rem;
}
.mb-16 {
  margin-bottom: 4rem;
}
.mb-2 {
  margin-bottom: 0.5rem;
}
.mb-20 {
  margin-bottom: 5rem;
}
.mb-3 {
  margin-bottom: 0.75rem;
}
.mb-4 {
  margin-bottom: 1rem;
}
.mb-5 {
  margin-bottom: 1.25rem;
}
.mb-6 {
  margin-bottom: 1.5rem;
}
.mb-7 {
  margin-bottom: 1.75rem;
}
.mb-8 {
  margin-bottom: 2rem;
}
.mt-10 {
  margin-top: 2.5rem;
}
.mt-12 {
  margin-top: 3rem;
}
.mt-2 {
  margin-top: 0.5rem;
}
.mt-3 {
  margin-top: 0.75rem;
}
.mt-5 {
  margin-top: 1.25rem;
}
.mt-6 {
  margin-top: 1.5rem;
}
.mt-9 {
  margin-top: 2.25rem;
}
.block {
  display: block;
}
.inline {
  display: inline;
}
.flex {
  display: flex;
}
.inline-flex {
  display: inline-flex;
}
.grid {
  display: grid;
}
.hidden {
  display: none;
}
.aspect-\[4\/3\] {
  aspect-ratio: 4/3;
}
.h-14 {
  height: 3.5rem;
}
.h-5 {
  height: 1.25rem;
}
.h-8 {
  height: 2rem;
}
.h-\[110px\] {
  height: 110px;
}
.h-\[190px\] {
  height: 190px;
}
.h-\[220px\] {
  height: 220px;
}
.h-\[42px\] {
  height: 42px;
}
.h-\[52px\] {
  height: 52px;
}
.h-\[610px\] {
  height: 610px;
}
.h-\[620px\] {
  height: 620px;
}
.h-\[70px\] {
  height: 70px;
}
.h-full {
  height: 100%;
}
.max-h-\[610px\] {
  max-height: 610px;
}
.min-h-\[100svh\] {
  min-height: 100svh;
}
.min-h-screen {
  min-height: 100vh;
}
.w-5 {
  width: 1.25rem;
}
.w-8 {
  width: 2rem;
}
.w-\[110px\] {
  width: 110px;
}
.w-\[42px\] {
  width: 42px;
}
.w-\[52px\] {
  width: 52px;
}
.w-\[70px\] {
  width: 70px;
}
.w-full {
  width: 100%;
}
.max-w-2xl {
  max-width: 42rem;
}
.max-w-\[1400px\] {
  max-width: 1400px;
}
.max-w-\[14rem\] {
  max-width: 14rem;
}
.max-w-\[1560px\] {
  max-width: 1560px;
}
.max-w-\[1600px\] {
  max-width: 1600px;
}
.max-w-\[460px\] {
  max-width: 460px;
}
.max-w-\[720px\] {
  max-width: 720px;
}
.max-w-md {
  max-width: 28rem;
}
.max-w-none {
  max-width: none;
}
.max-w-screen-xl {
  max-width: 1280px;
}
.max-w-xl {
  max-width: 36rem;
}
.max-w-xs {
  max-width: 20rem;
}
.flex-1 {
  flex: 1 1 0%;
}
.flex-\[1\.1\] {
  flex: 1.1;
}
.flex-shrink-0 {
  flex-shrink: 0;
}
.shrink-0 {
  flex-shrink: 0;
}
.grow {
  flex-grow: 1;
}
.transform {
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.select-none {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.resize {
  resize: both;
}
.grid-cols-1 {
  grid-template-columns: repeat(1, minmax(0, 1fr));
}
.grid-cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.flex-col {
  flex-direction: column;
}
.flex-wrap {
  flex-wrap: wrap;
}
.place-items-center {
  place-items: center;
}
.items-start {
  align-items: flex-start;
}
.items-end {
  align-items: flex-end;
}
.items-center {
  align-items: center;
}
.items-stretch {
  align-items: stretch;
}
.justify-center {
  justify-content: center;
}
.justify-between {
  justify-content: space-between;
}
.gap-1 {
  gap: 0.25rem;
}
.gap-1\.5 {
  gap: 0.375rem;
}
.gap-10 {
  gap: 2.5rem;
}
.gap-2 {
  gap: 0.5rem;
}
.gap-2\.5 {
  gap: 0.625rem;
}
.gap-3 {
  gap: 0.75rem;
}
.gap-4 {
  gap: 1rem;
}
.gap-5 {
  gap: 1.25rem;
}
.gap-6 {
  gap: 1.5rem;
}
.gap-8 {
  gap: 2rem;
}
.gap-\[3px\] {
  gap: 3px;
}
.space-y-2\.5 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(0.625rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(0.625rem * var(--tw-space-y-reverse));
}
.self-start {
  align-self: flex-start;
}
.overflow-hidden {
  overflow: hidden;
}
.rounded {
  border-radius: 0.25rem;
}
.rounded-2xl {
  border-radius: 1rem;
}
.rounded-\[20px\] {
  border-radius: 20px;
}
.rounded-\[28px\] {
  border-radius: 28px;
}
.rounded-\[32px\] {
  border-radius: 32px;
}
.rounded-full {
  border-radius: 9999px;
}
.border {
  border-width: 1px;
}
.border-2 {
  border-width: 2px;
}
.border-y {
  border-top-width: 1px;
  border-bottom-width: 1px;
}
.border-t {
  border-top-width: 1px;
}
.border-brand {
  border-color: var(--c-brand);
}
.border-line {
  border-color: var(--c-line);
}
.border-onbrand {
  border-color: var(--c-onbrand);
}
.bg-brand {
  background-color: var(--c-brand);
}
.bg-ink {
  background-color: var(--c-ink);
}
.bg-paper {
  background-color: var(--c-paper);
}
.bg-surface {
  background-color: var(--c-surface);
}
.object-cover {
  -o-object-fit: cover;
     object-fit: cover;
}
.p-10 {
  padding: 2.5rem;
}
.p-8 {
  padding: 2rem;
}
.px-4 {
  padding-left: 1rem;
  padding-right: 1rem;
}
.px-5 {
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}
.px-6 {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}
.px-7 {
  padding-left: 1.75rem;
  padding-right: 1.75rem;
}
.px-8 {
  padding-left: 2rem;
  padding-right: 2rem;
}
.py-12 {
  padding-top: 3rem;
  padding-bottom: 3rem;
}
.py-14 {
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
}
.py-16 {
  padding-top: 4rem;
  padding-bottom: 4rem;
}
.py-24 {
  padding-top: 6rem;
  padding-bottom: 6rem;
}
.py-3 {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}
.py-4 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}
.py-6 {
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
}
.pb-10 {
  padding-bottom: 2.5rem;
}
.pb-16 {
  padding-bottom: 4rem;
}
.pb-24 {
  padding-bottom: 6rem;
}
.pb-28 {
  padding-bottom: 7rem;
}
.pb-3 {
  padding-bottom: 0.75rem;
}
.pb-4 {
  padding-bottom: 1rem;
}
.pb-8 {
  padding-bottom: 2rem;
}
.pl-2 {
  padding-left: 0.5rem;
}
.pr-2 {
  padding-right: 0.5rem;
}
.pr-3 {
  padding-right: 0.75rem;
}
.pt-10 {
  padding-top: 2.5rem;
}
.pt-16 {
  padding-top: 4rem;
}
.pt-24 {
  padding-top: 6rem;
}
.pt-28 {
  padding-top: 7rem;
}
.pt-3 {
  padding-top: 0.75rem;
}
.pt-32 {
  padding-top: 8rem;
}
.pt-36 {
  padding-top: 9rem;
}
.pt-7 {
  padding-top: 1.75rem;
}
.text-center {
  text-align: center;
}
.font-display {
  font-family: "Bricolage Grotesque", sans-serif;
}
.font-mono {
  font-family: "JetBrains Mono", monospace;
}
.font-sans {
  font-family: Inter, sans-serif;
}
.text-2xl {
  font-size: 1.5rem;
  line-height: 2rem;
}
.text-4xl {
  font-size: 2.25rem;
  line-height: 2.5rem;
}
.text-6xl {
  font-size: 3.75rem;
  line-height: 1;
}
.text-\[\.65rem\] {
  font-size: .65rem;
}
.text-\[\.85rem\] {
  font-size: .85rem;
}
.text-\[1\.75rem\] {
  font-size: 1.75rem;
}
.text-\[11px\] {
  font-size: 11px;
}
.text-\[1rem\] {
  font-size: 1rem;
}
.text-\[clamp\(\.95rem\2c 1\.6vw\2c 1\.1rem\)\] {
  font-size: clamp(.95rem, 1.6vw, 1.1rem);
}
.text-\[clamp\(1rem\2c 1\.8vw\2c 1\.2rem\)\] {
  font-size: clamp(1rem, 1.8vw, 1.2rem);
}
.text-\[clamp\(1rem\2c 2vw\2c 1\.2rem\)\] {
  font-size: clamp(1rem, 2vw, 1.2rem);
}
.text-\[clamp\(2\.4rem\2c 5vw\2c 4\.8rem\)\] {
  font-size: clamp(2.4rem, 5vw, 4.8rem);
}
.text-\[clamp\(2\.4rem\2c 5vw\2c 5rem\)\] {
  font-size: clamp(2.4rem, 5vw, 5rem);
}
.text-\[clamp\(2\.4rem\2c 6\.5vw\2c 5\.5rem\)\] {
  font-size: clamp(2.4rem, 6.5vw, 5.5rem);
}
.text-\[clamp\(2\.6rem\2c 4\.8vw\2c 5\.2rem\)\] {
  font-size: clamp(2.6rem, 4.8vw, 5.2rem);
}
.text-\[clamp\(2\.8rem\2c 8vw\2c 8rem\)\] {
  font-size: clamp(2.8rem, 8vw, 8rem);
}
.text-\[clamp\(2rem\2c 4\.5vw\2c 3\.8rem\)\] {
  font-size: clamp(2rem, 4.5vw, 3.8rem);
}
.text-\[clamp\(2rem\2c 4vw\2c 3\.5rem\)\] {
  font-size: clamp(2rem, 4vw, 3.5rem);
}
.text-\[clamp\(2rem\2c 4vw\2c 3\.6rem\)\] {
  font-size: clamp(2rem, 4vw, 3.6rem);
}
.text-\[clamp\(2rem\2c 4vw\2c 3\.8rem\)\] {
  font-size: clamp(2rem, 4vw, 3.8rem);
}
.text-\[clamp\(2rem\2c 6vw\2c 5rem\)\] {
  font-size: clamp(2rem, 6vw, 5rem);
}
.text-\[clamp\(3rem\2c 11\.5vw\2c 12rem\)\] {
  font-size: clamp(3rem, 11.5vw, 12rem);
}
.text-\[clamp\(3rem\2c 7vw\2c 7\.5rem\)\] {
  font-size: clamp(3rem, 7vw, 7.5rem);
}
.text-base {
  font-size: 1rem;
  line-height: 1.5rem;
}
.text-lg {
  font-size: 1.125rem;
  line-height: 1.75rem;
}
.text-sm {
  font-size: 0.875rem;
  line-height: 1.25rem;
}
.text-xl {
  font-size: 1.25rem;
  line-height: 1.75rem;
}
.text-xs {
  font-size: 0.75rem;
  line-height: 1rem;
}
.font-bold {
  font-weight: 700;
}
.font-extrabold {
  font-weight: 800;
}
.font-normal {
  font-weight: 400;
}
.font-semibold {
  font-weight: 600;
}
.uppercase {
  text-transform: uppercase;
}
.capitalize {
  text-transform: capitalize;
}
.leading-\[\.92\] {
  line-height: .92;
}
.leading-\[0\.92\] {
  line-height: 0.92;
}
.leading-\[0\.95\] {
  line-height: 0.95;
}
.leading-\[0\.98\] {
  line-height: 0.98;
}
.leading-\[1\.0\] {
  line-height: 1.0;
}
.leading-\[1\.5\] {
  line-height: 1.5;
}
.leading-\[1\.75\] {
  line-height: 1.75;
}
.leading-relaxed {
  line-height: 1.625;
}
.leading-snug {
  line-height: 1.375;
}
.leading-tight {
  line-height: 1.25;
}
.tracking-\[-0\.035em\] {
  letter-spacing: -0.035em;
}
.tracking-\[-0\.038em\] {
  letter-spacing: -0.038em;
}
.tracking-\[-0\.03em\] {
  letter-spacing: -0.03em;
}
.tracking-\[\.13em\] {
  letter-spacing: .13em;
}
.tracking-\[\.16em\] {
  letter-spacing: .16em;
}
.tracking-\[0\.2em\] {
  letter-spacing: 0.2em;
}
.tracking-tight {
  letter-spacing: -0.025em;
}
.tracking-wider {
  letter-spacing: 0.05em;
}
.text-brand {
  color: var(--c-brand);
}
.text-brand-on {
  color: var(--c-onbrand);
}
.text-ink {
  color: var(--c-ink);
}
.text-muted {
  color: var(--c-muted);
}
.text-onbrand {
  color: var(--c-onbrand);
}
.no-underline {
  text-decoration-line: none;
}
.antialiased {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.opacity-60 {
  opacity: 0.6;
}
.opacity-80 {
  opacity: 0.8;
}
.opacity-90 {
  opacity: 0.9;
}
.outline {
  outline-style: solid;
}
.\!filter {
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow) !important;
}
.filter {
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
.transition {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}
.transition-colors {
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}
.transition-opacity {
  transition-property: opacity;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}
.transition-transform {
  transition-property: transform;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}
.duration-500 {
  transition-duration: 500ms;
}
.ease-out {
  transition-timing-function: cubic-bezier(0, 0, 0.2, 1);
}
.will-change-transform {
  will-change: transform;
}
.\[-webkit-mask-image\:linear-gradient\(to_left\2c black_70\%\2c transparent_100\%\)\] {
  -webkit-mask-image: linear-gradient(to left,black 70%,transparent 100%);
}
.\[mask-image\:linear-gradient\(to_left\2c black_70\%\2c transparent_100\%\)\] {
  -webkit-mask-image: linear-gradient(to left,black 70%,transparent 100%);
          mask-image: linear-gradient(to left,black 70%,transparent 100%);
}

/* ===========================================================================
   Design tokens — light / dark / forest themes (official client hex codes).
   These are CSS custom properties (not standalone style rules); they exist so
   the [data-theme] runtime switcher can swap palettes. Tailwind color tokens
   in tailwind.config.js reference these variables.
   =========================================================================== */

/* ===========================================================================
   @keyframes — kept at top level (cannot be nested inside @layer in older
   PostCSS). Consolidated & deduplicated from all mockup pages.
   =========================================================================== */
@keyframes float { 0%,100%{ transform:translateY(0) rotate(0deg);} 50%{ transform:translateY(-16px) rotate(6deg);} }
@keyframes spin-slow { to { transform:rotate(360deg);} }
@keyframes marq { to { transform:translateX(-50%);} }
@keyframes dotpulse{ 0%{ transform:scale(1); opacity:.55; } 80%,100%{ transform:scale(3.4); opacity:0; } }
@keyframes ab-spin{ to{ transform:translate(-50%,-50%) rotate(360deg);} }
@keyframes ab-counter{ from{ transform:translate(-50%,-50%) rotate(0deg);} to{ transform:translate(-50%,-50%) rotate(-360deg);} }

/* ===========================================================================
   Component layer — every unique component class from all mockup \3c style>
   blocks, deduplicated. Class names preserved verbatim (app.js + markup
   reference them). Theme custom-property declarations are NOT duplicated here
   (they live in @layer base above).
   =========================================================================== */

/* =========================================================================
   CONTACT FORM 7 — on-brand field styling (Rule 11: @layer components is the
   one allowed CSS exception, since CF7 generates its own class names).
   ========================================================================= */

.hover\:border-brand:hover {
  border-color: var(--c-brand);
}

.hover\:border-ink:hover {
  border-color: var(--c-ink);
}

.hover\:bg-onbrand:hover {
  background-color: var(--c-onbrand);
}

.hover\:text-brand:hover {
  color: var(--c-brand);
}

.hover\:opacity-90:hover {
  opacity: 0.9;
}

.focus\:not-sr-only:focus {
  position: static;
  width: auto;
  height: auto;
  padding: 0;
  margin: 0;
  overflow: visible;
  clip: auto;
  white-space: normal;
}

.focus\:absolute:focus {
  position: absolute;
}

.focus\:left-4:focus {
  left: 1rem;
}

.focus\:top-4:focus {
  top: 1rem;
}

.focus\:z-50:focus {
  z-index: 50;
}

.focus\:rounded:focus {
  border-radius: 0.25rem;
}

.focus\:bg-surface:focus {
  background-color: var(--c-surface);
}

.focus\:px-4:focus {
  padding-left: 1rem;
  padding-right: 1rem;
}

.focus\:py-2:focus {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

.focus\:text-ink:focus {
  color: var(--c-ink);
}

.focus\:shadow-lg:focus {
  --tw-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);
  box-shadow: var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow);
}

.group:hover .group-hover\:-translate-x-1 {
  --tw-translate-x: -0.25rem;
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

@media (min-width: 640px) {

  .sm\:inline-flex {
    display: inline-flex;
  }

  .sm\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sm\:flex-row {
    flex-direction: row;
  }

  .sm\:items-center {
    align-items: center;
  }

  .sm\:gap-1\.5 {
    gap: 0.375rem;
  }

  .sm\:gap-4 {
    gap: 1rem;
  }

  .sm\:px-5 {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }

  .sm\:pb-4 {
    padding-bottom: 1rem;
  }

  .sm\:pl-3 {
    padding-left: 0.75rem;
  }

  .sm\:pt-4 {
    padding-top: 1rem;
  }
}

@media (min-width: 768px) {

  .md\:col-span-1 {
    grid-column: span 1 / span 1;
  }

  .md\:mb-10 {
    margin-bottom: 2.5rem;
  }

  .md\:mb-14 {
    margin-bottom: 3.5rem;
  }

  .md\:mb-16 {
    margin-bottom: 4rem;
  }

  .md\:mb-8 {
    margin-bottom: 2rem;
  }

  .md\:mb-9 {
    margin-bottom: 2.25rem;
  }

  .md\:flex {
    display: flex;
  }

  .md\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .md\:grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .md\:gap-12 {
    gap: 3rem;
  }

  .md\:gap-16 {
    gap: 4rem;
  }

  .md\:gap-4 {
    gap: 1rem;
  }

  .md\:gap-6 {
    gap: 1.5rem;
  }

  .md\:gap-8 {
    gap: 2rem;
  }

  .md\:rounded-\[40px\] {
    border-radius: 40px;
  }

  .md\:px-10 {
    padding-left: 2.5rem;
    padding-right: 2.5rem;
  }

  .md\:px-16 {
    padding-left: 4rem;
    padding-right: 4rem;
  }

  .md\:py-20 {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }

  .md\:py-24 {
    padding-top: 6rem;
    padding-bottom: 6rem;
  }

  .md\:py-32 {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }

  .md\:py-36 {
    padding-top: 9rem;
    padding-bottom: 9rem;
  }

  .md\:py-40 {
    padding-top: 10rem;
    padding-bottom: 10rem;
  }

  .md\:pb-32 {
    padding-bottom: 8rem;
  }

  .md\:pb-36 {
    padding-bottom: 9rem;
  }

  .md\:pr-4 {
    padding-right: 1rem;
  }

  .md\:pt-20 {
    padding-top: 5rem;
  }

  .md\:pt-32 {
    padding-top: 8rem;
  }

  .md\:pt-36 {
    padding-top: 9rem;
  }

  .md\:pt-40 {
    padding-top: 10rem;
  }

  .md\:pt-44 {
    padding-top: 11rem;
  }

  .md\:text-lg {
    font-size: 1.125rem;
    line-height: 1.75rem;
  }

  .md\:text-xs {
    font-size: 0.75rem;
    line-height: 1rem;
  }
}

@media (min-width: 1024px) {

  .lg\:w-auto {
    width: auto;
  }

  .lg\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lg\:grid-cols-\[1\.2fr_1fr\] {
    grid-template-columns: 1.2fr 1fr;
  }

  .lg\:flex-row {
    flex-direction: row;
  }

  .lg\:items-end {
    align-items: flex-end;
  }

  .lg\:gap-14 {
    gap: 3.5rem;
  }
}

