/* ============================================================
   HEN AND STAG SLIGO - VISUAL REFRESH
   CSS-only overrides loaded AFTER style.min.css
   NO grid changes, NO framework changes, NO HTML changes
   ============================================================ */

/* ---- Typography ---- */
body,
p,
a,
span,
li,
td,
th,
label,
input,
select,
textarea,
button {
    font-family: 'Inter', 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

h1, h2, h3, h4, h5, h6,
.how-it-works-heading,
.actvity-page-top-title {
    font-family: 'Inter', 'Poppins', sans-serif !important;
    font-weight: 700 !important;
    color: #1a2744;
    letter-spacing: -0.3px;
}

body {
    color: #333;
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Only apply larger heading sizes to main section headings, not card titles */
.how-it-works-section > .row > .columns > h1,
.how-it-works-heading,
section > .container > h1,
section > .row > .columns > h1 {
    font-size: 2.4rem !important;
}

/* Package card titles - keep smaller */
.trend-title-stag-1,
.hen-card-homepage h2,
.hen-card-homepage h3,
.stag-card-homepage h2,
.stag-card-homepage h3,
.col-md-3 h2,
.col-md-3 h3 {
    font-size: 1rem !important;
    line-height: 1.3 !important;
    margin-bottom: 8px !important;
}

p {
    line-height: 1.7;
    color: #555;
}

/* ---- Section Spacing ---- */
section,
.how-it-works-section,
.hen-activities-main-section {
    padding: 50px 0 !important;
}

/* Alternating section backgrounds */
.how-it-works-section:nth-child(even) {
    background: #f8f9fa;
}

/* ---- Header & Navigation ---- */
header.mainhead {
    box-shadow: 0 2px 15px rgba(0,0,0,0.06);
}

.top-phone-numbers {
    background: #1a2744 !important;
    padding: 6px 0 !important;
    font-size: 13px;
}

.top-phone-numbers a {
    color: #fff !important;
    opacity: 0.9;
}

.top-phone-numbers a:hover {
    color: #ff6b35 !important;
    opacity: 1;
}

.call-us-today-text {
    color: #fff !important;
    font-size: 13px !important;
}

.top-phone-numbers .fa,
.top-phone-numbers i {
    color: #fff !important;
}

/* Nav links */
.top-bar-left .menu > li > a {
    font-weight: 500 !important;
    font-size: 14px !important;
    color: #333 !important;
    letter-spacing: 0.2px;
}

.top-bar-left .menu > li > a:hover {
    color: #ff6b35 !important;
}

/* Quick Enquiry button */
.quick-enquiry-btn {
    background: #ff6b35 !important;
    color: #fff !important;
    border-radius: 25px !important;
    padding: 10px 24px !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    text-transform: none !important;
    transition: all 0.3s ease !important;
    border: none !important;
}

.quick-enquiry-btn:hover {
    background: #e85a25 !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(255, 107, 53, 0.35) !important;
}

/* ---- Hero Section ---- */
.how-it-works-heading {
    font-size: 2.2rem !important;
    color: #1a2744 !important;
    line-height: 1.25 !important;
}

/* ---- Buttons (all types) ---- */
.btn_purple,
.btn_more,
.button-link-rounded,
.read-more-home-hen,
.hen-package-start-enquiry,
a.btn_purple {
    background: #e84393 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 12px 28px !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    text-transform: none !important;
    letter-spacing: 0.3px;
    transition: all 0.3s ease !important;
    display: inline-block;
    text-decoration: none !important;
}

.btn_purple:hover,
.btn_more:hover,
.button-link-rounded:hover,
.read-more-home-hen:hover,
.hen-package-start-enquiry:hover,
a.btn_purple:hover {
    background: #d63384 !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(232, 67, 147, 0.35) !important;
    color: #fff !important;
    text-decoration: none !important;
}

.read-more-home-stag,
a.read-more-home-stag {
    background: #0984e3 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 12px 28px !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    text-transform: none !important;
    transition: all 0.3s ease !important;
    display: inline-block;
    text-decoration: none !important;
}

.read-more-home-stag:hover,
a.read-more-home-stag:hover {
    background: #0773c5 !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(9, 132, 227, 0.35) !important;
    color: #fff !important;
    text-decoration: none !important;
}

/* ---- Package Cards ---- */
.hen-card-homepage,
.stag-card-homepage {
    background: #fff;
    border-radius: 12px !important;
    box-shadow: 0 2px 15px rgba(0,0,0,0.08) !important;
    overflow: hidden;
    transition: all 0.3s ease;
    margin-bottom: 25px !important;
    border: 1px solid #eee;
}

.hen-card-homepage:hover,
.stag-card-homepage:hover {
    box-shadow: 0 8px 30px rgba(0,0,0,0.12) !important;
    transform: translateY(-5px);
}

.hen-card-homepage img,
.stag-card-homepage img {
    border-radius: 0 !important;
    width: 100%;
}

.hen-card-homepage .edesc,
.stag-card-homepage .edesc {
    padding: 18px !important;
}

.hen-card-homepage h4,
.stag-card-homepage h4,
.hen-card-homepage h3,
.stag-card-homepage h3 {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #1a2744 !important;
    margin-bottom: 8px !important;
    line-height: 1.3 !important;
}

.hen-card-homepage p,
.stag-card-homepage p {
    font-size: 13px !important;
    color: #666 !important;
    line-height: 1.5 !important;
}

.color-purple,
.edesc.color-purple {
    background: transparent !important;
    color: #333 !important;
}

.color-blue,
.edesc.color-blue {
    background: transparent !important;
    color: #333 !important;
}

/* ---- "Why book with us" Section ---- */
.why-book-heading,
.why-book-heading-bottom {
    font-weight: 600 !important;
    font-size: 15px !important;
    color: #1a2744 !important;
}

.why-book-text,
.why-book-text-bottom {
    font-size: 13px !important;
    color: #666 !important;
    line-height: 1.6 !important;
}

/* ---- Trustpilot / Reviews ---- */
.review-picture-card,
.review-picture-card-bg {
    background: #fff !important;
    border-radius: 12px !important;
    box-shadow: 0 2px 15px rgba(0,0,0,0.06) !important;
    padding: 25px !important;
    border: 1px solid #eee !important;
}

.review-picture-text {
    font-size: 13px !important;
    line-height: 1.6 !important;
    color: #555 !important;
    font-style: italic;
}

.heading-trustpilot-review-package {
    font-weight: 600 !important;
    color: #1a2744 !important;
}

.hen-package-rating {
    font-weight: 600 !important;
    color: #1a2744 !important;
    font-size: 14px !important;
}

/* ---- Price Display ---- */
.page_price,
.price-display {
    color: #ff6b35 !important;
    font-weight: 700 !important;
    font-size: 1.5em !important;
}

/* ---- Footer ---- */
#footer,
footer,
.footer-section {
    background: #1a2744 !important;
    color: #fff !important;
    padding: 50px 0 25px !important;
}

#footer.purpled,
#footer.stag,
footer.purpled,
footer.stag {
    background: #1a2744 !important;
}

#footer h3,
#footer h4,
#footer h5,
footer h3,
footer h4,
footer h5 {
    color: #fff !important;
    font-weight: 600 !important;
    font-size: 16px !important;
    margin-bottom: 15px !important;
}

#footer a,
footer a,
.footer-section a {
    color: rgba(255,255,255,0.7) !important;
    transition: color 0.3s ease;
}

#footer a:hover,
footer a:hover,
.footer-section a:hover {
    color: #ff6b35 !important;
}

#footer p,
footer p,
.footer-section p {
    color: rgba(255,255,255,0.6) !important;
    font-size: 13px !important;
}

/* Footer logo and headings */
#footer h1,
#footer h2,
footer h1,
footer h2,
.footer-section h1,
.footer-section h2 {
    color: #fff !important;
}

/* Footer logo image - make white */
.henandstag-footer-logo,
#footer .henandstag-footer-logo {
    filter: brightness(0) invert(1) !important;
    opacity: 0.9;
}

/* Footer social icon images - make white */
.social-icons-footer img,
#footer .social-icons-footer img {
    filter: brightness(0) invert(1) !important;
    opacity: 0.7;
    transition: all 0.3s ease;
}

.social-icons-footer a:hover img,
#footer .social-icons-footer a:hover img {
    opacity: 1;
    filter: brightness(0) invert(1) sepia(1) saturate(5) hue-rotate(350deg) !important;
}

/* Footer links - all columns */
#footer li a,
footer li a,
.footer-section li a {
    color: rgba(255,255,255,0.7) !important;
}

#footer li a:hover,
footer li a:hover,
.footer-section li a:hover {
    color: #ff6b35 !important;
}

/* Social icons in footer */
footer .fa,
footer .fab,
footer .fas,
footer svg,
#footer .fa,
#footer .fab,
#footer .fas,
#footer svg,
.footer-section svg {
    color: rgba(255,255,255,0.7) !important;
    fill: rgba(255,255,255,0.7) !important;
    font-size: 18px !important;
    margin-right: 10px;
    transition: all 0.3s ease;
}

footer .fa:hover,
footer .fab:hover,
footer .fas:hover,
footer svg:hover,
#footer .fa:hover,
#footer svg:hover {
    color: #ff6b35 !important;
    fill: #ff6b35 !important;
    transform: translateY(-2px);
}

/* Footer all text and spans */
#footer span,
footer span,
.footer-section span {
    color: rgba(255,255,255,0.7) !important;
}

/* ---- Modal Improvements ---- */
.modal-content {
    border-radius: 12px !important;
    border: none !important;
    box-shadow: 0 10px 40px rgba(0,0,0,0.2) !important;
    overflow: hidden;
}

.modal-header {
    background: #1a2744 !important;
    border-bottom: none !important;
    padding: 18px 24px !important;
}

.quick-enquiry-modal-title {
    color: #fff !important;
    font-weight: 600 !important;
    font-size: 18px !important;
}

.modal-body {
    padding: 25px !important;
}

/* ---- Forms ---- */
.form-control,
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="date"],
select,
textarea {
    border: 1.5px solid #ddd !important;
    border-radius: 8px !important;
    padding: 10px 14px !important;
    font-size: 14px !important;
    transition: border-color 0.3s ease !important;
}

.form-control:focus,
input[type="text"]:focus,
input[type="email"]:focus,
select:focus,
textarea:focus {
    border-color: #ff6b35 !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(255,107,53,0.12) !important;
}

/* ---- "As seen in" Section ---- */
.as-seen-in {
    padding: 30px 0 !important;
    text-align: center;
}

/* ---- "How it works" icons ---- */
.how-it-works-icon {
    font-size: 2.5rem !important;
    color: #1a2744 !important;
    margin-bottom: 10px;
}

/* ---- Image treatments ---- */
.hero-slider-image {
    border-radius: 12px !important;
}

/* ---- Activity/Package detail pages ---- */
.title.pakages {
    background: #fff !important;
    border-radius: 12px !important;
    box-shadow: 0 2px 15px rgba(0,0,0,0.06) !important;
    padding: 25px !important;
    margin-bottom: 25px !important;
    border: 1px solid #eee !important;
    transition: all 0.3s ease;
}

.title.pakages:hover {
    box-shadow: 0 6px 25px rgba(0,0,0,0.1) !important;
}

/* ---- Breadcrumb ---- */
.breadcrumb,
.localizare {
    background: transparent !important;
    font-size: 13px;
    color: #999;
    padding: 10px 0 !important;
}

/* ---- Link colours ---- */
a {
    color: #0984e3;
    transition: color 0.2s ease;
}

a:hover {
    color: #ff6b35;
    text-decoration: none !important;
}

/* ---- Mobile Responsive ---- */
@media (max-width: 640px) {
    h1 { font-size: 1.7rem !important; }
    h2 { font-size: 1.5rem !important; }
    h3 { font-size: 1.2rem !important; }

    section,
    .how-it-works-section {
        padding: 35px 0 !important;
    }

    .btn_purple,
    .btn_more,
    .read-more-home-hen,
    .read-more-home-stag,
    .quick-enquiry-btn {
        padding: 10px 20px !important;
        font-size: 13px !important;
    }

    /* Top-bar Quick Enquiry button: vertically centre inside the 50px header
       and keep the label on one line. The legacy CSS adds margin-top + an 85%
       width that overflows the bar on small screens. */
    .hidden-desktop-quick-enquiry {
        height: 50px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    .hidden-desktop-quick-enquiry .quick-enquiry-btn {
        margin: 0 !important;
        padding: 6px 14px !important;
        font-size: 12px !important;
        line-height: 1.2 !important;
        white-space: nowrap !important;
        width: auto !important;
        float: none !important;
        display: inline-block !important;
    }

    .hen-card-homepage,
    .stag-card-homepage {
        margin-bottom: 20px !important;
    }

    #footer, footer {
        padding: 35px 0 20px !important;
        text-align: center;
    }
}
