| ... |
... |
@@ -123,59 +123,66 @@ |
| 123 |
123 |
/* === WHY CHOOSE (widgets using Bootstrap grid) === */ |
| 124 |
124 |
.widgets { |
| 125 |
125 |
margin-top: 12px; |
|
126 |
+ |
|
127 |
+ /* Flex layout = equal-height columns */ |
| 126 |
126 |
display: flex; |
| 127 |
127 |
flex-wrap: wrap; |
| 128 |
128 |
|
| 129 |
|
- /* optional: tighten columns a bit on small screens */ |
| 130 |
|
- .col-sm-6 { |
| 131 |
|
- margin-bottom: 16px; |
| 132 |
|
- } |
| 133 |
|
- } |
|
131 |
+ /* Cancel Bootstrap's outer gutters so cards align with heading */ |
|
132 |
+ margin-left: -15px; |
|
133 |
+ margin-right: -15px; |
| 134 |
134 |
|
| 135 |
|
- .widget { |
| 136 |
|
- background: #fff; |
| 137 |
|
- border: 1px solid @line; |
| 138 |
|
- border-radius: @radius; |
| 139 |
|
- padding: 18px; |
| 140 |
|
- box-shadow: @shadow-sm; |
| 141 |
|
- display: flex; |
| 142 |
|
- flex-direction: column; |
| 143 |
|
- justify-content: flex-start; |
| 144 |
|
- gap: 8px; |
| 145 |
|
- text-align: left; |
| 146 |
|
- transition: transform 0.18s ease, box-shadow 0.18s ease; |
|
135 |
+ .widget { |
|
136 |
+ /* Bootstrap grid classes (col-sm-6, col-md-3) still apply padding */ |
|
137 |
+ display: flex; |
|
138 |
+ flex-direction: column; |
|
139 |
+ height: 100%; |
| 147 |
147 |
|
| 148 |
|
- &:hover { |
| 149 |
|
- transform: translateY(-2px); |
| 150 |
|
- box-shadow: @shadow; |
| 151 |
|
- } |
|
141 |
+ /* Card design */ |
|
142 |
+ background: #fff; |
|
143 |
+ border: 1px solid @line; |
|
144 |
+ border-radius: @radius; |
|
145 |
+ box-shadow: @shadow-sm; |
|
146 |
+ padding: 18px; |
|
147 |
+ transition: transform .18s ease, box-shadow .18s ease; |
| 152 |
152 |
|
| 153 |
|
- .icon { |
| 154 |
|
- display: flex; |
| 155 |
|
- align-items: center; |
| 156 |
|
- gap: 10px; |
| 157 |
|
- padding: 6px 0; |
| 158 |
|
- border-bottom: 1px solid fade(@line, 60%); |
| 159 |
|
- margin-bottom: 6px; |
|
149 |
+ &:hover { |
|
150 |
+ transform: translateY(-2px); |
|
151 |
+ box-shadow: @shadow; |
|
152 |
+ } |
| 160 |
160 |
|
| 161 |
|
- i { |
| 162 |
|
- color: @brand; |
|
154 |
+ .icon { |
|
155 |
+ display: flex; |
|
156 |
+ align-items: center; |
|
157 |
+ gap: 10px; |
|
158 |
+ padding-bottom: 6px; |
|
159 |
+ margin-bottom: 8px; |
|
160 |
+ border-bottom: 1px solid fade(@line, 60%); |
|
161 |
+ |
|
162 |
+ i { color: @brand; } |
|
163 |
+ |
|
164 |
+ h4 { |
|
165 |
+ margin: 0; |
|
166 |
+ line-height: 1.2; |
|
167 |
+ color: @text; |
|
168 |
+ } |
| 163 |
163 |
} |
| 164 |
164 |
|
| 165 |
|
- h4 { |
|
171 |
+ p { |
| 166 |
166 |
margin: 0; |
| 167 |
|
- color: @text; |
| 168 |
|
- line-height: 1.2; |
|
173 |
+ color: @muted; |
|
174 |
+ line-height: 1.45; |
| 169 |
169 |
} |
| 170 |
170 |
} |
| 171 |
171 |
|
| 172 |
|
- p { |
| 173 |
|
- color: @muted; |
| 174 |
|
- margin: 0; |
| 175 |
|
- line-height: 1.45; |
|
178 |
+ @media (max-width: 767px) { |
|
179 |
+ .widget { |
|
180 |
+ margin-bottom: 16px; /* spacing between stacked items */ |
|
181 |
+ } |
| 176 |
176 |
} |
| 177 |
177 |
} |
| 178 |
178 |
|
|
185 |
+ |
| 179 |
179 |
/* SERVICES */ |
| 180 |
180 |
.services { |
| 181 |
181 |
h2 { |