/*
 Theme Name:   Trema Dev
 Theme URI:    https://trema-dev.blockletter.ca
 Template:     twentytwentyfive
 Version:      1.0.1
 Text Domain:  trema-dev
*/

/* Active nav item underline */
.wp-block-navigation-item__content[aria-current="page"] {
    text-decoration: underline !important;
}

/* MC4WP Mailchimp form — front page cover */
.mc4wp-form {
    background: rgba(0, 0, 0, 0.65) !important;
    padding: 1rem 0 1rem 1.5rem !important;
    max-width: 800px !important;
}

.mc4wp-form-fields p {
    display: flex !important;
    align-items: center !important;
    gap: 1.5rem !important;
}

.wpcf7 form div > div {
    min-width: 0 !important;
    margin: 0 !important;
}

.mc4wp-form label {
    color: #ffffff !important;
    font-family: inherit !important;
    font-size: inherit !important;
    font-weight: inherit !important;
    letter-spacing: inherit !important;
    white-space: nowrap !important;
    margin: 0 !important;
    background: transparent !important;
    padding: 0 !important;
}

.mc4wp-form input[type='email'] {
    background: transparent !important;
    border: none !important;
    border-bottom: 1px solid #ffffff !important;
    color: #ffffff !important;
    outline: none !important;
    padding: 0.25rem 0.4rem !important;
    flex: 1 !important;
    width: auto !important;
    box-shadow: none !important;
    font-family: inherit !important;
    font-size: inherit !important;
}

.mc4wp-form input[type='email']::placeholder {
    color: rgba(255, 255, 255, 0.6) !important;
}

.mc4wp-form input[type='submit'] {
    background: rgba(0, 0, 0, 1) !important;
    border: none !important;
    color: #ffffff !important;
    font-family: inherit !important;
    font-size: inherit !important;
    font-weight: inherit !important;
    letter-spacing: inherit !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    box-shadow: none !important;
    align-self: stretch !important;
    margin-top: -1rem !important;
    margin-bottom: -1rem !important;
    padding: 0 1.5rem !important;
    margin-left: 1.5rem !important;
}

.mc4wp-form input[type='submit']:hover {
    background: rgba(0, 0, 0, 0.65) !important;
}

/* Hide MC4WP API key warning on front end */
p[style*="indianred"] {
    display: none !important;
}

.mc4wp-alert {
    display: none !important;
}

.mc4wp-form .mc4wp-response .mc4wp-alert {
    display: block !important;
    color: #ffffff !important;
    padding: 0.5rem 0 0;
    font-size: 0.9em;
}

.mc4wp-form .mc4wp-response .mc4wp-alert p {
    margin: 0;
}

/* Hamburger nav — trigger at 900px instead of default 600px */
@media (max-width: 900px) {
    .wp-block-navigation.is-responsive > .wp-block-navigation__responsive-container:not(.is-menu-open) {
        display: none;
    }
    .wp-block-navigation.is-responsive > .wp-block-navigation__responsive-container-open {
        display: flex;
    }
}

@media (min-width: 901px) {
    .wp-block-navigation.is-responsive > .wp-block-navigation__responsive-container-open {
        display: none !important;
    }
    .wp-block-navigation.is-responsive > .wp-block-navigation__responsive-container.hidden-by-default:not(.is-menu-open) {
        display: block;
    }
}

/* Hamburger overlay menu — dark background to match page */
.wp-block-navigation__responsive-container.is-menu-open {
    background-color: rgba(0, 0, 0, 0.85) !important;
    color: #ffffff !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close {
    color: #ffffff !important;
}

/* Hamburger overlay — left-align menu items */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
    align-items: flex-start !important;
}

/* Hamburger overlay — left-align menu items (override items-justified-right) */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
    justify-content: flex-start !important;
    align-items: flex-start !important;
}

/* Subscription form — stack vertically on narrow screens */
@media (max-width: 600px) {
    .mc4wp-form {
        max-width: 100% !important;
        padding: 1rem !important;
    }

    .mc4wp-form-fields p {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 0.75rem !important;
    }

    .mc4wp-form input[type='email'] {
        width: 100% !important;
    }

    .mc4wp-form input[type='submit'] {
        align-self: stretch !important;
        margin: 0 !important;
        padding: 0.75rem 1rem !important;
        text-align: center !important;
    }
}

/* Page transition fade */
@view-transition {
    navigation: auto;
}

::view-transition {
    background-color: #000000;
}

::view-transition-old(root) {
    animation: 0.3s ease-in both fade-out;
}

::view-transition-new(root) {
    animation: 0.3s ease-out 0.3s both fade-in;
}

@keyframes fade-out {
    from { opacity: 1; }
    to   { opacity: 0; }
}

@keyframes fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* Remove focus outline on mouse click, keep for keyboard navigation */
.wp-block-navigation :where(a, button):focus:not(:focus-visible) {
    outline: none !important;
    box-shadow: none !important;
}

.wp-block-navigation__responsive-container-open:focus:not(:focus-visible),
.wp-block-navigation__responsive-container-close:focus:not(:focus-visible) {
    outline: none !important;
    box-shadow: none !important;
}

/* Square buttons */
.wp-block-button__link,
.wp-element-button {
    border-radius: 0 !important;
}

/* Sticky shrinking header */
header.wp-block-template-part {
    position: sticky;
    top: 0;
    z-index: 1000;
    background-color: #000000;
    transition: box-shadow 0.3s ease;
}

.wp-block-site-title,
.wp-block-site-title a {
    transition: font-size 0.3s ease;
}

header.wp-block-template-part.site-header-scrolled .wp-block-site-title,
header.wp-block-template-part.site-header-scrolled .wp-block-site-title a {
    font-size: 1rem !important;
}

header.wp-block-template-part.site-header-scrolled {
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
}

/* Admin bar offset for sticky header */
body.admin-bar header.wp-block-template-part {
    top: 32px;
}
@media screen and (max-width: 782px) {
    body.admin-bar header.wp-block-template-part {
        top: 46px;
    }
}

/* Logo image shrink on scroll — width driven by JS, will-change hints GPU */
.wp-block-site-logo img {
    will-change: width;
}

/* Tighter button padding */
.wp-block-button__link,
.wp-element-button {
    font-size: 0.7em !important;
    padding: 0.2em 0.6em !important;
}

/* Remove click outline on logo, keep for keyboard nav */
.wp-block-site-logo a:focus:not(:focus-visible) {
    outline: none !important;
    box-shadow: none !important;
}
/* ── CF7 Booking form ─────────────────────────────────────────── */

/* Container */
.wpcf7 {
    width: 100% !important;
    max-width: 1000px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
}

/* Text / number / date / email / tel inputs + textarea */
.wpcf7 input[type='text'],
.wpcf7 input[type='email'],
.wpcf7 input[type='tel'],
.wpcf7 input[type='number'],
.wpcf7 input[type='date'],
.wpcf7 input[type='url'],
.wpcf7 textarea {
    background: #ffffff !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    color: #000000 !important;
    font-family: inherit !important;
    font-size: inherit !important;
    padding: 0.25rem 0.4rem !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Flex rows */
.wpcf7 form div {
    gap: 1.5rem !important;
    flex-wrap: wrap !important;
    box-sizing: border-box !important;
}

/* Flex columns */
.wpcf7 form div > div {
    min-width: 0 !important;
    flex-shrink: 1 !important;
    box-sizing: border-box !important;
}

/* Labels */
.wpcf7 label {
    display: block !important;
    margin: 0 !important;
}

/* Suppress blank lines CF7 generates from empty template lines */
.wpcf7 form br {
    display: none !important;
}

.wpcf7 form p {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
}

/* Checkboxes — square, field-height, black X on checked */
.wpcf7 input[type='checkbox'] {
    appearance: none !important;
    -webkit-appearance: none !important;
    background: #ffffff !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    cursor: pointer !important;
    display: inline-block !important;
    width: 1.75em !important;
    height: 1.75em !important;
    vertical-align: middle !important;
    flex-shrink: 0 !important;
}

.wpcf7 input[type='checkbox']:checked {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cline x1='3' y1='3' x2='21' y2='21' stroke='%23000000' stroke-width='3.5' stroke-linecap='round'/%3E%3Cline x1='21' y1='3' x2='3' y2='21' stroke='%23000000' stroke-width='3.5' stroke-linecap='round'/%3E%3C/svg%3E") !important;
    background-size: 85% !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
}

.wpcf7 .wpcf7-list-item-label {
    vertical-align: middle !important;
}

/* CF7 submit — outline style matching Artists page Booking buttons */
.wpcf7 input[type='submit'] {
    background: transparent !important;
    border: 2px solid currentColor !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    color: inherit !important;
    cursor: pointer !important;
    font-family: inherit !important;
    font-size: 0.7em !important;
    padding: 0.2em 0.6em !important;
}
/* CF7 response messages — all border colours overridden to white */
.wpcf7 form .wpcf7-response-output,
.wpcf7 form.sent .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output,
.wpcf7 form.spam .wpcf7-response-output,
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
    border-color: #ffffff !important;
}

/* Flatpickr date picker — monochromatic */
.flatpickr-calendar {
    background: #ffffff !important;
    border: 1px solid #000000 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    color: #000000 !important;
}

.flatpickr-months,
.flatpickr-month {
    background: #000000 !important;
    color: #ffffff !important;
    fill: #ffffff !important;
}

.flatpickr-current-month input.cur-year,
.flatpickr-current-month .flatpickr-monthDropdown-months {
    color: #ffffff !important;
}

.flatpickr-weekday {
    background: #000000 !important;
    color: #ffffff !important;
}

.flatpickr-day {
    color: #000000 !important;
    border-radius: 0 !important;
}

.flatpickr-day:hover,
.flatpickr-day:focus {
    background: #e0e0e0 !important;
    border-color: #e0e0e0 !important;
    color: #000000 !important;
}

.flatpickr-day.today {
    border-color: #000000 !important;
    background: transparent !important;
    color: #000000 !important;
    font-weight: bold !important;
}

.flatpickr-day.today:hover {
    background: #000000 !important;
    color: #ffffff !important;
}

.flatpickr-day.selected,
.flatpickr-day.selected:hover {
    background: #000000 !important;
    border-color: #000000 !important;
    color: #ffffff !important;
}

.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover {
    color: #bbbbbb !important;
}

.flatpickr-prev-month,
.flatpickr-next-month {
    fill: #ffffff !important;
    color: #ffffff !important;
}

.flatpickr-prev-month:hover svg,
.flatpickr-next-month:hover svg {
    fill: #cccccc !important;
}

/* ── Events ────────────────────────────────────────────────────────────────── */

.trema-events-list {
    display: flex;
    flex-direction: column;
    max-width: 860px;
    margin-left: auto;
    margin-right: auto;
}

.trema-event-card {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: var(--wp--preset--spacing--40);
    border-top: 1px solid currentColor;
    padding: var(--wp--preset--spacing--40) 0;
}

.trema-event-card:last-child {
    border-bottom: 1px solid currentColor;
}

.trema-ec-image {
    display: block;
    flex-shrink: 0;
    width: 276px;
}

.trema-ec-image img {
    width: 100%;
    height: auto;
    display: block;
}

.trema-ec-body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.4em;
}

.trema-ec-info {
    display: flex;
    flex-direction: column;
    gap: 0.15em;
}

.trema-ec-date {
    font-size: 0.78em;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    opacity: 0.65;
}

.trema-ec-title {
    font-size: 1.15em;
    font-weight: 700;
    margin: 0;
    line-height: 1.2;
    text-transform: uppercase;
}

.trema-ec-title a {
    text-decoration: none;
    color: inherit;
}

.trema-ec-title a:hover {
    text-decoration: underline;
}

.trema-ec-meta-row {
    font-size: 0.82em;
    opacity: 0.85;
}

.trema-ec-label {
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-size: 0.78em;
    opacity: 0.6;
    margin-right: 0.3em;
}

.trema-ec-cost {
    font-size: 0.82em;
    opacity: 0.7;
    margin-top: 0.15em;
}

/* Ticket / action button — matches existing theme button style */
.trema-event-btn {
    display: inline-block;
    border: 2px solid currentColor;
    padding: 0.2em 0.6em;
    font-size: 0.7em;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none;
    color: inherit;
    background: transparent;
    white-space: nowrap;
    align-self: flex-start;
}

.trema-event-btn:hover {
    background: #fff;
    color: #000;
}

/* Single event meta block */
.trema-event-meta {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    gap: var(--wp--preset--spacing--50);
    border-top: 1px solid currentColor;
    border-bottom: 1px solid currentColor;
    padding: var(--wp--preset--spacing--40) 0;
    margin-bottom: var(--wp--preset--spacing--50);
    max-width: 960px;
    margin-left: auto;
    margin-right: auto;
}

.trema-em-image {
    flex-shrink: 0;
    width: 400px;
}

.trema-em-image img {
    width: 100%;
    height: auto;
    display: block;
}

.trema-em-details {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.45em;
}

.trema-em-row {
    display: flex;
    gap: 1em;
    font-size: 0.9em;
    align-items: baseline;
}

.trema-em-label {
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    font-size: 0.72em;
    min-width: 5.5em;
    flex-shrink: 0;
    opacity: 0.55;
    padding-top: 0.1em;
}

.trema-em-value {
    flex: 1;
}

.trema-em-address {
    display: block;
    opacity: 0.7;
    font-size: 0.9em;
}

.trema-em-tickets {
    margin-top: 0.6em;
}

.trema-ra-link {
    display: inline-block;
    align-self: flex-start;
}

.trema-ra-logo {
    display: block;
    height: 28px;
    width: auto;
    opacity: 0.7;
}

.trema-ra-link:hover .trema-ra-logo {
    opacity: 1;
}

/* ── Artists page — Booking buttons match ticket button style ───────────────── */

.page-id-21 .wp-block-button.is-style-outline .wp-block-button__link {
    border: 2px solid currentColor;
    border-radius: 0;
    background: transparent;
    color: inherit;
    padding: 0.2em 0.6em;
    font-size: 0.7em;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    box-shadow: none;
}

.page-id-21 .wp-block-button.is-style-outline .wp-block-button__link:hover {
    background: #fff;
    color: #000;
}

.single-event .wp-block-post-title {
    text-transform: uppercase;
}

.trema-events-list + .page-numbers {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.4em;
    list-style: none;
    margin: var(--wp--preset--spacing--50) 0 0;
    padding: 0;
}

.trema-events-list + .page-numbers li {
    margin: 0;
    padding: 0;
}

.trema-events-list + .page-numbers .page-numbers {
    display: inline-block;
    border: 1px solid currentColor;
    padding: 0.2em 0.55em;
    font-size: 0.78em;
    text-decoration: none;
    color: inherit;
    background: transparent;
}

.trema-events-list + .page-numbers .page-numbers.current {
    background: #fff;
    color: #000;
}

.trema-events-list + .page-numbers a.page-numbers:hover {
    background: #fff;
    color: #000;
}

.trema-events-empty {
    font-style: italic;
    opacity: 0.6;
    text-align: center;
}

@media (max-width: 690px) {
    .trema-event-meta {
        flex-direction: column;
    }
    .trema-em-image {
        width: 100%;
        max-width: 360px;
        margin-left: auto;
        margin-right: auto;
    }
    .trema-event-card {
        flex-direction: column;
        align-items: center;
    }
    .trema-ec-image {
        width: 100%;
        max-width: 360px;
    }
    .trema-ec-body {
        text-align: center;
        align-items: center;
    }
    .trema-event-btn {
        align-self: center;
    }
    .trema-ra-link {
        align-self: center;
    }
}
/* ── reCAPTCHA */
.grecaptcha-badge {
    visibility: hidden;
}

