/**
 * AllCruisesTravel — main.css
 * Supplemental styles: Gutenberg blocks, comment styles,
 * WooCommerce overrides, print styles, admin bar offset,
 * animation utilities, and component extras.
 */

/* =============================================
   GUTENBERG / BLOCK EDITOR COMPATIBILITY
============================================= */
.wp-block-image img { border-radius: var(--act-radius-md); }
.wp-block-quote {
    border-left: 4px solid var(--act-ocean);
    padding: var(--act-space-md) var(--act-space-xl);
    margin: var(--act-space-xl) 0;
    background: rgba(0,119,182,.04);
    border-radius: 0 var(--act-radius-md) var(--act-radius-md) 0;
}
.wp-block-quote cite { font-size: 14px; color: var(--act-silver); }
.wp-block-pullquote { border-color: var(--act-ocean); }
.wp-block-separator { border-color: var(--act-mist); }
.wp-block-table table { border-collapse: collapse; width: 100%; }
.wp-block-table td, .wp-block-table th { padding: 12px 16px; border: 1px solid var(--act-mist); }
.wp-block-table thead th { background: var(--act-navy); color: var(--act-white); }
.wp-block-button__link {
    background: var(--act-ocean) !important;
    border-radius: var(--act-radius-full) !important;
    padding: 14px 28px !important;
    font-family: var(--act-font-body) !important;
    font-weight: 600 !important;
    transition: var(--act-transition) !important;
}
.wp-block-button__link:hover { background: #005f91 !important; transform: translateY(-2px); }

.wp-block-cover { border-radius: var(--act-radius-lg); overflow: hidden; }

/* Alignwide / Alignfull */
@media (min-width: 1024px) {
    .alignwide { margin-left: -60px; margin-right: -60px; max-width: calc(100% + 120px); }
    .alignfull  { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); max-width: 100vw; }
}

/* =============================================
   COMMENTS STYLING
============================================= */
.act-comment-list { list-style: none; display: flex; flex-direction: column; gap: 20px; }

.comment-body {
    background: var(--act-cloud);
    border-radius: var(--act-radius-lg);
    padding: var(--act-space-xl);
    display: flex;
    gap: var(--act-space-md);
}

.comment-body img { border-radius: 50%; flex-shrink: 0; }

.comment-author .fn { font-weight: 700; color: var(--act-navy); font-size: 15px; }
.comment-metadata { font-size: 12px; color: var(--act-silver); margin-top: 2px; }
.comment-content p { font-size: 15px; color: var(--act-slate); margin-bottom: 0; }

.reply a {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--act-ocean);
    text-decoration: none;
    margin-top: 10px;
    display: inline-block;
}

.bypostauthor > .comment-body { border-left: 3px solid var(--act-ocean); }

/* =============================================
   ACF / CUSTOM FIELDS SHORTCODES
============================================= */
.act-pros-cons {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--act-space-lg);
    margin: var(--act-space-xl) 0;
}

.act-pros, .act-cons {
    border-radius: var(--act-radius-lg);
    padding: var(--act-space-xl);
}

.act-pros {
    background: rgba(16,185,129,.06);
    border: 1px solid rgba(16,185,129,.2);
}

.act-cons {
    background: rgba(239,68,68,.05);
    border: 1px solid rgba(239,68,68,.15);
}

.act-pros h4 { color: var(--act-success); font-size: 16px; margin-bottom: 14px; }
.act-cons h4 { color: var(--act-danger);  font-size: 16px; margin-bottom: 14px; }

.act-pros ul, .act-cons ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }

.act-pros li::before { content: '✓ '; color: var(--act-success); font-weight: 700; }
.act-cons li::before { content: '✕ '; color: var(--act-danger);  font-weight: 700; }

/* =============================================
   RATING STARS DISPLAY
============================================= */
.act-rating-widget {
    display: flex;
    align-items: center;
    gap: var(--act-space-sm);
    margin: var(--act-space-md) 0;
}

.act-rating-bar-wrap {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: var(--act-space-lg) 0;
}

.act-rating-bar-row {
    display: flex;
    align-items: center;
    gap: var(--act-space-md);
    font-size: 13.5px;
}

.act-rating-bar-label { width: 120px; color: var(--act-slate); font-weight: 500; }

.act-rating-bar-track {
    flex: 1;
    height: 8px;
    background: var(--act-mist);
    border-radius: var(--act-radius-full);
    overflow: hidden;
}

.act-rating-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--act-ocean), var(--act-ocean-light));
    border-radius: var(--act-radius-full);
    transition: width 1s ease;
}

.act-rating-bar-value { width: 36px; text-align: right; font-weight: 700; color: var(--act-navy); }

/* =============================================
   AFFILIATE LINK STYLES
============================================= */
.act-affiliate-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--act-space-sm);
    background: var(--act-sunset);
    color: var(--act-white);
    padding: 14px 28px;
    border-radius: var(--act-radius-full);
    font-weight: 700;
    font-size: 15px;
    text-decoration: none;
    transition: var(--act-transition);
}
.act-affiliate-btn:hover { background: #e08a45; transform: translateY(-2px); color: var(--act-white); }

.act-affiliate-disclaimer {
    font-size: 11px;
    color: var(--act-silver);
    margin-top: 6px;
    text-align: center;
}

/* =============================================
   GEAR / PRODUCT CARD (store)
============================================= */
.act-gear-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--act-space-lg); }

.act-gear-card {
    background: var(--act-white);
    border: 1px solid var(--act-mist);
    border-radius: var(--act-radius-lg);
    overflow: hidden;
    transition: var(--act-transition);
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
}
.act-gear-card:hover { transform: translateY(-4px); box-shadow: var(--act-shadow-md); }

.act-gear-card__img-wrap { height: 200px; overflow: hidden; background: var(--act-cloud); }
.act-gear-card__img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.act-gear-card:hover .act-gear-card__img { transform: scale(1.06); }

.act-gear-card__body { padding: var(--act-space-lg); flex: 1; display: flex; flex-direction: column; }
.act-gear-card__name { font-family: var(--act-font-display); font-size: 17px; font-weight: 700; color: var(--act-navy); margin-bottom: 8px; }
.act-gear-card__stars { color: var(--act-gold); font-size: 13px; margin-bottom: var(--act-space-sm); }
.act-gear-card__price { font-family: var(--act-font-display); font-size: 22px; font-weight: 700; color: var(--act-navy); margin-top: auto; padding-top: var(--act-space-md); border-top: 1px solid var(--act-mist); }
.act-gear-card__buy { display: block; width: 100%; text-align: center; background: var(--act-ocean); color: var(--act-white); padding: 12px; border-radius: var(--act-radius-md); font-weight: 700; font-size: 14px; margin-top: var(--act-space-sm); text-decoration: none; transition: var(--act-transition); }
.act-gear-card__buy:hover { background: #005f91; color: var(--act-white); }

/* =============================================
   NOTIFICATION / TOAST
============================================= */
.act-toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    background: var(--act-navy);
    color: var(--act-white);
    padding: 14px 22px;
    border-radius: var(--act-radius-md);
    font-size: 14px;
    font-weight: 500;
    z-index: 9999;
    box-shadow: var(--act-shadow-lg);
    animation: act-toast-in .3s ease;
    max-width: 320px;
    display: flex;
    align-items: center;
    gap: 10px;
}

@keyframes act-toast-in {
    from { transform: translateY(20px); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
}

/* =============================================
   COOKIE CONSENT BAR
============================================= */
.act-cookie-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--act-navy);
    color: rgba(255,255,255,.8);
    padding: var(--act-space-md) var(--act-space-lg);
    z-index: 1500;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--act-space-md);
    font-size: 13.5px;
    border-top: 1px solid rgba(255,255,255,.08);
    flex-wrap: wrap;
}

.act-cookie-bar a { color: var(--act-ocean-light); }

.act-cookie-bar__actions { display: flex; gap: var(--act-space-sm); }

.act-cookie-accept {
    background: var(--act-ocean);
    color: var(--act-white);
    border: none;
    padding: 9px 20px;
    border-radius: var(--act-radius-full);
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    transition: var(--act-transition);
}
.act-cookie-accept:hover { background: #005f91; }

.act-cookie-decline {
    background: transparent;
    color: rgba(255,255,255,.5);
    border: 1px solid rgba(255,255,255,.2);
    padding: 9px 20px;
    border-radius: var(--act-radius-full);
    font-size: 13px;
    cursor: pointer;
    transition: var(--act-transition);
}
.act-cookie-decline:hover { border-color: rgba(255,255,255,.5); color: rgba(255,255,255,.8); }

/* =============================================
   EXIT INTENT POPUP (CruiseMember plugin uses this)
============================================= */
.act-exit-popup-overlay {
    position: fixed;
    inset: 0;
    background: rgba(10,22,40,.7);
    backdrop-filter: blur(6px);
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--act-space-lg);
}

.act-exit-popup {
    background: var(--act-white);
    border-radius: var(--act-radius-xl);
    padding: 48px 40px;
    max-width: 520px;
    width: 100%;
    text-align: center;
    position: relative;
    animation: act-fade-up .4s ease;
}

.act-exit-popup__close {
    position: absolute;
    top: 16px;
    right: 16px;
    background: var(--act-cloud);
    border: none;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 16px;
    color: var(--act-slate);
    transition: var(--act-transition);
}
.act-exit-popup__close:hover { background: var(--act-mist); color: var(--act-navy); }

.act-exit-popup__icon { font-size: 56px; margin-bottom: 16px; }
.act-exit-popup__title { font-family: var(--act-font-display); font-size: 28px; font-weight: 700; color: var(--act-navy); margin-bottom: 10px; }
.act-exit-popup__desc { font-size: 15px; color: var(--act-slate); margin-bottom: 28px; line-height: 1.6; }

.act-exit-popup input[type="email"] {
    width: 100%;
    padding: 14px 18px;
    border: 2px solid var(--act-mist);
    border-radius: var(--act-radius-md);
    font-size: 15px;
    margin-bottom: var(--act-space-sm);
    outline: none;
    transition: border-color .2s;
}
.act-exit-popup input[type="email"]:focus { border-color: var(--act-ocean); }

/* =============================================
   PRINT STYLES
============================================= */
@media print {
    .act-site-topbar,
    .act-site-nav,
    .act-sidebar,
    .act-newsletter,
    .act-site-footer,
    .act-ad-slot-wrapper,
    .act-compare-strip,
    .act-trust-bar,
    .act-btn,
    .act-exit-popup-overlay,
    .act-cookie-bar { display: none !important; }

    .act-content-sidebar { grid-template-columns: 1fr !important; }
    .act-article-content { font-size: 14px !important; }
    body { background: white !important; color: black !important; }
    a { color: black !important; text-decoration: underline !important; }
    h1,h2,h3 { color: black !important; }
}

/* =============================================
   DARK MODE (respects system preference)
   Opt-in only — uncomment to enable
============================================= */
/*
@media (prefers-color-scheme: dark) {
    :root {
        --act-pearl: #0A1628;
        --act-cloud: #0D2040;
        --act-mist:  #162840;
        --act-white: #0D1F36;
        --act-ink:   #E8F0F8;
        --act-slate: #94A8C0;
    }
}
*/

/* =============================================
   REDUCED MOTION
============================================= */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
    }
    .act-trust-track { animation: none; }
}
