/**
 * Kalendarz Adwentowy Pro - Style Główne
 * Profesjonalny, minimalistyczny design UI/UX
 * Autor: Krystian Sonski | soskip.pl
 */

/* ============================================
   CSS CUSTOM PROPERTIES
   ============================================ */
:root {
    --acp-primary: #a52422;
    --acp-secondary: #2d5a3d;
    --acp-accent: #d4a84b;
    --acp-background: #1a2332;
    --acp-text: #ffffff;
    --acp-text-muted: rgba(255, 255, 255, 0.7);
    --acp-border-radius: 16px;
    --acp-border-radius-sm: 8px;
    --acp-border-radius-lg: 24px;
    --acp-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    --acp-transition-fast: all 0.15s ease;
    --acp-transition-slow: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    --acp-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
    --acp-shadow-hover: 0 20px 60px rgba(0, 0, 0, 0.4);
    --acp-shadow-glow: 0 0 30px rgba(212, 168, 75, 0.5);
    --acp-glass: rgba(255, 255, 255, 0.1);
    --acp-glass-border: rgba(255, 255, 255, 0.2);
}

/* ============================================
   CALENDAR WRAPPER
   ============================================ */
.acp-calendar-wrapper {
    position: relative;
    max-width: 1200px;
    margin: 0 auto;
    padding: 60px 40px;
    background: linear-gradient(135deg, var(--acp-background) 0%, color-mix(in srgb, var(--acp-background) 80%, var(--acp-primary)) 100%);
    background-size: cover;
    background-position: center;
    border-radius: var(--acp-border-radius-lg);
    overflow: hidden;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
}

.acp-calendar-wrapper::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: radial-gradient(ellipse at top, transparent 0%, rgba(0, 0, 0, 0.3) 100%);
    pointer-events: none;
}

/* ============================================
   HEADER
   ============================================ */
.acp-calendar-header {
    position: relative;
    text-align: center;
    margin-bottom: 50px;
    z-index: 1;
}

.acp-calendar-title {
    font-size: clamp(2rem, 5vw, 3.5rem);
    font-weight: 800;
    color: var(--acp-text);
    margin: 0 0 15px;
    text-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    letter-spacing: -0.02em;
    background: linear-gradient(135deg, var(--acp-text) 0%, var(--acp-accent) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.acp-calendar-subtitle {
    font-size: clamp(1rem, 2vw, 1.25rem);
    color: var(--acp-text-muted);
    margin: 0;
    font-weight: 400;
}

/* ============================================
   COUNTDOWN - Odliczanie do kolejnego okienka
   ============================================ */
.acp-countdown-container {
    margin-top: 30px;
    padding: 24px 32px;
    background: var(--acp-glass);
    border: 1px solid var(--acp-glass-border);
    border-radius: var(--acp-border-radius);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    display: inline-block;
}

.acp-countdown-label {
    font-size: 0.9rem;
    color: var(--acp-text-muted);
    margin: 0 0 16px;
    text-transform: uppercase;
    letter-spacing: 1px;
    font-weight: 500;
}

.acp-countdown-timer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.acp-countdown-unit {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 70px;
}

.acp-countdown-value {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--acp-accent);
    line-height: 1;
    font-variant-numeric: tabular-nums;
    text-shadow: 0 2px 10px rgba(212, 168, 75, 0.3);
}

.acp-countdown-text {
    font-size: 0.75rem;
    color: var(--acp-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 6px;
}

.acp-countdown-separator {
    font-size: 2rem;
    font-weight: 700;
    color: var(--acp-accent);
    opacity: 0.5;
    margin-bottom: 20px;
    animation: countdownBlink 1s ease-in-out infinite;
}

@keyframes countdownBlink {
    0%, 100% { opacity: 0.5; }
    50% { opacity: 1; }
}

.acp-countdown-next-day {
    margin: 16px 0 0;
    font-size: 0.85rem;
    color: var(--acp-text-muted);
}

.acp-countdown-next-day span {
    color: var(--acp-accent);
    font-weight: 700;
}

/* Responsywność odliczania */
@media (max-width: 480px) {
    .acp-countdown-container {
        padding: 20px 24px;
        margin-top: 24px;
    }

    .acp-countdown-unit {
        min-width: 55px;
    }

    .acp-countdown-value {
        font-size: 2rem;
    }

    .acp-countdown-separator {
        font-size: 1.5rem;
        margin-bottom: 16px;
    }

    .acp-countdown-label {
        font-size: 0.8rem;
    }
}

/* ============================================
   CALENDAR GRID - BASE
   ============================================ */
.acp-calendar-grid {
    position: relative;
    display: grid;
    gap: 15px;
    z-index: 1;
    max-width: 100%;
}

/* ============================================
   LAYOUT: Siatka 6x4 (domyślna)
   ============================================ */
.layout-grid-6x4 .acp-calendar-grid,
.acp-calendar-wrapper:not([class*="layout-"]) .acp-calendar-grid {
    grid-template-columns: repeat(6, 1fr);
    gap: 18px;
}

/* ============================================
   LAYOUT: Siatka 4x6
   ============================================ */
.layout-grid-4x6 .acp-calendar-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}

/* ============================================
   LAYOUT: Siatka 8x3
   ============================================ */
.layout-grid-8x3 .acp-calendar-grid {
    grid-template-columns: repeat(8, 1fr);
    gap: 12px;
}

/* ============================================
   LAYOUT: Siatka 3x8
   ============================================ */
.layout-grid-3x8 .acp-calendar-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}

/* ============================================
   LAYOUT: Bento Box - Asymetryczny nowoczesny układ
   ============================================ */
.layout-bento .acp-calendar-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-auto-rows: minmax(80px, auto);
    gap: 15px;
}

/* Duże kafelki na kluczowe dni */
.layout-bento .acp-door:nth-child(1) { grid-column: span 2; grid-row: span 2; }
.layout-bento .acp-door:nth-child(6) { grid-column: span 2; }
.layout-bento .acp-door:nth-child(12) { grid-column: span 2; grid-row: span 2; }
.layout-bento .acp-door:nth-child(18) { grid-column: span 2; }
.layout-bento .acp-door:nth-child(24) { grid-column: span 3; grid-row: span 2; }

/* ============================================
   LAYOUT: Pinterest Masonry - Kolumnowy z różnymi wysokościami
   ============================================ */
.layout-pinterest .acp-calendar-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-auto-rows: 60px;
    gap: 15px;
}

.layout-pinterest .acp-door { grid-row: span 2; }
.layout-pinterest .acp-door:nth-child(3n+1) { grid-row: span 3; }
.layout-pinterest .acp-door:nth-child(5n+2) { grid-row: span 2; }
.layout-pinterest .acp-door:nth-child(7n) { grid-row: span 4; }
.layout-pinterest .acp-door:nth-child(24) { grid-row: span 3; }

/* ============================================
   LAYOUT: Plaster Miodu (Honeycomb) - Heksagonalny
   ============================================ */
.layout-honeycomb .acp-calendar-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    max-width: 900px;
    margin: 0 auto;
}

.layout-honeycomb .acp-door {
    width: 100px;
    height: 115px;
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
    margin: 0 -15px;
}

.layout-honeycomb .acp-door:nth-child(7n+1),
.layout-honeycomb .acp-door:nth-child(7n+2),
.layout-honeycomb .acp-door:nth-child(7n+3),
.layout-honeycomb .acp-door:nth-child(7n+4),
.layout-honeycomb .acp-door:nth-child(7n+5),
.layout-honeycomb .acp-door:nth-child(7n+6),
.layout-honeycomb .acp-door:nth-child(7n) {
    margin-top: -30px;
}

.layout-honeycomb .acp-door:nth-child(-n+7) {
    margin-top: 0;
}

.layout-honeycomb .acp-door:nth-child(7n+1) {
    margin-left: 60px;
}

/* ============================================
   LAYOUT: Choinka (Christmas Tree)
   ============================================ */
.layout-christmas-tree .acp-calendar-grid {
    display: grid;
    grid-template-columns: repeat(9, 1fr);
    gap: 10px;
    max-width: 800px;
    margin: 0 auto;
}

/* Gwiazdka na czubku */
.layout-christmas-tree .acp-door:nth-child(24) {
    grid-column: 5;
    grid-row: 1;
    transform: scale(1.2);
}
/* Poziom 1 - 1 element */
.layout-christmas-tree .acp-door:nth-child(1) { grid-column: 5; grid-row: 2; }
/* Poziom 2 - 3 elementy */
.layout-christmas-tree .acp-door:nth-child(2) { grid-column: 4; grid-row: 3; }
.layout-christmas-tree .acp-door:nth-child(3) { grid-column: 5; grid-row: 3; }
.layout-christmas-tree .acp-door:nth-child(4) { grid-column: 6; grid-row: 3; }
/* Poziom 3 - 5 elementów */
.layout-christmas-tree .acp-door:nth-child(5) { grid-column: 3; grid-row: 4; }
.layout-christmas-tree .acp-door:nth-child(6) { grid-column: 4; grid-row: 4; }
.layout-christmas-tree .acp-door:nth-child(7) { grid-column: 5; grid-row: 4; }
.layout-christmas-tree .acp-door:nth-child(8) { grid-column: 6; grid-row: 4; }
.layout-christmas-tree .acp-door:nth-child(9) { grid-column: 7; grid-row: 4; }
/* Poziom 4 - 5 elementów */
.layout-christmas-tree .acp-door:nth-child(10) { grid-column: 3; grid-row: 5; }
.layout-christmas-tree .acp-door:nth-child(11) { grid-column: 4; grid-row: 5; }
.layout-christmas-tree .acp-door:nth-child(12) { grid-column: 5; grid-row: 5; }
.layout-christmas-tree .acp-door:nth-child(13) { grid-column: 6; grid-row: 5; }
.layout-christmas-tree .acp-door:nth-child(14) { grid-column: 7; grid-row: 5; }
/* Poziom 5 - 7 elementów */
.layout-christmas-tree .acp-door:nth-child(15) { grid-column: 2; grid-row: 6; }
.layout-christmas-tree .acp-door:nth-child(16) { grid-column: 3; grid-row: 6; }
.layout-christmas-tree .acp-door:nth-child(17) { grid-column: 4; grid-row: 6; }
.layout-christmas-tree .acp-door:nth-child(18) { grid-column: 5; grid-row: 6; }
.layout-christmas-tree .acp-door:nth-child(19) { grid-column: 6; grid-row: 6; }
.layout-christmas-tree .acp-door:nth-child(20) { grid-column: 7; grid-row: 6; }
.layout-christmas-tree .acp-door:nth-child(21) { grid-column: 8; grid-row: 6; }
/* Pień - 2 elementy */
.layout-christmas-tree .acp-door:nth-child(22) { grid-column: 4; grid-row: 7; }
.layout-christmas-tree .acp-door:nth-child(23) { grid-column: 6; grid-row: 7; }

/* ============================================
   LAYOUT: Wieniec (Wreath) - Okrągły układ
   ============================================ */
.layout-wreath .acp-calendar-grid {
    display: block;
    position: relative;
    width: 600px;
    height: 600px;
    margin: 0 auto;
}

.layout-wreath .acp-door {
    position: absolute;
    width: 80px;
    height: 80px;
    left: 50%;
    top: 50%;
}

/* Rozmieszczenie w okręgu */
.layout-wreath .acp-door:nth-child(1) { transform: translate(-50%, -50%) rotate(0deg) translateY(-250px) rotate(0deg); }
.layout-wreath .acp-door:nth-child(2) { transform: translate(-50%, -50%) rotate(15deg) translateY(-250px) rotate(-15deg); }
.layout-wreath .acp-door:nth-child(3) { transform: translate(-50%, -50%) rotate(30deg) translateY(-250px) rotate(-30deg); }
.layout-wreath .acp-door:nth-child(4) { transform: translate(-50%, -50%) rotate(45deg) translateY(-250px) rotate(-45deg); }
.layout-wreath .acp-door:nth-child(5) { transform: translate(-50%, -50%) rotate(60deg) translateY(-250px) rotate(-60deg); }
.layout-wreath .acp-door:nth-child(6) { transform: translate(-50%, -50%) rotate(75deg) translateY(-250px) rotate(-75deg); }
.layout-wreath .acp-door:nth-child(7) { transform: translate(-50%, -50%) rotate(90deg) translateY(-250px) rotate(-90deg); }
.layout-wreath .acp-door:nth-child(8) { transform: translate(-50%, -50%) rotate(105deg) translateY(-250px) rotate(-105deg); }
.layout-wreath .acp-door:nth-child(9) { transform: translate(-50%, -50%) rotate(120deg) translateY(-250px) rotate(-120deg); }
.layout-wreath .acp-door:nth-child(10) { transform: translate(-50%, -50%) rotate(135deg) translateY(-250px) rotate(-135deg); }
.layout-wreath .acp-door:nth-child(11) { transform: translate(-50%, -50%) rotate(150deg) translateY(-250px) rotate(-150deg); }
.layout-wreath .acp-door:nth-child(12) { transform: translate(-50%, -50%) rotate(165deg) translateY(-250px) rotate(-165deg); }
.layout-wreath .acp-door:nth-child(13) { transform: translate(-50%, -50%) rotate(180deg) translateY(-250px) rotate(-180deg); }
.layout-wreath .acp-door:nth-child(14) { transform: translate(-50%, -50%) rotate(195deg) translateY(-250px) rotate(-195deg); }
.layout-wreath .acp-door:nth-child(15) { transform: translate(-50%, -50%) rotate(210deg) translateY(-250px) rotate(-210deg); }
.layout-wreath .acp-door:nth-child(16) { transform: translate(-50%, -50%) rotate(225deg) translateY(-250px) rotate(-225deg); }
.layout-wreath .acp-door:nth-child(17) { transform: translate(-50%, -50%) rotate(240deg) translateY(-250px) rotate(-240deg); }
.layout-wreath .acp-door:nth-child(18) { transform: translate(-50%, -50%) rotate(255deg) translateY(-250px) rotate(-255deg); }
.layout-wreath .acp-door:nth-child(19) { transform: translate(-50%, -50%) rotate(270deg) translateY(-250px) rotate(-270deg); }
.layout-wreath .acp-door:nth-child(20) { transform: translate(-50%, -50%) rotate(285deg) translateY(-250px) rotate(-285deg); }
.layout-wreath .acp-door:nth-child(21) { transform: translate(-50%, -50%) rotate(300deg) translateY(-250px) rotate(-300deg); }
.layout-wreath .acp-door:nth-child(22) { transform: translate(-50%, -50%) rotate(315deg) translateY(-250px) rotate(-315deg); }
.layout-wreath .acp-door:nth-child(23) { transform: translate(-50%, -50%) rotate(330deg) translateY(-250px) rotate(-330deg); }
.layout-wreath .acp-door:nth-child(24) { transform: translate(-50%, -50%) rotate(345deg) translateY(-250px) rotate(-345deg); }

/* ============================================
   LAYOUT: Wzór Płatka Śniegu (Snowflake Pattern)
   ============================================ */
.layout-snowflake-pattern .acp-calendar-grid {
    display: block;
    position: relative;
    width: 700px;
    height: 700px;
    margin: 0 auto;
}

.layout-snowflake-pattern .acp-door {
    position: absolute;
    width: 70px;
    height: 70px;
    left: 50%;
    top: 50%;
}

/* Centrum */
.layout-snowflake-pattern .acp-door:nth-child(24) {
    transform: translate(-50%, -50%);
    width: 90px;
    height: 90px;
}
/* Wewnętrzny ring (6 elementów) */
.layout-snowflake-pattern .acp-door:nth-child(1) { transform: translate(-50%, -50%) translateY(-100px); }
.layout-snowflake-pattern .acp-door:nth-child(2) { transform: translate(-50%, -50%) rotate(60deg) translateY(-100px) rotate(-60deg); }
.layout-snowflake-pattern .acp-door:nth-child(3) { transform: translate(-50%, -50%) rotate(120deg) translateY(-100px) rotate(-120deg); }
.layout-snowflake-pattern .acp-door:nth-child(4) { transform: translate(-50%, -50%) rotate(180deg) translateY(-100px) rotate(-180deg); }
.layout-snowflake-pattern .acp-door:nth-child(5) { transform: translate(-50%, -50%) rotate(240deg) translateY(-100px) rotate(-240deg); }
.layout-snowflake-pattern .acp-door:nth-child(6) { transform: translate(-50%, -50%) rotate(300deg) translateY(-100px) rotate(-300deg); }
/* Środkowy ring (6 elementów) */
.layout-snowflake-pattern .acp-door:nth-child(7) { transform: translate(-50%, -50%) rotate(30deg) translateY(-180px) rotate(-30deg); }
.layout-snowflake-pattern .acp-door:nth-child(8) { transform: translate(-50%, -50%) rotate(90deg) translateY(-180px) rotate(-90deg); }
.layout-snowflake-pattern .acp-door:nth-child(9) { transform: translate(-50%, -50%) rotate(150deg) translateY(-180px) rotate(-150deg); }
.layout-snowflake-pattern .acp-door:nth-child(10) { transform: translate(-50%, -50%) rotate(210deg) translateY(-180px) rotate(-210deg); }
.layout-snowflake-pattern .acp-door:nth-child(11) { transform: translate(-50%, -50%) rotate(270deg) translateY(-180px) rotate(-270deg); }
.layout-snowflake-pattern .acp-door:nth-child(12) { transform: translate(-50%, -50%) rotate(330deg) translateY(-180px) rotate(-330deg); }
/* Zewnętrzne ramiona (11 elementów) */
.layout-snowflake-pattern .acp-door:nth-child(13) { transform: translate(-50%, -50%) translateY(-280px); }
.layout-snowflake-pattern .acp-door:nth-child(14) { transform: translate(-50%, -50%) rotate(30deg) translateY(-280px) rotate(-30deg); }
.layout-snowflake-pattern .acp-door:nth-child(15) { transform: translate(-50%, -50%) rotate(60deg) translateY(-280px) rotate(-60deg); }
.layout-snowflake-pattern .acp-door:nth-child(16) { transform: translate(-50%, -50%) rotate(90deg) translateY(-280px) rotate(-90deg); }
.layout-snowflake-pattern .acp-door:nth-child(17) { transform: translate(-50%, -50%) rotate(120deg) translateY(-280px) rotate(-120deg); }
.layout-snowflake-pattern .acp-door:nth-child(18) { transform: translate(-50%, -50%) rotate(150deg) translateY(-280px) rotate(-150deg); }
.layout-snowflake-pattern .acp-door:nth-child(19) { transform: translate(-50%, -50%) rotate(180deg) translateY(-280px) rotate(-180deg); }
.layout-snowflake-pattern .acp-door:nth-child(20) { transform: translate(-50%, -50%) rotate(210deg) translateY(-280px) rotate(-210deg); }
.layout-snowflake-pattern .acp-door:nth-child(21) { transform: translate(-50%, -50%) rotate(240deg) translateY(-280px) rotate(-240deg); }
.layout-snowflake-pattern .acp-door:nth-child(22) { transform: translate(-50%, -50%) rotate(300deg) translateY(-280px) rotate(-300deg); }
.layout-snowflake-pattern .acp-door:nth-child(23) { transform: translate(-50%, -50%) rotate(330deg) translateY(-280px) rotate(-330deg); }

/* ============================================
   LAYOUT: Stos Prezentów (Gift Stack)
   ============================================ */
.layout-gift-stack .acp-calendar-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-auto-rows: minmax(70px, auto);
    gap: 12px;
    max-width: 900px;
    margin: 0 auto;
}

/* Duże pudełka na spodzie */
.layout-gift-stack .acp-door:nth-child(1) { grid-column: 1 / 3; grid-row: span 2; }
.layout-gift-stack .acp-door:nth-child(2) { grid-column: 3 / 5; grid-row: span 2; }
.layout-gift-stack .acp-door:nth-child(3) { grid-column: 5; grid-row: span 3; }
/* Średnie pudełka */
.layout-gift-stack .acp-door:nth-child(6) { grid-column: span 2; }
.layout-gift-stack .acp-door:nth-child(12) { grid-column: span 2; grid-row: span 2; }
.layout-gift-stack .acp-door:nth-child(18) { grid-column: span 2; }
.layout-gift-stack .acp-door:nth-child(24) { grid-column: 2 / 5; grid-row: span 2; }

/* ============================================
   LAYOUT: Schody (Staircase)
   ============================================ */
.layout-staircase .acp-calendar-grid {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    gap: 10px;
    max-width: 1000px;
    margin: 0 auto;
}

/* Układamy schody - każdy rząd przesunięty */
.layout-staircase .acp-door:nth-child(1) { grid-column: 1; grid-row: 1; }
.layout-staircase .acp-door:nth-child(2) { grid-column: 2; grid-row: 1; }
.layout-staircase .acp-door:nth-child(3) { grid-column: 3; grid-row: 1; }
.layout-staircase .acp-door:nth-child(4) { grid-column: 2; grid-row: 2; }
.layout-staircase .acp-door:nth-child(5) { grid-column: 3; grid-row: 2; }
.layout-staircase .acp-door:nth-child(6) { grid-column: 4; grid-row: 2; }
.layout-staircase .acp-door:nth-child(7) { grid-column: 3; grid-row: 3; }
.layout-staircase .acp-door:nth-child(8) { grid-column: 4; grid-row: 3; }
.layout-staircase .acp-door:nth-child(9) { grid-column: 5; grid-row: 3; }
.layout-staircase .acp-door:nth-child(10) { grid-column: 4; grid-row: 4; }
.layout-staircase .acp-door:nth-child(11) { grid-column: 5; grid-row: 4; }
.layout-staircase .acp-door:nth-child(12) { grid-column: 6; grid-row: 4; }
.layout-staircase .acp-door:nth-child(13) { grid-column: 5; grid-row: 5; }
.layout-staircase .acp-door:nth-child(14) { grid-column: 6; grid-row: 5; }
.layout-staircase .acp-door:nth-child(15) { grid-column: 7; grid-row: 5; }
.layout-staircase .acp-door:nth-child(16) { grid-column: 6; grid-row: 6; }
.layout-staircase .acp-door:nth-child(17) { grid-column: 7; grid-row: 6; }
.layout-staircase .acp-door:nth-child(18) { grid-column: 8; grid-row: 6; }
.layout-staircase .acp-door:nth-child(19) { grid-column: 5; grid-row: 7; }
.layout-staircase .acp-door:nth-child(20) { grid-column: 6; grid-row: 7; }
.layout-staircase .acp-door:nth-child(21) { grid-column: 7; grid-row: 7; }
.layout-staircase .acp-door:nth-child(22) { grid-column: 4; grid-row: 8; }
.layout-staircase .acp-door:nth-child(23) { grid-column: 5; grid-row: 8; }
.layout-staircase .acp-door:nth-child(24) { grid-column: 6; grid-row: 8; grid-column: span 2; }

/* ============================================
   LAYOUT: Fala (Wave)
   ============================================ */
.layout-wave .acp-calendar-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 15px;
    max-width: 1000px;
    margin: 0 auto;
}

.layout-wave .acp-door {
    width: calc(12.5% - 15px);
    min-width: 80px;
    aspect-ratio: 1;
    transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Efekt fali przez margin-top */
.layout-wave .acp-door:nth-child(1) { margin-top: 0; }
.layout-wave .acp-door:nth-child(2) { margin-top: 20px; }
.layout-wave .acp-door:nth-child(3) { margin-top: 40px; }
.layout-wave .acp-door:nth-child(4) { margin-top: 50px; }
.layout-wave .acp-door:nth-child(5) { margin-top: 40px; }
.layout-wave .acp-door:nth-child(6) { margin-top: 20px; }
.layout-wave .acp-door:nth-child(7) { margin-top: 0; }
.layout-wave .acp-door:nth-child(8) { margin-top: 20px; }
.layout-wave .acp-door:nth-child(9) { margin-top: 0; }
.layout-wave .acp-door:nth-child(10) { margin-top: 20px; }
.layout-wave .acp-door:nth-child(11) { margin-top: 40px; }
.layout-wave .acp-door:nth-child(12) { margin-top: 50px; }
.layout-wave .acp-door:nth-child(13) { margin-top: 40px; }
.layout-wave .acp-door:nth-child(14) { margin-top: 20px; }
.layout-wave .acp-door:nth-child(15) { margin-top: 0; }
.layout-wave .acp-door:nth-child(16) { margin-top: 20px; }
.layout-wave .acp-door:nth-child(17) { margin-top: 0; }
.layout-wave .acp-door:nth-child(18) { margin-top: 20px; }
.layout-wave .acp-door:nth-child(19) { margin-top: 40px; }
.layout-wave .acp-door:nth-child(20) { margin-top: 50px; }
.layout-wave .acp-door:nth-child(21) { margin-top: 40px; }
.layout-wave .acp-door:nth-child(22) { margin-top: 20px; }
.layout-wave .acp-door:nth-child(23) { margin-top: 0; }
.layout-wave .acp-door:nth-child(24) { margin-top: 20px; }

/* ============================================
   LAYOUT: Diagonalna
   ============================================ */
.layout-diagonal .acp-calendar-grid {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    gap: 8px;
    max-width: 1000px;
    margin: 0 auto;
}

.layout-diagonal .acp-door:nth-child(1) { grid-column: 1; grid-row: 1; }
.layout-diagonal .acp-door:nth-child(2) { grid-column: 2; grid-row: 1; }
.layout-diagonal .acp-door:nth-child(3) { grid-column: 1; grid-row: 2; }
.layout-diagonal .acp-door:nth-child(4) { grid-column: 2; grid-row: 2; }
.layout-diagonal .acp-door:nth-child(5) { grid-column: 3; grid-row: 2; }
.layout-diagonal .acp-door:nth-child(6) { grid-column: 3; grid-row: 3; }
.layout-diagonal .acp-door:nth-child(7) { grid-column: 4; grid-row: 3; }
.layout-diagonal .acp-door:nth-child(8) { grid-column: 4; grid-row: 4; }
.layout-diagonal .acp-door:nth-child(9) { grid-column: 5; grid-row: 4; }
.layout-diagonal .acp-door:nth-child(10) { grid-column: 5; grid-row: 5; }
.layout-diagonal .acp-door:nth-child(11) { grid-column: 6; grid-row: 5; }
.layout-diagonal .acp-door:nth-child(12) { grid-column: 6; grid-row: 6; }
.layout-diagonal .acp-door:nth-child(13) { grid-column: 7; grid-row: 6; }
.layout-diagonal .acp-door:nth-child(14) { grid-column: 7; grid-row: 7; }
.layout-diagonal .acp-door:nth-child(15) { grid-column: 8; grid-row: 7; }
.layout-diagonal .acp-door:nth-child(16) { grid-column: 8; grid-row: 8; }
.layout-diagonal .acp-door:nth-child(17) { grid-column: 7; grid-row: 8; }
.layout-diagonal .acp-door:nth-child(18) { grid-column: 6; grid-row: 8; }
.layout-diagonal .acp-door:nth-child(19) { grid-column: 5; grid-row: 8; }
.layout-diagonal .acp-door:nth-child(20) { grid-column: 4; grid-row: 8; }
.layout-diagonal .acp-door:nth-child(21) { grid-column: 3; grid-row: 8; }
.layout-diagonal .acp-door:nth-child(22) { grid-column: 2; grid-row: 8; }
.layout-diagonal .acp-door:nth-child(23) { grid-column: 1; grid-row: 8; }
.layout-diagonal .acp-door:nth-child(24) { grid-column: 8; grid-row: 1; transform: scale(1.3); }

/* ============================================
   LAYOUT: Twórczy Chaos (Scattered Chaos)
   ============================================ */
.layout-scattered-chaos .acp-calendar-grid {
    display: block;
    position: relative;
    min-height: 700px;
    max-width: 1000px;
    margin: 0 auto;
}

.layout-scattered-chaos .acp-door {
    position: absolute;
    width: 90px;
    height: 90px;
}

/* Losowe pozycje dla każdego dnia */
.layout-scattered-chaos .acp-door:nth-child(1) { left: 5%; top: 10%; transform: rotate(-8deg); }
.layout-scattered-chaos .acp-door:nth-child(2) { left: 20%; top: 5%; transform: rotate(5deg); }
.layout-scattered-chaos .acp-door:nth-child(3) { left: 38%; top: 8%; transform: rotate(-3deg); }
.layout-scattered-chaos .acp-door:nth-child(4) { left: 55%; top: 3%; transform: rotate(10deg); }
.layout-scattered-chaos .acp-door:nth-child(5) { left: 72%; top: 10%; transform: rotate(-5deg); }
.layout-scattered-chaos .acp-door:nth-child(6) { left: 88%; top: 5%; transform: rotate(7deg); }
.layout-scattered-chaos .acp-door:nth-child(7) { left: 8%; top: 30%; transform: rotate(12deg); }
.layout-scattered-chaos .acp-door:nth-child(8) { left: 25%; top: 25%; transform: rotate(-10deg); }
.layout-scattered-chaos .acp-door:nth-child(9) { left: 42%; top: 32%; transform: rotate(4deg); }
.layout-scattered-chaos .acp-door:nth-child(10) { left: 60%; top: 28%; transform: rotate(-7deg); }
.layout-scattered-chaos .acp-door:nth-child(11) { left: 78%; top: 33%; transform: rotate(9deg); }
.layout-scattered-chaos .acp-door:nth-child(12) { left: 3%; top: 52%; transform: rotate(-6deg); width: 100px; height: 100px; }
.layout-scattered-chaos .acp-door:nth-child(13) { left: 22%; top: 48%; transform: rotate(8deg); }
.layout-scattered-chaos .acp-door:nth-child(14) { left: 40%; top: 55%; transform: rotate(-4deg); }
.layout-scattered-chaos .acp-door:nth-child(15) { left: 57%; top: 50%; transform: rotate(6deg); }
.layout-scattered-chaos .acp-door:nth-child(16) { left: 75%; top: 56%; transform: rotate(-9deg); }
.layout-scattered-chaos .acp-door:nth-child(17) { left: 90%; top: 52%; transform: rotate(3deg); }
.layout-scattered-chaos .acp-door:nth-child(18) { left: 10%; top: 75%; transform: rotate(11deg); }
.layout-scattered-chaos .acp-door:nth-child(19) { left: 28%; top: 72%; transform: rotate(-5deg); }
.layout-scattered-chaos .acp-door:nth-child(20) { left: 45%; top: 78%; transform: rotate(7deg); }
.layout-scattered-chaos .acp-door:nth-child(21) { left: 62%; top: 73%; transform: rotate(-8deg); }
.layout-scattered-chaos .acp-door:nth-child(22) { left: 80%; top: 80%; transform: rotate(4deg); }
.layout-scattered-chaos .acp-door:nth-child(23) { left: 35%; top: 92%; transform: rotate(-3deg); }
.layout-scattered-chaos .acp-door:nth-child(24) { left: 55%; top: 88%; transform: rotate(0deg) scale(1.3); width: 110px; height: 110px; }

/* ============================================
   LAYOUT: Spirala Kołowa (Circle Spiral)
   ============================================ */
.layout-circle-spiral .acp-calendar-grid {
    display: block;
    position: relative;
    width: 650px;
    height: 650px;
    margin: 0 auto;
}

.layout-circle-spiral .acp-door {
    position: absolute;
    left: 50%;
    top: 50%;
}

/* Spirala od środka na zewnątrz */
.layout-circle-spiral .acp-door:nth-child(24) { transform: translate(-50%, -50%); width: 80px; height: 80px; }
.layout-circle-spiral .acp-door:nth-child(1) { transform: translate(-50%, -50%) rotate(0deg) translateY(-60px) rotate(0deg); width: 60px; height: 60px; }
.layout-circle-spiral .acp-door:nth-child(2) { transform: translate(-50%, -50%) rotate(72deg) translateY(-70px) rotate(-72deg); width: 62px; height: 62px; }
.layout-circle-spiral .acp-door:nth-child(3) { transform: translate(-50%, -50%) rotate(144deg) translateY(-80px) rotate(-144deg); width: 64px; height: 64px; }
.layout-circle-spiral .acp-door:nth-child(4) { transform: translate(-50%, -50%) rotate(216deg) translateY(-90px) rotate(-216deg); width: 66px; height: 66px; }
.layout-circle-spiral .acp-door:nth-child(5) { transform: translate(-50%, -50%) rotate(288deg) translateY(-100px) rotate(-288deg); width: 68px; height: 68px; }
.layout-circle-spiral .acp-door:nth-child(6) { transform: translate(-50%, -50%) rotate(0deg) translateY(-120px) rotate(0deg); width: 65px; height: 65px; }
.layout-circle-spiral .acp-door:nth-child(7) { transform: translate(-50%, -50%) rotate(51deg) translateY(-135px) rotate(-51deg); width: 67px; height: 67px; }
.layout-circle-spiral .acp-door:nth-child(8) { transform: translate(-50%, -50%) rotate(102deg) translateY(-150px) rotate(-102deg); width: 69px; height: 69px; }
.layout-circle-spiral .acp-door:nth-child(9) { transform: translate(-50%, -50%) rotate(153deg) translateY(-165px) rotate(-153deg); width: 71px; height: 71px; }
.layout-circle-spiral .acp-door:nth-child(10) { transform: translate(-50%, -50%) rotate(204deg) translateY(-180px) rotate(-204deg); width: 73px; height: 73px; }
.layout-circle-spiral .acp-door:nth-child(11) { transform: translate(-50%, -50%) rotate(255deg) translateY(-195px) rotate(-255deg); width: 75px; height: 75px; }
.layout-circle-spiral .acp-door:nth-child(12) { transform: translate(-50%, -50%) rotate(306deg) translateY(-210px) rotate(-306deg); width: 77px; height: 77px; }
.layout-circle-spiral .acp-door:nth-child(13) { transform: translate(-50%, -50%) rotate(0deg) translateY(-235px) rotate(0deg); width: 72px; height: 72px; }
.layout-circle-spiral .acp-door:nth-child(14) { transform: translate(-50%, -50%) rotate(32deg) translateY(-250px) rotate(-32deg); width: 74px; height: 74px; }
.layout-circle-spiral .acp-door:nth-child(15) { transform: translate(-50%, -50%) rotate(64deg) translateY(-265px) rotate(-64deg); width: 76px; height: 76px; }
.layout-circle-spiral .acp-door:nth-child(16) { transform: translate(-50%, -50%) rotate(96deg) translateY(-280px) rotate(-96deg); width: 70px; height: 70px; }
.layout-circle-spiral .acp-door:nth-child(17) { transform: translate(-50%, -50%) rotate(128deg) translateY(-290px) rotate(-128deg); width: 72px; height: 72px; }
.layout-circle-spiral .acp-door:nth-child(18) { transform: translate(-50%, -50%) rotate(160deg) translateY(-295px) rotate(-160deg); width: 74px; height: 74px; }
.layout-circle-spiral .acp-door:nth-child(19) { transform: translate(-50%, -50%) rotate(192deg) translateY(-285px) rotate(-192deg); width: 70px; height: 70px; }
.layout-circle-spiral .acp-door:nth-child(20) { transform: translate(-50%, -50%) rotate(224deg) translateY(-275px) rotate(-224deg); width: 68px; height: 68px; }
.layout-circle-spiral .acp-door:nth-child(21) { transform: translate(-50%, -50%) rotate(256deg) translateY(-265px) rotate(-256deg); width: 66px; height: 66px; }
.layout-circle-spiral .acp-door:nth-child(22) { transform: translate(-50%, -50%) rotate(288deg) translateY(-255px) rotate(-288deg); width: 64px; height: 64px; }
.layout-circle-spiral .acp-door:nth-child(23) { transform: translate(-50%, -50%) rotate(320deg) translateY(-245px) rotate(-320deg); width: 62px; height: 62px; }

/* ============================================
   DOOR BASE STYLES
   ============================================ */
.acp-door {
    position: relative;
    aspect-ratio: 1;
    perspective: 1000px;
    cursor: pointer;
    outline: none;
    transform-style: preserve-3d;
}

.acp-door-front,
.acp-door-back {
    position: absolute;
    inset: 0;
    border-radius: var(--acp-border-radius);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: var(--acp-transition);
    backface-visibility: hidden;
}

.acp-door-front {
    background: linear-gradient(145deg, var(--acp-primary), color-mix(in srgb, var(--acp-primary) 70%, black));
    box-shadow: var(--acp-shadow);
    border: 2px solid var(--acp-glass-border);
}

.acp-door-back {
    background: linear-gradient(145deg, var(--acp-secondary), color-mix(in srgb, var(--acp-secondary) 70%, black));
    transform: rotateY(180deg);
    padding: 10px;
    overflow: hidden;
}

.acp-door-number {
    font-size: clamp(1.2rem, 3vw, 2rem);
    font-weight: 800;
    color: var(--acp-text);
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
    position: relative;
    z-index: 2;
}

.acp-door-shine {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.3) 0%, transparent 50%);
    border-radius: var(--acp-border-radius);
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.3s ease;
}

/* ============================================
   DOOR STYLE VARIATIONS
   ============================================ */

/* Classic */
.door-style-classic .acp-door-front {
    border-radius: var(--acp-border-radius);
}

/* Gift (Pudełko prezentowe) */
.door-style-gift .acp-door-front {
    border-radius: 8px;
    background: linear-gradient(145deg, var(--acp-primary), color-mix(in srgb, var(--acp-primary) 60%, black));
}

.door-style-gift .acp-door-front::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 8%;
    background: var(--acp-accent);
    transform: translateY(-50%);
    z-index: 1;
}

.door-style-gift .acp-door-front::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 8%;
    background: var(--acp-accent);
    transform: translateX(-50%);
    z-index: 1;
}

.door-style-gift .acp-door-number {
    z-index: 3;
}

/* Ornament (Bombka) */
.door-style-ornament .acp-door-front {
    border-radius: 50%;
}

.door-style-ornament .acp-door-back {
    border-radius: 50%;
}

.door-style-ornament .acp-door-front::before {
    content: '';
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    width: 18px;
    height: 18px;
    background: var(--acp-accent);
    border-radius: 4px;
}

.door-style-ornament .acp-door-front::after {
    content: '';
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    width: 8px;
    height: 12px;
    border: 3px solid var(--acp-accent);
    border-radius: 50% 50% 0 0;
    background: transparent;
}

/* Snowflake (Płatek śniegu) */
.door-style-snowflake .acp-door-front {
    clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
}

.door-style-snowflake .acp-door-back {
    clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
}

/* Minimal */
.door-style-minimal .acp-door-front {
    background: var(--acp-glass);
    backdrop-filter: blur(10px);
    border: 1px solid var(--acp-glass-border);
}

/* Rounded (Zaokrąglone) */
.door-style-rounded .acp-door-front {
    border-radius: 50% 50% 50% 50% / 40% 40% 60% 60%;
}

.door-style-rounded .acp-door-back {
    border-radius: 50% 50% 50% 50% / 40% 40% 60% 60%;
}

/* Hexagon */
.door-style-hexagon .acp-door-front {
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}

.door-style-hexagon .acp-door-back {
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
}

/* Diamond */
.door-style-diamond .acp-door-front {
    clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
}

.door-style-diamond .acp-door-back {
    clip-path: polygon(50% 0%, 100% 50%, 50% 100%, 0% 50%);
}

/* Envelope */
.door-style-envelope .acp-door-front {
    clip-path: polygon(0% 20%, 50% 0%, 100% 20%, 100% 100%, 0% 100%);
    border-radius: 0 0 var(--acp-border-radius) var(--acp-border-radius);
}

.door-style-envelope .acp-door-front::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 50%;
    background: linear-gradient(180deg, color-mix(in srgb, var(--acp-primary) 90%, white) 0%, var(--acp-primary) 100%);
    clip-path: polygon(0 0, 50% 60%, 100% 0);
}

.door-style-envelope .acp-door-back {
    clip-path: polygon(0% 20%, 50% 0%, 100% 20%, 100% 100%, 0% 100%);
}

/* Star */
.door-style-star .acp-door-front {
    clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
    background: linear-gradient(145deg, var(--acp-accent), color-mix(in srgb, var(--acp-accent) 70%, var(--acp-primary)));
}

.door-style-star .acp-door-back {
    clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
}

.door-style-star .acp-door-number {
    color: var(--acp-background);
    text-shadow: none;
}

/* Star Gold - Złote Gwiazdki */
.door-style-star-gold .acp-door-front {
    clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
    background: linear-gradient(145deg, #ffd700, #b8860b);
    box-shadow: 0 0 20px rgba(255, 215, 0, 0.5);
}

.door-style-star-gold .acp-door-back {
    clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
}

.door-style-star-gold .acp-door-number {
    color: #1a1a1a;
    text-shadow: 0 0 10px rgba(255, 255, 255, 0.5);
}

/* Gift Ribbon - Prezent ze Wstążką */
.door-style-gift-ribbon .acp-door-front {
    border-radius: 8px;
    background: linear-gradient(145deg, var(--acp-primary), color-mix(in srgb, var(--acp-primary) 60%, black));
    overflow: hidden;
}

.door-style-gift-ribbon .acp-door-front::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 12%;
    background: linear-gradient(90deg, var(--acp-accent), color-mix(in srgb, var(--acp-accent) 80%, white), var(--acp-accent));
    transform: translateY(-50%);
    z-index: 1;
}

.door-style-gift-ribbon .acp-door-front::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 50%;
    width: 12%;
    background: linear-gradient(180deg, var(--acp-accent), color-mix(in srgb, var(--acp-accent) 80%, white), var(--acp-accent));
    transform: translateX(-50%);
    z-index: 1;
}

.door-style-gift-ribbon .acp-door-number {
    z-index: 3;
    background: var(--acp-primary);
    padding: 5px 10px;
    border-radius: 50%;
}

/* Kokarda na prezencie */
.door-style-gift-ribbon .acp-door-front .acp-door-shine {
    content: '';
    position: absolute;
    top: -5px;
    left: 50%;
    transform: translateX(-50%);
    width: 40px;
    height: 25px;
    background: var(--acp-accent);
    clip-path: polygon(0% 100%, 50% 30%, 100% 100%, 80% 100%, 50% 60%, 20% 100%);
    z-index: 2;
    opacity: 1;
}

/* Ornament Shiny - Błyszczące Bombki */
.door-style-ornament-shiny .acp-door-front {
    border-radius: 50%;
    background: radial-gradient(circle at 30% 30%, white 0%, transparent 30%),
                linear-gradient(145deg, var(--acp-primary), color-mix(in srgb, var(--acp-primary) 50%, black));
    box-shadow: 0 0 25px rgba(var(--acp-primary), 0.5), inset 0 -5px 20px rgba(0, 0, 0, 0.3);
}

.door-style-ornament-shiny .acp-door-back {
    border-radius: 50%;
}

.door-style-ornament-shiny .acp-door-front::before {
    content: '';
    position: absolute;
    top: -15px;
    left: 50%;
    transform: translateX(-50%);
    width: 20px;
    height: 20px;
    background: linear-gradient(145deg, #c9a227, #8b7355);
    border-radius: 4px;
}

.door-style-ornament-shiny .acp-door-front::after {
    content: '';
    position: absolute;
    top: -25px;
    left: 50%;
    transform: translateX(-50%);
    width: 10px;
    height: 15px;
    border: 3px solid #c9a227;
    border-radius: 50% 50% 0 0;
    background: transparent;
}

/* Snowflake Crystal - Kryształki Lodu */
.door-style-snowflake-crystal .acp-door-front {
    clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(200, 220, 255, 0.8));
    backdrop-filter: blur(10px);
    border: 2px solid rgba(255, 255, 255, 0.5);
    box-shadow: 0 0 30px rgba(200, 220, 255, 0.5), inset 0 0 20px rgba(255, 255, 255, 0.3);
}

.door-style-snowflake-crystal .acp-door-back {
    clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
}

.door-style-snowflake-crystal .acp-door-number {
    color: #2c3e50;
    text-shadow: 0 0 10px rgba(255, 255, 255, 0.8);
}

/* Bell - Dzwoneczki */
.door-style-bell .acp-door-front {
    clip-path: polygon(20% 0%, 80% 0%, 100% 60%, 100% 80%, 85% 90%, 50% 100%, 15% 90%, 0% 80%, 0% 60%);
    background: linear-gradient(145deg, #ffd700, #b8860b);
}

.door-style-bell .acp-door-back {
    clip-path: polygon(20% 0%, 80% 0%, 100% 60%, 100% 80%, 85% 90%, 50% 100%, 15% 90%, 0% 80%, 0% 60%);
}

.door-style-bell .acp-door-front::before {
    content: '';
    position: absolute;
    top: -8px;
    left: 50%;
    transform: translateX(-50%);
    width: 30%;
    height: 15%;
    background: linear-gradient(145deg, #c9a227, #8b7355);
    border-radius: 50% 50% 0 0;
}

.door-style-bell .acp-door-number {
    color: #1a1a1a;
    margin-top: 10%;
}

/* Candy Cane - Laski Cukrowe */
.door-style-candy-cane .acp-door-front {
    border-radius: var(--acp-border-radius);
    background: repeating-linear-gradient(
        45deg,
        #fff,
        #fff 10px,
        #c0392b 10px,
        #c0392b 20px
    );
    border: 3px solid #c0392b;
}

.door-style-candy-cane .acp-door-number {
    background: #c0392b;
    color: white;
    padding: 8px 12px;
    border-radius: 50%;
}

/* Gingerbread - Pierniczki */
.door-style-gingerbread .acp-door-front {
    border-radius: 20% 20% 30% 30%;
    background: linear-gradient(145deg, #8b4513, #654321);
    border: 3px dashed #fff;
}

.door-style-gingerbread .acp-door-back {
    border-radius: 20% 20% 30% 30%;
}

.door-style-gingerbread .acp-door-number {
    color: #fff;
    font-family: 'Comic Sans MS', cursive;
}

.door-style-gingerbread .acp-door-front::before {
    content: '';
    position: absolute;
    top: 20%;
    left: 25%;
    width: 15%;
    height: 15%;
    background: #fff;
    border-radius: 50%;
}

.door-style-gingerbread .acp-door-front::after {
    content: '';
    position: absolute;
    top: 20%;
    right: 25%;
    width: 15%;
    height: 15%;
    background: #fff;
    border-radius: 50%;
}

/* Stocking - Skarpety Świąteczne */
.door-style-stocking .acp-door-front {
    clip-path: polygon(15% 0%, 85% 0%, 85% 15%, 100% 15%, 100% 100%, 30% 100%, 30% 50%, 15% 50%);
    background: linear-gradient(145deg, var(--acp-primary), color-mix(in srgb, var(--acp-primary) 60%, black));
}

.door-style-stocking .acp-door-back {
    clip-path: polygon(15% 0%, 85% 0%, 85% 15%, 100% 15%, 100% 100%, 30% 100%, 30% 50%, 15% 50%);
}

.door-style-stocking .acp-door-front::before {
    content: '';
    position: absolute;
    top: 0;
    left: 15%;
    right: 15%;
    height: 20%;
    background: #fff;
    border-radius: 0 0 10px 10px;
}

/* Tree - Mini Choinki */
.door-style-tree .acp-door-front {
    clip-path: polygon(50% 0%, 15% 40%, 25% 40%, 5% 70%, 20% 70%, 0% 100%, 100% 100%, 80% 70%, 95% 70%, 75% 40%, 85% 40%);
    background: linear-gradient(180deg, #1e5631, #2d5a3d, #1e4d2b);
}

.door-style-tree .acp-door-back {
    clip-path: polygon(50% 0%, 15% 40%, 25% 40%, 5% 70%, 20% 70%, 0% 100%, 100% 100%, 80% 70%, 95% 70%, 75% 40%, 85% 40%);
}

.door-style-tree .acp-door-front::before {
    content: '';
    position: absolute;
    top: -5px;
    left: 50%;
    transform: translateX(-50%);
    width: 15px;
    height: 15px;
    background: #ffd700;
    clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
}

.door-style-tree .acp-door-number {
    margin-top: 20%;
}

/* Wreath Door - Wieńce Świąteczne */
.door-style-wreath-door .acp-door-front {
    border-radius: 50%;
    background: radial-gradient(circle at center, transparent 30%, #2d5a3d 30%, #2d5a3d 70%, transparent 70%);
    box-shadow: 0 0 0 5px #8b4513;
}

.door-style-wreath-door .acp-door-back {
    border-radius: 50%;
}

.door-style-wreath-door .acp-door-front::before {
    content: '';
    position: absolute;
    bottom: 10%;
    left: 50%;
    transform: translateX(-50%);
    width: 30%;
    height: 20%;
    background: #c0392b;
    clip-path: polygon(0% 50%, 20% 0%, 40% 50%, 60% 0%, 80% 50%, 100% 0%, 100% 100%, 0% 100%);
}

/* Candle - Świeczki */
.door-style-candle .acp-door-front {
    clip-path: polygon(30% 15%, 70% 15%, 70% 100%, 30% 100%);
    background: linear-gradient(90deg, #f5deb3, #fff8dc, #f5deb3);
}

.door-style-candle .acp-door-back {
    clip-path: polygon(30% 15%, 70% 15%, 70% 100%, 30% 100%);
}

.door-style-candle .acp-door-front::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 20%;
    height: 20%;
    background: radial-gradient(ellipse at bottom, #ffa500, #ff6600, transparent);
    border-radius: 50% 50% 20% 20%;
    animation: candleFlicker 1s ease-in-out infinite;
}

@keyframes candleFlicker {
    0%, 100% { transform: translateX(-50%) scaleY(1); opacity: 1; }
    50% { transform: translateX(-50%) scaleY(0.9); opacity: 0.8; }
}

.door-style-candle .acp-door-number {
    color: #8b4513;
    margin-top: 30%;
}

/* Angel - Aniołki */
.door-style-angel .acp-door-front {
    clip-path: polygon(50% 0%, 40% 20%, 15% 25%, 20% 50%, 5% 100%, 35% 80%, 50% 100%, 65% 80%, 95% 100%, 80% 50%, 85% 25%, 60% 20%);
    background: linear-gradient(145deg, #fff8dc, #ffd700);
}

.door-style-angel .acp-door-back {
    clip-path: polygon(50% 0%, 40% 20%, 15% 25%, 20% 50%, 5% 100%, 35% 80%, 50% 100%, 65% 80%, 95% 100%, 80% 50%, 85% 25%, 60% 20%);
}

.door-style-angel .acp-door-front::before {
    content: '';
    position: absolute;
    top: 2%;
    left: 50%;
    transform: translateX(-50%);
    width: 25%;
    height: 15%;
    background: radial-gradient(circle, #ffd700, #ffec8b);
    border-radius: 50%;
    box-shadow: 0 0 15px rgba(255, 215, 0, 0.8);
}

.door-style-angel .acp-door-number {
    color: #8b4513;
    margin-top: 10%;
}

/* Heart - Serduszka */
.door-style-heart .acp-door-front {
    clip-path: polygon(50% 100%, 0% 35%, 0% 25%, 25% 0%, 50% 15%, 75% 0%, 100% 25%, 100% 35%);
    background: linear-gradient(145deg, #e74c3c, #c0392b);
}

.door-style-heart .acp-door-back {
    clip-path: polygon(50% 100%, 0% 35%, 0% 25%, 25% 0%, 50% 15%, 75% 0%, 100% 25%, 100% 35%);
}

.door-style-heart .acp-door-number {
    margin-top: -10%;
}

/* Shield - Tarcze */
.door-style-shield .acp-door-front {
    clip-path: polygon(0% 0%, 100% 0%, 100% 70%, 50% 100%, 0% 70%);
    background: linear-gradient(145deg, var(--acp-primary), color-mix(in srgb, var(--acp-primary) 60%, black));
    border: 3px solid var(--acp-accent);
}

.door-style-shield .acp-door-back {
    clip-path: polygon(0% 0%, 100% 0%, 100% 70%, 50% 100%, 0% 70%);
}

/* Glass - Szklane Karty */
.door-style-glass .acp-door-front {
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.05));
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2), inset 0 0 30px rgba(255, 255, 255, 0.1);
}

.door-style-glass .acp-door-front::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 50%;
    bottom: 50%;
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.4) 0%, transparent 100%);
    border-radius: var(--acp-border-radius) 0 0 0;
}

/* Neon - Neonowe */
.door-style-neon .acp-door-front {
    background: var(--acp-background);
    border: 3px solid var(--acp-accent);
    box-shadow: 0 0 10px var(--acp-accent), 0 0 20px var(--acp-accent), 0 0 30px var(--acp-accent), inset 0 0 10px rgba(var(--acp-accent), 0.1);
    animation: neonPulse 2s ease-in-out infinite;
}

@keyframes neonPulse {
    0%, 100% { box-shadow: 0 0 10px var(--acp-accent), 0 0 20px var(--acp-accent), 0 0 30px var(--acp-accent); }
    50% { box-shadow: 0 0 15px var(--acp-accent), 0 0 30px var(--acp-accent), 0 0 45px var(--acp-accent); }
}

.door-style-neon .acp-door-number {
    color: var(--acp-accent);
    text-shadow: 0 0 10px var(--acp-accent), 0 0 20px var(--acp-accent);
}

/* Vintage Retro */
.door-style-vintage .acp-door-front {
    background: linear-gradient(145deg, #d4a574, #8b6914);
    border: 4px double #5c4a1f;
    border-radius: 8px;
    box-shadow: inset 0 0 20px rgba(0, 0, 0, 0.3);
}

.door-style-vintage .acp-door-front::before {
    content: '';
    position: absolute;
    inset: 8px;
    border: 2px solid rgba(255, 255, 255, 0.2);
    border-radius: 4px;
}

.door-style-vintage .acp-door-number {
    font-family: 'Georgia', serif;
    color: #3d2914;
}

/* Wooden - Drewniane */
.door-style-wooden .acp-door-front {
    background:
        repeating-linear-gradient(
            90deg,
            transparent,
            transparent 2px,
            rgba(0, 0, 0, 0.1) 2px,
            rgba(0, 0, 0, 0.1) 4px
        ),
        linear-gradient(145deg, #8b5a2b, #5d3a1a);
    border: 4px solid #3d2914;
    border-radius: 4px;
    box-shadow: inset 0 0 30px rgba(0, 0, 0, 0.4);
}

.door-style-wooden .acp-door-front::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 20%;
    height: 20%;
    background: #3d2914;
    border-radius: 50%;
    border: 2px solid #5d3a1a;
}

.door-style-wooden .acp-door-number {
    color: #f5deb3;
    z-index: 2;
}

/* ============================================
   HOVER EFFECTS
   ============================================ */

/* Lift (domyślny) */
.acp-door.is-available.hover-lift:hover .acp-door-front,
.acp-door.is-available:not([class*="hover-"]):hover .acp-door-front {
    transform: translateY(-8px) scale(1.02);
    box-shadow: var(--acp-shadow-hover);
}

/* Glow */
.acp-door.is-available.hover-glow:hover .acp-door-front {
    box-shadow: var(--acp-shadow-glow), var(--acp-shadow);
}

/* Tilt 3D */
.acp-door.is-available.hover-tilt:hover {
    transform: perspective(1000px) rotateX(10deg) rotateY(-10deg);
}

.acp-door.is-available.hover-tilt:hover .acp-door-front {
    box-shadow: 15px 15px 30px rgba(0, 0, 0, 0.3);
}

/* Pulse */
.acp-door.is-available.hover-pulse:hover .acp-door-front {
    animation: doorPulse 0.6s ease-in-out infinite;
}

@keyframes doorPulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.05); }
}

/* Shake */
.acp-door.is-available.hover-shake:hover .acp-door-front {
    animation: doorShakeHover 0.3s ease-in-out infinite;
}

@keyframes doorShakeHover {
    0%, 100% { transform: translateX(0) rotate(0); }
    25% { transform: translateX(-3px) rotate(-1deg); }
    75% { transform: translateX(3px) rotate(1deg); }
}

/* Flip Peek */
.acp-door.is-available.hover-flip-peek:hover .acp-door-front {
    transform: rotateY(25deg);
}

/* Scale Rotate */
.acp-door.is-available.hover-scale-rotate:hover .acp-door-front {
    transform: scale(1.1) rotate(5deg);
}

/* Shine on hover */
.acp-door.is-available:hover .acp-door-shine {
    opacity: 1;
}

.acp-door.is-available:focus .acp-door-front {
    outline: 3px solid var(--acp-accent);
    outline-offset: 4px;
}

/* ============================================
   DOOR STATES
   ============================================ */

/* Locked */
.acp-door.is-locked .acp-door-front {
    background: linear-gradient(145deg, #4a4a4a, #2a2a2a);
    cursor: not-allowed;
}

.acp-door.is-locked .acp-door-number {
    opacity: 0.5;
}

.acp-lock-icon {
    position: absolute;
    bottom: 15%;
    width: 20px;
    height: 20px;
    color: var(--acp-text-muted);
    opacity: 0.5;
}

/* Today */
.acp-today-badge {
    position: absolute;
    top: -8px;
    right: -8px;
    background: var(--acp-accent);
    color: #1a1a1a;
    font-size: 0.6rem;
    font-weight: 700;
    padding: 4px 8px;
    border-radius: 20px;
    text-transform: uppercase;
    animation: todayPulse 2s ease-in-out infinite;
    box-shadow: 0 2px 10px rgba(212, 168, 75, 0.5);
    z-index: 10;
}

@keyframes todayPulse {
    0%, 100% { transform: scale(1); box-shadow: 0 2px 10px rgba(212, 168, 75, 0.5); }
    50% { transform: scale(1.1); box-shadow: 0 4px 20px rgba(212, 168, 75, 0.8); }
}

.acp-door.is-today .acp-door-front {
    box-shadow: 0 0 30px rgba(212, 168, 75, 0.5), var(--acp-shadow);
    animation: todayGlow 3s ease-in-out infinite;
}

@keyframes todayGlow {
    0%, 100% { box-shadow: 0 0 30px rgba(212, 168, 75, 0.5), var(--acp-shadow); }
    50% { box-shadow: 0 0 50px rgba(212, 168, 75, 0.8), var(--acp-shadow-hover); }
}

/* ============================================
   OPENING ANIMATIONS
   ============================================ */

/* Flip Animation */
.animation-flip .acp-door.is-opened .acp-door-front {
    transform: rotateY(180deg);
}

.animation-flip .acp-door.is-opening .acp-door-front {
    animation: flipOpen 0.6s ease-out forwards;
}

@keyframes flipOpen {
    0% { transform: rotateY(0); }
    100% { transform: rotateY(180deg); }
}

/* Slide Animation */
.animation-slide .acp-door-back {
    transform: rotateY(0);
}

.animation-slide .acp-door.is-opened .acp-door-front {
    transform: translateX(100%);
    opacity: 0;
}

.animation-slide .acp-door.is-opening .acp-door-front {
    animation: slideOpen 0.5s ease-out forwards;
}

@keyframes slideOpen {
    0% { transform: translateX(0); opacity: 1; }
    100% { transform: translateX(100%); opacity: 0; }
}

/* Fade Animation */
.animation-fade .acp-door-back {
    transform: rotateY(0);
}

.animation-fade .acp-door.is-opened .acp-door-front {
    opacity: 0;
}

.animation-fade .acp-door.is-opening .acp-door-front {
    animation: fadeOpen 0.5s ease-out forwards;
}

@keyframes fadeOpen {
    0% { opacity: 1; }
    100% { opacity: 0; }
}

/* Zoom Animation */
.animation-zoom .acp-door-back {
    transform: rotateY(0);
}

.animation-zoom .acp-door.is-opened .acp-door-front {
    transform: scale(0);
    opacity: 0;
}

.animation-zoom .acp-door.is-opening .acp-door-front {
    animation: zoomOpen 0.5s ease-out forwards;
}

@keyframes zoomOpen {
    0% { transform: scale(1); opacity: 1; }
    100% { transform: scale(0); opacity: 0; }
}

/* Bounce Animation */
.animation-bounce .acp-door-back {
    transform: rotateY(0);
}

.animation-bounce .acp-door.is-opened .acp-door-front {
    transform: scale(0) rotate(180deg);
    opacity: 0;
}

.animation-bounce .acp-door.is-opening .acp-door-front {
    animation: bounceOpen 0.6s cubic-bezier(0.68, -0.55, 0.265, 1.55) forwards;
}

@keyframes bounceOpen {
    0% { transform: scale(1) rotate(0); opacity: 1; }
    50% { transform: scale(1.2) rotate(90deg); }
    100% { transform: scale(0) rotate(180deg); opacity: 0; }
}

/* Shake Animation */
.animation-shake .acp-door-back {
    transform: rotateY(0);
}

.animation-shake .acp-door.is-opened .acp-door-front {
    transform: translateY(-100%);
    opacity: 0;
}

.animation-shake .acp-door.is-opening .acp-door-front {
    animation: shakeOpen 0.6s ease-out forwards;
}

@keyframes shakeOpen {
    0% { transform: translateX(0) translateY(0); }
    20% { transform: translateX(-10px) translateY(0); }
    40% { transform: translateX(10px) translateY(0); }
    60% { transform: translateX(-5px) translateY(-20px); }
    80% { transform: translateX(5px) translateY(-50px); }
    100% { transform: translateX(0) translateY(-100%); opacity: 0; }
}

/* Swing Animation */
.animation-swing .acp-door-back {
    transform: rotateY(0);
}

.animation-swing .acp-door.is-opened .acp-door-front {
    transform: rotateZ(-120deg);
    transform-origin: top left;
    opacity: 0;
}

.animation-swing .acp-door.is-opening .acp-door-front {
    animation: swingOpen 0.6s ease-out forwards;
    transform-origin: top left;
}

@keyframes swingOpen {
    0% { transform: rotateZ(0); opacity: 1; }
    50% { transform: rotateZ(-30deg); }
    100% { transform: rotateZ(-120deg); opacity: 0; }
}

/* Unfold Animation */
.animation-unfold .acp-door-back {
    transform: rotateY(0);
}

.animation-unfold .acp-door.is-opened .acp-door-front {
    transform: perspective(1000px) rotateX(-90deg);
    transform-origin: top center;
    opacity: 0;
}

.animation-unfold .acp-door.is-opening .acp-door-front {
    animation: unfoldOpen 0.6s ease-out forwards;
    transform-origin: top center;
}

@keyframes unfoldOpen {
    0% { transform: perspective(1000px) rotateX(0); opacity: 1; }
    100% { transform: perspective(1000px) rotateX(-90deg); opacity: 0; }
}

/* ============================================
   REWARD PREVIEW
   ============================================ */
.acp-reward-preview {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    text-align: center;
    color: var(--acp-text);
    padding: 8px;
    box-sizing: border-box;
    overflow: hidden;
}

.acp-reward-image {
    width: 100%;
    max-width: 50px;
    height: auto;
    max-height: 50%;
    object-fit: contain;
    margin-bottom: 6px;
    border-radius: var(--acp-border-radius-sm);
    flex-shrink: 0;
}

.acp-gift-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    min-width: 36px;
    min-height: 36px;
    max-width: 36px;
    max-height: 36px;
    color: var(--acp-accent);
    margin-bottom: 6px;
    flex-shrink: 0;
}

.acp-gift-icon svg {
    width: 100%;
    height: 100%;
    max-width: 100%;
    max-height: 100%;
    display: block;
    flex-shrink: 0;
}

.acp-reward-title {
    font-size: 0.65rem;
    font-weight: 600;
    display: block;
    line-height: 1.2;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex-shrink: 1;
}

/* Specjalne style dla nietypowych kształtów drzwiczek */
.door-style-snowflake .acp-reward-preview,
.door-style-star .acp-reward-preview,
.door-style-star-gold .acp-reward-preview,
.door-style-diamond .acp-reward-preview,
.door-style-hexagon .acp-reward-preview,
.door-style-tree .acp-reward-preview,
.door-style-stocking .acp-reward-preview,
.door-style-candle .acp-reward-preview,
.door-style-wreath-door .acp-reward-preview,
.door-style-angel .acp-reward-preview,
.door-style-heart .acp-reward-preview {
    padding: 15%;
}

.door-style-snowflake .acp-gift-icon,
.door-style-star .acp-gift-icon,
.door-style-star-gold .acp-gift-icon,
.door-style-diamond .acp-gift-icon,
.door-style-hexagon .acp-gift-icon,
.door-style-tree .acp-gift-icon,
.door-style-stocking .acp-gift-icon,
.door-style-candle .acp-gift-icon,
.door-style-wreath-door .acp-gift-icon,
.door-style-angel .acp-gift-icon,
.door-style-heart .acp-gift-icon {
    width: 28px;
    height: 28px;
    min-width: 28px;
    min-height: 28px;
    max-width: 28px;
    max-height: 28px;
    margin-bottom: 4px;
}

.door-style-snowflake .acp-reward-title,
.door-style-star .acp-reward-title,
.door-style-star-gold .acp-reward-title,
.door-style-diamond .acp-reward-title,
.door-style-hexagon .acp-reward-title,
.door-style-tree .acp-reward-title,
.door-style-stocking .acp-reward-title,
.door-style-candle .acp-reward-title,
.door-style-wreath-door .acp-reward-title,
.door-style-angel .acp-reward-title,
.door-style-heart .acp-reward-title {
    font-size: 0.55rem;
    max-width: 80%;
}

.door-style-snowflake .acp-reward-image,
.door-style-star .acp-reward-image,
.door-style-star-gold .acp-reward-image,
.door-style-diamond .acp-reward-image,
.door-style-hexagon .acp-reward-image,
.door-style-tree .acp-reward-image,
.door-style-stocking .acp-reward-image,
.door-style-candle .acp-reward-image,
.door-style-wreath-door .acp-reward-image,
.door-style-angel .acp-reward-image,
.door-style-heart .acp-reward-image {
    max-width: 35px;
    max-height: 35%;
}

/* ============================================
   PARTICLES / SNOW EFFECTS
   ============================================ */
.acp-particles-container {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
    z-index: 0;
}

.acp-snow-container {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
    z-index: 0;
}

.acp-snowflake {
    position: absolute;
    top: -20px;
    color: rgba(255, 255, 255, 0.8);
    animation: snowfall linear infinite;
    text-shadow: 0 0 5px rgba(255, 255, 255, 0.5);
}

@keyframes snowfall {
    0% {
        transform: translateY(-20px) rotate(0deg);
        opacity: 1;
    }
    100% {
        transform: translateY(100vh) rotate(360deg);
        opacity: 0.3;
    }
}

/* ============================================
   RESPONSIVE - LAYOUTS
   ============================================ */
@media (max-width: 1024px) {
    /* Gridy */
    .layout-grid-6x4 .acp-calendar-grid { grid-template-columns: repeat(4, 1fr); }
    .layout-grid-8x3 .acp-calendar-grid { grid-template-columns: repeat(6, 1fr); }
    .layout-bento .acp-calendar-grid { grid-template-columns: repeat(4, 1fr); }
    .layout-pinterest .acp-calendar-grid { grid-template-columns: repeat(4, 1fr); }

    /* Circular layouts */
    .layout-wreath .acp-calendar-grid,
    .layout-snowflake-pattern .acp-calendar-grid,
    .layout-circle-spiral .acp-calendar-grid {
        width: 500px;
        height: 500px;
    }

    .layout-wreath .acp-door { width: 60px; height: 60px; }
    .layout-snowflake-pattern .acp-door { width: 55px; height: 55px; }

    .layout-honeycomb .acp-door { width: 80px; height: 92px; margin: 0 -12px; }
}

@media (max-width: 768px) {
    .acp-calendar-wrapper {
        padding: 40px 20px;
        border-radius: var(--acp-border-radius);
    }

    /* Wszystkie gridy do 4 lub 3 kolumn */
    .layout-grid-6x4 .acp-calendar-grid,
    .layout-grid-4x6 .acp-calendar-grid,
    .layout-grid-8x3 .acp-calendar-grid,
    .layout-grid-3x8 .acp-calendar-grid {
        grid-template-columns: repeat(4, 1fr);
        gap: 10px;
    }

    .layout-bento .acp-calendar-grid,
    .layout-pinterest .acp-calendar-grid,
    .layout-gift-stack .acp-calendar-grid {
        grid-template-columns: repeat(3, 1fr);
    }

    /* Zmniejsz okrągłe layouty */
    .layout-wreath .acp-calendar-grid,
    .layout-snowflake-pattern .acp-calendar-grid,
    .layout-circle-spiral .acp-calendar-grid {
        width: 350px;
        height: 350px;
    }

    .layout-wreath .acp-door { width: 45px; height: 45px; }
    .layout-snowflake-pattern .acp-door { width: 40px; height: 40px; }
    .layout-scattered-chaos .acp-door { width: 60px; height: 60px; }
    .layout-wave .acp-door { width: calc(20% - 10px); min-width: 60px; }

    .layout-honeycomb .acp-door { width: 60px; height: 69px; margin: 0 -10px; }
    .layout-christmas-tree .acp-calendar-grid { grid-template-columns: repeat(7, 1fr); gap: 6px; }

    /* Reward preview na tabletach */
    .acp-gift-icon {
        width: 32px;
        height: 32px;
        min-width: 32px;
        min-height: 32px;
        max-width: 32px;
        max-height: 32px;
        margin-bottom: 5px;
    }

    .acp-reward-title {
        font-size: 0.6rem;
    }

    .acp-reward-image {
        max-width: 45px;
    }

    .acp-reward-preview {
        padding: 6px;
    }

    .acp-door-back {
        padding: 8px;
    }
}

@media (max-width: 480px) {
    .acp-calendar-wrapper {
        padding: 25px 15px;
    }

    .layout-grid-6x4 .acp-calendar-grid,
    .layout-grid-4x6 .acp-calendar-grid,
    .layout-grid-8x3 .acp-calendar-grid,
    .layout-grid-3x8 .acp-calendar-grid,
    .layout-bento .acp-calendar-grid,
    .layout-pinterest .acp-calendar-grid,
    .layout-gift-stack .acp-calendar-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 8px;
    }

    /* Bardzo małe ekrany - prostsze layouty */
    .layout-wreath .acp-calendar-grid,
    .layout-snowflake-pattern .acp-calendar-grid,
    .layout-circle-spiral .acp-calendar-grid {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        width: auto;
        height: auto;
        position: static;
    }

    .layout-wreath .acp-door,
    .layout-snowflake-pattern .acp-door,
    .layout-circle-spiral .acp-door {
        position: static;
        transform: none !important;
        width: auto;
        height: auto;
    }

    .layout-scattered-chaos .acp-calendar-grid {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        position: static;
        min-height: auto;
    }

    .layout-scattered-chaos .acp-door {
        position: static;
        transform: none !important;
        width: auto;
        height: auto;
    }

    .acp-calendar-title {
        font-size: 1.5rem;
    }

    .acp-door-number {
        font-size: 1rem;
    }

    /* Reward preview na małych ekranach */
    .acp-gift-icon {
        width: 28px;
        height: 28px;
        min-width: 28px;
        min-height: 28px;
        max-width: 28px;
        max-height: 28px;
        margin-bottom: 4px;
    }

    .acp-reward-title {
        font-size: 0.55rem;
    }

    .acp-reward-image {
        max-width: 40px;
    }

    .acp-reward-preview {
        padding: 5px;
    }

    .acp-door-back {
        padding: 6px;
    }
}

/* ============================================
   MODAL STYLES
   ============================================ */
.acp-reward-modal {
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.acp-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(15px);
    animation: fadeIn 0.3s ease;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

.acp-modal-container {
    position: relative;
    width: 100%;
    max-width: 480px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    animation: modalSlide 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes modalSlide {
    from {
        opacity: 0;
        transform: scale(0.9) translateY(20px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

.acp-modal-content {
    position: relative;
    background: linear-gradient(145deg, var(--acp-secondary), color-mix(in srgb, var(--acp-secondary) 70%, black));
    border-radius: var(--acp-border-radius-lg);
    padding: 40px;
    text-align: center;
    box-shadow: var(--acp-shadow-hover), 0 0 60px rgba(212, 168, 75, 0.2);
    overflow-y: auto;
    overflow-x: hidden;
    max-height: calc(90vh - 40px);
    border: 1px solid var(--acp-glass-border);
}

.acp-modal-close {
    position: absolute;
    top: 15px;
    right: 15px;
    width: 40px;
    height: 40px;
    background: var(--acp-glass);
    border: 1px solid var(--acp-glass-border);
    border-radius: 50%;
    color: var(--acp-text);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--acp-transition);
    z-index: 10;
}

.acp-modal-close:hover {
    background: var(--acp-primary);
    transform: rotate(90deg);
}

.acp-modal-close svg {
    width: 20px;
    height: 20px;
}

.acp-modal-header {
    margin-bottom: 25px;
}

.acp-modal-day {
    display: inline-block;
    background: var(--acp-accent);
    color: #1a1a1a;
    font-size: 0.85rem;
    font-weight: 700;
    padding: 6px 16px;
    border-radius: 30px;
    margin-bottom: 15px;
}

.acp-modal-title {
    font-size: 1.75rem;
    font-weight: 800;
    color: var(--acp-text);
    margin: 0;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

.acp-modal-body {
    margin-bottom: 25px;
}

.acp-modal-image-container {
    margin-bottom: 20px;
}

.acp-modal-image {
    max-width: 150px;
    max-height: 150px;
    object-fit: contain;
    border-radius: var(--acp-border-radius-sm);
    box-shadow: var(--acp-shadow);
}

.acp-modal-description {
    color: var(--acp-text-muted);
    font-size: 1rem;
    line-height: 1.6;
    margin: 0;
}

.acp-coupon-display {
    background: var(--acp-glass);
    border: 2px dashed var(--acp-accent);
    border-radius: var(--acp-border-radius);
    padding: 25px;
    margin-top: 25px;
}

.acp-coupon-label {
    color: var(--acp-text-muted);
    font-size: 0.875rem;
    margin: 0 0 15px;
}

.acp-coupon-code-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    flex-wrap: wrap;
}

.acp-coupon-code {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--acp-accent);
    background: rgba(0, 0, 0, 0.3);
    padding: 12px 24px;
    border-radius: var(--acp-border-radius-sm);
    letter-spacing: 0.1em;
    font-family: 'Courier New', monospace;
}

.acp-copy-coupon {
    display: flex;
    align-items: center;
    gap: 8px;
    background: var(--acp-accent);
    color: #1a1a1a;
    border: none;
    padding: 12px 20px;
    border-radius: var(--acp-border-radius-sm);
    font-weight: 600;
    cursor: pointer;
    transition: var(--acp-transition);
}

.acp-copy-coupon:hover {
    transform: scale(1.05);
    box-shadow: 0 5px 20px rgba(212, 168, 75, 0.4);
}

.acp-copy-coupon svg {
    width: 18px;
    height: 18px;
}

.acp-coupon-hint {
    color: var(--acp-text-muted);
    font-size: 0.8rem;
    margin: 15px 0 0;
}

.acp-modal-confetti {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
}

.confetti-piece {
    position: absolute;
    width: 10px;
    height: 10px;
    top: 50%;
    left: 50%;
    animation: confettiExplode 1s ease-out forwards;
}

@keyframes confettiExplode {
    0% {
        transform: translate(-50%, -50%) scale(0);
        opacity: 1;
    }
    100% {
        transform: translate(calc(-50% + var(--x)), calc(-50% + var(--y))) scale(1) rotate(720deg);
        opacity: 0;
    }
}

/* ============================================
   LOADING & LOGIN
   ============================================ */
.acp-loading-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 999998;
    backdrop-filter: blur(5px);
}

.acp-spinner {
    text-align: center;
}

.acp-spinner-ring {
    width: 50px;
    height: 50px;
    border: 4px solid var(--acp-glass);
    border-top-color: var(--acp-accent);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin: 0 auto 15px;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

.acp-spinner-text {
    color: var(--acp-text);
    font-size: 0.9rem;
}

.acp-login-notice {
    position: relative;
    text-align: center;
    margin-top: 30px;
    padding: 25px;
    background: var(--acp-glass);
    border: 1px solid var(--acp-glass-border);
    border-radius: var(--acp-border-radius);
    z-index: 1;
    backdrop-filter: blur(10px);
}

.acp-login-notice p {
    color: var(--acp-text);
    margin: 0 0 15px;
}

.acp-login-button {
    display: inline-block;
    background: var(--acp-accent);
    color: #1a1a1a;
    padding: 12px 30px;
    border-radius: 30px;
    text-decoration: none;
    font-weight: 600;
    transition: var(--acp-transition);
}

.acp-login-button:hover {
    transform: scale(1.05);
    box-shadow: 0 5px 20px rgba(212, 168, 75, 0.4);
    color: #1a1a1a;
}

/* ============================================
   THEME VARIATIONS
   ============================================ */
.theme-winter {
    --acp-primary: #a52422;
    --acp-secondary: #2d5a3d;
    --acp-accent: #d4a84b;
    --acp-background: #1a2332;
}

.theme-classic {
    --acp-primary: #8b2332;
    --acp-secondary: #1e4d2b;
    --acp-accent: #c9a227;
    --acp-background: #1a1a1a;
}

.theme-modern {
    --acp-primary: #2c3e50;
    --acp-secondary: #27ae60;
    --acp-accent: #e74c3c;
    --acp-background: #1a1a2e;
}

.theme-elegant {
    --acp-primary: #6b4423;
    --acp-secondary: #2c2c2c;
    --acp-accent: #c9a227;
    --acp-background: #0f0f0f;
}

.theme-playful {
    --acp-primary: #c0392b;
    --acp-secondary: #27ae60;
    --acp-accent: #f39c12;
    --acp-background: #1a2332;
}

.theme-dark {
    --acp-primary: #1a1a1a;
    --acp-secondary: #2c2c2c;
    --acp-accent: #c9a227;
    --acp-background: #0a0a0a;
}

/* ============================================
   GRY - KOŁO FORTUNY I MYSTERY BOX
   Minimalistyczny, elegancki design spójny z kalendarzem
   ============================================ */

/* Game Modal Base */
.acp-game-modal {
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.acp-game-modal.is-visible {
    opacity: 1;
    visibility: visible;
}

.acp-game-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.8);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

.acp-game-content {
    position: relative;
    background: var(--acp-secondary);
    border-radius: var(--acp-border-radius-lg);
    max-width: 400px;
    width: 100%;
    max-height: 90vh;
    overflow: hidden;
    box-shadow: var(--acp-shadow-hover);
    border: 1px solid var(--acp-glass-border);
    transform: scale(0.95) translateY(20px);
    transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.acp-game-modal.is-visible .acp-game-content {
    transform: scale(1) translateY(0);
}

/* Confetti Container */
.acp-game-confetti {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 100;
    overflow: hidden;
}

/* Close Button */
.acp-game-close {
    position: absolute;
    top: 16px;
    right: 16px;
    width: 32px;
    height: 32px;
    background: var(--acp-glass);
    border: 1px solid var(--acp-glass-border);
    border-radius: 50%;
    color: var(--acp-text-muted);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    z-index: 10;
}

.acp-game-close:hover {
    background: var(--acp-accent);
    color: var(--acp-secondary);
    transform: rotate(90deg);
}

.acp-game-close svg {
    width: 16px;
    height: 16px;
}

/* Inner Content */
.acp-game-inner {
    position: relative;
    padding: 40px 32px 32px;
    text-align: center;
    z-index: 1;
    overflow-y: auto;
    max-height: 90vh;
}

/* Game Header */
.acp-game-header {
    margin-bottom: 32px;
}

.acp-game-day {
    display: inline-block;
    background: var(--acp-accent);
    color: var(--acp-secondary);
    font-size: 0.7rem;
    font-weight: 700;
    padding: 5px 14px;
    border-radius: 20px;
    margin-bottom: 16px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.acp-game-title {
    color: var(--acp-text);
    font-size: 1.5rem;
    font-weight: 600;
    margin: 0 0 8px;
    line-height: 1.3;
    letter-spacing: -0.02em;
}

.acp-game-subtitle {
    color: var(--acp-text-muted);
    font-size: 0.9rem;
    margin: 0;
    font-weight: 400;
}

/* ============================================
   KOŁO FORTUNY - Elegancki design
   ============================================ */
.acp-wheel-wrapper {
    margin: 0 auto 32px;
    display: flex;
    justify-content: center;
}

.acp-wheel-container {
    position: relative;
    width: 260px;
    height: 260px;
}

/* Pointer - minimalistyczny trójkąt */
.acp-wheel-pointer {
    position: absolute;
    top: -6px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 20;
}

.acp-wheel-pointer svg {
    width: 24px;
    height: 30px;
    color: var(--acp-accent);
    filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));
}

/* Koło */
.acp-wheel {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    overflow: hidden;
    box-shadow:
        0 0 0 4px var(--acp-glass-border),
        0 8px 32px rgba(0, 0, 0, 0.3);
    transform: rotate(0deg);
    background: var(--acp-background);
}

.acp-wheel-segment {
    position: absolute;
    width: 50%;
    height: 50%;
    left: 50%;
    top: 0;
    transform-origin: 0% 100%;
    background: var(--segment-color);
    clip-path: polygon(0% 100%, 100% 100%, 50% 0%);
    transform: rotate(calc(var(--segment-index) * 45deg - 22.5deg));
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: 20px;
    border-right: 1px solid rgba(255, 255, 255, 0.1);
}

.acp-segment-text {
    color: white;
    font-weight: 700;
    font-size: 12px;
    letter-spacing: 0.5px;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.5);
    transform: rotate(22.5deg);
}

/* Center - minimalistyczny */
.acp-wheel-center {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 50px;
    height: 50px;
    background: var(--acp-secondary);
    border: 3px solid var(--acp-accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.acp-wheel-center svg {
    width: 20px;
    height: 20px;
    color: var(--acp-accent);
}

/* Spin Button */
.acp-spin-button {
    background: var(--acp-accent);
    color: var(--acp-secondary);
    border: none;
    padding: 14px 40px;
    font-size: 0.95rem;
    font-weight: 600;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    letter-spacing: 0.5px;
}

.acp-spin-button:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(201, 162, 39, 0.3);
}

.acp-spin-button:disabled {
    opacity: 0.7;
    cursor: not-allowed;
}

/* Result Section */
.acp-wheel-result,
.acp-mystery-result {
    animation: fadeInUp 0.5s ease;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.acp-result-badge {
    display: inline-block;
    background: var(--acp-accent);
    color: var(--acp-secondary);
    font-size: 0.75rem;
    font-weight: 700;
    padding: 6px 16px;
    border-radius: 20px;
    margin-bottom: 16px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.acp-result-title {
    color: var(--acp-text);
    font-size: 1.4rem;
    font-weight: 600;
    margin: 0 0 8px;
}

.acp-result-text {
    color: var(--acp-text-muted);
    font-size: 0.9rem;
    margin: 0 0 24px;
}

/* Coupon Box */
.acp-coupon-box {
    background: var(--acp-glass);
    border: 1px solid var(--acp-glass-border);
    border-radius: 12px;
    padding: 20px;
    margin-top: 20px;
}

.acp-coupon-code {
    display: block;
    background: linear-gradient(135deg, #27ae60, #2ecc71);
    color: white;
    font-size: 1.1rem;
    font-weight: 700;
    padding: 12px 24px;
    border-radius: 8px;
    letter-spacing: 2px;
    font-family: 'SF Mono', 'Monaco', 'Consolas', monospace;
    margin-bottom: 12px;
}

.acp-copy-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: transparent;
    border: 1px solid var(--acp-glass-border);
    color: var(--acp-text-muted);
    padding: 10px 20px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 500;
    transition: all 0.2s ease;
}

.acp-copy-btn:hover {
    background: var(--acp-glass);
    color: var(--acp-text);
    border-color: var(--acp-accent);
}

.acp-copy-btn.copied {
    background: #27ae60;
    border-color: #27ae60;
    color: white;
}

.acp-copy-btn svg {
    width: 16px;
    height: 16px;
}

/* ============================================
   MYSTERY BOX - Elegancki design
   ============================================ */
.acp-mystery-hint {
    color: var(--acp-text-muted);
    font-size: 0.9rem;
    margin-bottom: 24px !important;
}

.acp-mystery-boxes {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-bottom: 24px;
    max-width: 300px;
    margin-left: auto;
    margin-right: auto;
}

.acp-mystery-box {
    position: relative;
    width: 100%;
    aspect-ratio: 1;
    cursor: pointer;
    perspective: 1000px;
}

.acp-box-inner {
    position: relative;
    width: 100%;
    height: 100%;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    transform-style: preserve-3d;
}

.acp-mystery-box.is-flipped .acp-box-inner {
    transform: rotateY(180deg);
}

.acp-box-front,
.acp-box-back {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    border-radius: 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.acp-box-front {
    background: var(--acp-glass);
    border: 1px solid var(--acp-glass-border);
    transition: all 0.2s ease;
}

.acp-box-shine {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, transparent 50%);
    opacity: 0;
    transition: opacity 0.2s ease;
}

.acp-mystery-box:hover .acp-box-shine {
    opacity: 1;
}

.acp-mystery-box:hover .acp-box-front {
    transform: translateY(-4px);
    border-color: var(--acp-accent);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.2);
}

.acp-box-question {
    font-size: 2rem;
    font-weight: 700;
    color: var(--acp-accent);
}

.acp-box-back {
    transform: rotateY(180deg);
    border: 2px solid;
}

.acp-box-back[data-type="bronze"] {
    background: linear-gradient(145deg, #cd7f32, #a0522d);
    border-color: #cd7f32;
}

.acp-box-back[data-type="silver"] {
    background: linear-gradient(145deg, #c0c0c0, #808080);
    border-color: #c0c0c0;
}

.acp-box-back[data-type="gold"] {
    background: linear-gradient(145deg, #ffd700, #b8860b);
    border-color: #ffd700;
}

.acp-box-back[data-type="diamond"] {
    background: linear-gradient(145deg, #b9f2ff, #4fc3f7);
    border-color: #4fc3f7;
}

.acp-box-label {
    color: white;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
    margin-bottom: 4px;
}

.acp-box-range {
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.75rem;
    font-weight: 600;
}

.acp-mystery-box.is-winner .acp-box-inner {
    animation: winnerGlow 1s ease infinite;
}

@keyframes winnerGlow {
    0%, 100% {
        transform: rotateY(180deg) scale(1);
        filter: drop-shadow(0 0 10px rgba(201, 162, 39, 0.5));
    }
    50% {
        transform: rotateY(180deg) scale(1.05);
        filter: drop-shadow(0 0 20px rgba(201, 162, 39, 0.8));
    }
}

/* Responsywność gier */
@media (max-width: 480px) {
    .acp-game-inner {
        padding: 32px 24px 24px;
    }

    .acp-game-title {
        font-size: 1.3rem;
    }

    .acp-wheel-container {
        width: 220px;
        height: 220px;
    }

    .acp-wheel-center {
        width: 40px;
        height: 40px;
    }

    .acp-segment-text {
        font-size: 10px;
    }

    .acp-spin-button {
        padding: 12px 32px;
        font-size: 0.9rem;
    }

    .acp-mystery-boxes {
        gap: 12px;
        max-width: 260px;
    }

    .acp-coupon-code {
        font-size: 1rem;
        padding: 10px 20px;
        letter-spacing: 1.5px;
    }
}

/* ============================================
   LOCKED BADGE - Micro Minimalistyczny
   ============================================ */
.acp-lock-badge {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0.8);
    opacity: 0;
    z-index: 100;
    background: rgba(0, 0, 0, 0.8);
    color: var(--acp-accent);
    font-size: 11px;
    font-weight: 700;
    font-family: 'SF Mono', Monaco, Consolas, monospace;
    padding: 4px 8px;
    border-radius: 4px;
    white-space: nowrap;
    pointer-events: none;
    transition: all 0.15s ease;
}

.acp-lock-badge.show {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

/* ============================================
   NOTIFICATIONS
   ============================================ */
.acp-notification {
    position: fixed;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    background: var(--acp-secondary);
    border: 1px solid var(--acp-glass-border);
    border-radius: var(--acp-border-radius);
    padding: 15px 25px;
    box-shadow: var(--acp-shadow-hover);
    z-index: 999999;
    opacity: 0;
    transition: all 0.3s ease;
}

.acp-notification.is-visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

.acp-notification-message {
    color: var(--acp-text);
    font-size: 0.95rem;
    font-weight: 500;
}

.acp-notification-error {
    border-color: #e74c3c;
    background: linear-gradient(145deg, #2c1515, #1a0f0f);
}

.acp-notification-error .acp-notification-message {
    color: #ff6b6b;
}

.acp-notification-success {
    border-color: #27ae60;
    background: linear-gradient(145deg, #152c1a, #0f1a12);
}

.acp-notification-success .acp-notification-message {
    color: #6bff8e;
}

/* Responsive dla locked modal */
@media (max-width: 480px) {
    .acp-locked-content {
        padding: 30px 20px;
    }

    .acp-locked-icon {
        width: 60px;
        height: 60px;
    }

    .acp-locked-icon svg {
        width: 28px;
        height: 28px;
    }

    .acp-locked-title {
        font-size: 1.25rem;
    }

    .acp-locked-countdown {
        gap: 10px;
    }

    .acp-locked-countdown-unit {
        min-width: 50px;
    }

    .acp-locked-countdown-value {
        font-size: 1.5rem;
        padding: 8px 12px;
        min-width: 50px;
    }

    .acp-locked-countdown-label {
        font-size: 0.65rem;
    }
}
