/* ═══════════════════════════════════════════════════════════════
   MemberSignUp.css  —  HART Membership Enquiry UI
   Mirrors the HART Golf Booking design system
   ═══════════════════════════════════════════════════════════════ */

/* ─── Design Tokens ─────────────────────────────────────────────
   --ms-* variables fall back to the golf booking defaults when no
   hotel theme is configured. Override --ms-header-bg etc. inline
   via the Razor view with config values.
   ────────────────────────────────────────────────────────────── */
:root {
    --ms-primary:        var(--hart-primary,        #508A7B);
    --ms-primary-dk:     var(--hart-primary-active, #96B9B0);
    --ms-primary-lt:     var(--hart-primary-hover,  #73A195);
    --ms-primary-pale:   var(--hart-primary-subtle, #DCE8E5);
    --ms-cream:          var(--hart-primary-bg,     #EEF3F2);

    --ms-accent:         var(--hart-accent,         #C07830);

    --ms-bg:             var(--hart-bg,             #F7F7F7);
    --ms-white:          #FFFFFF;
    --ms-dark:           var(--hart-text-primary,   #484848);
    --ms-text:           var(--hart-text-primary,   #484848);
    --ms-muted:          var(--hart-text-secondary, #6D6D6D);
    --ms-border:         var(--hart-border,         #EBEBEB);

    --ms-shadow-sm:      0 1px 4px rgba(0,0,0,.06);
    --ms-shadow:         var(--hart-card-shadow,       0 6px 16px rgba(0,0,0,.12));
    --ms-shadow-hover:   var(--hart-card-shadow-hover, 0 6px 20px rgba(0,0,0,.20));

    /* Radii — pulled from DS */
    --ms-radius-sm:      var(--hart-btn-radius,    8px);
    --ms-radius:         var(--hart-card-radius,   12px);
    --ms-panel-radius:   var(--hart-paper-radius,  12px);

    /* Input tokens — pulled from DS */
    --ms-input-height:       var(--hart-input-height,        46px);
    --ms-input-radius:       var(--hart-input-radius,        8px);
    --ms-input-border:       var(--hart-input-border,        #808080);
    --ms-input-border-hover: var(--hart-input-border-hover,  #222222);
    --ms-input-border-focus: var(--hart-input-border-focus,  #222222);
    --ms-input-focus-width:  var(--hart-input-focus-width,   2px);

    /* Button tokens — pulled from DS */
    --ms-btn-radius:    var(--hart-btn-radius,     8px);
    --ms-btn-font-size: var(--hart-btn-font-size,  1rem);
    --ms-btn-weight:    var(--hart-btn-font-weight, 600);

    --ms-font-head:      var(--hart-font-heading, 'Josefin Sans', system-ui, sans-serif);
    --ms-font-body:      var(--hart-font-body,    'Open Sans', system-ui, sans-serif);

    /* Secondary palette */
    --ms-secondary:        var(--hart-secondary,        #7A9099);
    --ms-secondary-hover:  var(--hart-secondary-hover,  #8FAAB2);
    --ms-secondary-active: var(--hart-secondary-active, #6A8088);
    --ms-secondary-light:  var(--hart-secondary-light,  #B0C8CE);
    --ms-secondary-subtle: var(--hart-secondary-subtle, #D8E5E8);
    --ms-secondary-bg:     var(--hart-secondary-bg,     #EEF3F4);

    --ms-ease:             cubic-bezier(0.16, 1, 0.3, 1);

    /* Page background */
    --ms-page-bg:      var(--hart-bg);
    /* Subbar uses primary; footer bottom uses secondary — both from DS */
    --ms-subbar-bg:    var(--hart-primary);
    --ms-footer-bg:    var(--hart-secondary);
    --ms-panel-shadow: 0 12px 48px rgba(0,0,0,.22);
}

/* ─── Reset & Base ───────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
body { margin: 0; background-color: var(--ms-page-bg); }

/* ─── Page shell ─────────────────────────────────────────────── */
.ms-page {
    display:          flex;
    flex-direction:   column;
    min-height:       100dvh;
    font-family:      var(--ms-font-body);
    color:            var(--ms-text);
    background-color: var(--ms-page-bg);
}

/* ═══════════════════════════════════════════════════════════════
   HEADER  —  3-column: nav | brand | util
   ═══════════════════════════════════════════════════════════════ */
.ms-header {
    background: var(--ms-white);
    position:   sticky;
    top:        0;
    z-index:    200;
    box-shadow: var(--ms-shadow-sm);
}

.ms-header__inner {
    display:               grid;
    grid-template-columns: 1fr auto 1fr;
    align-items:           center;
    gap:                   16px;
    max-width:             1200px;
    margin:                0 auto;
    padding:               16px 32px;
}

.ms-header__nav { display: flex; align-items: center; }
.ms-header__nav a {
    font-size:       0.82rem;
    color:           var(--_text, var(--ms-muted));
    text-decoration: none;
    transition:      color 0.18s ease, opacity 0.18s ease;
}
.ms-header__nav a:hover { opacity: 0.7; }

.ms-header__brand  { text-align: center; }
.ms-header__logo {
    height:     52px;
    width:      auto;
    max-width:  220px;
    object-fit: contain;
    cursor:     pointer;
    display:    block;
    margin:     0 auto;
    transition: opacity 0.2s ease;
}
.ms-header__logo:hover { opacity: 0.85; }
.ms-header__brand-name {
    font-family:    var(--ms-font-head);
    font-size:      1.35rem;
    font-weight:    700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color:          var(--_text, var(--ms-dark));
    white-space:    nowrap;
}

.ms-header__util { display: flex; align-items: center; justify-content: flex-end; }
.ms-header__util a {
    font-size:       0.82rem;
    color:           var(--_text, var(--ms-muted));
    text-decoration: none;
    transition:      color 0.18s ease, opacity 0.18s ease;
}
.ms-header__util a:hover { opacity: 0.7; }

/* ═══════════════════════════════════════════════════════════════
   DARK SUBBAR  —  bullet-separated trust text
   ═══════════════════════════════════════════════════════════════ */
.ms-subbar {
    background: var(--ms-subbar-bg);
    padding:    10px 24px;
    text-align: center;
}
.ms-subbar__inner {
    font-size:      0.8rem;
    color:          var(--_text, #fff);
    letter-spacing: 0.03em;
}

/* ═══════════════════════════════════════════════════════════════
   PAGE BODY  —  decorative background, centres the panel
   ═══════════════════════════════════════════════════════════════ */
.ms-page__body {
    flex:                  1;
    padding:               48px 20px 64px;
    display:               flex;
    flex-direction:        column;
    align-items:           center;
    background-color:      var(--ms-page-bg);
    background-image:      var(--hart-bg-image,      none);
    background-size:       var(--hart-bg-size,       cover);
    background-repeat:     var(--hart-bg-repeat,     no-repeat);
    background-position:   var(--hart-bg-position,   center);
    background-attachment: var(--hart-bg-attachment, scroll);
}

/* ═══════════════════════════════════════════════════════════════
   PANEL  —  the floating white card
   ═══════════════════════════════════════════════════════════════ */
.ms-panel {
    background:    var(--ms-white);
    border-radius: var(--ms-panel-radius);
    box-shadow:    var(--ms-panel-shadow);
    width:         100%;
    max-width:     860px;
    overflow:      hidden;
}

.ms-panel__hero {
    text-align:    center;
    padding:       40px 32px 28px;
    border-bottom: 1px solid var(--ms-border);
}

.ms-panel__icon {
    height:     56px;
    width:      auto;
    max-width:  120px;
    margin:     0 auto 16px;
    display:    block;
    object-fit: contain;
}

.ms-panel__title {
    font-family:    var(--ms-font-head);
    font-size:      1.75rem;
    font-weight:    600;
    color:          var(--ms-dark);
    letter-spacing: 0.01em;
    margin:         0;
}

.ms-panel__body {
    padding: 32px;
}

/* ═══════════════════════════════════════════════════════════════
   VALIDATION SUMMARY
   ═══════════════════════════════════════════════════════════════ */
.ms-validation-summary {
    background:    var(--hart-error-bg);
    border:        1px solid var(--hart-error);
    border-radius: var(--ms-radius-sm);
    padding:       14px 18px;
    font-size:     0.875rem;
    color:         var(--hart-error);
    margin-bottom: 20px;
    animation:     ms-fade-up 0.25s var(--ms-ease) both;
}
.ms-validation-summary ul { margin: 6px 0 0 16px; }

/* ═══════════════════════════════════════════════════════════════
   RENEWAL LOOKUP BANNER
   ═══════════════════════════════════════════════════════════════ */
.ms-renewal-banner {
    background:    var(--ms-cream);
    border:        1px solid var(--ms-border);
    border-radius: var(--ms-radius);
    padding:       22px 24px;
    margin-bottom: 20px;
    animation:     ms-fade-up 0.3s var(--ms-ease) both;
}

.ms-renewal-hint {
    font-size:     0.875rem;
    color:         var(--ms-muted);
    margin:        0 0 16px;
    line-height:   1.6;
}

.ms-renewal-found {
    background:    var(--ms-primary-pale);
    border-left:   3px solid var(--ms-primary);
    border-radius: 0 var(--ms-radius-sm) var(--ms-radius-sm) 0;
    padding:       10px 14px;
    font-size:     0.875rem;
    color:         var(--ms-primary-dk);
    font-weight:   500;
    margin-top:    14px;
    animation:     ms-fade-up 0.2s var(--ms-ease) both;
}

/* ═══════════════════════════════════════════════════════════════
   SECTION CARDS
   ═══════════════════════════════════════════════════════════════ */
.ms-card {
    background:    var(--ms-white);
    border:        1px solid var(--ms-border);
    border-radius: var(--ms-radius);
    box-shadow:    var(--ms-shadow-sm);
    padding:       24px 28px;
    margin-bottom: 20px;
    animation:     ms-fade-up 0.3s var(--ms-ease) both;
}

.ms-card__header {
    display:        flex;
    align-items:    center;
    gap:            12px;
    margin-bottom:  20px;
    padding-bottom: 16px;
    border-bottom:  1px solid var(--ms-border);
}

.ms-card__icon {
    width:           36px;
    height:          36px;
    border-radius:   50%;
    background:      var(--ms-primary-pale);
    color:           var(--ms-primary-dk);
    display:         flex;
    align-items:     center;
    justify-content: center;
    font-size:       0.95rem;
    flex-shrink:     0;
}

.ms-card__title {
    font-family:    var(--ms-font-head);
    font-size:      0.92rem;
    font-weight:    600;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color:          var(--ms-dark);
    margin:         0;
    padding:        0;
    text-align:     left;
}

/* ═══════════════════════════════════════════════════════════════
   FORM LAYOUT & FIELDS
   ═══════════════════════════════════════════════════════════════ */
.ms-form-grid {
    display:               grid;
    grid-template-columns: 1fr 1fr;
    gap:                   16px;
}

.ms-form-grid--full { grid-column: 1 / -1; }

.ms-field {
    display:        flex;
    flex-direction: column;
    gap:            6px;
    margin-bottom:  0;
}

/* Override Bootstrap's bold label */
.ms-field > label,
.ms-label {
    font-size:      0.7rem !important;
    font-weight:    600 !important;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color:          var(--ms-muted) !important;
    padding:        0 !important;
    margin:         0;
}

.ms-field input,
.ms-field select,
.ms-field .form-control,
.ms-field .form-select {
    height:        var(--ms-input-height) !important;
    padding:       0 14px !important;
    border:        1px solid var(--ms-input-border) !important;
    border-radius: var(--ms-input-radius) !important;
    font-family:   var(--ms-font-body) !important;
    font-size:     0.92rem !important;
    color:         var(--ms-dark) !important;
    background:    var(--ms-white) !important;
    outline:       none;
    transition:    border-color 0.18s ease, box-shadow 0.18s ease;
    -webkit-appearance: none;
    appearance:    none;
    width:         100%;
    box-shadow:    none !important;
}

.ms-field input:hover,
.ms-field select:hover {
    border-color: var(--ms-input-border-hover) !important;
}

.ms-field select,
.ms-field .form-select {
    background-image:    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23808080' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
    background-repeat:   no-repeat !important;
    background-position: right 14px center !important;
    padding-right:       40px !important;
    cursor:              pointer;
}

.ms-field input:focus,
.ms-field select:focus,
.ms-field .form-control:focus,
.ms-field .form-select:focus {
    border-color: var(--ms-input-border-focus) !important;
    box-shadow:   0 0 0 var(--ms-input-focus-width) color-mix(in srgb, var(--ms-input-border-focus) 15%, transparent) !important;
}

.ms-field input.error {
    border-color: var(--hart-error) !important;
    box-shadow:   0 0 0 3px color-mix(in srgb, var(--hart-error) 10%, transparent) !important;
}

.ms-field__hint {
    font-size:  0.75rem;
    color:      var(--ms-muted);
    margin:     2px 0 0;
    line-height: 1.4;
}

.ms-field__error,
.ms-field .field-validation-error {
    font-size:  0.75rem;
    color:      var(--hart-error);
    margin:     2px 0 0;
}

/* ─── Kendo DatePicker overrides ─────────────────────────────── */
.ms-field .k-picker-wrap,
.ms-field .k-dateinput-wrap {
    border:        1px solid var(--ms-input-border) !important;
    border-radius: var(--ms-input-radius) !important;
    height:        var(--ms-input-height) !important;
    box-shadow:    none !important;
    background:    var(--ms-white) !important;
}

.ms-field .k-input {
    font-family: var(--ms-font-body) !important;
    font-size:   0.92rem !important;
    height:      calc(var(--ms-input-height) - 2px) !important;
    padding:     0 14px !important;
    color:       var(--ms-dark) !important;
}

.ms-field .k-select {
    border-radius: 0 var(--ms-input-radius) var(--ms-input-radius) 0 !important;
}

/* ─── Spacing utility ────────────────────────────────────────── */
.ms-mt-4  { margin-top:  4px;  }
.ms-mt-8  { margin-top:  8px;  }
.ms-mt-16 { margin-top:  16px; }

/* ═══════════════════════════════════════════════════════════════
   MEMBERSHIP INFORMATION
   ═══════════════════════════════════════════════════════════════ */
.ms-membership-pricing {
    background:    var(--ms-cream);
    border:        1px solid var(--ms-border);
    border-radius: var(--ms-radius-sm);
    padding:       18px 20px;
    margin-top:    18px;
    animation:     ms-fade-up 0.2s var(--ms-ease) both;
}

.ms-membership-pricing__title {
    font-size:      0.68rem;
    font-weight:    700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color:          var(--ms-muted);
    margin-bottom:  12px;
}

.ms-price-row {
    display:         flex;
    justify-content: space-between;
    align-items:     baseline;
    padding:         6px 0;
    font-size:       0.9rem;
    border-bottom:   1px solid var(--ms-border);
}
.ms-price-row:last-of-type { border-bottom: none; }

.ms-price-row__label { color: var(--ms-text); }

.ms-price-row__val {
    font-family: var(--ms-font-head);
    font-weight: 600;
    color:       var(--ms-primary-dk);
}

/* ─── Due today box ──────────────────────────────────────────── */
.ms-due-today {
    background:    var(--ms-primary);
    color:         var(--ms-white);
    border-radius: var(--ms-radius-sm);
    padding:       20px 24px;
    margin-top:    20px;
    text-align:    center;
    animation:     ms-fade-up 0.25s var(--ms-ease) both;
}

.ms-due-today__label {
    font-size:      0.7rem;
    font-weight:    600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    opacity:        0.82;
    margin-bottom:  4px;
}

.ms-due-today__amount {
    font-family:    var(--ms-font-head);
    font-size:      2.2rem;
    font-weight:    700;
    letter-spacing: 0.02em;
    line-height:    1.2;
}

.ms-breakdown {
    margin-top:    14px;
    font-size:     0.82rem;
    opacity:       0.9;
    border-top:    1px solid rgba(255,255,255,.25);
    padding-top:   12px;
    display:       grid;
    grid-template-columns: 1fr auto;
    gap:           4px 24px;
    text-align:    left;
}

.ms-breakdown__note {
    grid-column: 1 / -1;
    font-style:  italic;
    font-size:   0.75rem;
    opacity:     0.78;
    margin-top:  6px;
}

/* ═══════════════════════════════════════════════════════════════
   JOINT MEMBER PANEL
   ═══════════════════════════════════════════════════════════════ */
.ms-joint-panel {
    background:    var(--ms-primary-pale);
    border:        1px solid color-mix(in srgb, var(--ms-primary) 22%, transparent);
    border-radius: var(--ms-radius-sm);
    padding:       20px 24px;
    margin-top:    18px;
    animation:     ms-fade-up 0.3s var(--ms-ease) both;
}

.ms-joint-panel__title {
    font-family:    var(--ms-font-head);
    font-size:      0.82rem;
    font-weight:    600;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color:          var(--ms-primary-dk);
    margin-bottom:  12px;
    display:        flex;
    align-items:    center;
    gap:            8px;
}

.ms-joint-panel__notice {
    background:    var(--ms-white);
    border-left:   3px solid var(--ms-accent);
    border-radius: 0 var(--ms-radius-sm) var(--ms-radius-sm) 0;
    padding:       10px 14px;
    font-size:     0.85rem;
    color:         var(--ms-text);
    margin-bottom: 18px;
    line-height:   1.55;
}

/* ═══════════════════════════════════════════════════════════════
   CONSENT / CHECKBOXES
   ═══════════════════════════════════════════════════════════════ */
.ms-consent {
    display:    flex;
    flex-direction: column;
    gap:        0;
}

.ms-check-row {
    display:     flex;
    align-items: flex-start;
    gap:         12px;
    padding:     14px 0;
    border-top:  1px solid var(--ms-border);
    cursor:      pointer;
}

.ms-check-row:first-child { border-top: none; }

.ms-check-row input[type="checkbox"] {
    width:        18px !important;
    height:       18px !important;
    flex-shrink:  0;
    accent-color: var(--ms-primary);
    cursor:       pointer;
    margin-top:   2px;
    border:       none !important;
    padding:      0 !important;
    border-radius: 3px !important;
}

.ms-check-row__label {
    font-size:   0.875rem !important;
    font-weight: 400 !important;
    color:       var(--ms-text) !important;
    line-height: 1.55;
    cursor:      pointer;
    letter-spacing: 0 !important;
    text-transform: none !important;
    padding:     0 !important;
}

/* ═══════════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════════ */
.ms-btn {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    gap:             8px;
    height:          50px;
    padding:         var(--hart-btn-padding-v, 0) var(--hart-btn-padding-h, 28px);
    border:          none;
    border-radius:   var(--ms-btn-radius);
    font-family:     var(--ms-font-head);
    font-size:       var(--ms-btn-font-size);
    font-weight:     var(--ms-btn-weight);
    letter-spacing:  0.08em;
    text-transform:  uppercase;
    cursor:          pointer;
    transition:      background 0.18s ease, box-shadow 0.18s ease, transform 0.12s ease;
    white-space:     nowrap;
    text-decoration: none;
}

.ms-btn:active { transform: scale(0.97); }

.ms-btn--primary {
    background: var(--ms-primary);
    color:      var(--ms-white);
    box-shadow: 0 4px 14px color-mix(in srgb, var(--ms-primary) 35%, transparent);
    width:      100%;
}
.ms-btn--primary:hover { background: var(--ms-primary-dk); color: var(--ms-white); }

.ms-btn--ghost {
    background: transparent;
    color:      var(--ms-primary);
    border:     1.5px solid var(--ms-primary);
    height:     42px;
}
.ms-btn--ghost:hover { background: var(--ms-primary-pale); }

.ms-submit-wrap {
    margin-top: 8px;
}

.ms-submit-wrap .ms-btn--primary {
    font-size: 0.88rem;
    height:    54px;
    letter-spacing: 0.1em;
}

/* ═══════════════════════════════════════════════════════════════
   FOOTER — two dark sections matching the design file
   ═══════════════════════════════════════════════════════════════ */
.ms-footer { margin-top: auto; }

/* ─── Trust bar (same dark blue as the subbar) ───────────────── */
.ms-footer__trust {
    background:      var(--ms-subbar-bg);
    display:         flex;
    justify-content: center;
    align-items:     center;
    gap:             48px;
    flex-wrap:       wrap;
    padding:         18px 32px;
}

.ms-trust-item {
    display:     flex;
    align-items: center;
    gap:         8px;
    font-size:   0.875rem;
    font-weight: 600;
    color:       var(--_text, #fff);
}

.ms-trust-item i { color: var(--_text, #fff); }

/* ─── Bottom bar ─────────────────────────────────────────────── */
.ms-footer__bottom {
    background:      var(--ms-footer-bg);
    display:         flex;
    justify-content: space-between;
    align-items:     center;
    padding:         16px 32px;
    flex-wrap:       wrap;
    gap:             16px;
}

.ms-footer__meta {
    display:     flex;
    align-items: center;
    flex-wrap:   wrap;
    gap:         0;
    font-size:   0.8rem;
    color:       var(--_text-muted, rgba(255,255,255,.65));
}

.ms-footer__meta a {
    color:           var(--_text-muted, rgba(255,255,255,.65));
    text-decoration: none;
    transition:      color 0.18s ease;
}
.ms-footer__meta a:hover { color: var(--_text, #fff); }

.ms-footer__sep {
    margin:  0 10px;
    opacity: 0.4;
}

/* ─── Payment icons ──────────────────────────────────────────── */
.ms-footer__payments {
    display:     flex;
    align-items: center;
    gap:         6px;
    flex-wrap:   wrap;
}

.ms-footer__payments i {
    font-size: 2.2rem;
    color:     var(--_text-icon, rgba(255,255,255,.85));
}

/* ═══════════════════════════════════════════════════════════════
   INACTIVE FORM STATE
   ═══════════════════════════════════════════════════════════════ */
.ms-inactive {
    text-align:    center;
    padding:       60px 24px;
    color:         var(--ms-muted);
    font-size:     1rem;
}

.ms-inactive__icon {
    font-size:     2.5rem;
    color:         var(--ms-border);
    margin-bottom: 16px;
}

/* ═══════════════════════════════════════════════════════════════
   ANIMATIONS
   ═══════════════════════════════════════════════════════════════ */
@keyframes ms-fade-up {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 680px) {
    .ms-header__inner      { padding: 12px 16px; }
    .ms-header__nav        { display: none; }
    .ms-header__util       { display: none; }
    .ms-header__inner      { grid-template-columns: 1fr; justify-items: center; }
    .ms-header__logo       { height: 40px; }
    .ms-header__brand-name { font-size: 1rem; letter-spacing: 0.08em; }

    .ms-page__body         { padding: 24px 12px 48px; }
    .ms-panel__hero        { padding: 28px 20px 20px; }
    .ms-panel__title       { font-size: 1.35rem; }
    .ms-panel__body        { padding: 20px 16px; }

    .ms-card               { padding: 18px 16px; }
    .ms-form-grid          { grid-template-columns: 1fr; }

    .ms-footer__trust      { gap: 20px; padding: 16px 20px; }
    .ms-footer__bottom     { flex-direction: column; align-items: flex-start; gap: 12px; padding: 16px 20px; }
}

/* ─── Bootstrap conflict resets ──────────────────────────────── */
.ms-card h3, .ms-card h4, .ms-card h5 { text-align: left; padding-top: 0; }
