/* ============================================================
   Addyson Form Builder — Frontend Styles
   All rules scoped under .addyson-form-wrap to beat theme CSS.
   ============================================================ */

/* ── Default variable values ────────────────────────────────── */
.addyson-form-wrap {
    --am-field-bg:           #ffffff;
    --am-field-border-color: #d1d5db;
    --am-field-text:         #111827;
    --am-field-border-style: solid;
    --am-field-border-size:  1.5px;
    --am-field-radius:       8px;
    --am-field-pad:          10px 14px;
    --am-field-font:         15px;
    --am-label-color:        #374151;
    --am-label-font:         14px;
    --am-sublabel-color:     #6b7280;
    --am-error-color:        #dc2626;
    --am-btnp-bg:            #4f46e5;
    --am-btnp-text:          #ffffff;
    --am-btnp-border-color:  #4f46e5;
    --am-btnp-border-style:  none;
    --am-btnp-border-size:   0px;
    --am-btnp-radius:        8px;
    --am-btnp-pad:           12px 28px;
    --am-btnp-font:          15px;
    --am-btns-bg:            #f3f4f6;
    --am-btns-text:          #374151;
    --am-btns-border-color:  #e5e7eb;
    --am-btns-border-style:  solid;
    --am-btns-border-size:   1px;
    --am-btns-radius:        8px;
    --am-btns-pad:           12px 28px;
    --am-btns-font:          15px;

    width: 85vw;
    max-width: 85vw;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    margin: 0;
    font-family: inherit;
}

/* ── Step indicator ─────────────────────────────────────────── */
.addyson-form-wrap .addyson-step-indicator {
    display: flex; justify-content: center; gap: 8px; margin-bottom: 24px;
}
.addyson-form-wrap .addyson-step-dot {
    width: 10px; height: 10px; border-radius: 50% !important;
    background: #d1d5db !important; border: none !important;
    transition: background .25s; display: inline-block;
}
.addyson-form-wrap .addyson-step-dot--active    { background: var(--am-btnp-bg) !important; }
.addyson-form-wrap .addyson-step-dot--completed { background: var(--am-btnp-bg) !important; opacity: .5; }

/* ── Steps ──────────────────────────────────────────────────── */
.addyson-form-wrap .addyson-form-step          { display: none; }
.addyson-form-wrap .addyson-form-step.addyson-step--active { display: block; }

/* ── Fields ─────────────────────────────────────────────────── */
.addyson-form-wrap .addyson-field { margin-bottom: 18px; }

.addyson-form-wrap .addyson-label {
    display: block !important;
    font-weight: 600 !important;
    font-size: var(--am-label-font) !important;
    color: var(--am-label-color) !important;
    margin-bottom: 6px !important;
    background: none !important;
    padding: 0 !important;
    border: none !important;
}
.addyson-form-wrap .addyson-req {
    color: var(--am-error-color) !important;
    margin-left: 2px;
}

/* ── Inputs & selects ───────────────────────────────────────── */
.addyson-form-wrap .addyson-input,
.addyson-form-wrap .addyson-select {
    display: block !important;
    width: 100% !important;
    padding: var(--am-field-pad) !important;
    border-style: var(--am-field-border-style) !important;
    border-width: var(--am-field-border-size) !important;
    border-color: var(--am-field-border-color) !important;
    border-radius: var(--am-field-radius) !important;
    font-size: var(--am-field-font) !important;
    color: var(--am-field-text) !important;
    background: var(--am-field-bg) !important;
    box-shadow: none !important;
    outline: none;
    box-sizing: border-box;
    font-family: inherit;
    transition: border-color .15s, box-shadow .15s;
    -webkit-appearance: none;
    appearance: none;
}
.addyson-form-wrap .addyson-select { appearance: auto; -webkit-appearance: auto; }
.addyson-form-wrap .addyson-input:focus,
.addyson-form-wrap .addyson-select:focus {
    border-color: var(--am-btnp-bg) !important;
    box-shadow: 0 0 0 3px rgba(79,70,229,.15) !important;
    outline: none !important;
}
.addyson-form-wrap .addyson-input--error { border-color: var(--am-error-color) !important; }
.addyson-form-wrap textarea.addyson-input { resize: vertical; min-height: 90px; }

/* ── Address ────────────────────────────────────────────────── */
.addyson-form-wrap .addyson-address-row {
    display: grid; grid-template-columns: 1fr 140px; gap: 10px; margin-top: 8px;
}
.addyson-form-wrap .addyson-postcode { text-transform: uppercase; letter-spacing: .05em; }

/* ── Radio ──────────────────────────────────────────────────── */
.addyson-form-wrap .addyson-radio-group { display: flex; flex-direction: column; gap: 8px; }
.addyson-form-wrap .addyson-radio-label {
    display: flex !important; align-items: center; gap: 8px;
    font-size: var(--am-field-font); color: var(--am-field-text); cursor: pointer;
    background: none !important; border: none !important; padding: 0 !important;
}
.addyson-form-wrap .addyson-radio-label input[type="radio"] {
    accent-color: var(--am-btnp-bg); width: 16px !important; height: 16px !important;
    flex-shrink: 0;
}

/* ── Option cards ───────────────────────────────────────────── */
.addyson-form-wrap .addyson-option-cards {
    display: grid; grid-template-columns: repeat(auto-fill,minmax(130px,1fr)); gap: 10px;
}
.addyson-form-wrap .addyson-option-card {
    display: flex !important; align-items: center; justify-content: center;
    padding: var(--am-field-pad) !important;
    border-style: var(--am-field-border-style) !important;
    border-width: var(--am-field-border-size) !important;
    border-color: var(--am-field-border-color) !important;
    border-radius: var(--am-field-radius) !important;
    background: var(--am-field-bg) !important;
    color: var(--am-field-text) !important;
    cursor: pointer; font-size: var(--am-field-font); font-weight: 500;
    text-align: center; transition: all .15s; box-sizing: border-box;
}
.addyson-form-wrap .addyson-option-card input[type="radio"] { display: none !important; }
.addyson-form-wrap .addyson-option-card:hover {
    border-color: var(--am-btnp-bg) !important;
}
.addyson-form-wrap .addyson-option-card--selected {
    border-color: var(--am-btnp-bg) !important;
    background: var(--am-btnp-bg) !important;
    color: var(--am-btnp-text) !important;
}

/* ── File upload ────────────────────────────────────────────── */
.addyson-form-wrap .addyson-file-wrap {
    position: relative; display: inline-block; width: 100%;
}
.addyson-form-wrap .addyson-file-input {
    position: absolute; inset: 0; opacity: 0; cursor: pointer;
    width: 100%; height: 100%; z-index: 2;
}
.addyson-form-wrap .addyson-file-label {
    display: block !important;
    padding: var(--am-field-pad) !important;
    border: var(--am-field-border-size) dashed var(--am-field-border-color) !important;
    border-radius: var(--am-field-radius) !important;
    font-size: var(--am-field-font) !important;
    color: var(--am-sublabel-color) !important;
    background: var(--am-field-bg) !important;
    text-align: center; cursor: pointer; transition: border-color .15s;
    box-sizing: border-box;
}
.addyson-form-wrap .addyson-file-wrap:hover .addyson-file-label {
    border-color: var(--am-btnp-bg) !important;
    color: var(--am-btnp-bg) !important;
}
.addyson-form-wrap .addyson-field-hint {
    display: block; font-size: 12px; color: var(--am-sublabel-color); margin-top: 5px;
}

/* ── Navigation buttons ─────────────────────────────────────── */
.addyson-form-wrap .addyson-form-nav {
    display: flex; gap: 10px; margin-top: 24px;
}

/* Primary — Next / Submit */
.addyson-form-wrap .addyson-btn-next,
.addyson-form-wrap .addyson-btn-submit {
    flex: 1;
    display: inline-block !important;
    padding: var(--am-btnp-pad) !important;
    background: var(--am-btnp-bg) !important;
    color: var(--am-btnp-text) !important;
    border-style: var(--am-btnp-border-style) !important;
    border-width: var(--am-btnp-border-size) !important;
    border-color: var(--am-btnp-border-color) !important;
    border-radius: var(--am-btnp-radius) !important;
    font-size: var(--am-btnp-font) !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    font-family: inherit;
    text-align: center;
    text-decoration: none !important;
    box-shadow: none !important;
    transition: filter .15s;
    -webkit-appearance: none;
    appearance: none;
    line-height: normal;
}
.addyson-form-wrap .addyson-btn-next:hover,
.addyson-form-wrap .addyson-btn-submit:hover { filter: brightness(.9) !important; }
.addyson-form-wrap .addyson-btn-submit:disabled { opacity: .6; cursor: wait !important; }

/* Secondary — Previous */
.addyson-form-wrap .addyson-btn-prev {
    display: inline-block !important;
    padding: var(--am-btns-pad) !important;
    background: var(--am-btns-bg) !important;
    color: var(--am-btns-text) !important;
    border-style: var(--am-btns-border-style) !important;
    border-width: var(--am-btns-border-size) !important;
    border-color: var(--am-btns-border-color) !important;
    border-radius: var(--am-btns-radius) !important;
    font-size: var(--am-btns-font) !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    font-family: inherit;
    text-align: center;
    min-width: 100px;
    box-shadow: none !important;
    text-decoration: none !important;
    transition: filter .15s;
    -webkit-appearance: none;
    appearance: none;
    line-height: normal;
}
.addyson-form-wrap .addyson-btn-prev:hover { filter: brightness(.95) !important; }

/* ── Error message ──────────────────────────────────────────── */
.addyson-form-wrap .addyson-form-error {
    background: #fef2f2 !important;
    border: 1px solid #fecaca !important;
    color: var(--am-error-color) !important;
    border-radius: var(--am-field-radius) !important;
    padding: 12px 16px; font-size: 14px; margin-top: 12px;
    box-shadow: none !important;
}

/* ── Progress screen ────────────────────────────────────────── */
.addyson-form-wrap .addyson-progress-screen { display: none; padding: 40px 20px; }
.addyson-form-wrap .addyson-progress-inner  { text-align: center; max-width: 400px; margin: 0 auto; }
.addyson-form-wrap .addyson-progress-icon {
    font-size: 40px; margin-bottom: 16px; display: inline-block;
    animation: afb-spin 2s linear infinite;
}
.addyson-form-wrap .addyson-progress-heading {
    font-size: 20px; font-weight: 700;
    color: var(--am-label-color) !important; margin: 0 0 8px;
}
.addyson-form-wrap .addyson-progress-body {
    font-size: 14px; color: var(--am-sublabel-color) !important; margin: 0 0 24px;
}
@keyframes afb-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.addyson-form-wrap .addyson-progress-bar-wrap {
    height: 6px; background: var(--am-field-border-color); border-radius: 99px; overflow: hidden;
}
.addyson-form-wrap .addyson-progress-bar {
    height: 100%; background: var(--am-btnp-bg) !important;
    border-radius: 99px; width: 0; transition: width .1s linear;
}
.addyson-form-wrap .addyson-progress-spinner {
    width: 36px; height: 36px;
    border: 3px solid var(--am-field-border-color) !important;
    border-top-color: var(--am-btnp-bg) !important;
    border-radius: 50% !important;
    animation: afb-spin .8s linear infinite; margin: 0 auto;
}
.addyson-form-wrap .addyson-progress-pct {
    font-size: 32px; font-weight: 700; color: var(--am-btnp-bg) !important;
}

/* ── Confirmation ───────────────────────────────────────────── */
.addyson-form-wrap .addyson-form-confirmation { padding: 40px 20px; }
.addyson-form-wrap .addyson-conf-inner { text-align: center; max-width: 480px; margin: 0 auto; }
.addyson-form-wrap .addyson-conf-icon {
    width: 64px; height: 64px; background: #d1fae5 !important; color: #059669 !important;
    border-radius: 50% !important; font-size: 28px;
    display: flex; align-items: center; justify-content: center; margin: 0 auto 20px;
}
.addyson-form-wrap .addyson-conf-heading {
    font-size: 22px; font-weight: 700;
    color: var(--am-label-color) !important; margin: 0 0 10px;
}
.addyson-form-wrap .addyson-conf-message {
    font-size: 15px; color: var(--am-sublabel-color) !important; margin: 0 0 20px;
}
.addyson-form-wrap .addyson-conf-btn {
    display: inline-block !important;
    padding: var(--am-btnp-pad) !important;
    background: var(--am-btnp-bg) !important;
    color: var(--am-btnp-text) !important;
    border-radius: var(--am-btnp-radius) !important;
    border: none !important;
    text-decoration: none !important;
    font-size: var(--am-btnp-font) !important;
    font-weight: 600 !important;
    transition: filter .15s;
    box-shadow: none !important;
}
.addyson-form-wrap .addyson-conf-btn:hover { filter: brightness(.9); }

/* ── Icon / Visual Cards ────────────────────────────────────── */
.addyson-form-wrap .addyson-ic-grid {
    display: grid;
    gap: 10px;
    --ic-radius: 12px;
    --ic-shadow: 0 1px 3px rgba(0,0,0,.07), 0 2px 8px rgba(0,0,0,.05);
    --ic-sel-bg: #4f46e5;
    --ic-sel-border: #4f46e5;
    --ic-sel-text: #ffffff;
    --ic-sel-icon: #ffffff;
}
.addyson-form-wrap .addyson-ic-grid--cols-1 { grid-template-columns: 1fr; }
.addyson-form-wrap .addyson-ic-grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
.addyson-form-wrap .addyson-ic-grid--cols-3 { grid-template-columns: repeat(3, 1fr); }
.addyson-form-wrap .addyson-ic-grid--cols-4 { grid-template-columns: repeat(4, 1fr); }

.addyson-form-wrap .addyson-ic-card {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    padding: 22px 14px 18px !important;
    /* hard-coded white base; per-card --co-bg overrides if set by builder */
    background-color: var(--co-bg, #ffffff) !important;
    border-width: 2px !important;
    border-style: solid !important;
    border-color: var(--co-border, #e5e7eb) !important;
    border-radius: var(--ic-radius) !important;
    box-shadow: var(--ic-shadow) !important;
    color: var(--co-text, #111827) !important;
    cursor: pointer !important;
    text-align: center !important;
    box-sizing: border-box !important;
    min-height: 100px;
    transition: border-color .18s, background-color .18s, box-shadow .18s, transform .18s;
    -webkit-user-select: none; user-select: none;
    /* reset any theme padding/margin on block elements */
    margin: 0 !important;
}
.addyson-form-wrap .addyson-ic-card:focus-visible {
    outline: 3px solid var(--ic-sel-bg) !important;
    outline-offset: 2px;
}

/* Hover effects */
.addyson-form-wrap .addyson-ic-hover--scale .addyson-ic-card:not(.addyson-ic-card--selected):hover {
    transform: scale(1.03) !important;
    border-color: #c7d2fe !important;
}
.addyson-form-wrap .addyson-ic-hover--lift .addyson-ic-card:not(.addyson-ic-card--selected):hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 8px 20px rgba(0,0,0,.1) !important;
    border-color: #c7d2fe !important;
}
.addyson-form-wrap .addyson-ic-hover--glow .addyson-ic-card:not(.addyson-ic-card--selected):hover {
    box-shadow: 0 0 0 3px rgba(79,70,229,.2), var(--ic-shadow) !important;
    border-color: #a5b4fc !important;
}
.addyson-form-wrap .addyson-ic-hover--border .addyson-ic-card:not(.addyson-ic-card--selected):hover {
    border-color: var(--ic-sel-bg) !important;
}

/* SVG icon reset — beat theme overrides */
.addyson-form-wrap .afb-svg-icon {
    display: block !important;
    flex-shrink: 0 !important;
    pointer-events: none !important;
    fill: none !important;
    stroke: currentColor !important;
    overflow: visible;
}
.addyson-form-wrap .afb-svg-icon * {
    fill: inherit !important;
    stroke: inherit !important;
}

/* Icon bubble */
.addyson-form-wrap .addyson-ic-icon {
    width: 52px !important;
    height: 52px !important;
    background: var(--ic-def-bubble, #eef2ff) !important;
    border-radius: 50% !important;
    border: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 22px !important;
    color: var(--ic-def-icon, #4f46e5) !important;
    flex-shrink: 0;
    transition: background-color .18s, color .18s;
}
.addyson-form-wrap .addyson-ic-icon .afb-svg-icon {
    stroke: var(--ic-def-icon, #4f46e5) !important;
}
.addyson-form-wrap .addyson-ic-icon .afb-svg-icon * {
    stroke: var(--ic-def-icon, #4f46e5) !important;
    fill: none !important;
}
.addyson-form-wrap .addyson-ic-title {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: inherit !important;
    line-height: 1.25 !important;
    background: none !important;
    padding: 0 !important;
    border: none !important;
    margin: 0 !important;
}
.addyson-form-wrap .addyson-ic-desc {
    font-size: 12px !important;
    color: #6b7280 !important;
    line-height: 1.4 !important;
    margin: 0 !important;
    background: none !important;
    padding: 0 !important;
    border: none !important;
}

/* Tick badge */
.addyson-form-wrap .addyson-ic-check {
    display: none !important;
    position: absolute !important;
    top: 8px !important;
    right: 8px !important;
    width: 20px !important;
    height: 20px !important;
    background-color: rgba(255,255,255,.25) !important;
    border-radius: 50% !important;
    border: 2px solid rgba(255,255,255,.7) !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 9px !important;
    color: #fff !important;
    line-height: 1 !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* ── Selected state ─────────────────────────────────────────── */
.addyson-form-wrap .addyson-ic-card--selected {
    background-color: var(--ic-sel-bg) !important;
    border-color: var(--ic-sel-bg) !important;
    color: var(--ic-sel-text) !important;
    box-shadow: 0 0 0 3px rgba(79,70,229,.25), var(--ic-shadow) !important;
    transform: none !important;
}
.addyson-form-wrap .addyson-ic-card--selected .addyson-ic-icon {
    background-color: rgba(255,255,255,.2) !important;
    color: var(--ic-sel-icon) !important;
}
.addyson-form-wrap .addyson-ic-card--selected .addyson-ic-icon .afb-svg-icon {
    stroke: var(--ic-sel-icon) !important;
    color: var(--ic-sel-icon) !important;
}
.addyson-form-wrap .addyson-ic-card--selected .addyson-ic-icon .afb-svg-icon * {
    stroke: var(--ic-sel-icon) !important;
    fill: none !important;
}
.addyson-form-wrap .addyson-ic-card--selected .addyson-ic-title {
    color: var(--ic-sel-text) !important;
}
.addyson-form-wrap .addyson-ic-card--selected .addyson-ic-desc {
    color: var(--ic-sel-text) !important;
    opacity: .85;
}
.addyson-form-wrap .addyson-ic-card--selected .addyson-ic-check {
    display: flex !important;
}

/* Visual cards — taller, description always shown, bigger icon */
.addyson-form-wrap .addyson-vc-grid .addyson-ic-card {
    padding: 26px 16px 20px !important;
    gap: 12px !important;
    min-height: 130px;
}
.addyson-form-wrap .addyson-vc-grid .addyson-ic-icon {
    width: 60px !important;
    height: 60px !important;
    font-size: 26px !important;
}
.addyson-form-wrap .addyson-vc-grid .addyson-ic-desc {
    display: block !important;
}

/* ── Mobile ─────────────────────────────────────────────────── */
@media (max-width: 520px) {
    .addyson-form-wrap .addyson-address-row { grid-template-columns: 1fr; }
    .addyson-form-wrap .addyson-option-cards { grid-template-columns: 1fr 1fr; }
    .addyson-form-wrap .addyson-ic-grid--cols-3,
    .addyson-form-wrap .addyson-ic-grid--cols-4 { grid-template-columns: repeat(2, 1fr); }
    .addyson-form-wrap .addyson-ic-grid--cols-1 { grid-template-columns: 1fr; }
    .addyson-form-wrap .addyson-btn-next,
    .addyson-form-wrap .addyson-btn-submit,
    .addyson-form-wrap .addyson-btn-prev { width: 100% !important; }
    .addyson-form-wrap .addyson-form-nav { flex-direction: column-reverse; }
}
@media (max-width: 380px) {
    .addyson-form-wrap .addyson-ic-grid--cols-2,
    .addyson-form-wrap .addyson-ic-grid--cols-3,
    .addyson-form-wrap .addyson-ic-grid--cols-4 { grid-template-columns: 1fr; }
}

/* ── Video field ─────────────────────────────────────────────── */
.addyson-form-wrap .addyson-vid-wrap {
    border-radius: 16px; overflow: hidden;
    box-shadow: 0 4px 24px rgba(0,0,0,.15);
    position: relative; line-height: 0;
}
.addyson-form-wrap .addyson-vid-thumb {
    position: relative; cursor: pointer; display: block;
    border-radius: 16px; overflow: hidden;
}
.addyson-form-wrap .addyson-vid-poster {
    width: 100%; height: auto; display: block;
    border-radius: 16px;
}
.addyson-form-wrap .addyson-vid-poster--blank {
    width: 100%; padding-top: 56.25%; /* 16:9 */
    background: linear-gradient(135deg,#6366f1,#a855f7,#ec4899);
    border-radius: 16px;
}
.addyson-form-wrap .addyson-vid-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(160deg, rgba(80,40,140,.45) 0%, rgba(0,0,0,.25) 100%);
    border-radius: 16px;
    transition: background .2s;
}
.addyson-form-wrap .addyson-vid-thumb:hover .addyson-vid-overlay {
    background: linear-gradient(160deg, rgba(80,40,140,.6) 0%, rgba(0,0,0,.4) 100%);
}
.addyson-form-wrap .addyson-vid-play {
    position: absolute; top: 50%; left: 50%;
    transform: translate(-50%,-50%);
    width: 72px; height: 72px;
    transition: transform .18s;
    filter: drop-shadow(0 4px 16px rgba(0,0,0,.4));
}
.addyson-form-wrap .addyson-vid-thumb:hover .addyson-vid-play { transform: translate(-50%,-50%) scale(1.1); }
.addyson-form-wrap .addyson-vid-play svg { width: 100%; height: 100%; }

/* ── Contact preference cards ────────────────────────────────── */
.addyson-form-wrap .addyson-contact-pref-opts {
    display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin: 6px 0 16px;
}
.addyson-form-wrap .addyson-cp-opt { display: contents; }
.addyson-form-wrap .addyson-cp-opt .addyson-cp-card {
    border: 2px solid #e2e8f0; border-radius: 10px;
    padding: 16px 12px 14px; text-align: center; cursor: pointer;
    transition: border-color .15s, background .15s;
    display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.addyson-form-wrap .addyson-cp-radio { position: absolute; opacity: 0; width: 0; height: 0; }
.addyson-form-wrap .addyson-cp-icon  { font-size: 28px; line-height: 1; }
.addyson-form-wrap .addyson-cp-label { font-size: 13px; font-weight: 600; color: #374151; }
.addyson-form-wrap .addyson-cp-opt:has(input:checked) .addyson-cp-card,
.addyson-form-wrap .addyson-cp-opt .addyson-cp-card--selected {
    border-color: var(--afb-primary, #2563eb); background: #eff6ff;
}
@media (max-width: 480px) {
    .addyson-form-wrap .addyson-contact-pref-opts { grid-template-columns: 1fr; }
}

/* ── Showroom booking calendar ───────────────────────────────── */
.addyson-form-wrap .asb-card {
    background: #fff; border: 1.5px solid #ebebeb;
    border-radius: 14px; padding: 16px 16px 18px; margin-top: 8px;
    box-shadow: 0 2px 10px rgba(0,0,0,.05);
    max-width: 380px; margin-left: auto; margin-right: auto;
}

/* Header — month + flanking nav */
.addyson-form-wrap .asb-cal-header {
    display: flex; align-items: center; justify-content: center;
    gap: 12px; margin-bottom: 12px;
}
.addyson-form-wrap .asb-cal-month {
    font-size: 14px; font-weight: 700; color: #1e293b;
    min-width: 120px; text-align: center;
}
.addyson-form-wrap .asb-cal-nav {
    background: #f3f4f6 !important; border: none !important; outline: none !important;
    border-radius: 8px !important; width: 28px !important; height: 28px !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    font-size: 16px !important; color: #6b7280 !important; cursor: pointer !important;
    line-height: 1 !important; padding: 0 !important; box-shadow: none !important;
    transition: background .12s, color .12s !important; flex-shrink: 0;
}
.addyson-form-wrap .asb-cal-nav:hover { background: #e5e7eb !important; color: #1e293b !important; }

/* Day-of-week row */
.addyson-form-wrap .asb-dow-row {
    display: grid; grid-template-columns: repeat(7,1fr);
    text-align: center; margin-bottom: 4px;
}
.addyson-form-wrap .asb-dow-row span {
    font-size: 10px; font-weight: 600; color: #b0b7c3;
    text-transform: uppercase; letter-spacing: .05em; padding: 3px 0;
}

/* Day grid */
.addyson-form-wrap .asb-day-grid {
    display: grid; grid-template-columns: repeat(7,1fr); gap: 2px;
}
.addyson-form-wrap .asb-day {
    width: 100%; aspect-ratio: 1;
    display: flex; align-items: center; justify-content: center;
    border: none !important; background: none !important; box-shadow: none !important;
    border-radius: 50% !important; font-size: 13px; font-weight: 500;
    cursor: default; transition: background .12s, color .12s; padding: 0; line-height: 1;
    color: #cbd5e1;
}
.addyson-form-wrap .asb-day--empty { pointer-events: none; }
.addyson-form-wrap .asb-day--disabled { color: #dde1e7; cursor: not-allowed; }
.addyson-form-wrap .asb-day--open {
    color: #374151; cursor: pointer; font-weight: 600;
}
.addyson-form-wrap .asb-day--open:hover {
    background: #f3f4f6 !important; color: #111827 !important;
}
.addyson-form-wrap .asb-day--selected {
    background: var(--afb-primary,#2563eb) !important;
    color: #fff !important; font-weight: 700;
}

/* Selected date banner */
.addyson-form-wrap .asb-selected-date {
    display: flex; align-items: center; gap: 10px;
    background: linear-gradient(90deg,#f0f9ff,#e0f2fe);
    border: 1px solid #bae6fd; border-radius: 10px;
    padding: 10px 14px; margin-top: 12px;
}
.addyson-form-wrap .asb-selected-date__cal { font-size: 20px; flex-shrink: 0; }
.addyson-form-wrap .asb-selected-date__info { display: flex; flex-direction: column; gap: 1px; }
.addyson-form-wrap .asb-selected-date__dayname { font-size: 11px; font-weight: 700; color: #0284c7; text-transform: uppercase; letter-spacing: .06em; }
.addyson-form-wrap .asb-selected-date__full   { font-size: 15px; font-weight: 700; color: #0c4a6e; }

/* Time slots */
.addyson-form-wrap .asb-slots-wrap { margin-top: 14px; }
.addyson-form-wrap .asb-slots-label {
    font-size: 11px; font-weight: 700; color: #9ca3af;
    text-transform: uppercase; letter-spacing: .06em; margin: 0 0 8px;
}
.addyson-form-wrap .asb-slots { display: flex; flex-wrap: wrap; gap: 7px; }
.addyson-form-wrap .asb-slot {
    border: 1.5px solid #e5e7eb !important; border-radius: 50px !important;
    padding: 6px 14px; font-size: 13px; font-weight: 600; color: #374151;
    background: #f9fafb !important; cursor: pointer;
    transition: background .12s, border-color .12s, color .12s;
    box-shadow: none !important; display: inline-flex; align-items: center; gap: 0;
}
.addyson-form-wrap .asb-slot:hover {
    border-color: var(--afb-primary,#2563eb) !important;
    color: var(--afb-primary,#2563eb) !important;
    background: #fff !important;
}
.addyson-form-wrap .asb-slot--selected {
    background: var(--afb-primary,#2563eb) !important;
    border-color: var(--afb-primary,#2563eb) !important;
    color: #fff !important;
}
.addyson-form-wrap .addyson-sb-loading { font-size: 12px; color: #9ca3af; margin: 6px 0 0; }
.addyson-form-wrap .addyson-sb-none   { font-size: 12px; color: #ef4444;  margin: 6px 0 0; }

/* Fully booked day */
.addyson-form-wrap .asb-day--full .asb-day-num { color: #9ca3af; }
.addyson-form-wrap .asb-day-badge--full {
    font-size: 8px; font-weight: 700; color: #fff;
    background: #ef4444; border-radius: 3px; padding: 1px 3px; line-height: 1.2;
    pointer-events: none;
}
.addyson-form-wrap .asb-fully-booked {
    display: flex; align-items: center; gap: 8px;
    background: #fef2f2; border: 1px solid #fecaca;
    border-radius: 8px; padding: 10px 14px;
    font-size: 13px; color: #b91c1c; font-weight: 500;
}

/* Sale event banner (top of card) */
.addyson-form-wrap .asb-sale-banner {
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
    background: linear-gradient(90deg,#fff7ed,#fef3c7);
    border: 1px solid #fcd34d; border-radius: 10px;
    padding: 9px 13px; margin-bottom: 14px;
}
.addyson-form-wrap .asb-sale-banner__icon { font-size: 16px; flex-shrink: 0; }
.addyson-form-wrap .asb-sale-banner__title { font-size: 13px; font-weight: 700; color: #92400e; flex: 1; }
.addyson-form-wrap .asb-sale-banner__discount {
    font-size: 12px; font-weight: 700; color: #fff;
    background: #f59e0b; border-radius: 50px; padding: 2px 10px;
}

/* Sale day on calendar */
.addyson-form-wrap .asb-day { position: relative; flex-direction: column; gap: 1px; }
.addyson-form-wrap .asb-day-num { line-height: 1; }
.addyson-form-wrap .asb-day--sale .asb-day-num { color: #b45309; font-weight: 700; }
/* Dot indicator below sale date number */
.addyson-form-wrap .asb-day-dot {
    display: block; width: 5px; height: 5px; border-radius: 50%;
    background: #f59e0b; flex-shrink: 0; pointer-events: none;
}
.addyson-form-wrap .asb-day--selected .asb-day-dot { background: rgba(255,255,255,.7); }

/* Popular slot tag */
.addyson-form-wrap .asb-slot-popular {
    display: inline-block; margin-left: 5px;
    font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
    color: #fff; background: #f59e0b; border-radius: 50px; padding: 1px 5px;
    vertical-align: middle; pointer-events: none;
}

/* Weekend dow header greyed */
.addyson-form-wrap .asb-dow-row .asb-dow--off { color: #dde1e7 !important; }

/* Urgency bar above time slots */
.addyson-form-wrap .asb-urgency {
    display: flex; align-items: center; gap: 8px;
    background: #fff7ed; border: 1px solid #fed7aa;
    border-radius: 8px; padding: 8px 12px; margin-bottom: 10px;
    font-size: 12px; color: #92400e;
}
.addyson-form-wrap .asb-urgency__text { flex: 1; font-weight: 600; }
.addyson-form-wrap .asb-urgency__badge {
    font-size: 11px; font-weight: 700; color: #fff;
    background: #f59e0b; border-radius: 50px; padding: 2px 9px;
    white-space: nowrap; flex-shrink: 0;
}
.addyson-form-wrap .asb-urgency__fire { font-size: 15px; flex-shrink: 0; }
.addyson-form-wrap .asb-urgency__text strong { color: #b45309; }
