/* Trailer Catalogue — Elementor widget defaults.
   Sensible baseline styles so the widgets read correctly before any Elementor
   styling is applied. Everything here is overridable from the Elementor panel. */

/* Gallery */
.ds-tw-gallery { display: flex; flex-direction: column; gap: 10px; }
.ds-tw-gallery__main img { display: block; width: 100%; height: auto; }
.ds-tw-gallery__thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.ds-tw-gallery__thumb { display: block; line-height: 0; }
.ds-tw-gallery__thumb img { display: block; width: 100%; height: 78px; object-fit: cover; transition: box-shadow .15s ease; }

/* Price */
.ds-tw-price__row { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.ds-tw-price__amount { font-family: "Barlow Condensed", "Arial Narrow", sans-serif; font-size: 42px; font-weight: 700; line-height: 1; color: #2a2e33; }
.ds-tw-price__finance { font-size: 14px; color: #5d656c; }
.ds-tw-price__disclaimer { margin: 6px 0 0; font-size: 13px; color: #5d656c; }

/* Specs */
.ds-tw-specs__heading,
.ds-tw-features__heading,
.ds-tw-options__heading { font-family: "Barlow Condensed", "Arial Narrow", sans-serif; font-weight: 700; margin: 0 0 12px; }
.ds-tw-specs { border: 1px solid #d9dee2; border-radius: 8px; overflow: hidden; }
.ds-tw-specs__row { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 10px 16px; font-size: 14.5px; }
.ds-tw-specs__row + .ds-tw-specs__row { border-top: 1px solid #d9dee2; }
.ds-tw-specs__k { color: #5d656c; }
.ds-tw-specs__v { color: #2a2e33; font-weight: 600; text-align: right; }

/* Features */
.ds-tw-features { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(2, 1fr); row-gap: 8px; column-gap: 18px; }
.ds-tw-features__item { position: relative; padding-left: 24px; color: inherit; }
.ds-tw-features__item::before { content: "\2713"; position: absolute; left: 0; top: 0; color: #80b040; font-weight: 700; }

/* Options */
.ds-tw-options { border: 0; }
.ds-tw-options__row { display: flex; justify-content: space-between; align-items: flex-start; gap: 18px; padding: 12px 0; }
.ds-tw-options__row + .ds-tw-options__row { border-top: 1px solid #d9dee2; }
.ds-tw-options__main { display: flex; flex-direction: column; gap: 2px; }
.ds-tw-options__name { font-weight: 600; color: #2a2e33; }
.ds-tw-options__desc { font-size: 13.5px; color: #5d656c; }
.ds-tw-options__price { white-space: nowrap; font-weight: 700; color: #6a9831; }

/* Enquire buttons */
.ds-tw-enquire { display: flex; gap: 12px; flex-wrap: wrap; }
.ds-tw-enquire__btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-weight: 600; padding: 14px 28px; border-radius: 6px; border: 2px solid transparent; text-decoration: none; cursor: pointer; }
.ds-tw-enquire__primary { flex: 1 1 auto; background-color: #80b040; border-color: #80b040; color: #fff; }
.ds-tw-enquire__call { background: transparent; border-color: #1d2125; color: #1d2125; }

/* Generic field */
.ds-tw-field { margin: 0; }
.ds-tw-field--description p { margin: 0 0 1em; }
.ds-tw-field--tagline { color: #5d656c; }

/* Editor-only hint (never shown on the live site) */
.ds-tw-hint { padding: 10px 14px; border: 1px dashed #aeb6bc; border-radius: 6px; color: #6b7480; font-size: 13px; background: repeating-linear-gradient(45deg, #f3f5f6 0 14px, #eef1f2 14px 28px); }
