/* =========================================================================
   Trpeski Design — tokens + base layer
   ========================================================================= */
:root{
  --ink:#1B1D21; --paper:#F5F6F8; --panel:#EEF0F3; --accent:#CC3A1F; --muted:#8B9097;
  --ink-soft:#3a3e44; --ink-2:#5B6066;
  --svc-brand:#CC3A1F; --svc-web:#2A6FDB; --svc-social:#7A52C7; --svc-content:#1F8A5B;
  --hair:rgba(27,29,33,.10); --hair-strong:rgba(27,29,33,.14); --hair-soft:rgba(27,29,33,.08);
  --maxw:1440px; --maxw-text:1280px; --pad-x:40px; --rhythm:120px;
  --radius-pill:100px; --ease:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--paper);
  font-family:'Montserrat',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--accent);color:var(--paper);}
a{color:inherit;}
img,svg{max-width:100%;}
img{height:auto;}

/* Layout primitives ------------------------------------------------------ */
.trp-container{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);width:100%;}
.trp-container--text{max-width:var(--maxw-text);}
.trp-section{padding:var(--rhythm) var(--pad-x);}

/* Type primitives -------------------------------------------------------- */
.trp-eyebrow{font-size:12px;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);font-weight:600;}
.trp-display{font-weight:800;font-size:clamp(34px,4.6vw,68px);line-height:.96;letter-spacing:-.02em;}

/* Buttons — fill solid; on hover the dark layer rises from the bottom (prototype) */
.trp-btn{
  display:inline-block;text-decoration:none;border-radius:var(--radius-pill);
  padding:16px 30px;font-weight:600;font-size:15px;line-height:1;
  position:relative;overflow:hidden;z-index:0;isolation:isolate;
  transition:transform .4s var(--ease),box-shadow .4s ease,color .4s ease,border-color .4s ease;
}
.trp-btn--accent{background:var(--accent);color:var(--paper);box-shadow:0 6px 18px rgba(204,58,31,.26);}
.trp-btn--accent::after{content:'';position:absolute;inset:0;z-index:-1;background:linear-gradient(115deg,#1B1D21 0%,#3b2a26 60%,#5a322a 100%);transform:translateY(102%);transition:transform .5s var(--ease);}
.trp-btn--accent:hover::after{transform:translateY(0);}
.trp-btn--accent:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(27,29,33,.28);}
.trp-btn--ghost{border:1.5px solid var(--ink);color:var(--ink);}
.trp-btn--ghost::after{content:'';position:absolute;inset:0;z-index:-1;background:var(--ink);transform:translateY(102%);transition:transform .5s var(--ease);}
.trp-btn--ghost:hover{color:var(--paper);transform:translateY(-3px);}
.trp-btn--ghost:hover::after{transform:translateY(0);}

/* Reveal-on-scroll base state (JS in Plan 2 toggles .is-in) --------------- */
[data-reveal]{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease),transform 1s var(--ease);}
[data-reveal].is-in{opacity:1;transform:none;}

/* Reduced motion --------------------------------------------------------- */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  [data-reveal]{opacity:1;transform:none;transition:none;}
  .trp-hero__bg,.trp-hero__canvas{opacity:1 !important;animation:none !important;}
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;}
}

/* =========================================================================
   Header / nav
   ========================================================================= */
.trp-skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--ink);color:var(--paper);padding:10px 16px;border-radius:0 0 8px 0;}
.trp-skip:focus{left:0;}

.trp-header{position:sticky;top:0;left:0;right:0;z-index:60;background:#fff;border-bottom:1px solid var(--hair-soft);}
.trp-header__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:16px 30px;}
.trp-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);}
.trp-logo__mark{display:block;height:30px;width:auto;}
.trp-logo__name{font-weight:800;font-size:21px;letter-spacing:-.02em;}
.trp-logo__sub{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:600;}

.trp-nav__list{list-style:none;display:flex;align-items:center;gap:26px;margin:0;padding:0;}
.trp-nav__list a{position:relative;text-decoration:none;color:var(--ink);font-size:14px;font-weight:500;transition:color .35s ease;}
.trp-nav__list a::after{content:'';position:absolute;left:0;bottom:-5px;height:1.5px;width:0;background:var(--accent);transition:width .4s var(--ease);}
.trp-nav__list a:hover::after,
.trp-nav__list .current-menu-item>a::after{width:100%;}
.trp-nav__list .current-menu-item>a{color:var(--accent);}

.trp-header__actions{display:flex;align-items:center;gap:10px;}
.trp-phone{display:inline-flex;align-items:center;gap:7px;text-decoration:none;color:var(--ink);border:1.5px solid var(--ink);border-radius:var(--radius-pill);padding:8px 14px;font-size:11.5px;letter-spacing:.02em;font-weight:600;position:relative;overflow:hidden;z-index:0;isolation:isolate;transition:color .35s ease,border-color .35s ease;}
.trp-phone::after{content:'';position:absolute;inset:0;z-index:-1;background:var(--ink);transform:translateY(102%);transition:transform .45s var(--ease);}
.trp-phone:hover{color:var(--paper);}
.trp-phone:hover::after{transform:translateY(0);}
.trp-phone__ico{transition:transform .3s ease;transform-origin:center;}
.trp-phone:hover .trp-phone__ico{animation:trp-ring .65s ease-in-out infinite;}
@keyframes trp-ring{0%,100%{transform:rotate(0);}10%{transform:rotate(-21deg);}22%{transform:rotate(17deg);}36%{transform:rotate(-13deg);}50%{transform:rotate(9deg);}64%{transform:rotate(-6deg);}78%{transform:rotate(3deg);}}

.trp-cta{text-decoration:none;background:var(--accent);color:var(--paper);border-radius:var(--radius-pill);padding:10px 20px;font-size:12.5px;font-weight:600;white-space:nowrap;position:relative;overflow:hidden;z-index:0;isolation:isolate;box-shadow:0 6px 18px rgba(204,58,31,.26);transition:transform .4s var(--ease),box-shadow .4s ease;}
.trp-cta::after{content:'';position:absolute;inset:0;z-index:-1;background:linear-gradient(115deg,#1B1D21 0%,#3b2a26 60%,#5a322a 100%);transform:translateY(102%);transition:transform .5s var(--ease);}
.trp-cta:hover::after{transform:translateY(0);}
.trp-cta:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(27,29,33,.28);}

.site-main{min-height:40vh;}

/* =========================================================================
   Footer CTA (dark)
   ========================================================================= */
.trp-cta-block{position:relative;overflow:hidden;color:var(--paper);
  background:
    radial-gradient(100% 80% at 82% 4%, rgba(204,58,31,.18) 0%, rgba(204,58,31,0) 44%),
    radial-gradient(90% 80% at 12% 92%, rgba(86,118,216,.16) 0%, rgba(86,118,216,0) 52%),
    radial-gradient(130% 120% at 68% 16%, #181B24 0%, #0D0F14 58%, #07080B 100%);
}
.trp-cta-block__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;}
.trp-cta-block__inner{position:relative;z-index:2;padding:130px var(--pad-x) 70px;}
.trp-cta-block__title{font-weight:800;font-size:clamp(54px,11vw,168px);line-height:.9;letter-spacing:-.035em;max-width:13ch;}
.trp-cta-block__title em{color:var(--accent);font-style:italic;}
.trp-cta-block .trp-btn--accent{margin-top:46px;padding:18px 40px;font-size:16px;}

.trp-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr;gap:48px;margin-top:130px;padding-top:54px;border-top:1px solid rgba(244,245,247,.16);align-items:start;}
.trp-footer-brand{font-weight:800;font-size:26px;letter-spacing:-.02em;margin-bottom:24px;}
.trp-footer-contact{font-size:15px;line-height:1.9;color:rgba(244,245,247,.72);display:flex;flex-direction:column;}
.trp-footer-contact a{color:rgba(244,245,247,.72);text-decoration:none;}
.trp-footer-social{display:flex;flex-direction:column;gap:12px;font-size:14px;}
.trp-footer-social a{color:var(--paper);text-decoration:none;transition:color .3s ease;}
.trp-footer-social a:hover{color:var(--accent);}
.trp-footer-news__label{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:rgba(244,245,247,.6);margin-bottom:16px;font-weight:600;}
.trp-footer-news__blurb{font-size:14px;line-height:1.6;color:rgba(244,245,247,.72);margin-bottom:18px;}
.trp-footer-legal{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-top:64px;font-size:11px;letter-spacing:.08em;color:rgba(244,245,247,.5);}

@media (max-width:900px){
  .trp-footer-grid{grid-template-columns:1fr;gap:40px;}
  .trp-nav{display:none;}
}

/* =========================================================================
   Keyframes
   ========================================================================= */
@keyframes tp-fade{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}
@keyframes tp-charin{from{transform:translateY(125%);}to{transform:translateY(0);}}
@keyframes tp-rise-out{from{transform:translateY(0);}to{transform:translateY(-105%);}}
@keyframes tp-rotate{to{transform:rotate(360deg);}}
@keyframes tp-marquee{to{transform:translateX(-50%);}}

/* =========================================================================
   Home header overlay (transparent over hero → white on scroll)
   ========================================================================= */
.home .trp-header{position:fixed;left:0;right:0;background:transparent;border-bottom-color:transparent;transition:background .4s ease,border-color .4s ease,padding .4s ease;}
.home .trp-header.is-stuck{background:#fff;border-bottom-color:var(--hair-soft);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding-top:0;padding-bottom:0;}
.home .trp-header.is-stuck .trp-header__inner{padding-top:12px;padding-bottom:12px;}

/* =========================================================================
   Hero
   ========================================================================= */
.trp-hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:center;overflow:hidden;}
.trp-hero__bg{position:absolute;inset:0;z-index:0;background:
  radial-gradient(95% 75% at 80% 4%, rgba(204,58,31,.07) 0%, rgba(204,58,31,0) 44%),
  radial-gradient(90% 80% at 14% 96%, rgba(86,118,216,.06) 0%, rgba(86,118,216,0) 50%),
  radial-gradient(130% 120% at 72% 18%, #FFFFFF 0%, #EDF0F5 56%, #E2E7ED 100%);}
.trp-hero__canvas{position:absolute;top:0;left:0;width:100%;z-index:1;pointer-events:none;}
/* Hero background (gradient + canvas waves) fades in AFTER the content has animated in. */
.trp-hero__bg,.trp-hero__canvas{opacity:0;animation:trp-hero-bg-in 1.1s ease forwards;animation-delay:1.4s;}
@keyframes trp-hero-bg-in{to{opacity:1;}}
.trp-hero__stamp{position:absolute;bottom:48px;right:48px;width:clamp(83px,10.5vw,165px);z-index:1;pointer-events:none;}
.trp-hero__stamp img{width:100%;height:auto;display:block;animation:tp-rotate 26s linear infinite;opacity:.92;}
.trp-hero__inner{position:relative;z-index:2;width:100%;padding-top:160px;padding-bottom:90px;}
.trp-hero__eyebrow{margin-bottom:34px;opacity:0;animation:tp-fade .9s ease forwards;animation-delay:.05s;}
.trp-hero__title{font-weight:700;font-size:clamp(38px,7.2vw,112px);line-height:.94;letter-spacing:-.035em;margin-bottom:8px;}
.trp-hero__static{display:block;white-space:nowrap;}
.trp-hero__rotate{display:block;color:var(--accent);font-style:italic;min-height:1em;}
.trp-hero__sub{max-width:560px;font-size:clamp(16px,1.4vw,20px);line-height:1.55;color:var(--ink-2);margin:32px 0 40px;opacity:0;animation:tp-fade .9s ease forwards;animation-delay:.42s;}
.trp-hero__cta{display:flex;flex-wrap:wrap;gap:16px;opacity:0;animation:tp-fade .9s ease forwards;animation-delay:.54s;}
.trp-hero__scroll{position:absolute;bottom:34px;left:40px;display:flex;align-items:center;gap:12px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);opacity:0;animation:tp-fade .9s ease forwards;animation-delay:.7s;}
.trp-hero__scroll-line{display:inline-block;width:30px;height:1px;background:currentColor;opacity:.6;}

/* =========================================================================
   Marquee
   ========================================================================= */
.trp-marquee-sec{padding:30px 0 70px;border-top:1px solid var(--hair-strong);border-bottom:1px solid var(--hair-strong);overflow:hidden;}
.trp-marquee-sec__head{display:flex;align-items:flex-start;justify-content:space-between;gap:40px;padding-top:50px;padding-bottom:56px;flex-wrap:wrap;}
.trp-marquee-sec__title{font-weight:600;font-size:clamp(34px,4.6vw,68px);line-height:.96;letter-spacing:-.02em;}
.trp-marquee-sec__lead{max-width:420px;font-size:16px;line-height:1.6;color:var(--ink-2);padding-top:8px;}
.trp-marquee{overflow:hidden;width:100%;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.trp-marquee__track{display:flex;width:max-content;animation:tp-marquee 38s linear infinite;}
.trp-marquee__group{display:flex;align-items:center;gap:72px;padding-right:72px;}
.trp-marquee__logo{height:46px;width:auto;object-fit:contain;flex:none;}

/* =========================================================================
   Work
   ========================================================================= */
.trp-work__head{margin-bottom:48px;}
.trp-work__title{font-weight:600;font-size:clamp(44px,7vw,104px);line-height:.92;letter-spacing:-.03em;}
.trp-work__lead{max-width:480px;font-size:17px;line-height:1.55;color:var(--ink-2);margin-top:22px;}
.trp-work__filters{display:flex;flex-wrap:wrap;gap:8px 28px;align-items:center;margin:0 0 52px;border-top:1px solid var(--hair-strong);border-bottom:1px solid var(--hair-strong);padding:18px 0;}
.trp-work__chip{background:none;border:none;font-family:inherit;font-size:13px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);padding:6px 2px;position:relative;cursor:pointer;}
.trp-work__chip.is-active::after{content:'';position:absolute;left:0;right:0;bottom:-19px;height:2px;background:var(--accent);}
.trp-work__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:56px 48px;}
.trp-card{display:block;text-decoration:none;color:inherit;}
.trp-card__media{position:relative;overflow:hidden;aspect-ratio:3/2;background:#E4E7EB;border-radius:3px;}
.trp-card__img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.1s var(--ease);}
.trp-card:hover .trp-card__img{transform:scale(1.07);}
.trp-card__overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(27,29,33,.5));display:flex;align-items:flex-end;justify-content:flex-end;padding:22px;opacity:0;transition:opacity .55s ease;}
.trp-card:hover .trp-card__overlay{opacity:1;}
.trp-card__arrow{width:52px;height:52px;border-radius:50%;background:var(--accent);color:var(--paper);display:flex;align-items:center;justify-content:center;font-size:22px;}
.trp-card__meta{display:flex;align-items:baseline;justify-content:space-between;gap:20px;border-top:1px solid var(--ink);margin-top:20px;padding-top:18px;}
.trp-card__name{font-weight:600;font-size:clamp(22px,2.4vw,32px);letter-spacing:-.02em;line-height:1.05;}
.trp-card__cats{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:9px;}
.trp-card__num{font-size:13px;color:var(--accent);flex:none;}

/* =========================================================================
   Services
   ========================================================================= */
.trp-services{background:var(--panel);border-top:1px solid var(--hair);padding:120px 0;}
.trp-services__head{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-bottom:60px;}
.trp-services__title{font-weight:600;font-size:clamp(44px,7vw,104px);line-height:.92;letter-spacing:-.03em;}
.trp-services__lead{max-width:400px;font-size:17px;line-height:1.55;color:var(--ink-2);}
.trp-services__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--hair);border:1px solid var(--hair);border-radius:4px;overflow:hidden;}
.trp-svc{position:relative;overflow:hidden;background:var(--panel);padding:46px 42px;min-height:300px;display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s ease;}
.trp-svc::before{content:'';position:absolute;inset:0;z-index:0;opacity:0;transition:opacity .55s ease;background:linear-gradient(135deg, color-mix(in srgb, var(--c) 22%, var(--panel)) 0%, var(--panel) 60%);}
.trp-svc:hover::before{opacity:1;}
.trp-svc:hover{box-shadow:0 22px 50px rgba(27,29,33,.12);z-index:2;}
.trp-svc>*{position:relative;z-index:1;}
.trp-svc__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:auto;}
.trp-svc__icon img{width:64px;height:64px;object-fit:contain;display:block;}
.trp-svc__num{font-size:13px;color:var(--muted);transition:color .4s ease;}
.trp-svc:hover .trp-svc__num{color:var(--c);}
.trp-svc__title{font-weight:700;font-size:clamp(24px,2.4vw,30px);letter-spacing:-.02em;margin:28px 0 14px;}
.trp-svc__desc{font-size:15px;line-height:1.65;color:var(--ink-2);}

/* Canvas waves revealed on hover — undulate in place (JS: initServiceWaves), full box coverage. */
.trp-svc-waves{position:absolute;inset:0;z-index:0;opacity:0;pointer-events:none;transition:opacity .6s ease;}
.trp-svc .trp-svc-waves{z-index:0;}
.trp-svc:hover .trp-svc-waves,.trp-svc-block:hover .trp-svc-waves{opacity:.2;}
.trp-svc-wave-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;}

/* =========================================================================
   Testimonials carousel
   ========================================================================= */
.trp-testi__head{margin-bottom:56px;}
.trp-testi__title{font-weight:800;font-size:clamp(40px,6vw,88px);line-height:.94;letter-spacing:-.03em;max-width:14ch;}
.trp-caro{position:relative;}
.trp-caro__vp{overflow:hidden;transition:height .55s var(--ease);}
.trp-caro__track{display:flex;align-items:flex-start;gap:30px;will-change:transform;transition:transform .65s var(--ease);}
.trp-caro__slide{flex:0 0 72%;margin:0;transition:opacity .55s ease;}
.trp-caro__card{background:#fff;border:1px solid var(--hair-strong);border-radius:14px;padding:clamp(38px,5vw,68px);box-shadow:0 18px 50px rgba(27,29,33,.06);}
.trp-caro__quote-mark{font-size:78px;line-height:.6;color:var(--accent);margin-bottom:24px;font-weight:800;}
.trp-caro__quote{font-weight:600;font-size:clamp(19px,2.3vw,33px);line-height:1.4;letter-spacing:-.015em;color:var(--ink);}
.trp-caro__cap{margin-top:38px;padding-top:26px;border-top:1px solid var(--hair-strong);display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;}
.trp-caro__name{font-weight:700;font-size:19px;}
.trp-caro__dot-sep{width:5px;height:5px;border-radius:50%;background:var(--muted);align-self:center;}
.trp-caro__role{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.trp-caro__nav{position:absolute;top:50%;width:54px;height:54px;border-radius:50%;border:1.5px solid var(--ink);background:var(--paper);color:var(--ink);font-size:19px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;transition:background .35s,color .35s,border-color .35s,transform .35s;transform:translateY(-50%);}
.trp-caro__nav:hover{background:var(--accent);color:var(--paper);border-color:var(--accent);transform:translateY(-50%) scale(1.07);}
.trp-caro__nav--prev{left:-8px;}
.trp-caro__nav--next{right:-8px;}
.trp-caro__dots{display:flex;gap:10px;justify-content:center;margin-top:44px;}
.trp-caro__dot{width:36px;height:14px;background:none;border:none;padding:0;cursor:pointer;position:relative;}
.trp-caro__dot::after{content:'';position:absolute;left:0;right:0;top:50%;height:1.4px;background:rgba(27,29,33,.28);transition:background .4s,height .4s;}
.trp-caro__dot.is-active::after{background:var(--accent);height:1.8px;}

/* Smaller desktops / laptops (incl. 16" MBP ~1728px): testimonials go full-width + compact.
   Large monitors (>=1760px) keep the centered 1280px column. */
@media (min-width:1025px) and (max-width:1760px){
  .trp-testi.trp-section{padding-top:84px;padding-bottom:52px;}
  .trp-testi .trp-container--text{max-width:none;}
  .trp-testi .trp-testi__head{margin-bottom:36px;}
  .trp-testi .trp-caro__slide{flex-basis:64%;}
  .trp-testi .trp-caro__card{padding:clamp(32px,3vw,50px);}
  .trp-testi .trp-caro__quote{font-size:clamp(19px,1.9vw,28px);}
  .trp-testi .trp-caro__quote-mark{font-size:64px;margin-bottom:18px;}
  .trp-testi .trp-caro__cap{margin-top:28px;padding-top:20px;}
  .trp-testi .trp-caro__dots{margin-top:26px;}
}

/* =========================================================================
   Homepage responsive
   ========================================================================= */
@media (max-width:768px){
  .trp-work__grid,.trp-services__grid{grid-template-columns:1fr;}
  .trp-hero__inner{padding-top:130px;}
  .trp-hero__static{white-space:normal;}
  .trp-hero__title{font-size:clamp(34px,9vw,56px);}
  .trp-hero__canvas{display:none;}
  .trp-hero__stamp{width:90px;bottom:24px;right:24px;}
  .trp-hero__scroll{left:24px;}
  .trp-caro__slide{flex:0 0 86%;}
  .trp-marquee-sec__head{padding-top:40px;padding-bottom:40px;}
}

/* =========================================================================
   Single project (case study)
   ========================================================================= */
.trp-project__intro{padding-top:40px;padding-bottom:24px;}
.trp-breadcrumb{display:flex;align-items:center;gap:10px;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.trp-breadcrumb a{color:var(--muted);text-decoration:none;}
.trp-breadcrumb__current{color:var(--ink);}
.trp-project__pills{display:flex;flex-wrap:wrap;gap:10px;margin:28px 0;}
.trp-project__pill{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:600;border:1px solid rgba(204,58,31,.4);border-radius:100px;padding:7px 15px;}
.trp-project__title{font-weight:800;font-size:clamp(52px,9vw,148px);line-height:.9;letter-spacing:-.04em;max-width:14ch;}
.trp-project__summary{max-width:640px;font-size:19px;line-height:1.6;color:var(--ink-2);margin-top:32px;}
.trp-project__hero{margin-top:40px;margin-bottom:64px;}
.trp-project__hero-img{width:100%;height:auto;display:block;border-radius:8px;border:1px solid var(--hair);}
.trp-project__metagrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hair);border:1px solid var(--hair);border-radius:8px;overflow:hidden;margin-bottom:80px;}
.trp-project__metacell{background:var(--paper);padding:28px 26px;}
.trp-project__metakey{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:12px;}
.trp-project__metaval{font-size:15px;line-height:1.5;font-weight:500;}
.trp-project__brief{background:var(--panel);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);}
.trp-project__brief-inner{display:grid;grid-template-columns:0.7fr 1.3fr;gap:64px;padding-top:104px;padding-bottom:104px;align-items:start;}
.trp-project__brief-body{display:flex;flex-direction:column;gap:40px;max-width:680px;}
.trp-project__section-h{font-weight:700;font-size:clamp(26px,2.8vw,40px);letter-spacing:-.02em;margin-bottom:16px;}
.trp-project__section-b{font-size:18px;line-height:1.7;color:var(--ink-soft);}
.trp-project__gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;padding-top:80px;padding-bottom:40px;}
.trp-project__shot{position:relative;overflow:hidden;border-radius:8px;border:1px solid var(--hair);background:#E4E7EB;margin:0;}
.trp-project__shot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.trp-project__shot-label{position:absolute;left:20px;bottom:20px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2);font-weight:600;background:rgba(245,246,248,.85);padding:7px 13px;border-radius:100px;}
.trp-project__deliver{background:#131517;color:var(--paper);}
.trp-project__deliver-inner{display:grid;grid-template-columns:0.8fr 1.2fr;gap:64px;padding-top:104px;padding-bottom:104px;align-items:start;}
.trp-project__deliver-title{font-weight:800;font-size:clamp(30px,3.4vw,52px);line-height:1;letter-spacing:-.03em;}
.trp-project__deliver-list{display:grid;grid-template-columns:repeat(2,1fr);gap:0 40px;}
.trp-project__deliver-item{display:flex;align-items:center;gap:16px;padding:20px 0;border-top:1px solid rgba(244,245,247,.16);font-size:17px;font-weight:500;}
.trp-project__deliver-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex:none;}
.trp-related{background:var(--panel);border-top:1px solid var(--hair);padding:96px 0;}
.trp-related__head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:48px;flex-wrap:wrap;}
.trp-related__title{font-weight:800;font-size:clamp(32px,4.6vw,68px);line-height:.96;letter-spacing:-.03em;}
.trp-related__all{text-decoration:none;color:var(--ink);border:1.5px solid var(--ink);border-radius:100px;padding:13px 26px;font-size:14px;font-weight:600;}
.trp-related__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}
.trp-related__name{font-weight:700;font-size:21px;letter-spacing:-.02em;margin-top:18px;}
@media (max-width:768px){
  .trp-project__metagrid{grid-template-columns:repeat(2,1fr);}
  .trp-project__brief-inner,.trp-project__deliver-inner{grid-template-columns:1fr;gap:32px;padding-top:64px;padding-bottom:64px;}
  .trp-project__deliver-list{grid-template-columns:1fr;}
  .trp-project__gallery,.trp-related__grid{grid-template-columns:1fr;}
}

/* =========================================================================
   About page
   ========================================================================= */
.trp-about-hero{position:relative;overflow:hidden;border-bottom:1px solid var(--hair-soft);}
.trp-about-hero__bgtext{position:absolute;top:48%;left:0;transform:translateY(-50%);width:100%;overflow:hidden;pointer-events:none;z-index:0;}
.trp-about-hero__marquee{display:flex;width:max-content;animation:tp-marquee 30s linear infinite;white-space:nowrap;}
.trp-about-hero__marquee span{font-weight:800;font-size:clamp(58px,10.9vw,179px);letter-spacing:-.03em;color:rgba(27,29,33,.05);line-height:1;}
.trp-about-hero__inner{position:relative;z-index:1;padding-top:104px;padding-bottom:90px;}
.trp-about-hero__title{font-weight:800;font-size:clamp(22px,3.3vw,48px);line-height:1.16;letter-spacing:-.025em;margin-top:30px;}
.trp-about-hero__title em{font-style:italic;}
.trp-about-hero__accent{color:#a9aeb4;}
.trp-about-hero__row{display:flex;flex-wrap:wrap;gap:48px;margin-top:50px;align-items:flex-end;}
.trp-about-hero__lead{max-width:560px;font-size:18px;line-height:1.65;color:var(--ink-2);}
.trp-about-hero__stats{display:flex;gap:48px;margin-left:auto;}
.trp-stat__num{font-weight:800;font-size:clamp(40px,4vw,64px);letter-spacing:-.03em;}
.trp-stat__label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:6px;font-weight:600;}
.trp-about-story{background:var(--panel);border-top:1px solid var(--hair);}
.trp-about-story__inner{display:grid;grid-template-columns:0.8fr 1.2fr;gap:64px;padding-top:110px;padding-bottom:110px;align-items:start;}
.trp-about-story__h{font-weight:800;font-size:clamp(36px,4.4vw,68px);line-height:.98;letter-spacing:-.03em;margin-top:18px;}
.trp-about-story__body{display:flex;flex-direction:column;gap:24px;font-size:17px;line-height:1.7;color:var(--ink-soft);max-width:620px;}
.trp-about-beliefs__h{font-weight:800;font-size:clamp(34px,5vw,76px);line-height:.96;letter-spacing:-.03em;margin:14px 0 56px;max-width:18ch;}
.trp-about-beliefs__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.trp-belief{position:relative;overflow:hidden;background:#fff;border:1px solid var(--hair);border-radius:8px;padding:40px 34px;min-height:340px;display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s ease,border-color .5s ease;}
.trp-belief:hover{transform:translateY(-4px);box-shadow:0 24px 56px rgba(27,29,33,.10);border-color:color-mix(in srgb,var(--c) 32%,transparent);}
.trp-belief__num{position:absolute;top:-20px;right:4px;font-weight:800;font-size:clamp(120px,13vw,180px);line-height:1;letter-spacing:-.05em;color:var(--c);opacity:.10;pointer-events:none;}
.trp-belief__title{font-weight:700;font-size:clamp(26px,2.6vw,36px);letter-spacing:-.02em;margin:auto 0 16px;position:relative;}
.trp-belief__desc{font-size:15px;line-height:1.65;color:var(--ink-2);position:relative;}

/* =========================================================================
   Clients page
   ========================================================================= */
.trp-clients-hero{padding-top:96px;padding-bottom:64px;}
.trp-clients-hero__row{display:flex;align-items:flex-end;justify-content:space-between;gap:48px;flex-wrap:wrap;margin-top:22px;}
.trp-clients-hero__title{font-weight:800;font-size:clamp(64px,12vw,180px);line-height:.88;letter-spacing:-.04em;}
.trp-clients-hero__lead{max-width:440px;font-size:18px;line-height:1.6;color:var(--ink-2);padding-bottom:18px;}
.trp-clients-grid-sec{padding-bottom:100px;}
.trp-clients-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.trp-client-card{background:#fff;border:1px solid var(--hair);border-radius:12px;padding:38px 26px 32px;display:flex;flex-direction:column;align-items:center;text-align:center;transition:transform .45s var(--ease),box-shadow .45s ease,border-color .45s ease;}
.trp-client-card:hover{transform:translateY(-5px);box-shadow:0 18px 40px rgba(27,29,33,.10);border-color:rgba(27,29,33,.2);}
.trp-client-card__logo{height:92px;display:flex;align-items:center;justify-content:center;margin-bottom:22px;}
.trp-client-card__logo img{height:72px;width:auto;max-width:150px;object-fit:contain;}
.trp-client-card__name{font-weight:700;font-size:15px;letter-spacing:.04em;}
.trp-client-card__rule{width:26px;height:2px;background:var(--accent);margin:13px 0 14px;}
.trp-client-card__meta{font-size:12.5px;line-height:1.8;color:var(--ink-2);}
.trp-client-card__meta span{color:var(--muted);}
.trp-clients-showcase{background:var(--panel);border-top:1px solid var(--hair);}
.trp-clients-showcase>.trp-container{padding-top:104px;padding-bottom:104px;}
.trp-clients-showcase__head{margin-bottom:52px;}
.trp-clients-showcase__h{font-weight:800;font-size:clamp(40px,6vw,92px);line-height:.94;letter-spacing:-.03em;}
.trp-clients-showcase__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:56px 48px;}

/* =========================================================================
   Services page
   ========================================================================= */
.trp-svc-hero{padding-top:96px;padding-bottom:48px;}
.trp-svc-hero__row{display:flex;align-items:flex-end;justify-content:space-between;gap:48px;flex-wrap:wrap;margin-top:22px;}
.trp-svc-hero__title{font-weight:800;font-size:clamp(64px,12vw,180px);line-height:.88;letter-spacing:-.04em;}
.trp-svc-hero__lead{max-width:440px;font-size:18px;line-height:1.6;color:var(--ink-2);padding-bottom:18px;}

/* Portfolio page hero (mirrors the Services hero scale). */
.trp-portfolio-hero{padding-top:96px;padding-bottom:24px;}
.trp-portfolio-hero__row{display:flex;align-items:flex-end;justify-content:space-between;gap:48px;flex-wrap:wrap;margin-top:22px;}
.trp-portfolio-hero__title{font-weight:800;font-size:clamp(64px,12vw,180px);line-height:.88;letter-spacing:-.04em;}
.trp-portfolio-hero__lead{max-width:440px;font-size:18px;line-height:1.6;color:var(--ink-2);padding-bottom:18px;}
/* On the Portfolio page the hero already provides the top gap. */
.page-template-page-portfolio .trp-work.trp-section{padding-top:24px;}

.trp-svc-blocks{padding-bottom:80px;}
/* White card (mirrors the prototype .sv-row): inner padding, border, rounded, waves fill the whole box. */
.trp-svc-block{position:relative;overflow:hidden;display:grid;grid-template-columns:0.95fr 1.05fr;gap:56px;padding:50px 44px;background:#fff;border:1px solid var(--hair);border-radius:20px;align-items:start;transition:transform .55s var(--ease),box-shadow .55s ease,border-color .55s ease;}
.trp-svc-block + .trp-svc-block{margin-top:18px;}
.trp-svc-block::before{content:'';position:absolute;inset:0;z-index:0;opacity:0;transition:opacity .55s ease;background:linear-gradient(135deg, color-mix(in srgb, var(--c) 20%, #fff) 0%, #fff 56%);}
.trp-svc-block:hover::before{opacity:1;}
.trp-svc-block:hover{transform:translateY(-4px);box-shadow:0 26px 62px rgba(27,29,33,.13);border-color:color-mix(in srgb, var(--c) 34%, transparent);}
.trp-svc-block__left,.trp-svc-block__right{position:relative;z-index:1;}
.trp-svc-block__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;}
.trp-svc-block__icon{width:88px;height:88px;border-radius:16px;background:#fff;border:1px solid var(--hair);display:flex;align-items:center;justify-content:center;}
.trp-svc-block__icon img{width:56px;height:56px;object-fit:contain;}
.trp-svc-block__num{font-size:clamp(40px,5vw,80px);font-weight:800;color:var(--c);opacity:.18;letter-spacing:-.04em;}
.trp-svc-block__title{font-weight:800;font-size:clamp(30px,3.4vw,52px);letter-spacing:-.02em;line-height:1;}
.trp-svc-block__desc{font-size:18px;line-height:1.6;color:var(--ink-soft);margin-bottom:24px;}
.trp-svc-block__list{list-style:none;}
.trp-svc-block__list li{position:relative;display:flex;align-items:center;gap:16px;padding:14px 0;font-size:16px;font-weight:500;}
.trp-svc-block__list li::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--c);flex:none;}
/* Separator hairline — retracts to 0 on card hover so it doesn't clash with the waves. */
.trp-svc-block__list li::after{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--hair);transform:scaleX(1);transform-origin:left;transition:transform .55s var(--ease);}
.trp-svc-block:hover .trp-svc-block__list li::after{transform:scaleX(0);}
.trp-svc-process{background:var(--ink);color:var(--paper);}
.trp-svc-process>.trp-container{padding-top:104px;padding-bottom:104px;}
.trp-svc-process__head{margin-bottom:56px;}
.trp-svc-process__h{font-weight:800;font-size:clamp(40px,6vw,88px);line-height:.94;letter-spacing:-.03em;}
.trp-svc-process__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.trp-phase{border-top:2px solid var(--c);padding-top:24px;}
.trp-phase__num{font-size:13px;color:var(--c);font-weight:700;}
.trp-phase__title{font-weight:700;font-size:22px;letter-spacing:-.02em;margin:14px 0 12px;}
.trp-phase__desc{font-size:14px;line-height:1.6;color:rgba(244,245,247,.66);}

@media (max-width:900px){
  .trp-clients-grid{grid-template-columns:repeat(2,1fr);}
  .trp-svc-process__grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:768px){
  .trp-about-story__inner{grid-template-columns:1fr;gap:24px;padding-top:64px;padding-bottom:64px;}
  .trp-about-beliefs__grid{grid-template-columns:1fr;}
  .trp-about-hero__stats{margin-left:0;}
  .trp-clients-showcase__grid{grid-template-columns:1fr;}
  .trp-svc-block{grid-template-columns:1fr;gap:24px;padding:32px 22px;}
}

/* =========================================================================
   Contact page + Contact Form 7
   ========================================================================= */
.trp-contact-hero{padding-top:96px;padding-bottom:40px;}
.trp-contact-hero__title{font-weight:800;font-size:clamp(64px,12vw,180px);line-height:.88;letter-spacing:-.04em;}
.trp-contact-hero__lead{max-width:560px;font-size:18px;line-height:1.6;color:var(--ink-2);margin-top:30px;}
.trp-contact-grid{display:grid;grid-template-columns:0.78fr 1.22fr;gap:64px;align-items:start;padding-top:30px;padding-bottom:110px;}
.trp-contact-info{display:flex;flex-direction:column;gap:40px;}
.trp-contact-info__label{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:14px;}
.trp-contact-info__value{font-size:18px;line-height:1.7;font-weight:500;}
.trp-contact-info__rule{height:1px;background:var(--hair-strong);}
.trp-contact-info__name{font-weight:700;font-size:20px;letter-spacing:-.01em;margin-bottom:14px;}
.trp-contact-info__links{display:flex;flex-direction:column;gap:8px;font-size:16px;}
.trp-contact-info__links a{color:var(--ink);text-decoration:none;}
.trp-contact-info__socials{display:flex;flex-wrap:wrap;gap:8px 22px;font-size:15px;font-weight:500;}
.trp-contact-info__socials a{color:var(--ink);text-decoration:none;transition:color .3s;}
.trp-contact-info__socials a:hover{color:var(--accent);}
.trp-contact-form-wrap{position:relative;background:#fff;border:1px solid var(--hair-strong);border-radius:18px;padding:clamp(34px,4vw,56px);box-shadow:0 24px 60px rgba(27,29,33,.07);overflow:hidden;}
.trp-contact-form-glow{position:absolute;top:-120px;right:-120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(204,58,31,.08),transparent 68%);pointer-events:none;}
.trp-contact-form-wrap .wpcf7{position:relative;z-index:1;}
.trp-contact-form-wrap form.wpcf7-form{display:flex;flex-direction:column;gap:26px;}
.trp-form__row{display:grid;grid-template-columns:1fr 1fr;gap:26px;}
.trp-form__field{display:block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2);font-weight:600;}
.trp-form__field > span{color:var(--accent);}
.trp-form__field .wpcf7-form-control-wrap{display:block;margin-top:10px;}
.trp-contact-form-wrap input[type=text],
.trp-contact-form-wrap input[type=email],
.trp-contact-form-wrap textarea{width:100%;background:var(--paper);border:1.5px solid rgba(27,29,33,.14);border-radius:10px;padding:15px 16px;font-family:inherit;font-size:15px;color:var(--ink);text-transform:none;letter-spacing:normal;font-weight:400;transition:border-color .35s,background .35s;}
.trp-contact-form-wrap input:focus,.trp-contact-form-wrap textarea:focus{outline:none;border-color:var(--accent);background:#fff;}
.trp-contact-form-wrap textarea{min-height:130px;resize:vertical;}
.trp-contact-form-wrap input::placeholder,.trp-contact-form-wrap textarea::placeholder{color:#9aa0a6;text-transform:none;letter-spacing:normal;font-weight:400;}
.trp-contact-form-wrap .wpcf7-submit{align-self:flex-start;background:var(--accent);color:var(--paper);border:none;border-radius:100px;padding:17px 40px;font-family:inherit;font-weight:600;font-size:16px;cursor:pointer;box-shadow:0 6px 18px rgba(204,58,31,.26);transition:transform .4s var(--ease),box-shadow .4s;}
.trp-contact-form-wrap .wpcf7-submit:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(27,29,33,.28);}
.trp-contact-form-wrap .wpcf7-response-output{border-radius:10px;margin:8px 0 0;padding:14px 18px;font-size:14px;}
@media (max-width:768px){
  .trp-contact-grid{grid-template-columns:1fr;gap:40px;}
  .trp-form__row{grid-template-columns:1fr;}
}

/* =========================================================================
   Blog
   ========================================================================= */
.trp-blog-hero{padding-top:96px;padding-bottom:48px;}
.trp-blog-hero__title{font-weight:800;font-size:clamp(48px,9vw,120px);line-height:.9;letter-spacing:-.04em;}
/* Accent only the genuine highlight span (search query / archive term), not the
   per-char animation spans (which carry inline style). */
.trp-blog-hero__title span:not([style]){color:var(--accent);}
.trp-blog-hero__lead{max-width:480px;font-size:18px;line-height:1.6;color:var(--ink-2);margin-top:20px;}
.trp-blog{padding-bottom:110px;}
.trp-blog__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px 32px;}
.trp-blog__empty{font-size:18px;color:var(--ink-2);padding:40px 0 80px;}
.trp-post-card__media{display:block;overflow:hidden;aspect-ratio:3/2;background:#E4E7EB;border-radius:6px;}
.trp-post-card__img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.1s var(--ease);}
.trp-post-card:hover .trp-post-card__img{transform:scale(1.05);}
.trp-post-card__body{padding-top:20px;}
.trp-post-card__cat{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:600;}
.trp-post-card__title{font-weight:700;font-size:22px;line-height:1.2;letter-spacing:-.02em;margin:10px 0 12px;}
.trp-post-card__title a{text-decoration:none;color:var(--ink);transition:color .3s;}
.trp-post-card__title a:hover{color:var(--accent);}
.trp-post-card__excerpt{font-size:15px;line-height:1.6;color:var(--ink-2);margin-bottom:14px;}
.trp-post-card__date{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.trp-pagination{margin-top:72px;}
.trp-pagination .nav-links{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}
.trp-pagination a,.trp-pagination .current{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:0 14px;border:1.5px solid var(--hair-strong);border-radius:100px;text-decoration:none;color:var(--ink);font-weight:600;font-size:14px;}
.trp-pagination .current{background:var(--ink);color:var(--paper);border-color:var(--ink);}

/* Single post */
.trp-single__head{padding-top:48px;max-width:880px;}
.trp-single__cats{display:flex;gap:10px;flex-wrap:wrap;margin:24px 0 18px;}
.trp-single__cat{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);font-weight:600;border:1px solid rgba(204,58,31,.4);border-radius:100px;padding:7px 15px;text-decoration:none;}
.trp-single__title{font-weight:800;font-size:clamp(34px,5vw,72px);line-height:1;letter-spacing:-.03em;}
.trp-single__meta{display:flex;gap:10px;align-items:center;margin-top:22px;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.trp-single__media{margin:48px auto;}
.trp-single__img{width:100%;height:auto;border-radius:8px;display:block;}
.trp-single__content{max-width:760px;font-size:18px;line-height:1.8;color:var(--ink-soft);}
.trp-single__content h2{font-weight:700;font-size:clamp(26px,3vw,40px);letter-spacing:-.02em;margin:48px 0 18px;color:var(--ink);}
.trp-single__content h3{font-weight:700;font-size:24px;margin:36px 0 14px;color:var(--ink);}
.trp-single__content p{margin-bottom:24px;}
.trp-single__content a{color:var(--accent);}
.trp-single__content img{border-radius:8px;height:auto;}
.trp-single__content blockquote{border-left:3px solid var(--accent);padding-left:24px;margin:32px 0;font-style:italic;color:var(--ink);}
.trp-single__foot{max-width:760px;padding-top:48px;padding-bottom:40px;}

/* Search form */
.search-form{display:flex;gap:10px;max-width:420px;margin-top:24px;}
.search-form .search-field{flex:1;background:#fff;border:1.5px solid var(--hair-strong);border-radius:100px;padding:13px 20px;font-family:inherit;font-size:15px;}
.search-form .search-field:focus{outline:none;border-color:var(--accent);}
.search-form .search-submit{background:var(--accent);color:var(--paper);border:none;border-radius:100px;padding:13px 24px;font-weight:600;cursor:pointer;}

/* 404 */
.trp-404{min-height:60vh;display:flex;flex-direction:column;justify-content:center;padding-top:80px;padding-bottom:80px;}
.trp-404__title{font-weight:800;font-size:clamp(40px,7vw,104px);line-height:.96;letter-spacing:-.03em;margin:18px 0 24px;max-width:16ch;}
.trp-404__lead{font-size:18px;line-height:1.6;color:var(--ink-2);max-width:480px;margin-bottom:36px;}
.trp-404__cta{display:flex;gap:16px;flex-wrap:wrap;}

/* =========================================================================
   Mobile nav
   ========================================================================= */
.trp-burger{display:none;flex-direction:column;justify-content:center;gap:6px;width:44px;height:44px;background:none;border:none;cursor:pointer;padding:0;z-index:90;position:relative;}
.trp-burger span{display:block;width:24px;height:2px;background:var(--ink);margin:0 auto;transition:transform .3s var(--ease),opacity .25s;}
.trp-burger.is-active span:nth-child(1){transform:translateY(8px) rotate(45deg);}
.trp-burger.is-active span:nth-child(2){opacity:0;}
.trp-burger.is-active span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}
.trp-mobile-menu{position:fixed;inset:0;z-index:70;background:var(--paper);transform:translateY(-100%);transition:transform .5s var(--ease);display:flex;flex-direction:column;justify-content:center;padding:90px 30px 40px;visibility:hidden;}
.trp-mobile-menu.is-open{transform:translateY(0);visibility:visible;}
body.trp-nav-open .trp-header{z-index:80;background:transparent;border-bottom-color:transparent;}
.trp-mobile-menu .trp-nav__list{flex-direction:column;gap:6px;align-items:flex-start;}
.trp-mobile-menu .trp-nav__list a{font-size:clamp(30px,9vw,44px);font-weight:700;letter-spacing:-.02em;padding:8px 0;}
.trp-mobile-menu .trp-nav__list a::after{display:none;}
.trp-mobile-menu__actions{display:flex;flex-direction:column;gap:14px;margin-top:40px;align-items:flex-start;}
body.trp-nav-open{overflow:hidden;}

@media (max-width:900px){
  .trp-burger{display:flex;}
  .trp-header__actions .trp-phone,.trp-header__actions .trp-cta{display:none;}
  .home .trp-header.is-stuck .trp-header__inner{padding-top:10px;padding-bottom:10px;}
}
@media (max-width:1024px) and (min-width:769px){
  .trp-blog__grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:768px){
  .trp-blog__grid{grid-template-columns:1fr;}
}

/* =========================================================================
   Hover polish — interactive elements that lacked feedback
   ========================================================================= */
/* "View all work" (single project) — outline → fill */
.trp-related__all{position:relative;overflow:hidden;z-index:0;isolation:isolate;transition:color .4s ease,transform .4s var(--ease);}
.trp-related__all::after{content:'';position:absolute;inset:0;z-index:-1;background:var(--ink);transform:translateY(102%);transition:transform .5s var(--ease);}
.trp-related__all:hover{color:var(--paper);transform:translateY(-2px);}
.trp-related__all:hover::after{transform:translateY(0);}

/* Work filter chips — hint on hover (inactive ones shift toward accent) */
.trp-work__chip{cursor:pointer;transition:color .3s ease;}
.trp-work__chip:hover{color:var(--accent);}

/* Blog pagination */
.trp-pagination a{transition:background .3s ease,color .3s ease,border-color .3s ease;}
.trp-pagination a:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);}

/* Breadcrumb links */
.trp-breadcrumb a{transition:color .3s ease;}
.trp-breadcrumb a:hover{color:var(--accent);}

/* Blog-post category pill (link) — fill on hover */
.trp-single__cat{transition:background .3s ease,color .3s ease,border-color .3s ease;}
.trp-single__cat:hover{background:var(--accent);color:var(--paper);border-color:var(--accent);}

/* Footer contact links (phone/email) → accent */
.trp-footer-contact a{transition:color .3s ease;}
.trp-footer-contact a:hover{color:var(--accent);}

/* Contact page founder links (email/phone) → accent */
.trp-contact-info__links a{transition:color .3s ease;}
.trp-contact-info__links a:hover{color:var(--accent);}

/* Search submit */
.search-form .search-submit{transition:transform .35s var(--ease),box-shadow .35s ease,background .35s ease;}
.search-form .search-submit:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(204,58,31,.28);}

/* Blog body links — underline grows on hover */
.trp-single__content a{text-decoration:none;background-image:linear-gradient(var(--accent),var(--accent));background-size:0% 1.5px;background-position:0 100%;background-repeat:no-repeat;transition:background-size .35s var(--ease);}
.trp-single__content a:hover{background-size:100% 1.5px;}

/* Related card title shifts to accent with the image scale */
.trp-related__card{transition:none;}
.trp-related__card .trp-related__name{transition:color .35s ease;}
.trp-related__card:hover .trp-related__name{color:var(--accent);}

/* Logo — subtle dim on hover */
.trp-logo{transition:opacity .3s ease;}
.trp-logo:hover{opacity:.78;}

/* Tighter gutters on small phones (token-level, applies to all containers/sections) */
@media (max-width:600px){
  :root{ --pad-x:22px; }
}
