| ... |
... |
@@ -124,23 +124,23 @@ |
| 124 |
124 |
.widgets { |
| 125 |
125 |
margin-top: 12px; |
| 126 |
126 |
|
| 127 |
|
- /* Flexbox makes Bootstrap columns equal height */ |
|
127 |
+ /* Flex layout for equal-height and spacing */ |
| 128 |
128 |
display: flex; |
| 129 |
129 |
flex-wrap: wrap; |
|
130 |
+ justify-content: space-between; |
| 130 |
130 |
|
| 131 |
|
- /* Remove default Bootstrap left/right gutters |
| 132 |
|
- so cards align with the section heading */ |
| 133 |
|
- margin-left: -15px; |
| 134 |
|
- margin-right: -15px; |
| 135 |
|
- |
| 136 |
|
- /* Cards (inside columns) */ |
| 137 |
137 |
.widget { |
| 138 |
|
- /* Bootstrap grid classes remain active (col-sm-6 col-md-3) */ |
|
133 |
+ box-sizing: border-box; |
|
134 |
+ |
|
135 |
+ /* Desktop (md+) – 4 per row */ |
|
136 |
+ flex: 0 0 24%; |
|
137 |
+ max-width: 24%; |
|
138 |
+ margin-bottom: 16px; |
|
139 |
+ |
|
140 |
+ /* Card look */ |
| 139 |
139 |
display: flex; |
| 140 |
140 |
flex-direction: column; |
| 141 |
141 |
height: 100%; |
| 142 |
|
- |
| 143 |
|
- /* Card styling */ |
| 144 |
144 |
padding: 18px; |
| 145 |
145 |
background: #fff; |
| 146 |
146 |
border: 1px solid @line; |
| ... |
... |
@@ -153,7 +153,6 @@ |
| 153 |
153 |
box-shadow: @shadow; |
| 154 |
154 |
} |
| 155 |
155 |
|
| 156 |
|
- /* Icon row */ |
| 157 |
157 |
.icon { |
| 158 |
158 |
display: flex; |
| 159 |
159 |
align-items: center; |
| ... |
... |
@@ -161,35 +161,34 @@ |
| 161 |
161 |
padding-bottom: 6px; |
| 162 |
162 |
margin-bottom: 8px; |
| 163 |
163 |
border-bottom: 1px solid fade(@line, 60%); |
| 164 |
|
- |
| 165 |
|
- i { |
| 166 |
|
- color: @brand; |
| 167 |
|
- } |
| 168 |
|
- |
| 169 |
|
- h4 { |
| 170 |
|
- margin: 0; |
| 171 |
|
- line-height: 1.2; |
| 172 |
|
- color: @text; |
| 173 |
|
- } |
|
163 |
+ i { color: @brand; } |
|
164 |
+ h4 { margin: 0; line-height: 1.2; color: @text; } |
| 174 |
174 |
} |
| 175 |
175 |
|
| 176 |
|
- /* Card text */ |
| 177 |
177 |
p { |
| 178 |
178 |
margin: 0; |
| 179 |
|
- line-height: 1.45; |
| 180 |
180 |
color: @muted; |
|
170 |
+ line-height: 1.45; |
| 181 |
181 |
} |
| 182 |
182 |
} |
| 183 |
183 |
|
| 184 |
|
- /* Mobile spacing */ |
|
174 |
+ /* Tablet (sm–md) – 2 per row */ |
|
175 |
+ @media (max-width: 991px) { |
|
176 |
+ .widget { |
|
177 |
+ flex: 0 0 48%; |
|
178 |
+ max-width: 48%; |
|
179 |
+ } |
|
180 |
+ } |
|
181 |
+ |
|
182 |
+ /* Mobile (xs) – 1 per row */ |
| 185 |
185 |
@media (max-width: 767px) { |
| 186 |
186 |
.widget { |
| 187 |
|
- margin-bottom: 16px; |
|
185 |
+ flex: 0 0 100%; |
|
186 |
+ max-width: 100%; |
| 188 |
188 |
} |
| 189 |
189 |
} |
| 190 |
190 |
} |
| 191 |
191 |
|
| 192 |
|
- |
| 193 |
193 |
/* SERVICES */ |
| 194 |
194 |
.services { |
| 195 |
195 |
h2 { |