| ... |
... |
@@ -123,24 +123,25 @@ |
| 123 |
123 |
/* === WHY CHOOSE (widgets using Bootstrap grid) === */ |
| 124 |
124 |
.widgets { |
| 125 |
125 |
margin-top: 12px; |
| 126 |
|
- |
| 127 |
|
- /* Flexbox makes Bootstrap columns equal height */ |
| 128 |
128 |
display: flex; |
| 129 |
129 |
flex-wrap: wrap; |
| 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) */ |
|
130 |
+ box-sizing: border-box; |
|
131 |
+ |
|
132 |
+ /* Desktop (md+): 4 per row, with 8px side gaps */ |
|
133 |
+ flex: 0 0 calc(25% - 16px); |
|
134 |
+ max-width: calc(25% - 16px); |
|
135 |
+ margin: 0 8px 16px; |
|
136 |
+ |
|
137 |
+ /* First: no left margin; last: no right margin */ |
|
138 |
+ &:first-child { margin-left: 0; } |
|
139 |
+ &:last-child { margin-right: 0; } |
|
140 |
+ |
|
141 |
+ /* Card styling */ |
| 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; |
| ... |
... |
@@ -162,30 +162,28 @@ |
| 162 |
162 |
margin-bottom: 8px; |
| 163 |
163 |
border-bottom: 1px solid fade(@line, 60%); |
| 164 |
164 |
|
| 165 |
|
- i { |
| 166 |
|
- color: @brand; |
| 167 |
|
- } |
| 168 |
|
- |
| 169 |
|
- h4 { |
| 170 |
|
- margin: 0; |
| 171 |
|
- line-height: 1.2; |
| 172 |
|
- color: @text; |
| 173 |
|
- } |
|
165 |
+ i { color: @brand; } |
|
166 |
+ 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; |
|
172 |
+ line-height: 1.45; |
| 181 |
181 |
} |
| 182 |
|
- } |
| 183 |
183 |
|
| 184 |
|
- /* Mobile spacing */ |
| 185 |
|
- @media (max-width: 767px) { |
| 186 |
|
- .widget { |
| 187 |
|
- margin-bottom: 16px; |
|
175 |
+ /* Tablet (sm–md): 2 per row, with gaps */ |
|
176 |
+ @media (max-width: 991px) { |
|
177 |
+ flex: 0 0 calc(50% - 16px); |
|
178 |
+ max-width: calc(50% - 16px); |
| 188 |
188 |
} |
|
180 |
+ |
|
181 |
+ /* Mobile (xs): full width stacked */ |
|
182 |
+ @media (max-width: 767px) { |
|
183 |
+ flex: 0 0 100%; |
|
184 |
+ max-width: 100%; |
|
185 |
+ margin: 0 0 16px 0; |
|
186 |
+ } |
| 189 |
189 |
} |
| 190 |
190 |
} |
| 191 |
191 |
|