/* ================================================================
   CloudST Directory — Frontend Styles
   Uses Elementor CSS variables with fallbacks for font & colour.
   ================================================================ */

:root {
  --cstd-primary:       var(--e-global-color-accent,    #0ea5e9);
  --cstd-text:          var(--e-global-color-text,       #1f2937);
  --cstd-heading-font:  var(--e-global-typography-primary-font-family, inherit);
  --cstd-body-font:     var(--e-global-typography-text-font-family,    inherit);
  --cstd-muted:         #6b7280;
  --cstd-border:        #e5e7eb;
  --cstd-surface:       #ffffff;
  --cstd-bg:            #f8fafc;
  --cstd-radius:        12px;
  --cstd-radius-sm:     8px;
  --cstd-shadow:        0 1px 3px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.04);
  --cstd-shadow-hover:  0 4px 14px rgba(0,0,0,.10);
  --cstd-star-on:       #f59e0b;
  --cstd-star-off:      #d1d5db;
  --cstd-transition:    .18s ease;
}

/* ── Grid ─────────────────────────────────────────────── */
.cstd-grid {
  display: grid;
  gap: 20px;
  margin: 0 0 32px;
  font-family: var(--cstd-body-font);
}
.cstd-cols-4 { grid-template-columns: repeat(4,1fr); }
.cstd-cols-3 { grid-template-columns: repeat(3,1fr); }
.cstd-cols-2 { grid-template-columns: repeat(2,1fr); }
.cstd-cols-1 { grid-template-columns: 1fr; }
@media (max-width:1200px) { .cstd-cols-4 { grid-template-columns: repeat(3,1fr); } }
@media (max-width:900px)  { .cstd-cols-4, .cstd-cols-3 { grid-template-columns: repeat(2,1fr); } }
@media (max-width:600px)  { .cstd-cols-4, .cstd-cols-3, .cstd-cols-2 { grid-template-columns: 1fr; } }

/* ── Card ─────────────────────────────────────────────── */
.cstd-card {
  background: var(--cstd-surface);
  border: 1px solid var(--cstd-border);
  border-radius: var(--cstd-radius);
  box-shadow: var(--cstd-shadow);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: box-shadow var(--cstd-transition), transform var(--cstd-transition);
}
.cstd-card:hover { box-shadow: var(--cstd-shadow-hover); transform: translateY(-2px); }

.cstd-card__rating { display: flex; align-items: center; gap: 6px; }
.cstd-card__body   { flex: 1; display: flex; flex-direction: column; gap: 6px; }

.cstd-card__title {
  font-family: var(--cstd-heading-font);
  font-size: 16px; font-weight: 700;
  color: var(--cstd-text);
  margin: 4px 0 2px; line-height: 1.3;
}
.cstd-card__province {
  font-size: 11px; font-weight: 700; letter-spacing: .06em;
  color: var(--cstd-primary); text-transform: uppercase; margin: 0 0 4px;
}
.cstd-card__info {
  display: flex; align-items: flex-start; gap: 6px;
  font-size: 13px; color: var(--cstd-muted); margin: 0; line-height: 1.45;
}
.cstd-card__info a { color: var(--cstd-primary); text-decoration: none; }
.cstd-card__info a:hover { text-decoration: underline; }
.cstd-icon { width: 14px; height: 14px; flex-shrink: 0; margin-top: 2px; stroke: var(--cstd-muted); }

.cstd-card__footer {
  display: flex; gap: 10px;
  padding-top: 12px; border-top: 1px solid var(--cstd-border); margin-top: auto;
}

/* ── Stars ────────────────────────────────────────────── */
.cstd-stars { position: relative; display: inline-block; font-size: 17px; line-height: 1; letter-spacing: 2px; user-select: none; }
.cstd-stars__empty  { color: var(--cstd-star-off); }
.cstd-stars__filled { position: absolute; inset: 0; overflow: hidden; white-space: nowrap; color: var(--cstd-star-on); pointer-events: none; }
.cstd-review-count  { font-size: 12px; color: var(--cstd-muted); }

/* ── Buttons ──────────────────────────────────────────── */
.cstd-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 8px 16px; border-radius: var(--cstd-radius-sm);
  font-family: var(--cstd-body-font); font-size: 13px; font-weight: 500;
  line-height: 1; text-decoration: none; cursor: pointer;
  border: 1px solid transparent;
  transition: background var(--cstd-transition), color var(--cstd-transition), border-color var(--cstd-transition);
  flex: 1; text-align: center; white-space: nowrap;
}
.cstd-btn--primary { background: var(--cstd-primary); color: #fff; border-color: var(--cstd-primary); }
.cstd-btn--primary:hover { filter: brightness(.88); color: #fff; }
.cstd-btn--outline { background: var(--cstd-surface); color: var(--cstd-text); border-color: var(--cstd-border); }
.cstd-btn--outline:hover { background: var(--cstd-bg); }
.cstd-btn--lg { padding: 12px 28px; font-size: 15px; }

/* ── Search Form ──────────────────────────────────────── */
.cstd-search-form {
  background: var(--cstd-surface); border: 1px solid var(--cstd-border);
  border-radius: var(--cstd-radius); padding: 18px 20px; margin-bottom: 24px;
}
.cstd-search-form__fields { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.cstd-input, .cstd-select {
  padding: 10px 14px; border: 1px solid var(--cstd-border);
  border-radius: var(--cstd-radius-sm); font-family: var(--cstd-body-font);
  font-size: 14px; color: var(--cstd-text); background: var(--cstd-surface);
  outline: none; transition: border-color var(--cstd-transition), box-shadow var(--cstd-transition);
  box-sizing: border-box;
}
.cstd-input:focus, .cstd-select:focus {
  border-color: var(--cstd-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cstd-primary) 18%, transparent);
}
.cstd-select {
  cursor: pointer; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center; padding-right: 34px;
}
.cstd-input--search { flex: 2; min-width: 200px; }
.cstd-search-form .cstd-select { flex: 1; min-width: 160px; }
.cstd-search-form .cstd-btn { flex: 0 0 auto; }

/* ── No Results ───────────────────────────────────────── */
.cstd-no-results { grid-column: 1/-1; text-align: center; padding: 56px 20px; color: var(--cstd-muted); font-size: 15px; }
.cstd-no-results a { color: var(--cstd-primary); text-decoration: none; }
.cstd-no-results a:hover { text-decoration: underline; }

/* ── Pagination ───────────────────────────────────────── */
.cstd-pagination { display: flex; justify-content: center; align-items: center; gap: 6px; margin: 32px 0; flex-wrap: wrap; }
.cstd-pagination__item, .cstd-pagination__ellipsis {
  min-width: 36px; height: 36px; display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--cstd-border); border-radius: var(--cstd-radius-sm);
  font-size: 14px; text-decoration: none; color: var(--cstd-text); background: var(--cstd-surface);
  transition: all var(--cstd-transition); cursor: pointer; padding: 0 6px;
}
.cstd-pagination__ellipsis { border-color: transparent; background: transparent; color: var(--cstd-muted); }
.cstd-pagination__item:hover, .cstd-pagination__item--active { background: var(--cstd-primary); border-color: var(--cstd-primary); color: #fff; }

/* ── Submit Form ──────────────────────────────────────── */
.cstd-submit-form { max-width: 680px; font-family: var(--cstd-body-font); }
.cstd-form-section { margin-bottom: 8px; }
.cstd-form-section__title { font-family: var(--cstd-heading-font); font-size: 15px; font-weight: 700; color: var(--cstd-text); margin: 0 0 16px; padding-bottom: 8px; border-bottom: 1px solid var(--cstd-border); }
.cstd-form-group { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.cstd-form-group--full { grid-column: 1/-1; }
.cstd-form-group label { font-size: 14px; font-weight: 600; color: var(--cstd-text); }
.cstd-form-group .cstd-input, .cstd-form-group .cstd-select { width: 100%; }
.cstd-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width:600px) { .cstd-form-row { grid-template-columns: 1fr; } }
.cstd-required { color: #ef4444; }
.cstd-form-label-note { font-weight: 400; font-size: 12px; color: var(--cstd-muted); }
.cstd-divider { border: none; border-top: 1px solid var(--cstd-border); margin: 24px 0; }
.cstd-form-submit { margin-top: 8px; }
.cstd-success { background: #f0fdf4; border: 1px solid #86efac; border-radius: var(--cstd-radius); padding: 20px 24px; color: #166534; font-size: 15px; font-family: var(--cstd-body-font); }
