| ... |
... |
@@ -124,56 +124,72 @@ |
| 124 |
124 |
.widgets { |
| 125 |
125 |
margin-top: 12px; |
| 126 |
126 |
|
| 127 |
|
- /* optional: tighten columns a bit on small screens */ |
| 128 |
|
- .col-sm-6 { |
| 129 |
|
- margin-bottom: 16px; |
| 130 |
|
- } |
| 131 |
|
- } |
| 132 |
|
- |
| 133 |
|
- .widget { |
| 134 |
|
- background: #fff; |
| 135 |
|
- border: 1px solid @line; |
| 136 |
|
- border-radius: @radius; |
| 137 |
|
- padding: 18px; |
| 138 |
|
- box-shadow: @shadow-sm; |
|
127 |
+ /* Flexbox makes Bootstrap columns equal height */ |
| 139 |
139 |
display: flex; |
| 140 |
|
- flex-direction: column; |
| 141 |
|
- justify-content: flex-start; |
| 142 |
|
- gap: 8px; |
| 143 |
|
- text-align: left; |
| 144 |
|
- transition: transform 0.18s ease, box-shadow 0.18s ease; |
|
129 |
+ flex-wrap: wrap; |
| 145 |
145 |
|
| 146 |
|
- &:hover { |
| 147 |
|
- transform: translateY(-2px); |
| 148 |
|
- box-shadow: @shadow; |
| 149 |
|
- } |
|
131 |
+ /* Remove default Bootstrap left/right gutters |
|
132 |
+ so cards align with the section heading */ |
|
133 |
+ margin-left: -15px; |
|
134 |
+ margin-right: -15px; |
| 150 |
150 |
|
| 151 |
|
- .icon { |
|
136 |
+ /* Cards (inside columns) */ |
|
137 |
+ .widget { |
|
138 |
+ /* Bootstrap grid classes remain active (col-sm-6 col-md-3) */ |
| 152 |
152 |
display: flex; |
| 153 |
|
- align-items: center; |
| 154 |
|
- gap: 10px; |
| 155 |
|
- padding: 6px 0; |
| 156 |
|
- border-bottom: 1px solid fade(@line, 60%); |
| 157 |
|
- margin-bottom: 6px; |
|
140 |
+ flex-direction: column; |
|
141 |
+ height: 100%; |
| 158 |
158 |
|
| 159 |
|
- i { |
| 160 |
|
- color: @brand; |
|
143 |
+ /* Card styling */ |
|
144 |
+ padding: 18px; |
|
145 |
+ background: #fff; |
|
146 |
+ border: 1px solid @line; |
|
147 |
+ border-radius: @radius; |
|
148 |
+ box-shadow: @shadow-sm; |
|
149 |
+ transition: transform .18s ease, box-shadow .18s ease; |
|
150 |
+ |
|
151 |
+ &:hover { |
|
152 |
+ transform: translateY(-2px); |
|
153 |
+ box-shadow: @shadow; |
| 161 |
161 |
} |
| 162 |
162 |
|
| 163 |
|
- h4 { |
|
156 |
+ /* Icon row */ |
|
157 |
+ .icon { |
|
158 |
+ display: flex; |
|
159 |
+ align-items: center; |
|
160 |
+ gap: 10px; |
|
161 |
+ padding-bottom: 6px; |
|
162 |
+ margin-bottom: 8px; |
|
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 |
+ } |
|
174 |
+ } |
|
175 |
+ |
|
176 |
+ /* Card text */ |
|
177 |
+ p { |
| 164 |
164 |
margin: 0; |
| 165 |
|
- color: @text; |
| 166 |
|
- line-height: 1.2; |
|
179 |
+ line-height: 1.45; |
|
180 |
+ color: @muted; |
| 167 |
167 |
} |
| 168 |
168 |
} |
| 169 |
169 |
|
| 170 |
|
- p { |
| 171 |
|
- color: @muted; |
| 172 |
|
- margin: 0; |
| 173 |
|
- line-height: 1.45; |
|
184 |
+ /* Mobile spacing */ |
|
185 |
+ @media (max-width: 767px) { |
|
186 |
+ .widget { |
|
187 |
+ margin-bottom: 16px; |
|
188 |
+ } |
| 174 |
174 |
} |
| 175 |
175 |
} |
| 176 |
176 |
|
|
192 |
+ |
| 177 |
177 |
/* SERVICES */ |
| 178 |
178 |
.services { |
| 179 |
179 |
h2 { |