/* ───────────────────────────────────────────────
   Zizania — WooCommerce Notices (reusable)
   
   Styles all WC notices across shop, cart,
   checkout, my-account. Zero JS, DRY.
   ─────────────────────────────────────────────── */

/* Base: shared layout for all notice types */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info,
.woocommerce-notice {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    margin-bottom: 1.5rem;
    border-radius: var(--radius-md);
    border: none;
    border-left: 4px solid transparent;
    outline: none;
    font-size: 1rem;
    line-height: 1.5;
    color: var(--on-surface);
    box-shadow: 0 4px 12px rgba(var(--on-surface-rgb), 0.08);
}

/* Success state (add-to-cart, save, etc.) */
.woocommerce-message {
    background-color: rgba(var(--tertiary-rgb), 0.08);
    border-left-color: var(--tertiary);
}

/* Tick icon (inline flex child, not absolute) */
.woocommerce-message::before {
    content: "\2713";
    flex: 0 0 auto;
    width: 1.25rem;
    height: 1.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--tertiary);
    font-weight: 700;
    font-size: 1.125rem;
    position: static;
    background: transparent;
}

/* Button inside notice (zz-btn--primary look) */
.woocommerce-message a.button {
    margin-left: auto;
    flex-shrink: 0;
    padding: 0.75rem 1.5rem;
    background-color: var(--primary);
    color: var(--on-primary);
    border-radius: var(--radius-full);
    border: none;
    font-weight: 600;
    text-decoration: none;
    box-shadow: 0 2px 8px rgba(var(--primary-rgb), 0.25);
    transition: transform 300ms ease-in-out, box-shadow 200ms ease-in-out;
}

.woocommerce-message a.button:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(var(--primary-rgb), 0.35);
    text-decoration: none;
}

.woocommerce-message a.button:focus-visible {
    outline: 2px solid var(--primary);
    outline-offset: 2px;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
    .woocommerce-message a.button { transition: none; }
    .woocommerce-message a.button:hover { transform: none; }
}


/* ───────────────────────────────────────────────
   Dismiss button (X) — κλείνει το notice
   Markup injection γίνεται από notices.js
   ─────────────────────────────────────────────── */

/* Spacing reservation: όλα τα notices αφήνουν χώρο για το X */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info,
.woocommerce-notice {
    position: relative;
    padding-right: 3.5rem;
}

/* The X button itself */
.zz-notice-dismiss {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    width: 2rem;
    height: 2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    color: var(--on-surface-variant, #4a4842);
    opacity: 0.6;
    transition: opacity 200ms ease, background-color 200ms ease, transform 200ms ease;
    padding: 0;
    line-height: 0;
}

.zz-notice-dismiss:hover {
    opacity: 1;
    background-color: rgba(var(--on-surface-rgb), 0.08);
}

.zz-notice-dismiss:focus-visible {
    outline: 2px solid var(--primary);
    outline-offset: 2px;
    opacity: 1;
}

.zz-notice-dismiss:active {
    transform: scale(0.92);
}

.zz-notice-dismiss svg {
    width: 1rem;
    height: 1rem;
    display: block;
    pointer-events: none;
}

/* Fade-out animation όταν πατάμε X */
.woocommerce-message.zz-notice-dismissing,
.woocommerce-error.zz-notice-dismissing,
.woocommerce-info.zz-notice-dismissing,
.woocommerce-notice.zz-notice-dismissing {
    opacity: 0;
    transform: translateY(-4px);
    transition: opacity 250ms ease, transform 250ms ease, margin 250ms ease, padding 250ms ease, max-height 300ms ease;
    overflow: hidden;
    max-height: 0;
    margin-top: 0;
    margin-bottom: 0;
    padding-top: 0;
    padding-bottom: 0;
}

/* Reduced motion: instant dismiss χωρίς animation */
@media (prefers-reduced-motion: reduce) {
    .zz-notice-dismiss { transition: none; }
    .zz-notice-dismiss:active { transform: none; }
    .woocommerce-message.zz-notice-dismissing,
    .woocommerce-error.zz-notice-dismissing,
    .woocommerce-info.zz-notice-dismissing,
    .woocommerce-notice.zz-notice-dismissing {
        transition: none;
    }
}
