:root { --tt-granate:        #3C101A;
--tt-granate-soft:   oklch(28% 0.06 12);
--tt-granate-deep:   oklch(14% 0.05 12);
--tt-yellow:         #FFD700;
--tt-mustard:        #DFA900; --tt-cream:          oklch(98.2% 0.012 40);
--tt-cream-2:        oklch(95.5% 0.015 40);
--tt-ink:            oklch(18% 0.020 12);
--tt-muted:          oklch(45% 0.018 12);
--tt-border:         oklch(86% 0.012 30); --tt-on-granate:     oklch(96% 0.012 40);
--tt-on-granate-mut: oklch(78% 0.020 30); --tt-serif: "Fraunces", ui-serif, Georgia, serif;
--tt-sans:  "Inter", system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif; --fs-xs:   13px;
--fs-sm:   15px;
--fs-base: 17px;
--fs-lg:   22px;
--fs-xl:   30px;
--fs-2xl:  40px;
--fs-3xl:  56px;
--fs-4xl:  76px; --container: 1200px;
--container-narrow: 880px;
--space-1:   8px;
--space-2:  12px;
--space-3:  16px;
--space-4:  24px;
--space-5:  32px;
--space-6:  48px;
--space-7:  72px;
--space-8: 112px;
--space-9: 160px; --ease-out: cubic-bezier(0.25, 1, 0.5, 1);
--dur-1: 200ms;
--dur-2: 320ms;
--dur-3: 480ms;
} *, *::before, *::after { box-sizing: border-box; }
html {
-webkit-text-size-adjust: 100%;
tab-size: 4;
scroll-behavior: smooth;
scroll-padding-top: 84px; }
body { overflow-x: clip;
max-width: 100%;
} .tt-container *,
.tt-container--narrow * {
min-width: 0;
} img, video, iframe { max-width: 100%; } .tt-offer h3, .tt-offer__desc,
.tt-pillar h3, .tt-pillar p,
.tt-step h3, .tt-step p,
.tt-value h3, .tt-value p,
.tt-team__info, .tt-contact-row__value,
.tt-form__check, .tt-form__file__hint,
.tt-form-status, .tt-empty,
.tt-footer__list, .tt-footer__address {
overflow-wrap: anywhere;
word-break: break-word;
}
@media (prefers-reduced-motion: reduce) {
html { scroll-behavior: auto; }
}
body {
margin: 0;
font-family: var(--tt-sans);
font-size: var(--fs-base);
line-height: 1.55;
color: var(--tt-ink);
background: var(--tt-cream);
font-weight: 300;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-rendering: optimizeLegibility;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
button, input, select, textarea { font: inherit; color: inherit; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--tt-yellow); color: var(--tt-granate); } h1, h2, h3, h4 {
font-family: var(--tt-serif);
font-weight: 400;
letter-spacing: -0.01em;
line-height: 1.08;
margin: 0;
font-variation-settings: "opsz" 144, "SOFT" 30;
}
h1 { font-size: clamp(40px, 6vw, 76px); }
h2 { font-size: clamp(30px, 4vw, 56px); }
h3 { font-size: clamp(22px, 2.4vw, 30px); line-height: 1.15; }
h4 { font-size: var(--fs-lg); line-height: 1.25; }
p { margin: 0 0 1em; max-width: 68ch; }
.lede {
font-size: var(--fs-lg);
color: var(--tt-muted);
max-width: 60ch;
font-weight: 300;
}
em, .tt-italic { font-style: italic; }
.tt-eyebrow {
display: inline-block;
font-family: var(--tt-sans);
font-size: var(--fs-xs);
letter-spacing: 0.18em;
text-transform: uppercase;
color: var(--tt-muted);
font-weight: 500;
} .tt-container { max-width: var(--container); margin: 0 auto; padding: 0 var(--space-4); }
.tt-container--narrow { max-width: var(--container-narrow); margin: 0 auto; padding: 0 var(--space-4); }
.tt-section { padding: var(--space-8) 0; }
.tt-section--tight { padding: var(--space-7) 0; }
.tt-section--cream { background: var(--tt-cream-2); }
.tt-section--granate { background: var(--tt-granate); color: var(--tt-on-granate); }
.tt-section--granate h1, .tt-section--granate h2, .tt-section--granate h3 { color: var(--tt-on-granate); }
.tt-section--granate p, .tt-section--granate .lede { color: var(--tt-on-granate-mut); }
.tt-section--granate .tt-eyebrow { color: var(--tt-mustard); }
.tt-rule {
display: block;
width: 56px;
height: 1px;
background: var(--tt-mustard);
margin: var(--space-3) 0 var(--space-4);
border: 0;
} .tt-skip {
position: absolute;
left: -9999px;
top: 0;
background: var(--tt-granate);
color: var(--tt-on-granate);
padding: 12px 18px;
z-index: 9999;
font-size: var(--fs-sm);
}
.tt-skip:focus { left: 12px; top: 12px; } .tt-btn {
display: inline-flex;
align-items: center;
gap: 10px;
padding: 14px 22px;
font-family: var(--tt-sans);
font-size: var(--fs-sm);
font-weight: 500;
letter-spacing: 0.01em;
border-radius: 999px;
border: 1px solid transparent;
transition: transform var(--dur-1) var(--ease-out), background var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out), border-color var(--dur-1) var(--ease-out);
white-space: nowrap;
cursor: pointer;
}
.tt-btn:hover { transform: translateY(-1px); }
.tt-btn:focus-visible { outline: 2px solid var(--tt-yellow); outline-offset: 3px; }
.tt-btn--primary {
background: var(--tt-yellow);
color: var(--tt-granate);
}
.tt-btn--primary:hover { background: var(--tt-mustard); }
.tt-btn--granate {
background: var(--tt-granate);
color: var(--tt-on-granate);
}
.tt-btn--granate:hover { background: var(--tt-granate-soft); }
.tt-btn--ghost {
background: transparent;
color: var(--tt-ink);
border-color: var(--tt-ink);
}
.tt-btn--ghost:hover { background: var(--tt-ink); color: var(--tt-cream); } .tt-hero .tt-btn--ghost,
.tt-section--granate .tt-btn--ghost,
.tt-page-hero .tt-btn--ghost {
color: var(--tt-on-granate);
border-color: oklch(96% 0.012 40 / 0.5);
background: oklch(96% 0.012 40 / 0.04);
}
.tt-hero .tt-btn--ghost:hover,
.tt-section--granate .tt-btn--ghost:hover,
.tt-page-hero .tt-btn--ghost:hover {
border-color: var(--tt-yellow);
color: var(--tt-yellow);
background: oklch(89% 0.179 95 / 0.1);
}
.tt-btn--block { width: 100%; justify-content: center; } .tt-btn__icon,
.tt-btn svg {
width: 18px !important;
height: 18px !important;
flex-shrink: 0;
display: inline-block;
max-width: none;
vertical-align: middle;
}
.tt-link {
color: inherit;
text-decoration: none;
border-bottom: 1px solid currentColor;
padding-bottom: 1px;
transition: opacity var(--dur-1) var(--ease-out);
}
.tt-link:hover { opacity: 0.7; }
.tt-arrow-link {
display: inline-flex;
align-items: center;
gap: 8px;
font-family: var(--tt-sans);
font-weight: 500;
color: var(--tt-granate);
transition: gap var(--dur-1) var(--ease-out);
}
.tt-arrow-link::after {
content: "";
display: inline-block;
width: 18px;
height: 1px;
background: currentColor;
position: relative;
}
.tt-arrow-link:hover { gap: 14px; } .tt-header {
position: sticky;
top: 0;
z-index: 100;
background: var(--tt-granate);
color: var(--tt-on-granate);
border-bottom: 1px solid transparent;
transition: border-color var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out);
} body.admin-bar .tt-header { top: 32px; }
@media (max-width: 782px) {
body.admin-bar .tt-header { top: 46px; }
}
.tt-header.is-scrolled {
border-bottom-color: var(--tt-granate-soft);
box-shadow: 0 8px 24px -16px oklch(8% 0.04 12 / 0.6);
}
.tt-header__inner {
display: flex;
align-items: center;
justify-content: space-between;
gap: var(--space-4);
padding: 16px 0;
}
.tt-logo {
display: inline-flex;
align-items: center;
gap: 12px;
color: var(--tt-on-granate);
}
.tt-logo img { display: block; }
.tt-logo svg { width: 36px; height: 36px; }
.tt-logo__word {
font-family: var(--tt-serif);
font-weight: 500;
font-size: 20px;
letter-spacing: 0.02em;
} .tt-logo--badge {
width: 156px;
height: 156px;
background: var(--tt-cream);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
padding: 28px;
box-shadow: 0 8px 24px -12px oklch(8% 0.04 12 / 0.5);
transition: transform var(--dur-2) var(--ease-out);
}
.tt-logo--badge:hover { transform: translateY(-2px); }
.tt-logo--badge img {
display: block;
width: 100%;
height: auto !important;
max-height: 100%;
object-fit: contain;
margin: 0 auto;
} .tt-footer__brand {
display: flex;
flex-direction: column;
align-items: center;
justify-content: flex-start;
text-align: center;
}
.tt-footer__brand p {
margin: var(--space-4) auto 0;
max-width: 32ch;
}
.tt-nav { display: flex; align-items: center; gap: var(--space-5); }
.tt-nav__list {
display: flex;
align-items: center;
gap: var(--space-5);
list-style: none;
margin: 0; padding: 0;
}
.tt-nav__list a {
color: var(--tt-on-granate);
font-size: var(--fs-sm);
font-weight: 400;
letter-spacing: 0.01em;
padding: 6px 0;
border-bottom: 1px solid transparent;
transition: border-color var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out);
}
.tt-nav__list a:hover { border-bottom-color: var(--tt-mustard); color: var(--tt-yellow); }
.tt-nav__list .is-current a, .tt-nav__list a[aria-current="page"],
.tt-nav__list .current_page_item a, .tt-nav__list .current-menu-item a {
border-bottom-color: var(--tt-mustard);
color: var(--tt-yellow);
}
.tt-header__cta { display: inline-flex; align-items: center; gap: var(--space-3); }
.tt-header__cta .tt-btn { padding: 11px 18px; font-weight: 500; } .tt-burger {
display: none;
width: 44px; height: 44px;
background: transparent;
border: 0;
padding: 0;
color: inherit;
}
.tt-burger__bar {
display: block;
width: 22px;
height: 1.5px;
background: currentColor;
margin: 5px auto;
transition: transform var(--dur-1) var(--ease-out), opacity var(--dur-1) var(--ease-out);
}
.tt-burger[aria-expanded="true"] .tt-burger__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.tt-burger[aria-expanded="true"] .tt-burger__bar:nth-child(2) { opacity: 0; }
.tt-burger[aria-expanded="true"] .tt-burger__bar:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }
.tt-drawer {
position: fixed;
inset: 0;
background: var(--tt-granate);
color: var(--tt-on-granate);
transform: translateY(-100%);
transition: transform var(--dur-3) var(--ease-out);
z-index: 90;
display: flex;
flex-direction: column;
padding: 96px var(--space-4) var(--space-5);
visibility: hidden;
}
.tt-drawer.is-open { transform: translateY(0); visibility: visible; }
.tt-drawer__list {
list-style: none;
margin: 0; padding: 0;
display: flex; flex-direction: column;
gap: var(--space-4);
flex: 1;
}
.tt-drawer__list a {
font-family: var(--tt-serif);
font-size: clamp(36px, 8vw, 56px);
font-weight: 400;
color: var(--tt-on-granate);
display: block;
padding: 8px 0;
}
.tt-drawer__list a:hover { color: var(--tt-yellow); }
.tt-drawer__cta { padding-top: var(--space-4); border-top: 1px solid var(--tt-granate-soft); } .tt-hero {
background: var(--tt-granate);
color: var(--tt-on-granate);
position: relative;
overflow: hidden;
padding: clamp(64px, 10vw, 144px) 0 clamp(72px, 10vw, 160px);
}
.tt-hero__inner {
position: relative;
z-index: 1;
max-width: 760px;
}
.tt-hero h1 {
color: var(--tt-on-granate);
font-weight: 300;
max-width: 14ch;
font-variation-settings: "opsz" 144, "SOFT" 50;
}
.tt-hero h1 em {
font-style: italic;
color: var(--tt-yellow);
font-weight: 300;
}
.tt-hero__lede {
color: var(--tt-on-granate-mut);
font-size: var(--fs-lg);
max-width: 56ch;
margin-top: var(--space-4);
font-weight: 300;
}
.tt-hero__lede::before {
content: "";
display: block;
width: 56px;
height: 1px;
background: var(--tt-mustard);
margin-bottom: var(--space-3);
}
.tt-hero__cta {
display: flex;
flex-wrap: wrap;
gap: var(--space-3);
margin-top: var(--space-5);
} .tt-trust {
background: var(--tt-granate-soft);
color: var(--tt-on-granate);
padding: var(--space-6) 0;
}
.tt-trust__inner {
display: flex;
align-items: center;
justify-content: center;
flex-wrap: wrap;
gap: var(--space-6);
}
.tt-trust__item {
display: flex;
align-items: center;
gap: var(--space-3);
max-width: 32ch;
}
.tt-trust__num {
font-family: var(--tt-serif);
font-size: clamp(40px, 6vw, 64px);
font-weight: 300;
color: var(--tt-yellow);
letter-spacing: -0.02em;
line-height: 1;
flex-shrink: 0;
font-variation-settings: "opsz" 144;
}
.tt-trust__label {
font-size: var(--fs-sm);
color: var(--tt-on-granate-mut);
line-height: 1.4;
max-width: 18ch;
}
.tt-trust__sep {
width: 1px;
height: 56px;
background: oklch(96% 0.012 40 / 0.12);
} .tt-hero__rings {
position: absolute;
pointer-events: none;
user-select: none;
}
.tt-hero__rings--lg {
top: -15%;
right: -10%;
width: clamp(300px, 48vw, 660px);
aspect-ratio: 1;
border: 1.5px solid oklch(89% 0.179 95 / 0.18);
border-radius: 50%;
}
.tt-hero__rings--sm {
top: 2%;
right: -2%;
width: clamp(200px, 32vw, 440px);
aspect-ratio: 1;
border: 1px solid oklch(89% 0.179 95 / 0.10);
border-radius: 50%;
} .tt-pillars { display: flex; flex-direction: column; }
.tt-pillar {
display: grid;
grid-template-columns: 4rem 1fr;
gap: 0 var(--space-6);
padding: clamp(32px, 5vw, 56px) 0;
border-top: 1px solid var(--tt-border);
align-items: start;
}
.tt-pillar:last-child { border-bottom: 1px solid var(--tt-border); }
.tt-pillar__num {
font-family: var(--tt-serif);
font-size: clamp(48px, 6vw, 72px);
font-weight: 400;
color: oklch(22.5% 0.078 12 / 0.12);
line-height: 0.9;
letter-spacing: -0.02em;
user-select: none;
font-variation-settings: "opsz" 144;
}
.tt-pillar h3 { margin-bottom: var(--space-3); }
.tt-pillar p { color: var(--tt-muted); max-width: 60ch; }
.tt-pillar__detail {
display: inline-flex;
align-items: center;
gap: 8px;
margin-top: var(--space-4);
font-size: var(--fs-xs);
font-weight: 600;
letter-spacing: 0.1em;
text-transform: uppercase;
color: var(--tt-granate);
}
.tt-pillar__detail::before {
content: "";
display: inline-block;
width: 18px; height: 1px;
background: var(--tt-mustard);
} .tt-process {
padding: clamp(64px, 9vw, 112px) 0;
background: var(--tt-granate);
color: var(--tt-on-granate);
}
.tt-process h2 { color: var(--tt-on-granate); }
.tt-process p { color: var(--tt-on-granate-mut); }
.tt-process__steps {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: var(--space-4);
margin-top: var(--space-6);
position: relative;
}
.tt-process__steps::before {
content: "";
position: absolute;
top: 36px;
left: 36px;
right: 36px;
height: 1px;
background: oklch(96% 0.012 40 / 0.12);
}
.tt-step {
padding: 0 var(--space-2);
position: relative;
display: flex;
flex-direction: column;
gap: var(--space-3);
}
.tt-step__circle {
display: flex;
align-items: center;
justify-content: center;
width: 72px; height: 72px;
border-radius: 50%;
background: var(--tt-granate-soft);
border: 1.5px solid oklch(96% 0.012 40 / 0.12);
font-family: var(--tt-serif);
font-size: var(--fs-lg);
font-style: italic;
color: var(--tt-yellow);
margin-bottom: var(--space-3);
transition: background var(--dur-2) var(--ease-out), color var(--dur-2) var(--ease-out), border-color var(--dur-2) var(--ease-out);
}
.tt-step:hover .tt-step__circle {
background: var(--tt-yellow);
color: var(--tt-granate);
border-color: var(--tt-yellow);
}
.tt-step h3 {
color: var(--tt-on-granate);
font-size: var(--fs-lg);
font-style: italic;
font-weight: 400;
}
.tt-step p {
font-size: var(--fs-sm);
line-height: 1.55;
} .tt-drenched {
background: var(--tt-yellow);
color: var(--tt-granate);
padding: clamp(64px, 9vw, 104px) 0;
position: relative;
overflow: hidden;
}
.tt-drenched::before, .tt-drenched::after {
content: "";
position: absolute;
right: -5%;
border-radius: 50%;
pointer-events: none;
border-style: solid;
}
.tt-drenched::before {
bottom: -25%;
width: clamp(200px, 38vw, 520px);
aspect-ratio: 1;
border: 1.5px solid oklch(22.5% 0.078 12 / 0.14);
}
.tt-drenched::after {
bottom: -10%;
right: 4%;
width: clamp(130px, 24vw, 340px);
aspect-ratio: 1;
border: 1px solid oklch(22.5% 0.078 12 / 0.08);
}
.tt-drenched__inner {
display: grid;
grid-template-columns: 1fr auto;
gap: var(--space-6);
align-items: center;
position: relative;
z-index: 1;
}
.tt-drenched h2 {
color: var(--tt-granate);
max-width: 22ch;
font-weight: 300;
}
.tt-drenched h2 em { font-style: italic; }
.tt-drenched p {
color: oklch(22.5% 0.078 12 / 0.78);
font-size: var(--fs-lg);
max-width: 50ch;
margin-top: var(--space-3);
font-weight: 300;
}
.tt-drenched .tt-btn--primary {
background: var(--tt-granate);
color: var(--tt-yellow);
}
.tt-drenched .tt-btn--primary:hover {
background: var(--tt-granate-deep);
} .tt-team {
display: flex;
flex-direction: column;
gap: var(--space-3);
margin: var(--space-5) 0;
}
.tt-team__member {
display: flex;
align-items: center;
gap: var(--space-3);
}
.tt-team__avatar {
width: 52px; height: 52px;
border-radius: 50%;
background: var(--tt-granate-soft);
border: 1.5px solid oklch(96% 0.012 40 / 0.10);
display: flex;
align-items: center;
justify-content: center;
font-family: var(--tt-serif);
font-style: italic;
font-weight: 400;
color: var(--tt-yellow);
font-size: 18px;
flex-shrink: 0;
}
.tt-team__info { min-width: 0; line-height: 1.3; }
.tt-team__info strong {
display: block;
font-family: var(--tt-sans);
font-weight: 600;
color: var(--tt-on-granate);
font-size: var(--fs-sm);
}
.tt-team__info a {
font-size: var(--fs-xs);
color: var(--tt-on-granate-mut);
transition: color var(--dur-1);
}
.tt-team__info a:hover { color: var(--tt-yellow); }
.tt-contact-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: clamp(40px, 6vw, 96px);
align-items: start;
}
.tt-contact-grid__info {
color: var(--tt-on-granate);
}
.tt-contact-grid__info p {
color: var(--tt-on-granate-mut);
max-width: 44ch;
line-height: 1.65;
font-weight: 300;
}
.tt-contact-grid__direct {
display: flex;
flex-direction: column;
gap: 10px;
margin-top: var(--space-4);
}
.tt-contact-grid__direct a {
display: inline-flex;
align-items: center;
gap: 10px;
font-size: var(--fs-sm);
color: var(--tt-on-granate-mut);
transition: color var(--dur-1);
}
.tt-contact-grid__direct a:hover { color: var(--tt-yellow); }
.tt-contact-grid__direct svg {
width: 16px; height: 16px;
stroke: currentColor;
stroke-width: 1.5;
fill: none;
flex-shrink: 0;
}
.tt-contact-form-card {
background: oklch(96% 0.012 40 / 0.04);
border: 1px solid oklch(96% 0.012 40 / 0.10);
border-radius: 12px;
padding: clamp(24px, 4vw, 36px);
}
.tt-contact-form-card .tt-form__label { color: var(--tt-on-granate-mut); }
.tt-contact-form-card .tt-form__input,
.tt-contact-form-card .tt-form__textarea {
background: oklch(96% 0.012 40 / 0.05);
border: 1px solid oklch(96% 0.012 40 / 0.14);
color: var(--tt-on-granate);
}
.tt-contact-form-card .tt-form__input::placeholder,
.tt-contact-form-card .tt-form__textarea::placeholder {
color: oklch(78% 0.020 30 / 0.45);
}
.tt-contact-form-card .tt-form__input:focus,
.tt-contact-form-card .tt-form__textarea:focus {
border-color: var(--tt-yellow);
background: oklch(96% 0.012 40 / 0.09);
}
.tt-contact-form-card .tt-btn--primary {
background: var(--tt-yellow);
color: var(--tt-granate);
} .tt-marquee {
padding: var(--space-7) 0;
background: var(--tt-cream-2);
border-top: 1px solid var(--tt-border);
border-bottom: 1px solid var(--tt-border);
position: relative;
}
.tt-marquee__title {
text-align: center;
font-size: var(--fs-xs);
letter-spacing: 0.2em;
text-transform: uppercase;
color: var(--tt-mustard);
margin-bottom: var(--space-5);
font-weight: 600;
}
.tt-marquee__viewport {
max-width: 1280px;
margin: 0 auto;
overflow: hidden;
-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%);
}
.tt-marquee__track {
display: flex;
align-items: center;
gap: 80px;
width: max-content;
animation: tt-marquee 50s linear infinite;
will-change: transform;
}
.tt-marquee__viewport:hover .tt-marquee__track { animation-play-state: paused; }
.tt-marquee__item {
flex: 0 0 auto;
height: 64px;
padding: 0 8px;
display: flex; align-items: center; justify-content: center;
}
.tt-marquee__item img {
height: 100%;
width: auto;
max-width: 200px;
object-fit: contain;
opacity: 0.78;
transition: opacity var(--dur-2) var(--ease-out), transform var(--dur-2) var(--ease-out);
}
.tt-marquee__item:hover img { opacity: 1; transform: scale(1.04); }
.tt-marquee__placeholder {
font-family: var(--tt-serif);
font-size: 22px;
letter-spacing: 0.02em;
color: var(--tt-muted);
white-space: nowrap;
opacity: 0.65;
}
@keyframes tt-marquee {
from { transform: translateX(0); }
to   { transform: translateX(-50%); }
} .tt-about-preview {
display: grid;
grid-template-columns: 1fr 1.2fr;
gap: var(--space-7);
align-items: start;
}
.tt-about-preview h2 { max-width: 14ch; }
.tt-about-preview p { font-size: var(--fs-lg); } .tt-cta-banner {
text-align: center;
padding: clamp(72px, 12vw, 160px) var(--space-4);
}
.tt-cta-banner h2 {
max-width: 18ch;
margin: 0 auto var(--space-5);
font-weight: 300;
}
.tt-cta-banner h2 em { font-style: italic; color: var(--tt-yellow); }
.tt-cta-banner p { margin: 0 auto var(--space-5); max-width: 50ch; } .tt-page-hero {
padding: clamp(64px, 9vw, 128px) 0 clamp(56px, 7vw, 96px);
background: var(--tt-granate);
color: var(--tt-on-granate);
position: relative;
}
.tt-page-hero::after {
content: "";
position: absolute;
left: 0; right: 0; bottom: 0;
height: 1px;
background: var(--tt-mustard);
opacity: 0.4;
}
.tt-page-hero__eyebrow { color: var(--tt-mustard); }
.tt-page-hero h1 { margin-top: var(--space-3); max-width: 22ch; color: var(--tt-on-granate); }
.tt-page-hero p { margin-top: var(--space-4); max-width: 56ch; font-size: var(--fs-lg); color: var(--tt-on-granate-mut); } .tt-filters {
display: flex;
flex-wrap: wrap;
gap: var(--space-2);
padding: var(--space-5) 0;
border-bottom: 1px solid var(--tt-border);
}
.tt-filter {
display: inline-flex;
align-items: center;
padding: 8px 16px;
border-radius: 999px;
border: 1px solid var(--tt-border);
font-family: var(--tt-sans);
font-size: var(--fs-sm);
font-weight: 400;
color: var(--tt-ink);
background: transparent;
cursor: pointer;
transition: background var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out), border-color var(--dur-1) var(--ease-out);
}
.tt-filter:hover { border-color: var(--tt-ink); }
.tt-filter.is-active { background: var(--tt-granate); color: var(--tt-on-granate); border-color: var(--tt-granate); }
.tt-filter:focus-visible { outline: 2px solid var(--tt-yellow); outline-offset: 2px; }
.tt-offers {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: var(--space-5) var(--space-4);
padding: var(--space-6) 0;
}
.tt-offer {
display: flex;
flex-direction: column;
gap: var(--space-3);
padding: var(--space-5);
border: 1px solid var(--tt-border);
background: var(--tt-cream);
transition: border-color var(--dur-2) var(--ease-out), transform var(--dur-2) var(--ease-out), background var(--dur-2) var(--ease-out);
height: 100%;
position: relative;
min-width: 0;
max-width: 100%;
}
.tt-offer:hover {
border-color: var(--tt-ink);
transform: translateY(-2px);
} .tt-offer--destacada {
border-color: var(--tt-mustard);
background: linear-gradient(180deg, oklch(98.5% 0.025 85 / 0.55) 0%, var(--tt-cream) 60%);
box-shadow: 0 1px 0 var(--tt-mustard) inset;
}
.tt-offer--destacada:hover {
border-color: var(--tt-mustard);
box-shadow: 0 1px 0 var(--tt-mustard) inset, 0 12px 24px -16px oklch(75% 0.155 85 / 0.55);
}
.tt-offer__badge {
position: absolute;
top: 14px;
right: 14px;
font-family: var(--tt-sans);
font-size: 10px;
font-weight: 600;
letter-spacing: 0.12em;
text-transform: uppercase;
color: var(--tt-granate);
background: var(--tt-mustard);
padding: 4px 9px;
border-radius: 999px;
line-height: 1;
z-index: 2;
} .tt-pager {
display: flex;
align-items: center;
justify-content: center;
gap: var(--space-4);
margin-top: var(--space-6);
padding-top: var(--space-5);
border-top: 1px solid var(--tt-border);
}
.tt-pager[hidden] { display: none; }
.tt-pager__btn {
display: inline-flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
border: 1px solid var(--tt-border);
background: transparent;
color: var(--tt-ink);
border-radius: 999px;
cursor: pointer;
transition: border-color var(--dur-1) var(--ease-out), background var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out);
}
.tt-pager__btn:hover:not(:disabled) {
border-color: var(--tt-granate);
background: var(--tt-granate);
color: var(--tt-on-granate);
}
.tt-pager__btn:disabled {
opacity: 0.3;
cursor: not-allowed;
}
.tt-pager__btn:focus-visible {
outline: 2px solid var(--tt-mustard);
outline-offset: 2px;
}
.tt-pager__indicator {
font-family: var(--font-serif);
font-size: 17px;
color: var(--tt-ink);
letter-spacing: 0.01em;
min-width: 110px;
text-align: center;
}
.tt-pager__sep {
color: var(--tt-mustard);
margin: 0 4px;
}
.tt-offer__sector {
display: inline-block;
font-size: var(--fs-xs);
letter-spacing: 0.18em;
text-transform: uppercase;
color: var(--tt-mustard);
font-weight: 500;
}
.tt-offer h3 {
font-size: var(--fs-xl);
line-height: 1.15;
}
.tt-offer__meta {
font-size: var(--fs-sm);
color: var(--tt-muted);
letter-spacing: 0.01em;
}
.tt-offer__desc {
font-size: var(--fs-sm);
color: var(--tt-muted);
line-height: 1.55;
display: -webkit-box;
-webkit-line-clamp: 3;
-webkit-box-orient: vertical;
overflow: hidden;
}
.tt-offer__more {
margin-top: auto;
padding-top: var(--space-3);
display: inline-flex;
align-items: center;
gap: 8px;
font-size: var(--fs-sm);
font-weight: 500;
color: var(--tt-granate);
border-top: 1px solid var(--tt-border);
transition: gap var(--dur-1) var(--ease-out);
}
.tt-offer__more::after { content: "→"; transition: transform var(--dur-1) var(--ease-out); }
.tt-offer:hover .tt-offer__more::after { transform: translateX(4px); }
.tt-offer__link { position: absolute; inset: 0; }
.tt-empty {
padding: var(--space-7) 0;
text-align: center;
color: var(--tt-muted);
font-family: var(--tt-serif);
font-size: var(--fs-xl);
font-style: italic;
} .tt-offer-detail {
display: grid;
grid-template-columns: 1.4fr 1fr;
gap: var(--space-7);
padding: var(--space-7) 0;
align-items: start;
}
.tt-offer-detail__head { margin-bottom: var(--space-5); }
.tt-offer-detail__head h1 { margin-top: var(--space-3); max-width: 22ch; }
.tt-offer-detail__meta {
margin-top: var(--space-4);
font-size: var(--fs-sm);
color: var(--tt-muted);
letter-spacing: 0.01em;
}
.tt-offer-detail__body h2 {
font-size: var(--fs-xl);
margin-top: var(--space-6);
margin-bottom: var(--space-3);
}
.tt-offer-detail__body h2:first-child { margin-top: 0; }
.tt-offer-detail__body ul {
list-style: none;
margin: 0; padding: 0;
}
.tt-offer-detail__body li {
position: relative;
padding-left: 28px;
margin-bottom: var(--space-2);
color: var(--tt-ink);
}
.tt-offer-detail__body li::before {
content: "";
position: absolute;
left: 0; top: 0.7em;
width: 16px; height: 1px;
background: var(--tt-mustard);
}
.tt-apply-aside {
position: sticky;
top: 96px;
padding: var(--space-5);
background: var(--tt-cream-2);
border: 1px solid var(--tt-border);
}
.tt-apply-aside h2 {
font-size: var(--fs-xl);
margin-bottom: var(--space-2);
}
.tt-apply-aside__sub {
font-size: var(--fs-sm);
color: var(--tt-muted);
margin-bottom: var(--space-4);
}
.tt-apply-aside__alt {
margin-top: var(--space-4);
padding-top: var(--space-4);
border-top: 1px solid var(--tt-border);
font-size: var(--fs-sm);
color: var(--tt-muted);
display: flex;
flex-direction: column;
gap: var(--space-2);
} .tt-form { display: flex; flex-direction: column; gap: var(--space-3); }
.tt-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
.tt-form__field { display: flex; flex-direction: column; gap: 6px; }
.tt-form__label {
font-size: var(--fs-xs);
letter-spacing: 0.1em;
text-transform: uppercase;
font-weight: 500;
color: var(--tt-muted);
}
.tt-form__input,
.tt-form__textarea {
width: 100%;
padding: 12px 14px;
border: 1px solid var(--tt-border);
background: var(--tt-cream);
font-family: var(--tt-sans);
font-size: var(--fs-sm);
color: var(--tt-ink);
transition: border-color var(--dur-1) var(--ease-out), background var(--dur-1) var(--ease-out);
border-radius: 0;
}
.tt-form__input:focus,
.tt-form__textarea:focus {
border-color: var(--tt-granate);
outline: none;
background: #fff;
}
.tt-form__textarea { resize: vertical; min-height: 96px; } .tt-form__file {
position: relative;
display: flex;
align-items: center;
gap: 14px;
padding: 14px 14px 14px 16px;
border: 1px solid var(--tt-border);
background: #fff;
cursor: pointer;
transition: border-color var(--dur-1) var(--ease-out), background var(--dur-1) var(--ease-out), box-shadow var(--dur-1) var(--ease-out);
min-height: 64px;
}
.tt-form__file:hover {
border-color: var(--tt-granate);
background: var(--tt-cream);
}
.tt-form__file:focus-within {
border-color: var(--tt-granate);
box-shadow: 0 0 0 3px oklch(22.5% 0.078 12 / 0.12);
}
.tt-form__file.is-filled {
border-color: var(--tt-granate);
background: var(--tt-cream-2);
}
.tt-form__file__input {
position: absolute;
left: 0; top: 0;
width: 100%; height: 100%;
opacity: 0;
cursor: pointer;
}
.tt-form__file__icon {
flex: 0 0 auto;
width: 36px; height: 36px;
display: inline-flex; align-items: center; justify-content: center;
border: 1px solid var(--tt-border);
border-radius: 50%;
color: var(--tt-granate);
background: var(--tt-cream);
transition: background var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out), border-color var(--dur-1) var(--ease-out);
}
.tt-form__file__icon svg { width: 18px; height: 18px; }
.tt-form__file:hover .tt-form__file__icon,
.tt-form__file.is-filled .tt-form__file__icon {
background: var(--tt-granate);
color: var(--tt-on-granate);
border-color: var(--tt-granate);
}
.tt-form__file__text {
display: flex; flex-direction: column; gap: 2px;
flex: 1; min-width: 0;
}
.tt-form__file__title {
font-family: var(--font-serif);
font-size: 17px;
color: var(--tt-ink);
line-height: 1.2;
}
.tt-form__file.is-filled .tt-form__file__title { color: var(--tt-granate); }
.tt-form__file__hint {
display: block;
font-size: var(--fs-xs);
color: var(--tt-muted);
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
max-width: 100%;
}
.tt-form__file__btn {
flex: 0 0 auto;
font-size: 12px;
letter-spacing: 0.08em;
text-transform: uppercase;
color: var(--tt-granate);
padding: 8px 14px;
border: 1px solid var(--tt-granate);
background: transparent;
transition: background var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out);
border-radius: 999px;
}
.tt-form__file:hover .tt-form__file__btn,
.tt-form__file.is-filled .tt-form__file__btn {
background: var(--tt-granate);
color: var(--tt-on-granate);
} .tt-form__check {
display: flex; align-items: flex-start; gap: 12px;
font-size: var(--fs-sm);
color: var(--tt-ink);
line-height: 1.55;
cursor: pointer;
user-select: none;
}
.tt-form__check__input {
position: absolute;
width: 1px; height: 1px;
padding: 0; margin: -1px;
overflow: hidden; clip: rect(0,0,0,0);
border: 0;
}
.tt-form__check__box {
flex: 0 0 auto;
width: 20px; height: 20px;
margin-top: 1px;
display: inline-flex;
align-items: center; justify-content: center;
background: #fff;
border: 1.5px solid var(--tt-border);
border-radius: 4px;
color: transparent;
transition: background var(--dur-1) var(--ease-out), border-color var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out), box-shadow var(--dur-1) var(--ease-out);
}
.tt-form__check__box svg {
width: 13px; height: 13px;
transform: scale(0.7);
transition: transform var(--dur-1) var(--ease-out);
}
.tt-form__check:hover .tt-form__check__box {
border-color: var(--tt-granate);
}
.tt-form__check__input:focus-visible + .tt-form__check__box {
border-color: var(--tt-granate);
box-shadow: 0 0 0 3px oklch(22.5% 0.078 12 / 0.18);
}
.tt-form__check__input:checked + .tt-form__check__box {
background: var(--tt-granate);
border-color: var(--tt-granate);
color: var(--tt-on-granate);
}
.tt-form__check__input:checked + .tt-form__check__box svg { transform: scale(1); }
.tt-form__check__text { color: var(--tt-muted); }
.tt-form__check a {
color: var(--tt-granate);
text-decoration: underline;
text-underline-offset: 2px;
}
.tt-form__check a:hover { text-decoration-thickness: 2px; }
.tt-form__honeypot { position: absolute; left: -10000px; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.tt-form-status {
padding: 14px 16px;
margin-bottom: var(--space-4);
font-size: var(--fs-sm);
border: 1px solid var(--tt-border);
}
.tt-form-status--success { background: oklch(95% 0.05 145); border-color: oklch(75% 0.1 145); color: oklch(28% 0.06 145); }
.tt-form-status--error   { background: oklch(95% 0.04 30); border-color: var(--tt-granate); color: var(--tt-granate); } .tt-manifesto {
padding: var(--space-7) 0;
}
.tt-manifesto__inner {
display: grid;
grid-template-columns: 1fr 1.6fr;
gap: var(--space-7);
align-items: start;
border-top: 1px solid var(--tt-border);
padding-top: var(--space-6);
}
.tt-about-hero {
max-width: 56ch;
padding-bottom: var(--space-3);
}
.tt-about-hero h2 {
font-size: clamp(36px, 5vw, 64px);
font-weight: 300;
font-variation-settings: "opsz" 144, "SOFT" 50;
}
.tt-about-hero h2 em {
font-style: italic;
color: var(--tt-granate);
}
.tt-manifesto h2 { max-width: 12ch; font-size: clamp(28px, 3.5vw, 44px); }
.tt-manifesto__body { font-size: var(--fs-lg); }
.tt-manifesto__body p { color: var(--tt-ink); max-width: 60ch; line-height: 1.55; margin-bottom: var(--space-4); }
.tt-manifesto__body p:first-of-type::first-line { font-style: italic; color: var(--tt-granate); }
.tt-values {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 0;
}
.tt-value {
padding: var(--space-6) var(--space-4) var(--space-5);
border-top: 1px solid var(--tt-border);
}
.tt-value__num {
font-family: var(--tt-serif);
font-style: italic;
font-size: var(--fs-xl);
color: var(--tt-mustard);
}
.tt-value h3 { margin: var(--space-3) 0 var(--space-3); }
.tt-value p { color: var(--tt-muted); }
.tt-office {
padding: var(--space-7) 0;
display: grid;
grid-template-columns: 1fr 1fr;
gap: var(--space-7);
align-items: end;
}
.tt-office h2 { max-width: 14ch; }
.tt-office p { font-size: var(--fs-lg); margin-bottom: var(--space-4); }
.tt-office__address {
font-family: var(--tt-serif);
font-style: italic;
font-size: var(--fs-xl);
color: var(--tt-granate);
} .tt-contact {
padding: var(--space-8) 0;
background: var(--tt-cream-2);
display: flex;
justify-content: center;
}
.tt-contact-card {
max-width: 720px;
width: 100%;
padding: clamp(40px, 6vw, 72px);
background: var(--tt-cream);
border: 1px solid var(--tt-border);
position: relative;
}
.tt-contact-card::before {
content: "";
position: absolute;
left: 0; top: 0;
width: 56px; height: 1px;
background: var(--tt-mustard);
}
.tt-contact-card h1 {
font-size: clamp(40px, 5vw, 64px);
font-weight: 300;
margin-bottom: var(--space-3);
}
.tt-contact-card h1 em { font-style: italic; color: var(--tt-granate); }
.tt-contact-card__lede {
font-size: var(--fs-lg);
color: var(--tt-muted);
max-width: 50ch;
margin-bottom: var(--space-6);
}
.tt-contact-card__rule {
border: 0;
border-top: 1px solid var(--tt-border);
margin: 0 0 var(--space-5);
}
.tt-contact-card__rows {
display: grid;
gap: var(--space-4);
margin-bottom: var(--space-6);
}
.tt-contact-row {
display: grid;
grid-template-columns: 110px 1fr;
gap: var(--space-4);
align-items: baseline;
}
.tt-contact-row__label {
font-size: var(--fs-xs);
letter-spacing: 0.18em;
text-transform: uppercase;
color: var(--tt-muted);
font-weight: 500;
}
.tt-contact-row__value {
font-family: var(--tt-serif);
font-size: var(--fs-lg);
color: var(--tt-ink);
}
.tt-contact-row__value a { color: inherit; border-bottom: 1px solid var(--tt-border); padding-bottom: 2px; }
.tt-contact-row__value a:hover { border-bottom-color: var(--tt-granate); }
.tt-contact-card__cta { margin-top: var(--space-3); display: flex; flex-wrap: wrap; gap: var(--space-3); }
.tt-contact-card__social {
margin-top: var(--space-5);
padding-top: var(--space-5);
border-top: 1px solid var(--tt-border);
display: flex; gap: var(--space-4);
color: var(--tt-muted);
}
.tt-contact-card__social a:hover { color: var(--tt-granate); }
.tt-contact-card__social svg { width: 20px; height: 20px; stroke: currentColor; stroke-width: 1.4; fill: none; } .tt-footer {
background: var(--tt-granate);
color: var(--tt-on-granate);
padding: var(--space-6) 0 var(--space-3);
position: relative;
}
.tt-footer::before {
content: "";
position: absolute;
top: 0; left: 0; right: 0;
height: 1px;
background: var(--tt-mustard);
}
.tt-footer__grid {
display: grid;
grid-template-columns: 1.4fr 1fr 1fr;
gap: var(--space-6);
padding-bottom: var(--space-6);
border-bottom: 1px solid var(--tt-granate-soft);
}
.tt-footer__brand .tt-logo { color: var(--tt-on-granate); }
.tt-footer__brand .tt-logo svg { width: 56px; height: 56px; }
.tt-footer__brand .tt-logo__word { font-size: 24px; }
.tt-footer__brand p {
color: var(--tt-on-granate-mut);
margin-top: var(--space-4);
max-width: 36ch;
font-size: var(--fs-sm);
line-height: 1.6;
}
.tt-footer h4 {
font-size: var(--fs-xs);
letter-spacing: 0.18em;
text-transform: uppercase;
font-family: var(--tt-sans);
font-weight: 500;
color: var(--tt-mustard);
margin-bottom: var(--space-3);
}
.tt-footer__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.tt-footer__list a, .tt-footer__list span {
color: var(--tt-on-granate);
font-size: var(--fs-sm);
transition: color var(--dur-1) var(--ease-out);
}
.tt-footer__list a:hover { color: var(--tt-yellow); }
.tt-footer__address {
font-size: var(--fs-sm);
color: var(--tt-on-granate-mut);
font-style: normal;
line-height: 1.6;
margin-top: var(--space-2);
}
.tt-footer__social { display: flex; gap: var(--space-3); margin-top: var(--space-3); }
.tt-footer__social a {
width: 36px; height: 36px;
border: 1px solid var(--tt-granate-soft);
border-radius: 50%;
display: inline-flex;
align-items: center;
justify-content: center;
color: var(--tt-on-granate);
transition: border-color var(--dur-1) var(--ease-out), color var(--dur-1) var(--ease-out), background var(--dur-1) var(--ease-out);
}
.tt-footer__social a:hover { border-color: var(--tt-yellow); color: var(--tt-granate); background: var(--tt-yellow); }
.tt-footer__social svg { width: 16px; height: 16px; stroke: currentColor; stroke-width: 1.4; fill: none; }
.tt-footer__base {
display: flex;
justify-content: space-between;
align-items: center;
padding-top: var(--space-4);
font-size: var(--fs-xs);
color: var(--tt-on-granate-mut);
gap: var(--space-3);
flex-wrap: wrap;
}
.tt-footer__legal { display: flex; gap: var(--space-4); flex-wrap: wrap; }
.tt-footer__legal a:hover { color: var(--tt-yellow); } .tt-fab {
position: fixed;
right: 16px;
bottom: 16px;
z-index: 80;
width: 56px; height: 56px;
border-radius: 50%;
background: var(--tt-granate);
color: var(--tt-yellow);
display: none;
align-items: center; justify-content: center;
box-shadow: 0 12px 28px -8px oklch(20% 0.05 12 / 0.45);
transition: transform var(--dur-2) var(--ease-out);
}
.tt-fab:hover { transform: translateY(-2px); }
.tt-fab svg { width: 24px; height: 24px; } .tt-reveal {
opacity: 0;
transform: translateY(16px);
transition: opacity var(--dur-3) var(--ease-out), transform var(--dur-3) var(--ease-out);
}
.tt-reveal.is-visible { opacity: 1; transform: translateY(0); }  @media (max-width: 1024px) {
.tt-offers { grid-template-columns: repeat(2, 1fr); }
.tt-pillar { grid-template-columns: 3rem 1fr; gap: 0 var(--space-4); }
.tt-process__steps { grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
.tt-process__steps::before { display: none; }
.tt-values { grid-template-columns: 1fr; }
.tt-value { padding: var(--space-5) 0; }
.tt-trust__sep { display: none; }
.tt-trust__inner { gap: var(--space-4); flex-direction: column; align-items: flex-start; }
.tt-drenched__inner { grid-template-columns: 1fr; }
.tt-contact-grid { grid-template-columns: 1fr; gap: var(--space-6); }
.tt-about-preview, .tt-manifesto__inner, .tt-office { grid-template-columns: 1fr; gap: var(--space-5); }
.tt-offer-detail { grid-template-columns: 1fr; }
.tt-apply-aside { position: static; }
.tt-footer__grid { grid-template-columns: 1fr 1fr; }
} @media (max-width: 768px) {
html { scroll-padding-top: 64px; }
body { font-size: 16px; } .tt-container, .tt-container--narrow { padding: 0 20px; width: 100%; } .tt-section, .tt-section--cream, .tt-section--granate, .tt-section--tight { padding: clamp(48px, 10vw, 72px) 0; } .tt-header__inner { padding: 12px 0; gap: var(--space-3); }
.tt-logo img { height: 28px !important; }
.tt-nav, .tt-header__cta .tt-btn:not(.tt-burger) { display: none; }
.tt-burger { display: flex; flex-direction: column; align-items: center; justify-content: center; } .tt-hero { padding: clamp(48px, 10vw, 80px) 0 clamp(56px, 10vw, 96px); }
.tt-hero h1 { max-width: 100%; font-size: clamp(32px, 8.5vw, 48px); }
.tt-hero__lede { font-size: var(--fs-base); max-width: 100%; }
.tt-hero__cta { flex-direction: column; align-items: stretch; }
.tt-hero__cta .tt-btn { width: 100%; justify-content: center; }
.tt-hero__rings--lg { right: -45%; top: -10%; width: 80vw; }
.tt-hero__rings--sm { right: -30%; top: 8%; width: 55vw; } .tt-trust { padding: var(--space-5) 0; }
.tt-trust__inner { flex-direction: column; align-items: flex-start; gap: var(--space-3); width: 100%; }
.tt-trust__num { font-size: clamp(36px, 11vw, 48px); }
.tt-trust__item { gap: var(--space-3); align-items: center; }
.tt-trust__label { max-width: none; } .tt-pillars { width: 100%; }
.tt-pillar { grid-template-columns: 1fr; gap: var(--space-2); padding: var(--space-5) 0; }
.tt-pillar__num { font-size: 40px; }
.tt-pillar p { max-width: 100%; } .tt-process__steps { grid-template-columns: 1fr; gap: var(--space-4); }
.tt-step { padding: 0; }
.tt-step__circle { width: 56px; height: 56px; font-size: var(--fs-base); }
.tt-step h3, .tt-step p { max-width: 100%; } .tt-drenched { padding: clamp(48px, 10vw, 80px) 0; }
.tt-drenched__inner { gap: var(--space-4); grid-template-columns: 1fr; }
.tt-drenched .tt-btn { width: 100%; justify-content: center; }
.tt-drenched p { max-width: 100%; }
.tt-drenched::before { right: -55%; bottom: -25%; width: 80vw; }
.tt-drenched::after { right: -25%; bottom: -8%; width: 50vw; } .tt-offers { grid-template-columns: 1fr; gap: var(--space-3); padding: var(--space-5) 0; }
.tt-offer { padding: var(--space-4); gap: var(--space-2); width: 100%; }
.tt-offer h3 { font-size: var(--fs-lg); line-height: 1.2; }
.tt-offer__meta, .tt-offer__desc { font-size: var(--fs-xs); } .tt-filters {
gap: 6px;
padding: var(--space-4) 0;
overflow-x: auto;
overflow-y: hidden;
flex-wrap: nowrap;
-webkit-overflow-scrolling: touch;
scrollbar-width: none;
margin: 0 -20px;
padding-left: 20px;
padding-right: 20px;
}
.tt-filters::-webkit-scrollbar { display: none; }
.tt-filter { white-space: nowrap; flex-shrink: 0; } .tt-manifesto__inner { padding-top: var(--space-5); }
.tt-manifesto__body { font-size: var(--fs-base); }
.tt-manifesto__body p { max-width: 100%; }
.tt-about-hero h2 { font-size: clamp(28px, 8vw, 40px); }
.tt-values { gap: 0; }
.tt-value { padding: var(--space-4) 0; } .tt-office__address { font-size: var(--fs-lg); }
.tt-office .tt-btn { width: auto; } #contacto.tt-section--granate { padding: clamp(48px, 10vw, 80px) 0 clamp(20px, 4vw, 40px); }
.tt-contact-grid { gap: var(--space-5); grid-template-columns: 1fr; }
.tt-contact-grid__info p, .tt-contact-form-card { max-width: 100%; }
.tt-form { width: 100%; }
.tt-form__row { grid-template-columns: 1fr; gap: var(--space-3); }
.tt-form__input, .tt-form__textarea { width: 100%; max-width: 100%; }
.tt-form__check { font-size: 11px; }
.tt-contact-row { grid-template-columns: 1fr; gap: 4px; }
.tt-contact-row__value { font-size: var(--fs-base); }
.tt-team__avatar { width: 44px; height: 44px; font-size: 14px; }
.tt-contact-form-card { padding: var(--space-4); }
.tt-contact-grid__direct a { flex-wrap: wrap; } .tt-marquee { padding: var(--space-5) 0; }
.tt-marquee__track { gap: 48px; animation-duration: 35s; }
.tt-marquee__item { height: 44px; padding: 0 4px; }
.tt-marquee__item img { max-width: 140px; } .tt-footer { padding: var(--space-5) 0 var(--space-3); }
.tt-footer__grid {
grid-template-columns: 1fr;
gap: var(--space-5);
padding-bottom: var(--space-5);
text-align: center;
}
.tt-footer__brand p { max-width: 100%; }
.tt-footer__list { align-items: center; }
.tt-footer__list a, .tt-footer__list span { font-size: var(--fs-xs); }
.tt-footer__address { text-align: center; }
.tt-footer__social { justify-content: center; }
.tt-footer__base {
flex-direction: column;
align-items: center;
text-align: center;
gap: var(--space-2);
font-size: 11px;
}
.tt-footer__legal { justify-content: center; flex-wrap: wrap; gap: var(--space-3); }
.tt-logo--badge { width: 128px; height: 128px; padding: 22px; } .tt-cta-banner { padding: clamp(56px, 10vw, 96px) var(--space-3); }
.tt-cta-banner h2 { font-size: clamp(28px, 8vw, 40px); max-width: 100%; }
.tt-cta-banner p { max-width: 100%; } .tt-fab {
display: inline-flex;
right: 16px;
bottom: 16px;
width: 52px;
height: 52px;
}
.tt-fab svg { width: 22px; height: 22px; } .tt-offer-detail { gap: var(--space-5); }
.tt-apply-aside { padding: var(--space-4); } .tt-eyebrow { font-size: 11px; }
} @media (max-width: 480px) {
.tt-container, .tt-container--narrow { padding: 0 16px; }
.tt-hero h1 { font-size: clamp(28px, 9vw, 40px); }
.tt-hero__lede { font-size: var(--fs-sm); }
.tt-trust { padding: var(--space-4) 0; }
.tt-trust__num { font-size: 32px; }
.tt-trust__label { font-size: var(--fs-xs); }
.tt-pillar__num { font-size: 32px; }
.tt-pillar h3 { font-size: var(--fs-lg); }
.tt-marquee__track { gap: 36px; }
.tt-marquee__item { height: 38px; }
.tt-marquee__item img { max-width: 120px; }
.tt-step__circle { width: 48px; height: 48px; }
.tt-drenched .tt-eyebrow { font-size: 10px; }
.tt-contact-form-card { padding: 18px; }
.tt-form__input, .tt-form__textarea { padding: 10px 12px; font-size: var(--fs-sm); }
.tt-team__avatar { width: 40px; height: 40px; font-size: 13px; }
.tt-logo--badge { width: 112px; height: 112px; padding: 18px; }
.tt-cta-banner h2 { font-size: clamp(24px, 8vw, 36px); }
.tt-filters { margin: 0 -16px; padding-left: 16px; padding-right: 16px; } .tt-cta-banner { padding: clamp(48px, 10vw, 72px) var(--space-3); }
} @media (prefers-reduced-motion: reduce) {
*, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
.tt-marquee__track { animation: none !important; }
.tt-reveal { opacity: 1; transform: none; }
}#cookie-notice{position:fixed;min-width:100%;height:auto;z-index:100000;font-size:13px;letter-spacing:0;line-height:20px;left:0;text-align:center;font-weight:400;font-family:-apple-system,BlinkMacSystemFont,Arial,Roboto,"Helvetica Neue",sans-serif}#cookie-notice,#cookie-notice *{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}#cookie-notice.cn-animated{-webkit-animation-duration:0.5s!important;animation-duration:0.5s!important;-webkit-animation-fill-mode:both;animation-fill-mode:both}#cookie-notice.cn-animated.cn-effect-none{-webkit-animation-duration:0.001s!important;animation-duration:0.001s!important}#cookie-notice .cookie-notice-container{display:block}#cookie-notice.cookie-notice-hidden .cookie-notice-container{display:none}#cookie-notice .cookie-revoke-container{display:block}#cookie-notice.cookie-revoke-hidden .cookie-revoke-container{display:none}.cn-position-top{top:0}.cn-position-bottom{bottom:0}.cookie-notice-container{padding:15px 30px;text-align:center;width:100%;z-index:2}.cookie-revoke-container{padding:15px 30px;width:100%;z-index:1}.cn-close-icon{position:absolute;right:15px;top:50%;margin-top:-10px;width:15px;height:15px;opacity:.5;padding:10px;outline:none;cursor:pointer}.cn-close-icon:hover{opacity:1}.cn-close-icon:before,.cn-close-icon:after{position:absolute;content:' ';height:15px;width:2px;top:3px;background-color:rgba(128,128,128,1)}.cn-close-icon:before{transform:rotate(45deg)}.cn-close-icon:after{transform:rotate(-45deg)}#cookie-notice .cn-revoke-cookie{margin:0}#cookie-notice .cn-button{margin:0 0 0 10px;display:inline-block}#cookie-notice .cn-button:not(.cn-button-custom){font-family:-apple-system,BlinkMacSystemFont,Arial,Roboto,"Helvetica Neue",sans-serif;font-weight:400;font-size:13px;letter-spacing:.25px;line-height:20px;margin:0 0 0 10px;text-align:center;text-transform:none;display:inline-block;cursor:pointer;touch-action:manipulation;white-space:nowrap;outline:none;box-shadow:none;text-shadow:none;border:none;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;text-decoration:none;padding:8.5px 10px;line-height:1;color:inherit}.cn-text-container{margin:0 0 6px 0}.cn-text-container,.cn-buttons-container{display:inline-block}#cookie-notice.cookie-notice-visible.cn-effect-none,#cookie-notice.cookie-revoke-visible.cn-effect-none{-webkit-animation-name:fadeIn;animation-name:fadeIn}#cookie-notice.cn-effect-none{-webkit-animation-name:fadeOut;animation-name:fadeOut}#cookie-notice.cookie-notice-visible.cn-effect-fade,#cookie-notice.cookie-revoke-visible.cn-effect-fade{-webkit-animation-name:fadeIn;animation-name:fadeIn}#cookie-notice.cn-effect-fade{-webkit-animation-name:fadeOut;animation-name:fadeOut}#cookie-notice.cookie-notice-visible.cn-effect-slide,#cookie-notice.cookie-revoke-visible.cn-effect-slide{-webkit-animation-name:slideInUp;animation-name:slideInUp}#cookie-notice.cn-effect-slide{-webkit-animation-name:slideOutDown;animation-name:slideOutDown}#cookie-notice.cookie-notice-visible.cn-position-top.cn-effect-slide,#cookie-notice.cookie-revoke-visible.cn-position-top.cn-effect-slide{-webkit-animation-name:slideInDown;animation-name:slideInDown}#cookie-notice.cn-position-top.cn-effect-slide{-webkit-animation-name:slideOutUp;animation-name:slideOutUp}@-webkit-keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@-webkit-keyframes fadeOut{from{opacity:1}to{opacity:0}}@keyframes fadeOut{from{opacity:1}to{opacity:0}}@-webkit-keyframes slideInUp{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0);visibility:visible}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}@keyframes slideInUp{from{-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0);visibility:visible}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}@-webkit-keyframes slideOutDown{from{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{visibility:hidden;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@keyframes slideOutDown{from{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{visibility:hidden;-webkit-transform:translate3d(0,100%,0);transform:translate3d(0,100%,0)}}@-webkit-keyframes slideInDown{from{-webkit-transform:translate3d(0,-100%,0);transform:translate3d(0,-100%,0);visibility:visible}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}@keyframes slideInDown{from{-webkit-transform:translate3d(0,-100%,0);transform:translate3d(0,-100%,0);visibility:visible}to{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}}@-webkit-keyframes slideOutUp{from{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{visibility:hidden;-webkit-transform:translate3d(0,-100%,0);transform:translate3d(0,-100%,0)}}@keyframes slideOutUp{from{-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}to{visibility:hidden;-webkit-transform:translate3d(0,-100%,0);transform:translate3d(0,-100%,0)}}@media all and (max-width:900px){.cookie-notice-container #cn-notice-text{display:block}.cookie-notice-container #cn-notice-buttons{display:block}#cookie-notice .cn-button{margin:0 5px 5px 5px}}@media all and (max-width:480px){.cookie-notice-container,.cookie-revoke-container{padding:15px 25px}}