| ... |
... |
@@ -123,27 +123,30 @@ |
| 123 |
123 |
/* === WHY CHOOSE (widgets using Bootstrap grid) === */ |
| 124 |
124 |
.widgets { |
| 125 |
125 |
margin-top: 12px; |
| 126 |
|
- |
| 127 |
|
- /* Flex layout = equal-height columns */ |
| 128 |
128 |
display: flex; |
| 129 |
129 |
flex-wrap: wrap; |
| 130 |
130 |
|
| 131 |
|
- /* Cancel Bootstrap's outer gutters so cards align with heading */ |
| 132 |
|
- margin-left: -15px; |
| 133 |
|
- margin-right: -15px; |
| 134 |
|
- |
| 135 |
135 |
.widget { |
| 136 |
|
- /* Bootstrap grid classes (col-sm-6, col-md-3) still apply padding */ |
|
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 */ |
| 137 |
137 |
display: flex; |
| 138 |
138 |
flex-direction: column; |
| 139 |
139 |
height: 100%; |
| 140 |
|
- |
| 141 |
|
- /* Card design */ |
|
145 |
+ padding: 18px; |
| 142 |
142 |
background: #fff; |
| 143 |
143 |
border: 1px solid @line; |
| 144 |
144 |
border-radius: @radius; |
| 145 |
145 |
box-shadow: @shadow-sm; |
| 146 |
|
- padding: 18px; |
| 147 |
147 |
transition: transform .18s ease, box-shadow .18s ease; |
| 148 |
148 |
|
| 149 |
149 |
&:hover { |
| ... |
... |
@@ -159,13 +159,8 @@ |
| 159 |
159 |
margin-bottom: 8px; |
| 160 |
160 |
border-bottom: 1px solid fade(@line, 60%); |
| 161 |
161 |
|
| 162 |
|
- i { color: @brand; } |
| 163 |
|
- |
| 164 |
|
- h4 { |
| 165 |
|
- margin: 0; |
| 166 |
|
- line-height: 1.2; |
| 167 |
|
- color: @text; |
| 168 |
|
- } |
|
165 |
+ i { color: @brand; } |
|
166 |
+ h4 { margin: 0; line-height: 1.2; color: @text; } |
| 169 |
169 |
} |
| 170 |
170 |
|
| 171 |
171 |
p { |
| ... |
... |
@@ -173,12 +173,19 @@ |
| 173 |
173 |
color: @muted; |
| 174 |
174 |
line-height: 1.45; |
| 175 |
175 |
} |
| 176 |
|
- } |
| 177 |
177 |
|
| 178 |
|
- @media (max-width: 767px) { |
| 179 |
|
- .widget { |
| 180 |
|
- margin-bottom: 16px; /* spacing between stacked items */ |
|
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); |
| 181 |
181 |
} |
|
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 |
+ } |
| 182 |
182 |
} |
| 183 |
183 |
} |
| 184 |
184 |
|