/* ============================================================
   Table & Chair Rental — Frontend CSS  v1.4
   ============================================================ */

:root {
    --tcr-primary:    #d97757;
    --tcr-primary-lt: #e8956e;
    --tcr-primary-dk: #b85e3e;
    --tcr-bg:         #fdf8f5;
    --tcr-surface:    #ffffff;
    --tcr-border:     #e8ddd5;
    --tcr-text:       #2d1a0e;
    --tcr-muted:      #7a6458;
    --tcr-error:      #c0392b;
    --tcr-radius:     12px;
    --tcr-radius-sm:  8px;
    --tcr-shadow:     0 4px 24px rgba(0,0,0,.08);
    --tcr-trans:      all .22s cubic-bezier(.4,0,.2,1);
    --tcr-font-ui:    -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --tcr-font-serif: Georgia, 'Times New Roman', serif;
}

/* ── Wrapper ─────────────────────────────────────────────── */
.tcr-booking-wrapper {
    max-width: 780px;
    margin: 2rem auto;
    font-family: var(--tcr-font-ui);
    color: var(--tcr-text);
    padding: 0 1rem;
}

/* ── Step cards ──────────────────────────────────────────── */
.tcr-step {
    background: var(--tcr-surface);
    border: 1px solid var(--tcr-border);
    border-radius: var(--tcr-radius);
    box-shadow: var(--tcr-shadow);
    margin-bottom: 1.5rem;
    overflow: hidden;
    transition: var(--tcr-trans);
}
.tcr-step--active {
    border-color: var(--tcr-primary);
    box-shadow: 0 0 0 2px rgba(217,119,87,.18), var(--tcr-shadow);
}

/* ── Step header ─────────────────────────────────────────── */
.tcr-step-header {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: 1.1rem 1.4rem;
    border-bottom: 1px solid var(--tcr-border);
    background: linear-gradient(135deg, #fdf0ea 0%, #fdf8f5 100%);
}
.tcr-step-badge {
    width: 34px; height: 34px;
    border-radius: 50%;
    background: var(--tcr-primary);
    color: #fff;
    font-weight: 700;
    font-size: .95rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.tcr-step-badge--done { background: var(--tcr-primary-dk); }

.tcr-step-title {
    font-family: var(--tcr-font-serif);
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0;
    color: var(--tcr-primary-dk);
    line-height: 1.3;
}
.tcr-step-body {
    padding: 1.4rem;
}
.tcr-step-desc {
    color: var(--tcr-muted);
    font-size: .88rem;
    margin: 0 0 1.2rem;
    line-height: 1.65;
}

/* ── ZIP field ───────────────────────────────────────────── */
.tcr-zip-field { display: flex; gap: .7rem; margin-bottom: .9rem; }
.tcr-zip-field .tcr-input { flex: 1; }

/* ── Inputs / Selects ────────────────────────────────────── */
.tcr-input, .tcr-select {
    width: 100%;
    padding: .72rem 1rem;
    border: 2px solid var(--tcr-border);
    border-radius: var(--tcr-radius-sm);
    font-size: 1rem;
    font-family: var(--tcr-font-ui);
    color: var(--tcr-text);
    background: var(--tcr-surface);
    transition: var(--tcr-trans);
    outline: none;
    box-sizing: border-box;
}
.tcr-input:focus, .tcr-select:focus {
    border-color: var(--tcr-primary);
    box-shadow: 0 0 0 3px rgba(217,119,87,.18);
}

/* ── Buttons ─────────────────────────────────────────────── */
.tcr-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .45rem;
    padding: .78rem 1.4rem;
    border: none;
    border-radius: var(--tcr-radius-sm);
    font-size: 1rem;
    font-weight: 700;
    font-family: var(--tcr-font-ui);
    cursor: pointer;
    transition: var(--tcr-trans);
    white-space: nowrap;
    text-decoration: none;
}
.tcr-btn--primary {
    background: linear-gradient(135deg, var(--tcr-primary-dk) 0%, var(--tcr-primary) 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 12px rgba(217,119,87,.32) !important;
}
.tcr-btn--primary:hover,
.tcr-btn--primary:focus {
    background: linear-gradient(135deg, #9e4e2e 0%, var(--tcr-primary-dk) 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 6px 18px rgba(217,119,87,.42) !important;
    transform: translateY(-1px);
}
.tcr-btn--primary .tcr-btn-text,
.tcr-btn--primary span { color: #ffffff !important; }

.tcr-btn--ghost {
    background: transparent !important;
    color: var(--tcr-muted) !important;
    border: 2px solid var(--tcr-border) !important;
}
.tcr-btn--ghost:hover {
    border-color: var(--tcr-primary) !important;
    color: var(--tcr-primary) !important;
}
.tcr-btn--full { width: 100%; margin-top: .9rem; }
.tcr-btn:disabled { opacity: .6; cursor: not-allowed; transform: none !important; }

.tcr-link-btn {
    background: none; border: none;
    color: var(--tcr-primary);
    font-size: .83rem;
    cursor: pointer;
    text-decoration: underline;
    padding: 0;
    margin-left: auto;
    font-family: var(--tcr-font-ui);
}

/* ── Spinner ─────────────────────────────────────────────── */
.tcr-spinner {
    width: 17px; height: 17px;
    border: 2px solid rgba(255,255,255,.35);
    border-top-color: #fff;
    border-radius: 50%;
    animation: tcr-spin .75s linear infinite;
}
@keyframes tcr-spin { to { transform: rotate(360deg); } }

/* ── Notices ─────────────────────────────────────────────── */
.tcr-notice {
    display: none;
    padding: .85rem 1.05rem;
    border-radius: var(--tcr-radius-sm);
    font-size: .88rem;
    line-height: 1.55;
    margin-top: .7rem;
    border-left: 4px solid;
}
.tcr-notice--success { background:#fdf0ea; border-color:var(--tcr-primary);    color:var(--tcr-primary-dk); }
.tcr-notice--error   { background:#fff5f5; border-color:var(--tcr-error);      color:#7b1e1e; }
.tcr-notice--info    { background:#fdf0ea; border-color:var(--tcr-primary-lt); color:var(--tcr-primary-dk); }

/* ── Package card ────────────────────────────────────────── */
.tcr-package-preview { margin-top: 1.4rem; }
.tcr-package-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: .95rem 1.2rem;
    background: linear-gradient(135deg, var(--tcr-primary-dk), var(--tcr-primary));
    border-radius: var(--tcr-radius-sm);
    color: #fff;
}
.tcr-package-icon { font-size: 1.9rem; }
.tcr-package-info strong { display: block; font-size: .97rem; font-weight: 700; margin-bottom: .15rem; }
.tcr-package-info span   { font-size: 1.18rem; font-family: var(--tcr-font-serif); color: #ffe4d6; font-weight: 700; }

/* ── ZIP summary bar ─────────────────────────────────────── */
.tcr-zip-summary { font-size: .88rem; color: var(--tcr-primary-dk); font-weight: 600; }

/* ── Calendar ────────────────────────────────────────────── */
.tcr-calendar {
    border-radius: var(--tcr-radius-sm);
    overflow: hidden;
    border: 1px solid var(--tcr-border);
    margin-bottom: 1.2rem;
}
.fc { font-family: var(--tcr-font-ui) !important; }
.fc-toolbar-title { font-family: var(--tcr-font-serif) !important; font-size: 1.1rem !important; color: var(--tcr-primary-dk) !important; }
.fc-button-primary { background: var(--tcr-primary) !important; border-color: var(--tcr-primary) !important; }
.fc-button-primary:hover { background: var(--tcr-primary-dk) !important; border-color: var(--tcr-primary-dk) !important; }
.fc-day-today { background: #fdf0ea !important; }
.fc-day-today .fc-daygrid-day-number { color: var(--tcr-primary) !important; font-weight: 700; }

/* ── Selected date cell ──────────────────────────────────── */
.tcr-sel-date {
    background-color: var(--tcr-primary) !important;
}
.tcr-sel-date .fc-daygrid-day-number {
    color: #ffffff !important;
    font-weight: 700 !important;
    background: transparent !important;
}

/* ── Blocked / past cells ────────────────────────────────── */
.tcr-blacked-out-day {
    opacity: .42 !important;
    pointer-events: none !important;
    cursor: not-allowed !important;
}
.tcr-blacked-out-day .fc-daygrid-day-number { text-decoration: line-through; color: #aaa !important; }
.tcr-past-day { opacity: .36 !important; pointer-events: none !important; }

/* ── Dates section (chips) ───────────────────────────────── */
.tcr-dates-section { margin: 1rem 0; }
.tcr-label {
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--tcr-muted);
    margin-bottom: .4rem;
}
.tcr-dates-chips {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    padding: .75rem;
    background: #fdf8f5;
    border: 1px solid var(--tcr-border);
    border-radius: var(--tcr-radius-sm);
    min-height: 46px;
    align-items: center;
}
.tcr-date-chip {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .28rem .72rem;
    background: var(--tcr-primary);
    color: #ffffff !important;
    border-radius: 999px;
    font-size: .79rem;
    font-weight: 600;
    cursor: default;
    user-select: none;
}
.tcr-chip-x {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 15px; height: 15px;
    background: rgba(255,255,255,.25);
    border-radius: 50%;
    font-size: .72rem;
    cursor: pointer;
    transition: background .12s;
    line-height: 1;
}
.tcr-chip-x:hover { background: rgba(255,255,255,.55); }

/* ── Date/time grid ──────────────────────────────────────── */
.tcr-datetime-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-top: 1rem;
    padding: 1.1rem;
    background: #fdf8f5;
    border-radius: var(--tcr-radius-sm);
    border: 1px solid var(--tcr-border);
}
.tcr-datetime-group { display: flex; flex-direction: column; gap: .35rem; }

/* ── Pricing card ────────────────────────────────────────── */
.tcr-pricing-card {
    background: var(--tcr-bg);
    border: 1px solid var(--tcr-border);
    border-radius: var(--tcr-radius-sm);
    overflow: hidden;
    margin-bottom: 1rem;
}
.tcr-pricing-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .82rem 1.2rem;
    font-size: .93rem;
    border-bottom: 1px solid var(--tcr-border);
}
.tcr-pricing-row:last-child { border-bottom: none; }
.tcr-pricing-row--sub { color: var(--tcr-muted); font-size: .88rem; }
.tcr-pricing-row--total {
    background: linear-gradient(135deg, var(--tcr-primary-dk), var(--tcr-primary));
    color: #fff;
    font-size: 1.08rem;
    font-weight: 700;
    padding: .95rem 1.2rem;
    border-bottom: none;
}
.tcr-pricing-divider {
    height: 2px;
    background: linear-gradient(90deg, var(--tcr-primary-dk), var(--tcr-primary-lt));
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 580px) {
    .tcr-zip-field { flex-direction: column; }
    .tcr-datetime-grid { grid-template-columns: 1fr; }
    .tcr-step-header { flex-wrap: wrap; }
}

/* Scoped button-text colour override for theme compatibility */
#tcr-booking-wrapper .tcr-btn--primary,
#tcr-booking-wrapper .tcr-btn--primary:hover,
#tcr-booking-wrapper .tcr-btn--primary:focus,
#tcr-booking-wrapper .tcr-btn--primary:visited,
#tcr-booking-wrapper button.tcr-btn--primary { color: #ffffff !important; }
