1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
|
@use "@styles/abstracts/functions" as fun;
@use "@styles/abstracts/mixins" as mix;
.wrapper {
--logo-size: clamp(#{fun.convert-px(68)}, 18vw, #{fun.convert-px(100)});
display: grid;
grid-template-columns:
var(--logo-size)
minmax(0, 1fr);
grid-template-rows: repeat(2, max-content);
align-items: center;
column-gap: var(--spacing-sm);
padding: var(--spacing-sm) 0;
text-shadow: fun.convert-px(2) fun.convert-px(2) 0 var(--color-fg-inverted);
}
.logo {
--branding-logo-animation: none;
grid-column: 1;
grid-row: 1 / -1;
justify-self: center;
display: flex;
place-content: center;
width: var(--logo-size);
height: var(--logo-size);
position: relative;
border-radius: 50%;
transition: all 0.6s linear 0s;
transform-style: preserve-3d;
animation: var(--branding-logo-animation);
&__front,
&__back {
width: 100%;
height: 100%;
padding: clamp(fun.convert-px(2), 0.8vw, fun.convert-px(5));
position: absolute;
top: 0;
left: 0;
backface-visibility: hidden;
background: var(--color-bg);
border: fun.convert-px(2) solid var(--color-primary-dark);
border-radius: 50%;
transition: all 0.6s linear 0s;
}
&__front {
box-shadow: fun.convert-px(1) fun.convert-px(2) fun.convert-px(1) 0
var(--color-shadow-light),
fun.convert-px(2) fun.convert-px(3) fun.convert-px(3) 0
var(--color-shadow-light);
}
&__back {
transform: rotateY(180deg);
}
img,
svg {
border-radius: 50%;
}
&:hover {
transform: rotateY(180deg);
}
&:hover & {
&__front {
box-shadow: none;
}
&__back {
box-shadow: fun.convert-px(1) fun.convert-px(2) fun.convert-px(1) 0
var(--color-shadow-light),
fun.convert-px(2) fun.convert-px(3) fun.convert-px(3) 0
var(--color-shadow-light);
}
}
}
.name {
--branding-name-animation: none;
grid-column: 2;
grid-row: 1;
margin: 0;
font-family: var(--font-family-secondary);
font-size: clamp(var(--font-size-xl), 6vw, var(--font-size-2xl));
font-weight: 500;
letter-spacing: 0.01ex;
position: relative;
&::after {
content: "|";
display: block;
width: 100%;
height: 100%;
position: absolute;
top: 0;
right: 0;
background: var(--color-bg);
color: var(--color-primary-darker);
font-weight: 400;
visibility: hidden;
transform: scaleX(0) translateX(100%);
transform-origin: right;
animation: var(--branding-name-animation);
}
}
.job {
--branding-job-animation: none;
grid-column: 2;
grid-row: 2;
width: max-content;
margin: 0;
color: var(--color-fg-light);
font-family: var(--font-family-secondary);
font-size: var(--font-size-lg);
font-weight: 500;
position: relative;
&::after {
content: "|";
display: block;
width: 100%;
height: 100%;
position: absolute;
top: 0;
right: 0;
background: var(--color-bg);
color: var(--color-primary-darker);
font-weight: 400;
visibility: hidden;
transform: scaleX(0) translateX(100%);
transform-origin: right;
animation: var(--branding-job-animation);
}
}
.link {
background: linear-gradient(
to top,
var(--color-primary-light) fun.convert-px(5),
transparent fun.convert-px(5)
)
left / 0 100% no-repeat;
text-decoration: none;
transition: all 0.6s ease-out 0s;
&:hover,
&:focus {
background-size: 100% 100%;
}
&:focus {
color: var(--color-primary-light);
}
&:active {
background-size: 0 100%;
color: var(--color-primary-dark);
}
}
|