/* ============================================================
   Party Packages - Inflatable Rentals
   Styles for party browse, package detail, the builder wizard,
   cake designer and interactive scene builder.
   ============================================================ */

.party-hero {
    background: linear-gradient(135deg, var(--secondary) 0%, var(--primary) 100%);
    color: #fff;
    padding: 3rem 0 2.5rem;
    position: relative;
}
.party-hero h1 { color: #fff; font-size: 2.4rem; margin-bottom: .5rem; }
.party-hero p  { opacity: .92; font-size: 1.05rem; max-width: 680px; }
.party-hero .breadcrumb a { color: rgba(255,255,255,.75); }
.party-hero .breadcrumb-current { color: #fff; }

/* ---- Party type grid ---- */
.party-type-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1.5rem;
}
.party-type-card {
    background: #fff;
    border-radius: var(--radius-lg, 16px);
    box-shadow: var(--shadow, 0 4px 20px rgba(0,0,0,.1));
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    transition: transform .2s, box-shadow .2s;
    border: 2px solid transparent;
}
.party-type-card:hover { transform: translateY(-6px); box-shadow: 0 12px 32px rgba(0,0,0,.16); border-color: var(--accent); }
.party-type-card-top {
    height: 150px;
    background: linear-gradient(135deg, var(--primary) 0%, var(--accent) 100%);
    display: flex; align-items: center; justify-content: center;
    color: #fff;
}
.party-type-card-top img { width: 100%; height: 100%; object-fit: cover; }
.party-type-card-top i { font-size: 3.4rem; opacity: .92; }
.party-type-card-body { padding: 1.25rem; flex: 1; display: flex; flex-direction: column; }
.party-type-card-body h3 { font-family: var(--font-heading); color: var(--dark); margin-bottom: .4rem; font-size: 1.2rem; }
.party-type-card-body p { color: var(--gray-600, #5b6472); font-size: .92rem; flex: 1; }
.party-type-card-foot { margin-top: .75rem; font-weight: 700; color: var(--primary); }

/* ---- Package comparison cards ---- */
.package-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
    align-items: stretch;
}
.package-card {
    background: #fff;
    border-radius: var(--radius-lg, 16px);
    box-shadow: var(--shadow, 0 4px 20px rgba(0,0,0,.1));
    overflow: hidden;
    display: flex;
    flex-direction: column;
    border: 3px solid transparent;
    position: relative;
}
.package-card.is-featured { border-color: var(--accent); }
.package-ribbon {
    position: absolute; top: 14px; right: -34px;
    background: var(--accent); color: var(--dark);
    font-family: var(--font-heading); font-size: .8rem;
    padding: .3rem 2.5rem; transform: rotate(45deg);
}
.package-card-img { height: 170px; background: linear-gradient(135deg, var(--secondary), var(--primary)); display:flex;align-items:center;justify-content:center; }
.package-card-img img { width: 100%; height: 100%; object-fit: cover; }
.package-card-img i { font-size: 3rem; color: #fff; opacity: .6; }
.package-card-body { padding: 1.4rem; display: flex; flex-direction: column; flex: 1; }
.package-tier-tag {
    display: inline-block; align-self: flex-start;
    background: var(--light); color: var(--secondary);
    font-weight: 700; font-size: .72rem; letter-spacing: .04em;
    padding: .25rem .65rem; border-radius: 50px; text-transform: uppercase;
    margin-bottom: .5rem;
}
.package-card-body h3 { font-family: var(--font-heading); color: var(--dark); font-size: 1.35rem; margin-bottom: .35rem; }
.package-price { font-family: var(--font-heading); color: var(--primary); font-size: 2rem; line-height: 1; margin: .35rem 0 .75rem; }
.package-price small { font-size: .85rem; color: var(--gray-600, #5b6472); font-family: var(--font-body); }
.package-card-desc { color: var(--gray-700, #41495a); font-size: .92rem; margin-bottom: .9rem; }
.package-incl { list-style: none; padding: 0; margin: 0 0 1rem; }
.package-incl li { padding: .3rem 0; font-size: .9rem; color: var(--gray-700, #41495a); display: flex; gap: .55rem; }
.package-incl li i { color: var(--success, #06D6A0); margin-top: .15rem; }
.package-card-body .btn { margin-top: auto; }

/* ---- Generic party section ---- */
.party-section { padding: 3rem 0; }
.party-section-light { background: var(--light); }

/* ---- Color chooser (per-occasion photo color picker) ---- */
.color-chooser { text-align: center; margin: 0 auto 2.75rem; max-width: 860px; }
.color-chooser-stage {
    border-radius: var(--radius-lg, 16px);
    overflow: hidden;
    box-shadow: var(--shadow, 0 4px 20px rgba(0,0,0,.12));
    margin: 1.25rem 0 1rem;
    background: var(--light);
    aspect-ratio: 16 / 9;
}
.color-chooser-stage img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
    transition: opacity .25s ease;
}
.color-chooser-swatches {
    display: flex; flex-wrap: wrap;
    gap: .6rem; justify-content: center;
}
.color-swatch {
    display: inline-flex; align-items: center; gap: .5rem;
    padding: .45rem .9rem .45rem .5rem;
    background: #fff;
    border: 2px solid var(--gray-200, #e6e8ee);
    border-radius: 50px;
    cursor: pointer;
    font-family: var(--font-body); font-weight: 700; font-size: .9rem;
    color: var(--dark);
    transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.color-swatch:hover { transform: translateY(-2px); }
.color-swatch.active {
    border-color: var(--primary);
    box-shadow: 0 6px 16px -6px rgba(232,69,95,.5);
}
.color-swatch-dot {
    width: 26px; height: 26px; border-radius: 50%;
    border: 2px solid #fff;
    box-shadow: 0 0 0 1px rgba(0,0,0,.12);
}
@media (max-width: 480px) {
    .color-swatch-label { font-size: .82rem; }
}

/* ---- Builder wizard ---- */
.builder-steps {
    display: flex; flex-wrap: wrap; gap: .5rem;
    margin-bottom: 1.75rem;
}
.builder-step {
    flex: 1; min-width: 110px;
    text-align: center; padding: .65rem .5rem;
    border-radius: var(--radius, 12px);
    background: #fff; box-shadow: var(--shadow);
    font-weight: 700; font-size: .85rem; color: var(--gray-500, #8b94a3);
    border: 2px solid transparent;
}
.builder-step.active { color: var(--primary); border-color: var(--primary); }
.builder-step.done { color: var(--success, #06D6A0); }
.builder-step .step-num {
    display: inline-flex; width: 24px; height: 24px;
    align-items: center; justify-content: center;
    border-radius: 50%; background: var(--light);
    margin-right: .35rem; font-size: .8rem;
}
.builder-step.active .step-num { background: var(--primary); color: #fff; }
.builder-step.done .step-num { background: var(--success, #06D6A0); color: #fff; }

.builder-layout { display: grid; grid-template-columns: 1fr 320px; gap: 1.5rem; align-items: start; }
.builder-panel {
    background: #fff; border-radius: var(--radius-lg, 16px);
    box-shadow: var(--shadow); padding: 1.5rem;
}
.builder-panel h2 { font-family: var(--font-heading); color: var(--dark); margin-bottom: .35rem; }
.builder-pane { display: none; }
.builder-pane.active { display: block; }

/* Summary sidebar */
.party-summary {
    background: #fff; border-radius: var(--radius-lg, 16px);
    box-shadow: var(--shadow); padding: 1.4rem; position: sticky; top: 90px;
}
.party-summary h3 { font-family: var(--font-heading); color: var(--dark); margin-bottom: .75rem; }
.summary-line { display: flex; justify-content: space-between; padding: .35rem 0; font-size: .92rem; gap: 1rem; }
.summary-line .s-label { color: var(--gray-700, #41495a); }
.summary-line.s-total { border-top: 2px solid var(--gray-200, #e6e8ee); margin-top: .5rem; padding-top: .65rem; font-weight: 800; font-size: 1.1rem; }
.summary-line.s-deposit { color: var(--secondary); font-weight: 700; }

/* Option cards (upgrades / add-ons) */
.option-card {
    display: flex; gap: 1rem; align-items: center;
    border: 2px solid var(--gray-200, #e6e8ee);
    border-radius: var(--radius, 12px);
    padding: 1rem; margin-bottom: .75rem; cursor: pointer;
    transition: border-color .15s, background .15s;
}
.option-card:hover { border-color: var(--primary); }
.option-card.selected { border-color: var(--primary); background: rgba(255,107,53,.05); }
.option-card--unavailable {
    opacity: .6;
    filter: grayscale(.8);
    cursor: not-allowed;
}
.option-card--unavailable:hover { border-color: var(--gray-200, #e6e8ee); }
.unavailable-tag {
    display: inline-block;
    font-size: .62rem; font-weight: 800; letter-spacing: .06em;
    text-transform: uppercase;
    background: var(--gray-300, #cdd2db); color: var(--dark);
    padding: .14rem .5rem; border-radius: 50px;
    vertical-align: middle; margin-left: .4rem;
}
.option-card-img {
    width: 60px; height: 60px; border-radius: 10px; flex-shrink: 0;
    background: var(--light); display:flex;align-items:center;justify-content:center;
    color: var(--primary); overflow: hidden;
}
.option-card-img img { width: 100%; height: 100%; object-fit: cover; }
.option-card-info { flex: 1; }
.option-card-info h4 { margin: 0 0 .15rem; font-size: 1rem; color: var(--dark); }
.option-card-info p { margin: 0; font-size: .85rem; color: var(--gray-600, #5b6472); }
.option-card-price { font-family: var(--font-heading); color: var(--primary); white-space: nowrap; }
.option-qty { display: flex; align-items: center; gap: .35rem; }
.option-qty input { width: 56px; text-align: center; }

/* ---- Cake designer ---- */
.cake-designer { display: grid; grid-template-columns: 280px 1fr; gap: 1.5rem; align-items: start; }
.cake-preview-wrap {
    background: linear-gradient(160deg, #fdf0f5, #eef4fb);
    border-radius: var(--radius-lg, 16px); padding: 1.5rem;
    display: flex; flex-direction: column; align-items: center;
    position: sticky; top: 90px;
}
.cake-stage { width: 220px; height: 200px; position: relative; }
.cake-tier {
    position: absolute; left: 50%; transform: translateX(-50%);
    border-radius: 12px 12px 6px 6px;
}
.cake-tier-bottom { width: 200px; height: 90px; bottom: 0; }
.cake-tier-top    { width: 130px; height: 70px; bottom: 84px; }
.cake-frosting {
    position: absolute; left: 50%; transform: translateX(-50%);
    height: 20px; border-radius: 50%;
}
.cake-msg {
    position: absolute; left: 0; right: 0; bottom: 110px;
    text-align: center; font-family: var(--font-heading);
    font-size: .95rem; padding: 0 12px; word-break: break-word;
}
.cake-plate { position:absolute; bottom:-10px; left:50%; transform:translateX(-50%); width:230px; height:22px; background:#dfe3ea; border-radius:50%; }

/* ---- Scene builder ---- */
.scene-builder-wrap { display: grid; grid-template-columns: 220px 1fr; gap: 1rem; }
.scene-palette {
    background: #fff; border-radius: var(--radius, 12px);
    box-shadow: var(--shadow); padding: 1rem; max-height: 560px; overflow-y: auto;
}
.scene-palette h4 { font-size: .8rem; text-transform: uppercase; color: var(--gray-500,#8b94a3); margin: .85rem 0 .4rem; letter-spacing: .04em; }
.scene-palette h4:first-child { margin-top: 0; }
.palette-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; }
.palette-item {
    background: var(--light); border-radius: 10px; padding: .5rem;
    cursor: grab; text-align: center; border: 2px solid transparent;
}
.palette-item:hover { border-color: var(--primary); }
.palette-item img, .palette-item svg { width: 100%; height: 46px; object-fit: contain; pointer-events: none; }
.palette-item span { font-size: .68rem; color: var(--gray-600,#5b6472); display: block; margin-top: .2rem; }

.scene-stage-col { display: flex; flex-direction: column; gap: .75rem; }
.scene-toolbar { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center; }
.scene-canvas {
    position: relative; width: 100%; height: 460px;
    border-radius: var(--radius, 12px); overflow: hidden;
    box-shadow: var(--shadow); background-size: cover; background-position: center;
}
.scene-bg-sky    { background: linear-gradient(#bfe3ff 0%, #e7f5ff 55%, #bfe6b8 55%, #9ed18f 100%); }
.scene-bg-indoor { background: linear-gradient(#f3e9d8 0%, #efe2ca 60%, #d8c2a0 60%, #c9ad84 100%); }
.scene-bg-night  { background: linear-gradient(#1b2a4a 0%, #38406b 55%, #2a3550 55%, #1b2236 100%); }
.scene-bg-garden { background: linear-gradient(#cdeafe 0%, #e8f7ff 50%, #aee0a0 50%, #7ec46b 100%); }

.scene-item { position: absolute; cursor: move; touch-action: none; }
.scene-item .scene-item-inner { width: 100%; height: 100%; }
.scene-item.selected { outline: 2px dashed var(--primary); outline-offset: 3px; }
.scene-item svg { width: 100%; height: 100%; display: block; }
.scene-item img { width: 100%; height: 100%; display: block; }
.scene-handle {
    position: absolute; width: 22px; height: 22px; border-radius: 50%;
    background: var(--primary); color: #fff; display: none;
    align-items: center; justify-content: center; font-size: .65rem;
    cursor: pointer; z-index: 5;
}
.scene-item.selected .scene-handle { display: flex; }
.scene-handle-del    { top: -11px; right: -11px; background: var(--danger, #EF476F); }
.scene-handle-resize { bottom: -11px; right: -11px; cursor: nwse-resize; background: var(--secondary); }
.scene-handle-rotate { top: -11px; left: -11px; cursor: grab; background: var(--accent); color: var(--dark); }

.scene-colorbar {
    display: flex; flex-wrap: wrap; gap: .35rem; align-items: center;
    background: #fff; border-radius: var(--radius, 12px);
    box-shadow: var(--shadow); padding: .65rem .85rem;
}
.scene-swatch {
    width: 26px; height: 26px; border-radius: 50%;
    border: 2px solid #fff; box-shadow: 0 0 0 1px rgba(0,0,0,.15); cursor: pointer;
}
.scene-swatch.active { box-shadow: 0 0 0 2px var(--primary); }

/* ---- Agreement signing ---- */
.agreement-box {
    max-height: 260px;
    overflow-y: auto;
    border: 1px solid var(--gray-200, #e6e8ee);
    border-radius: var(--radius, 12px);
    padding: 1rem 1.25rem;
    background: var(--light);
    font-size: .9rem;
    line-height: 1.65;
    margin-bottom: 1rem;
}
.agreement-box h3 {
    font-family: var(--font-heading);
    font-size: 1rem;
    color: var(--dark);
    margin: 1.1rem 0 .35rem;
}
.agreement-box h3:first-child { margin-top: 0; }
.signature-canvas {
    width: 100%;
    height: 160px;
    border: 2px dashed var(--gray-300, #cdd2db);
    border-radius: var(--radius, 12px);
    background: #fff;
    touch-action: none;
    cursor: crosshair;
    display: block;
}

/* ---- Locked notice ---- */
.lock-banner {
    background: #FFF3CD; border: 1px solid #FFD166; color: #856404;
    border-radius: var(--radius, 12px); padding: 1rem 1.25rem; margin-bottom: 1.5rem;
}
.lock-banner i { margin-right: .5rem; }

/* ============================================================
   RESPONSIVE  —  mobile-perfect pass
   ============================================================ */

/* Tablet / small laptop */
@media (max-width: 900px) {
    .builder-layout { grid-template-columns: 1fr; }
    .party-summary { position: static; }
    .cake-designer { grid-template-columns: 1fr; }
    .cake-preview-wrap { position: static; }
    .scene-builder-wrap { grid-template-columns: 1fr; }
    .scene-palette { max-height: 220px; }
    .builder-panel { padding: 1.25rem; }
}

/* Phones */
@media (max-width: 768px) {
    .party-hero { padding: 2.4rem 0 2rem; }
    .party-hero h1 { font-size: clamp(1.9rem, 7vw, 2.4rem); }
    .party-section { padding: 2.25rem 0; }

    /* Wizard step pills: compact, horizontally scrollable strip */
    .builder-steps {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        padding-bottom: 4px;
    }
    .builder-steps::-webkit-scrollbar { display: none; }
    .builder-step { min-width: 88px; font-size: 0.74rem; padding: 0.55rem 0.4rem; }
    .builder-step .step-num { width: 20px; height: 20px; font-size: 0.72rem; }

    /* Option cards (upgrades / add-ons): let content wrap gracefully */
    .option-card { flex-wrap: wrap; gap: 0.65rem 0.85rem; }
    .option-card-info { flex: 1 1 60%; min-width: 55%; }
    .option-card-price { order: 3; }
    .option-card > input[type="checkbox"] { margin-left: auto; }
    .option-qty { order: 4; margin-left: auto; }

    /* Summary sidebar full width */
    .party-summary { margin-top: 1.25rem; }

    /* Scene builder: shorter canvas, taller scrollable palette */
    .scene-canvas { height: 360px; }
    .scene-palette { max-height: 260px; }
    .palette-item img, .palette-item svg { height: 40px; }
    .scene-toolbar { gap: 0.4rem; }
    .scene-toolbar .btn-sm { flex: 1 1 auto; }

    /* Cake preview scales down */
    .cake-stage { transform: scale(0.92); }

    /* Package + party-type grids: single column reads better on phones */
    .package-grid,
    .party-type-grid { grid-template-columns: 1fr; }

    .package-ribbon { font-size: 0.72rem; padding: 0.28rem 2.2rem; }
}

/* Small phones */
@media (max-width: 480px) {
    .party-hero h1 { font-size: clamp(1.65rem, 8vw, 2.05rem); }
    .builder-panel { padding: 1rem; }
    .builder-panel h2 { font-size: 1.15rem; }
    .option-card { padding: 0.85rem; }
    .option-card-img { width: 48px; height: 48px; }
    .scene-canvas { height: 300px; }
    .cake-stage { transform: scale(0.82); transform-origin: top center; }
    .summary-line { font-size: 0.88rem; }
}
