/*
 * Blessings Temple Sanctuary Styles
 * Sacred · Serene · Contemplative · Sanctuary-like
 * Inspired by columbarium architecture: threshold, corridor, alcoves, reveal
 * Version: 4.0.0
 */

/* ========================================
   TEMPLE GATE — Entry Threshold (Dark Sanctuary)
   ======================================== */
.kit-temple-gate {
    position: relative;
    min-height: 100vh;
    margin-top: var(--header-height, 72px);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    width: 100vw;
    margin-left: calc(-50vw + 50%);
}

.kit-temple-gate-bg {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background:
        linear-gradient(180deg,
            rgba(20,18,15,0.65) 0%,
            rgba(20,18,15,0.35) 40%,
            rgba(20,18,15,0.70) 100%),
        linear-gradient(160deg,
            #2a2520 0%,
            #1e1b18 50%,
            #141210 100%);
    overflow: hidden;
}

.kit-temple-gate-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(
        ellipse 60% 40% at 50% 30%,
        rgba(201,169,110,0.10) 0%,
        transparent 70%
    );
    pointer-events: none;
}

.kit-temple-gate-bg::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 120px;
    background: linear-gradient(to top, var(--ivory, #FAF7F2), transparent);
    pointer-events: none;
}

.kit-temple-gate-overlay {
    position: absolute;
    inset: 0;
    background: radial-gradient(
        ellipse 80% 60% at 50% 60%,
        rgba(201,169,110,0.06) 0%,
        transparent 60%
    );
    pointer-events: none;
}

.kit-temple-gate-content {
    position: relative;
    z-index: 1;
    text-align: center;
    padding: 60px 24px;
    max-width: 700px;
    animation: templeReveal 2s cubic-bezier(0.25, 0.1, 0.25, 1) forwards;
}

@keyframes templeReveal {
    0% { opacity: 0; transform: translateY(40px); }
    100% { opacity: 1; transform: translateY(0); }
}

.kit-temple-icon {
    margin-bottom: 40px;
}

.kit-temple-buddha-img {
    width: 180px;
    height: 180px;
    object-fit: cover;
    border-radius: 50%;
    margin: 0 auto;
    box-shadow:
        0 0 60px rgba(201,169,110,0.25),
        0 0 120px rgba(201,169,110,0.08);
    border: 2px solid rgba(201,169,110,0.35);
    animation: buddhaGlow 4s ease-in-out infinite alternate;
}

@keyframes buddhaGlow {
    0% { box-shadow: 0 0 60px rgba(201,169,110,0.20), 0 0 120px rgba(201,169,110,0.06); }
    100% { box-shadow: 0 0 80px rgba(201,169,110,0.30), 0 0 160px rgba(201,169,110,0.10); }
}

.kit-temple-gate-title {
    font-family: var(--font-heading, 'Playfair Display', serif);
    font-size: 46px;
    font-weight: 300;
    color: var(--gold-light, #E8D5A8);
    letter-spacing: 3px;
    margin-bottom: 16px;
    text-shadow: 0 2px 20px rgba(201,169,110,0.2);
}

.kit-temple-gate-subtitle {
    font-size: 18px;
    color: rgba(255,255,255,0.70);
    line-height: 1.8;
    margin-bottom: 28px;
}

.kit-temple-gate-inscription {
    margin-bottom: 40px;
    padding: 20px 32px;
    border-top: 1px solid rgba(201,169,110,0.20);
    border-bottom: 1px solid rgba(201,169,110,0.20);
}

.kit-temple-gate-inscription p {
    font-family: var(--font-heading, 'Playfair Display', serif);
    font-size: 17px;
    font-style: italic;
    color: rgba(201,169,110,0.70);
    letter-spacing: 0.5px;
}

.kit-temple-enter {
    font-size: 15px;
    padding: 16px 44px;
    animation: enterPulse 3s ease-in-out infinite;
}

@keyframes enterPulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(201,169,110,0.3); }
    50% { box-shadow: 0 0 0 12px rgba(201,169,110,0); }
}


/* ========================================
   PRAYER HALL — Central Devotional Corridor
   ======================================== */
.kit-prayer-hall {
    background:
        linear-gradient(180deg, #1e1b18 0%, #2a2520 50%, #1e1b18 100%);
    position: relative;
    overflow: hidden;
}

/* Architectural pillar rhythm — repeating vertical lines */
.kit-prayer-hall::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: repeating-linear-gradient(
        90deg,
        transparent 0px,
        transparent 80px,
        rgba(201,169,110,0.12) 80px,
        rgba(201,169,110,0.12) 82px
    );
}

.kit-prayer-hall::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: repeating-linear-gradient(
        90deg,
        transparent 0px,
        transparent 80px,
        rgba(201,169,110,0.12) 80px,
        rgba(201,169,110,0.12) 82px
    );
}


/* ========================================
   BLESSING LIFECYCLE STEPS — Processional Flow
   ======================================== */
.kit-blessing-lifecycle {
    max-width: 800px;
    margin: 0 auto 60px;
    padding: 40px;
    background: var(--white, #FFFFFF);
    border: 1px solid var(--cream, #EDE8DD);
    border-radius: 8px;
    box-shadow: var(--shadow-soft, 0 2px 20px rgba(0,0,0,0.06));
}

.kit-lifecycle-steps {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 16px;
}

.kit-lifecycle-step {
    flex: 1;
    text-align: center;
    padding: 24px 16px;
    background: var(--ivory, #FAF7F2);
    border-radius: 8px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.kit-lifecycle-step:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.06);
}

.kit-lifecycle-icon {
    font-size: 36px;
    margin-bottom: 12px;
}

.kit-lifecycle-step h3 {
    font-family: var(--font-heading, 'Playfair Display', serif);
    font-size: 18px;
    font-weight: 400;
    color: var(--gold-warm, #B8943F);
    margin-bottom: 8px;
}

.kit-lifecycle-step p {
    font-size: 14px;
    color: var(--text-secondary, #6B6560);
    line-height: 1.6;
}

.kit-lifecycle-arrow {
    display: flex;
    align-items: center;
    font-size: 24px;
    color: var(--gold-light, #E8D5A8);
    padding-top: 40px;
    opacity: 0.6;
}


/* ========================================
   THREE ALCOVES — Side Sanctuaries
   ======================================== */
.kit-three-alcoves {
    margin-top: 60px;
}

.kit-alcoves-heading {
    font-family: var(--font-heading, 'Playfair Display', serif);
    font-size: 30px;
    font-weight: 300;
    text-align: center;
    color: rgba(232, 213, 168, 0.9);
    margin-bottom: 12px;
    letter-spacing: 2px;
}

.kit-alcoves-desc {
    text-align: center;
    font-size: 16px;
    color: rgba(255, 255, 255, 0.55);
    margin-bottom: 40px;
}

.kit-alcoves-grid {
    display: flex;
    flex-direction: column;
    gap: 28px;
    width: 96%;
    max-width: 1060px;
    margin: 0 auto;
}

.kit-alcove {
    width: 100%;
    overflow: visible !important;  /* override theme.css overflow:hidden that clips border */
}

.kit-alcove-inner {
    min-height: 0 !important;
    max-height: 420px !important;
    padding: 28px 32px !important;
    display: grid !important;
    grid-template-columns: 150px 1fr 220px !important;
    grid-template-rows: auto !important;
    column-gap: 18px !important;
    align-items: center !important;
    flex-direction: row !important;  /* override theme.css flex-direction:column */
    text-align: left !important;     /* override theme.css text-align:center */
    justify-content: normal !important; /* override theme.css justify-content:center */
    border: 2px solid rgba(190, 140, 65, 0.68) !important;
    border-top: 2px solid rgba(190, 140, 65, 0.68) !important;  /* override theme.css border-top:none */
    border-radius: 14px;
    background:
        radial-gradient(circle at 14% 50%, rgba(218, 166, 72, 0.14), transparent 32%),
        linear-gradient(90deg, rgba(22, 18, 13, 0.95), rgba(10, 9, 7, 0.94));
    box-shadow:
        inset 0 0 22px rgba(218, 166, 72, 0.05),
        0 10px 28px rgba(0, 0, 0, 0.3);
}

.kit-alcove:hover .kit-alcove-inner {
    border-color: rgba(218, 166, 72, 0.85);
    box-shadow:
        inset 0 0 22px rgba(218, 166, 72, 0.08),
        0 10px 28px rgba(0, 0, 0, 0.38);
}

.kit-alcove-icon {
    grid-column: 1 !important;
    grid-row: 1 !important;
    width: 160px;
    height: 160px;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-bottom: 0 !important;  /* override theme.css margin-bottom:16px */
}

.kit-alcove-icon-img {
    max-width: 140px;
    max-height: 155px;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 0 18px rgba(226, 170, 62, 0.4));
}

.kit-alcove-text {
    grid-column: 2 !important;
    grid-row: 1 !important;
    text-align: left !important;
    align-self: center !important;
}

.kit-alcove-title {
    font-family: var(--font-heading, 'Playfair Display', serif);
    font-size: 30px;
    line-height: 1.12;
    font-weight: 400;
    color: rgba(232, 213, 168, 0.95);
    margin: 0 0 14px;
}

.kit-alcove-duration {
    font-family: var(--font-ui, sans-serif);
    font-size: 15px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    line-height: 1.2;
    color: rgba(201, 169, 110, 0.75);
    margin: 0 0 18px;
}

.kit-alcove-desc {
    font-size: 15px;
    color: rgba(255, 255, 255, 0.5);
    line-height: 1.55;
    max-width: 320px;
    margin: 0;
}

.kit-alcove-cta {
    grid-column: 3 !important;
    grid-row: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
}

.kit-alcove-cta .kit-btn {
    width: 200px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.kit-alcove-enter {
    position: relative;
    z-index: 1;
    white-space: nowrap;
    margin-top: 0 !important;  /* override theme.css margin-top:auto */
}

.kit-alcove-enter.kit-btn--outline {
    background: transparent;
    color: rgba(201, 169, 110, 0.85);
    border-color: rgba(190, 140, 65, 0.68);
    font-size: 14px;
    padding: 14px 22px;
    border-radius: 6px;
}

.kit-alcove-enter.kit-btn--outline:hover {
    background: rgba(201, 169, 110, 0.08);
    border-color: rgba(218, 166, 72, 0.85);
}


/* ========================================
   MOBILE IMAGE-BASED ALCOVE CARDS
   ======================================== */

/* Hide mobile image cards on desktop */
.kit-alcoves-mobile {
    display: none;
}

/* Show desktop grid by default */
.kit-alcoves-desktop {
    display: flex;
}

.kit-alcove-image-card {
    margin-bottom: 18px;
}

.kit-alcove-image-card:last-child {
    margin-bottom: 0;
}

.kit-alcove-image-btn {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
    border: none;
    background: none;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    transition: opacity 0.2s ease, transform 0.15s ease;
}

.kit-alcove-image-btn:active {
    opacity: 0.85;
    transform: scale(0.985);
}

.kit-alcove-card-img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 0;
}

/* ========================================
   BLESSING CREATION UI (2-step)
   ======================================== */
.kit-blessing-create {
    margin-top: 60px;
    padding: 60px 40px;
    background: rgba(26, 18, 12, 0.4);
    border: 1px solid rgba(201, 169, 110, 0.15);
    border-radius: 8px;
}

.kit-blessing-create-inner {
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
}

.kit-bless-step {
    opacity: 1;
    transform: translateY(0);
}

.kit-bless-title {
    font-family: var(--font-heading, 'Playfair Display', serif);
    font-size: 26px;
    font-weight: 400;
    color: rgba(232, 213, 168, 0.9);
    margin-bottom: 8px;
    letter-spacing: 1px;
}

.kit-bless-subtitle {
    font-size: 15px;
    color: rgba(255, 255, 255, 0.5);
    margin-bottom: 32px;
    font-style: italic;
}

.kit-bless-textarea {
    width: 100%;
    min-height: 160px;
    padding: 20px;
    background: rgba(15, 12, 10, 0.5);
    border: 1px solid rgba(201, 169, 110, 0.2);
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.85);
    font-family: var(--font-body, Georgia, serif);
    font-size: 16px;
    line-height: 1.8;
    resize: vertical;
    outline: none;
    transition: border-color 0.3s ease;
}

.kit-bless-textarea:focus {
    border-color: rgba(201, 169, 110, 0.4);
}

.kit-bless-textarea::placeholder {
    color: rgba(255, 255, 255, 0.25);
    font-style: italic;
}

.kit-bless-error {
    color: #d4836a;
    font-size: 13px;
    margin-top: 8px;
    margin-bottom: 0;
}

.kit-bless-name-wrap {
    margin-top: 24px;
    text-align: left;
}

.kit-bless-label {
    display: block;
    font-size: 13px;
    color: rgba(201, 169, 110, 0.7);
    margin-bottom: 8px;
    letter-spacing: 0.5px;
}

.kit-bless-name {
    width: 100%;
    padding: 12px 16px;
    background: rgba(15, 12, 10, 0.5);
    border: 1px solid rgba(201, 169, 110, 0.2);
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.85);
    font-family: var(--font-body, Georgia, serif);
    font-size: 15px;
    outline: none;
    transition: border-color 0.3s ease;
}

.kit-bless-name:focus {
    border-color: rgba(201, 169, 110, 0.4);
}

.kit-bless-name::placeholder {
    color: rgba(255, 255, 255, 0.25);
    font-style: italic;
}

.kit-bless-continue,
.kit-bless-place {
    margin-top: 32px;
    padding: 12px 40px;
    font-size: 15px;
}

/* ========================================
   CHARITY SELECTION STEP
   ======================================== */
.kit-bless-charity-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    margin: 24px 0;
}

@media (min-width: 480px) {
    .kit-bless-charity-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

.kit-bless-charity-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    padding: 20px 12px;
    border: 1px solid rgba(201, 169, 110, 0.2);
    border-radius: 8px;
    background: rgba(26, 18, 12, 0.4);
    cursor: pointer;
    transition: border-color 0.2s ease, background 0.2s ease;
}

.kit-bless-charity-card:hover {
    border-color: rgba(201, 169, 110, 0.4);
    background: rgba(26, 18, 12, 0.6);
}

.kit-bless-charity-card.kit-selected {
    border-color: rgba(201, 169, 110, 0.7);
    background: rgba(201, 169, 110, 0.1);
    box-shadow: 0 0 12px rgba(201, 169, 110, 0.15);
}

.kit-bless-charity-logo {
    width: 56px;
    height: 56px;
    object-fit: contain;
    border-radius: 50%;
    opacity: 0.85;
}

.kit-bless-charity-name {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.7);
    text-align: center;
    line-height: 1.4;
    letter-spacing: 0.3px;
}

.kit-bless-charity-card.kit-selected .kit-bless-charity-name {
    color: rgba(201, 169, 110, 0.9);
}

.kit-bless-charity-empty {
    font-size: 14px;
    color: rgba(255, 255, 255, 0.4);
    font-style: italic;
    text-align: center;
    padding: 20px;
}

.kit-bless-charity-continue {
    margin-top: 24px;
    padding: 12px 40px;
    font-size: 15px;
}

/* Duration options */
.kit-bless-duration-label {
    font-size: 15px;
    color: rgba(255, 255, 255, 0.6);
    margin-bottom: 20px;
    text-align: left;
}

.kit-bless-durations {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 32px;
}

.kit-bless-duration-option {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    background: rgba(15, 12, 10, 0.4);
    border: 1px solid rgba(201, 169, 110, 0.15);
    border-radius: 6px;
    cursor: pointer;
    transition: border-color 0.3s ease;
}

.kit-bless-duration-option:hover {
    border-color: rgba(201, 169, 110, 0.3);
}

.kit-bless-duration-option input[type="radio"] {
    appearance: none;
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    border: 1px solid rgba(201, 169, 110, 0.4);
    border-radius: 50%;
    background: transparent;
    cursor: pointer;
    position: relative;
    flex-shrink: 0;
}

.kit-bless-duration-option input[type="radio"]:checked {
    border-color: rgba(201, 169, 110, 0.7);
}

.kit-bless-duration-option input[type="radio"]:checked::after {
    content: '';
    position: absolute;
    top: 3px;
    left: 3px;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(201, 169, 110, 0.7);
}

.kit-bless-duration-text {
    font-size: 15px;
    color: rgba(255, 255, 255, 0.7);
}

/* Offering input */
.kit-bless-offering-wrap {
    text-align: left;
    margin-bottom: 16px;
}

.kit-bless-offering-input {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 8px;
}

.kit-bless-currency {
    font-size: 16px;
    color: rgba(201, 169, 110, 0.7);
    font-weight: 600;
}

.kit-bless-offering {
    width: 120px;
    padding: 12px 16px;
    background: rgba(15, 12, 10, 0.5);
    border: 1px solid rgba(201, 169, 110, 0.2);
    border-radius: 6px;
    color: rgba(255, 255, 255, 0.85);
    font-family: var(--font-body, Georgia, serif);
    font-size: 16px;
    outline: none;
    transition: border-color 0.3s ease;
}

.kit-bless-offering:focus {
    border-color: rgba(201, 169, 110, 0.4);
}

/* Remove number input spinners */
.kit-bless-offering::-webkit-inner-spin-button,
.kit-bless-offering::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.kit-bless-offering {
    -moz-appearance: textfield;
}

.kit-bless-offering-note {
    font-size: 13px;
    color: rgba(255, 255, 255, 0.45);
    margin-top: 10px;
    margin-bottom: 4px;
}

.kit-bless-offering-hint {
    font-size: 12px;
    color: rgba(201, 169, 110, 0.45);
    font-style: italic;
    margin-bottom: 0;
}

/* Confirmation */
.kit-bless-confirmation {
    padding: 40px 20px;
}

.kit-bless-confirm-text {
    font-family: var(--font-heading, 'Playfair Display', serif);
    font-size: 20px;
    font-style: italic;
    color: rgba(232, 213, 168, 0.85);
    line-height: 1.8;
}

.kit-chamber-buddha {
    margin-bottom: 28px;
}

.kit-chamber-buddha-img {
    width: 120px;
    height: 120px;
    object-fit: cover;
    border-radius: 50%;
    margin: 0 auto;
    box-shadow: 0 0 40px rgba(201,169,110,0.15);
    border: 2px solid var(--gold-light, #E8D5A8);
}

.kit-chamber-title {
    font-family: var(--font-heading, 'Playfair Display', serif);
    font-size: 26px;
    font-weight: 400;
    color: var(--text-primary, #3A3530);
    margin-bottom: 12px;
}

.kit-chamber-instruction {
    font-size: 15px;
    color: var(--text-secondary, #6B6560);
    line-height: 1.7;
    margin-bottom: 36px;
}

/* Step labels */
.kit-step-label {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: var(--font-ui, sans-serif);
    font-size: 15px;
    font-weight: 600;
    color: var(--text-primary, #3A3530);
    margin-bottom: 20px;
    text-align: left;
}

.kit-step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--gold-warm, #B8943F);
    color: var(--white, #FFFFFF);
    font-size: 14px;
    font-weight: 700;
    flex-shrink: 0;
}

/* Confirmation */
.kit-blessing-confirmation {
    padding: 40px;
    text-align: center;
}

.kit-confirmation-icon {
    font-size: 48px;
    margin-bottom: 16px;
}

.kit-blessing-confirmation p {
    font-size: 17px;
    color: var(--text-primary, #3A3530);
    line-height: 1.8;
}


/* ========================================
   FIELD OF BLESSINGS — Prayer Plaque Wall
   ======================================== */
.kit-field-of-blessings {
    background: var(--ivory-warm, #F5F0E8);
    position: relative;
}

/* Contemplative corridor rhythm — vertical gold line */
.kit-field-of-blessings::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 1px;
    height: 80px;
    background: linear-gradient(180deg, transparent, rgba(201,169,110,0.3), transparent);
}

.kit-prayer-wall {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 20px;
    margin-bottom: 60px;
}

/* Individual prayer plaque */
.kit-prayer-plaque {
    background: var(--white, #FFFFFF);
    border: 1px solid var(--cream, #EDE8DD);
    border-radius: 8px;
    padding: 24px;
    text-align: center;
    position: relative;
    overflow: hidden;
    transition: all 0.4s cubic-bezier(0.25, 0.1, 0.25, 1);
}

.kit-prayer-plaque::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--gold-light, #E8D5A8), var(--gold, #C9A96E), var(--gold-light, #E8D5A8));
}

.kit-prayer-plaque:hover {
    box-shadow: var(--shadow-glow, 0 0 40px rgba(201,169,110,0.12));
    transform: translateY(-2px);
}

.kit-plaque-type-icon {
    font-size: 28px;
    margin-bottom: 8px;
}

.kit-plaque-name {
    font-family: var(--font-heading, 'Playfair Display', serif);
    font-size: 16px;
    font-weight: 400;
    color: var(--text-primary, #3A3530);
    margin-bottom: 4px;
}

.kit-plaque-type {
    font-family: var(--font-ui, sans-serif);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--gold-warm, #B8943F);
    margin-bottom: 8px;
}

.kit-plaque-status {
    font-size: 13px;
    color: var(--text-light, #8A8580);
    font-style: italic;
}

/* Status-specific glow */
.kit-prayer-plaque[data-status="offered"] {
    border-color: var(--gold-light, #E8D5A8);
}

.kit-prayer-plaque[data-status="held"] {
    border-color: var(--gold, #C9A96E);
    box-shadow: 0 0 20px rgba(201,169,110,0.08);
}

.kit-prayer-plaque[data-status="released"] {
    border-color: var(--cream, #EDE8DD);
    opacity: 0.7;
}


/* ========================================
   EMA SANCTUARY — HANGING PLAQUE WALL
   ======================================== */

/* Sanctuary atmosphere */
.kit-field-of-blessings {
    background: linear-gradient(180deg, #1a1008 0%, #2a1a0a 40%, #1f150b 100%);
    position: relative;
    overflow: hidden;
}

.kit-field-of-blessings::before {
    content: '';
    position: absolute;
    top: -60px;
    left: 50%;
    transform: translateX(-50%);
    width: 600px;
    height: 400px;
    background: radial-gradient(ellipse, rgba(201, 169, 110, 0.08) 0%, transparent 70%);
    pointer-events: none;
    z-index: 0;
}

.kit-field-of-blessings .kit-container {
    position: relative;
    z-index: 1;
}

.kit-field-of-blessings .kit-section-title,
.kit-field-of-blessings .kit-section-subtitle {
    color: rgba(232, 213, 168, 0.9);
}

/* Wooden beam */
.kit-ema-beam {
    width: 100%;
    height: 14px;
    background: linear-gradient(180deg, #8b6914 0%, #5c3a1e 40%, #4a2e16 100%);
    border-radius: 3px;
    box-shadow:
        0 2px 6px rgba(0, 0, 0, 0.5),
        inset 0 1px 0 rgba(201, 169, 110, 0.2),
        inset 0 -1px 0 rgba(0, 0, 0, 0.3);
    margin-bottom: 0;
    position: relative;
    z-index: 1;
}

.kit-ema-beam::before,
.kit-ema-beam::after {
    content: '';
    position: absolute;
    top: 2px;
    width: 20px;
    height: 10px;
    background: linear-gradient(180deg, #9b7924, #6b4423);
    border-radius: 2px;
}

.kit-ema-beam::before {
    left: 8px;
}

.kit-ema-beam::after {
    right: 8px;
}

/* Prayer wall container */
.kit-field-of-blessings .kit-prayer-wall {
    display: block;
    padding-top: 40px;
    margin-bottom: 60px;
}

/* Blessings grid — ema layout */
.kit-field-of-blessings .kit-blessings-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 24px 20px;
    position: relative;
    z-index: 2;
}

/* Individual ema plaque */
.kit-field-of-blessings .kit-blessing-plaque {
    background: linear-gradient(160deg, #8b6914 0%, #6b4423 50%, #5a3a1e 100%);
    border: 1px solid rgba(201, 169, 110, 0.3);
    border-radius: 4px;
    padding: 14px 10px 12px;
    text-align: center;
    position: relative;
    cursor: pointer;
    overflow: visible;
    min-height: 130px;
    max-width: 140px;
    margin: 0 auto;
    box-shadow:
        0 4px 12px rgba(0, 0, 0, 0.4),
        inset 0 1px 0 rgba(232, 213, 168, 0.15);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    z-index: 2;
}

/* Hanging string — from beam to plaque */
.kit-field-of-blessings .kit-blessing-plaque::before {
    content: '';
    position: absolute;
    top: -40px;
    left: 50%;
    transform: translateX(-50%);
    width: 1.5px;
    height: 40px;
    background: linear-gradient(180deg, rgba(180, 120, 60, 0.6), rgba(201, 169, 110, 0.4));
    pointer-events: none;
    z-index: -1;
}

/* Vertical stagger for depth */
.kit-field-of-blessings .kit-blessing-plaque:nth-child(even) {
    margin-top: 12px;
}

/* Desktop hover */
@media (hover: hover) {
    .kit-field-of-blessings .kit-blessing-plaque:hover {
        transform: scale(1.03);
        box-shadow:
            0 6px 20px rgba(0, 0, 0, 0.5),
            0 0 12px rgba(201, 169, 110, 0.15),
            inset 0 1px 0 rgba(232, 213, 168, 0.25);
        border-color: rgba(201, 169, 110, 0.5);
    }
}

/* Hide status label and share actions in ema wall view */
.kit-field-of-blessings .kit-blessing-status,
.kit-field-of-blessings .kit-blessing-actions {
    display: none;
}

/* Plaque icon (actual shortcode class) */
.kit-field-of-blessings .kit-blessing-icon {
    margin-bottom: 6px;
    margin-top: 0;
    opacity: 0.8;
}

.kit-field-of-blessings .kit-blessing-icon svg {
    display: inline-block;
    width: 22px;
    height: 22px;
}

/* Plaque content wrapper */
.kit-field-of-blessings .kit-blessing-content {
    flex: 1;
}

/* Plaque message — truncated (actual shortcode class) */
.kit-field-of-blessings .kit-blessing-message {
    font-family: var(--font-body, 'Noto Serif TC', Georgia, serif);
    font-size: 11px;
    font-style: italic;
    line-height: 1.5;
    color: rgba(232, 213, 168, 0.85);
    margin: 0 0 8px 0;
    min-height: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

/* Plaque author name (actual shortcode class) */
.kit-field-of-blessings .kit-blessing-author {
    font-family: var(--font-ui, sans-serif);
    font-size: 10px;
    letter-spacing: 0.3px;
    color: rgba(201, 169, 110, 0.7);
    margin: 0;
    display: block;
    padding-top: 4px;
    border-top: 1px solid rgba(201, 169, 110, 0.15);
}


/* ========================================
   EMA MODAL — ENLARGED BLESSING VIEW
   ======================================== */

.kit-ema-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.kit-ema-modal.kit-ema-modal--open {
    opacity: 1;
    visibility: visible;
}

.kit-ema-modal-backdrop {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(10, 6, 2, 0.85);
    pointer-events: auto;
}

.kit-ema-modal-card {
    position: relative;
    background: linear-gradient(160deg, #8b6914 0%, #6b4423 40%, #5a3a1e 100%);
    border: 1px solid rgba(201, 169, 110, 0.4);
    border-radius: 8px;
    padding: 40px 32px 32px;
    max-width: 420px;
    width: 100%;
    text-align: center;
    box-shadow:
        0 20px 60px rgba(0, 0, 0, 0.6),
        0 0 30px rgba(201, 169, 110, 0.1);
    transform: scale(0.92);
    transition: transform 0.3s ease;
    z-index: 1;
}

.kit-ema-modal--open .kit-ema-modal-card {
    transform: scale(1);
}

.kit-ema-modal-close {
    position: absolute;
    top: 12px;
    right: 16px;
    background: none;
    border: none;
    color: rgba(201, 169, 110, 0.7);
    font-size: 24px;
    cursor: pointer;
    line-height: 1;
    padding: 4px 8px;
    transition: color 0.2s ease;
}

.kit-ema-modal-close:hover {
    color: rgba(232, 213, 168, 1);
}

.kit-ema-modal-icon {
    margin-bottom: 16px;
    opacity: 0.8;
}

.kit-ema-modal-icon svg {
    width: 36px;
    height: 36px;
}

.kit-ema-modal-msg {
    font-family: var(--font-body, 'Noto Serif TC', Georgia, serif);
    font-size: 18px;
    font-style: italic;
    line-height: 1.8;
    color: rgba(232, 213, 168, 0.9);
    margin: 0 0 20px 0;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.kit-ema-modal-name {
    font-family: var(--font-ui, sans-serif);
    font-size: 14px;
    letter-spacing: 0.5px;
    color: rgba(201, 169, 110, 0.8);
    margin: 0;
    padding-top: 12px;
    border-top: 1px solid rgba(201, 169, 110, 0.2);
}


/* ========================================
   EMA SANCTUARY — RESPONSIVE
   ======================================== */

@media (max-width: 768px) {
    .kit-field-of-blessings .kit-blessings-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px 16px;
    }

    .kit-field-of-blessings .kit-prayer-wall {
        padding-top: 32px;
    }

    .kit-field-of-blessings .kit-blessing-plaque {
        max-width: 100%;
        min-height: 110px;
        padding: 12px 8px 10px;
    }

    .kit-field-of-blessings .kit-blessing-plaque::before {
        height: 32px;
        top: -32px;
    }

    .kit-field-of-blessings .kit-blessing-plaque:nth-child(even) {
        margin-top: 10px;
    }

    .kit-ema-beam {
        height: 10px;
    }

    .kit-ema-modal-card {
        padding: 32px 20px 24px;
    }

    .kit-ema-modal-msg {
        font-size: 16px;
    }
}

@media (max-width: 480px) {
    .kit-field-of-blessings .kit-blessings-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 16px 12px;
    }

    .kit-field-of-blessings .kit-prayer-wall {
        padding-top: 28px;
    }

    .kit-field-of-blessings .kit-blessing-plaque {
        min-height: 100px;
        padding: 10px 6px 8px;
    }

    .kit-field-of-blessings .kit-blessing-plaque-msg {
        font-size: 10px;
        -webkit-line-clamp: 2;
    }

    .kit-field-of-blessings .kit-blessing-plaque::before {
        height: 28px;
        top: -28px;
    }
}


/* ========================================
   HEALING NAMES REGISTRY
   ======================================== */
.kit-healing-names {
    margin-top: 60px;
    padding-top: 48px;
    border-top: 1px solid var(--cream, #EDE8DD);
    text-align: center;
}

.kit-healing-title {
    font-family: var(--font-heading, 'Playfair Display', serif);
    font-size: 24px;
    font-weight: 400;
    color: var(--text-primary, #3A3530);
    margin-bottom: 12px;
}

.kit-healing-desc {
    font-size: 15px;
    color: var(--text-secondary, #6B6560);
    margin-bottom: 28px;
}

.kit-healing-names-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
}

.kit-healing-name {
    display: inline-block;
    padding: 8px 20px;
    font-family: var(--font-body, serif);
    font-size: 15px;
    color: var(--text-primary, #3A3530);
    background: var(--white, #FFFFFF);
    border: 1px solid var(--cream, #EDE8DD);
    border-radius: 24px;
    transition: all 0.3s ease;
}

.kit-healing-name:hover {
    border-color: var(--gold-light, #E8D5A8);
    box-shadow: 0 0 16px rgba(201,169,110,0.1);
}

.kit-names-item {
    display: inline-block;
    padding: 8px 20px;
    font-family: var(--font-body, serif);
    font-size: 15px;
    color: var(--text-primary, #3A3530);
    background: var(--white, #FFFFFF);
    border: 1px solid var(--cream, #EDE8DD);
    border-radius: 24px;
}


/* ========================================
   RELEASED PRAYERS GARDEN
   ======================================== */
.kit-released-prayers {
    background: var(--ivory, #FAF7F2);
    position: relative;
}

.kit-released-prayers::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 1px;
    height: 60px;
    background: linear-gradient(180deg, transparent, rgba(201,169,110,0.3), transparent);
}

.kit-released-wall {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
}

.kit-released-plaque {
    background: var(--ivory-warm, #F5F0E8);
    border: 1px solid var(--cream, #EDE8DD);
    border-radius: 8px;
    padding: 20px;
    text-align: center;
    opacity: 0.75;
    transition: opacity 0.3s ease;
}

.kit-released-plaque:hover {
    opacity: 1;
}

.kit-released-icon {
    font-size: 20px;
    margin-bottom: 8px;
    color: var(--gold-light, #E8D5A8);
}

.kit-released-name {
    font-size: 14px;
    color: var(--text-secondary, #6B6560);
}

.kit-released-date {
    font-size: 12px;
    color: var(--text-light, #8A8580);
    margin-top: 4px;
}


/* ========================================
   CANDLE OFFERING (within Blessings)
   ======================================== */
.kit-candle-offering {
    background: var(--ivory-warm, #F5F0E8);
}

.kit-candle-display {
    margin-top: 40px;
}


/* ========================================
   SEASONAL OBSERVANCES (Stub)
   ======================================== */
.kit-seasonal {
    background: var(--ivory, #FAF7F2);
}

.kit-seasonal-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}

.kit-seasonal-card {
    background: var(--white, #FFFFFF);
    border: 1px solid var(--cream, #EDE8DD);
    border-radius: 8px;
    padding: 28px;
    text-align: center;
}

.kit-seasonal-card h3 {
    font-family: var(--font-heading, 'Playfair Display', serif);
    font-size: 18px;
    font-weight: 400;
    color: var(--text-primary, #3A3530);
    margin-bottom: 8px;
}

.kit-seasonal-card p {
    font-size: 14px;
    color: var(--text-light, #8A8580);
}


/* ========================================
   RESPONSIVE — TABLET (horizontal)
   ======================================== */
@media (max-width: 1024px) {
    .kit-alcoves-grid {
        width: 97%;
        gap: 24px;
    }

    .kit-alcove-inner {
        padding: 24px !important;
        column-gap: 14px !important;
        display: grid !important;
        grid-template-columns: 130px 1fr 190px !important;
        align-items: center !important;
        text-align: left !important;
    }

    .kit-alcove-icon {
        grid-column: 1 !important;
        grid-row: 1 !important;
        width: 140px;
        height: 140px;
    }

    .kit-alcove-icon-img {
        max-width: 125px;
        max-height: 135px;
    }

    .kit-alcove-cta .kit-btn {
        width: 180px;
        height: 56px;
    }

    .kit-seasonal-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}


/* ========================================
   RESPONSIVE — NARROW TABLET (horizontal)
   ======================================== */
@media (max-width: 768px) {
    /* Switch to image-based cards on mobile */
    .kit-alcoves-desktop {
        display: none !important;
    }
    .kit-alcoves-mobile {
        display: block !important;
        width: 94%;
        max-width: 600px;
        margin: 0 auto;
    }

    .kit-alcoves-grid {
        width: 98%;
        gap: 20px;
    }

    .kit-alcove-inner {
        padding: 18px 14px !important;
        display: grid !important;
        grid-template-columns: 100px 1fr 145px !important;
        column-gap: 12px !important;
        align-items: center !important;
        text-align: left !important;
        min-height: 220px !important;
        max-height: none !important;
    }

    .kit-alcove-icon {
        grid-column: 1 !important;
        grid-row: 1 !important;
        width: 100px;
        height: 100px;
    }

    .kit-alcove-icon-img {
        max-width: 90px;
        max-height: 95px;
    }

    .kit-alcove-title {
        font-size: 24px;
        margin-bottom: 10px;
    }

    .kit-alcove-duration {
        font-size: 13px;
        margin-bottom: 12px;
    }

    .kit-alcove-desc {
        font-size: 13px;
        line-height: 1.45;
        max-width: 100%;
    }

    .kit-alcove-cta .kit-btn {
        width: 140px;
        height: 48px;
        font-size: 12px;
        padding: 10px 12px;
    }
}


/* ========================================
   RESPONSIVE — MOBILE (STILL HORIZONTAL)
   ======================================== */
@media (max-width: 560px) {
    .kit-temple-gate-title {
        font-size: 26px;
        letter-spacing: 1px;
    }

    .kit-temple-gate-subtitle {
        font-size: 14px;
    }

    .kit-temple-buddha-img {
        width: 110px;
        height: 110px;
    }

    .kit-alcoves-grid {
        width: calc(100% - 8px);
        gap: 16px;
    }

    .kit-alcove-inner {
        padding: 22px 18px !important;
        display: grid !important;
        grid-template-columns: 78px minmax(190px, 1fr) 96px !important;
        column-gap: 10px !important;
        align-items: center !important;
        text-align: left !important;
        min-height: 220px !important;
        max-height: none !important;
    }

    .kit-alcove-icon {
        grid-column: 1 !important;
        grid-row: 1 !important;
        width: 78px !important;
        height: 78px !important;
        margin-bottom: 0 !important;
    }

    .kit-alcove-icon-img {
        max-width: 70px !important;
        max-height: 70px !important;
        filter: drop-shadow(0 0 10px rgba(226,170,62,0.18)) !important;
    }

    .kit-alcove-text {
        grid-column: 2 !important;
        grid-row: 1 !important;
        text-align: left !important;
    }

    .kit-alcove-title {
        font-size: 19px !important;
        line-height: 1.1 !important;
        margin-bottom: 6px !important;
        white-space: nowrap !important;
    }

    .kit-alcove-duration {
        font-size: 12px !important;
        margin-bottom: 8px !important;
    }

    .kit-alcove-desc {
        font-size: 14px !important;
        line-height: 1.45 !important;
        max-width: 100% !important;
    }

    .kit-alcove-cta {
        grid-column: 3 !important;
        grid-row: 1 !important;
        justify-content: flex-end !important;
    }

    .kit-alcove-cta .kit-btn {
        width: 96px !important;
        min-height: 42px !important;
        font-size: 11px !important;
        white-space: normal !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        line-height: 1.15 !important;
        text-align: center !important;
        padding: 6px 4px !important;
    }

    .kit-lifecycle-steps {
        flex-direction: column;
        gap: 8px;
    }

    .kit-lifecycle-arrow {
        transform: rotate(90deg);
        padding: 0;
        justify-content: center;
    }

    .kit-blessing-chamber {
        padding: 40px 16px;
    }

    .kit-blessing-create {
        padding: 40px 16px;
    }

    .kit-bless-title {
        font-size: 20px;
    }

    .kit-prayer-wall {
        grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    }

    .kit-released-wall {
        grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    }

    .kit-seasonal-grid {
        grid-template-columns: 1fr;
    }
}


/* ========================================
   RESPONSIVE — VERY SMALL MOBILE (still horizontal, compressed)
   ======================================== */
@media (max-width: 380px) {
    .kit-alcove-inner {
        padding: 16px 12px !important;
        display: grid !important;
        grid-template-columns: 62px minmax(150px, 1fr) 80px !important;
        column-gap: 6px !important;
        align-items: center !important;
        text-align: left !important;
        min-height: 190px !important;
        max-height: none !important;
    }

    .kit-alcove-icon {
        grid-column: 1 !important;
        grid-row: 1 !important;
        width: 62px !important;
        height: 62px !important;
        margin-bottom: 0 !important;
    }

    .kit-alcove-icon-img {
        max-width: 54px !important;
        max-height: 54px !important;
        filter: drop-shadow(0 0 8px rgba(226,170,62,0.15)) !important;
    }

    .kit-alcove-title {
        font-size: 16px !important;
        line-height: 1.1 !important;
        margin-bottom: 4px !important;
        white-space: nowrap !important;
    }

    .kit-alcove-duration {
        font-size: 11px !important;
        margin-bottom: 6px !important;
    }

    .kit-alcove-desc {
        font-size: 12px !important;
        line-height: 1.4 !important;
    }

    .kit-alcove-cta {
        grid-column: 3 !important;
        grid-row: 1 !important;
        justify-content: flex-end !important;
    }

    .kit-alcove-cta .kit-btn {
        width: 80px !important;
        min-height: 38px !important;
        font-size: 10px !important;
        white-space: normal !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        line-height: 1.15 !important;
        text-align: center !important;
        padding: 5px 3px !important;
    }
}


/* ========================================
   GUIDED DONATION STEP + CONFIRMATION CHECKBOX
   ======================================== */
.kit-bless-donate-details {
    margin: 1.5rem 0;
    padding: 1.2rem 1.5rem;
    background: rgba(201,169,110,0.06);
    border: 1px solid rgba(201,169,110,0.15);
    border-radius: 8px;
}

.kit-bless-donate-charity,
.kit-bless-donate-amount {
    margin: 0.4rem 0;
    font-size: 0.95rem;
    color: var(--kit-text-secondary, #b8a88a);
}

.kit-bless-donate-details strong {
    color: var(--kit-gold, #c9a96e);
}

#bless-donate-link {
    display: inline-block;
    margin: 1.2rem 0;
    text-align: center;
    width: 100%;
    max-width: 360px;
}

.kit-bless-confirm-checkbox-wrap {
    margin: 1.8rem 0 1rem;
    padding: 1rem 1.2rem;
    background: rgba(201,169,110,0.04);
    border: 1px solid rgba(201,169,110,0.12);
    border-radius: 6px;
}

.kit-bless-confirm-label {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    cursor: pointer;
    font-size: 0.92rem;
    line-height: 1.5;
    color: var(--kit-text-secondary, #b8a88a);
}

.kit-bless-confirm-checkbox {
    width: 18px;
    height: 18px;
    min-width: 18px;
    margin-top: 2px;
    accent-color: var(--kit-gold, #c9a96e);
    cursor: pointer;
}

.kit-bless-place:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.kit-bless-ajax-error {
    color: #e74c3c;
    font-size: 0.88rem;
    margin-top: 0.75rem;
}

.kit-bless-email-wrap {
    margin-top: 1rem;
}

.kit-bless-email {
    width: 100%;
    padding: 0.6rem 0.8rem;
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(201,169,110,0.2);
    border-radius: 6px;
    color: var(--kit-text-primary, #e8dcc8);
    font-size: 0.92rem;
    transition: border-color 0.2s ease;
}

.kit-bless-email:focus {
    outline: none;
    border-color: rgba(201,169,110,0.5);
}

/* ========================================
   HEALING NAMES REGISTRY — CHIP LAYOUT
   ======================================== */

.kit-blessing-names-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 8px;
    justify-content: center;
    padding: 0 20px;
}

.kit-name-chip {
    display: inline-flex;
    align-items: center;
    padding: 6px 14px;
    background: rgba(201, 169, 110, 0.12);
    border: 1px solid rgba(201, 169, 110, 0.3);
    border-radius: 20px;
    font-size: 13px;
    color: rgba(232, 213, 168, 0.85);
    white-space: nowrap;
    transition: background 0.2s ease;
}

.kit-name-chip:hover {
    background: rgba(201, 169, 110, 0.2);
}

.kit-name-chip--hidden {
    display: none;
}

.kit-names-show-more {
    display: block;
    margin: 16px auto 0;
    background: none;
    border: 1px solid rgba(201, 169, 110, 0.4);
    border-radius: 16px;
    padding: 6px 18px;
    font-size: 12px;
    color: rgba(201, 169, 110, 0.8);
    cursor: pointer;
    transition: border-color 0.2s ease, color 0.2s ease;
}

.kit-names-show-more:hover {
    border-color: rgba(201, 169, 110, 0.7);
    color: rgba(232, 213, 168, 1);
}

@media (max-width: 768px) {
    .kit-blessing-names-chips {
        gap: 8px 6px;
        padding: 0 12px;
    }

    .kit-name-chip {
        padding: 5px 12px;
        font-size: 12px;
    }
}

@media (max-width: 480px) {
    .kit-blessing-names-chips {
        gap: 6px 5px;
        padding: 0 8px;
    }

    .kit-name-chip {
        padding: 4px 10px;
        font-size: 11px;
    }
}
