/*
Theme Name: Theatre Workshop of Nantucket
Theme URI: https://theatrenantucket.org/
Author: Boston Web Designers
Author URI: https://bostonwebdesigners.net/
Description: A custom Elementor-ready WordPress theme for Theatre Workshop of Nantucket. Built for easy content management with Custom Post Types for Shows, Staff, and Sponsors.
Version: 1.0.0
Tested up to: 6.4
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: twn

This theme is designed to work seamlessly with Elementor page builder,
providing easy content management for theatre productions, staff, and sponsors.
*/

/* ==========================================================================
   CSS Custom Properties (Design Tokens)
   ========================================================================== */

:root {
    /* Brand Colors - Matching current TWN Webflow site */
    --twn-primary: #1a1a1a;
    --twn-secondary: #2d2d2d;
    --twn-accent: #c9a227;
    /* Gold - Buy Tickets buttons */
    --twn-accent-light: #d4b94a;
    --twn-accent-dark: #a68521;
    --twn-purple: #7B2D8E;
    /* Purple - Support/Subscribe buttons */
    --twn-purple-light: #9a4bad;
    --twn-purple-dark: #5c1f6a;

    /* Text Colors */
    --twn-text-light: #ffffff;
    --twn-text-dark: #1a1a1a;
    --twn-text-muted: #888888;

    /* Background Colors */
    --twn-bg-dark: #1a1a1a;
    --twn-bg-darker: #0d0d0d;
    --twn-bg-light: #f5f5f5;
    --twn-bg-white: #ffffff;
    --twn-bg-gray: #f0f0f0;

    /* Typography - Matching TWN Webflow site */
    --twn-font-heading: 'Cormorant Garamond', Georgia, serif;
    --twn-font-body: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --twn-font-script: 'Italianno', 'Playfair Display', cursive;

    /* Spacing */
    --twn-spacing-xs: 0.5rem;
    --twn-spacing-sm: 1rem;
    --twn-spacing-md: 2rem;
    --twn-spacing-lg: 4rem;
    --twn-spacing-xl: 6rem;

    /* Borders */
    --twn-border-radius: 4px;
    --twn-border-radius-lg: 8px;

    /* Shadows */
    --twn-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    --twn-shadow-lg: 0 10px 40px rgba(0, 0, 0, 0.2);

    /* Transitions */
    --twn-transition: 0.3s ease;
}

/* ==========================================================================
   Base Styles
   ========================================================================== */

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    padding: 0;
    font-family: var(--twn-font-body);
    font-size: 16px;
    line-height: 1.6;
    color: var(--twn-text-dark);
    background-color: var(--twn-bg-white);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Dark theme body (for Elementor sections) */
body.twn-dark-theme {
    background-color: var(--twn-bg-dark);
    color: var(--twn-text-light);
}

/* ==========================================================================
   Typography
   ========================================================================== */

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: var(--twn-font-heading);
    font-weight: 700;
    line-height: 1.2;
    margin-top: 0;
    margin-bottom: var(--twn-spacing-sm);
}

h1 {
    font-size: clamp(2rem, 5vw, 3.5rem);
}

h2 {
    font-size: clamp(1.75rem, 4vw, 2.75rem);
}

h3 {
    font-size: clamp(1.5rem, 3vw, 2rem);
}

h4 {
    font-size: clamp(1.25rem, 2.5vw, 1.5rem);
}

h5 {
    font-size: 1.125rem;
}

h6 {
    font-size: 1rem;
}

p {
    margin-top: 0;
    margin-bottom: var(--twn-spacing-sm);
}

a {
    color: var(--twn-accent);
    text-decoration: none;
    transition: color var(--twn-transition);
}

a:hover,
a:focus {
    color: var(--twn-accent-light);
}

/* ==========================================================================
   Layout Utilities
   ========================================================================== */

.twn-container {
    width: 100%;
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--twn-spacing-sm);
    padding-right: var(--twn-spacing-sm);
}

.twn-container-wide {
    max-width: 1400px;
}

.twn-container-narrow {
    max-width: 800px;
}

/* ==========================================================================
   Buttons
   ========================================================================== */

.twn-button,
.twn-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 2rem;
    font-family: var(--twn-font-body);
    font-size: 0.875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    text-decoration: none;
    border: 2px solid transparent;
    border-radius: var(--twn-border-radius);
    cursor: pointer;
    transition: all var(--twn-transition);
}

.twn-btn-primary {
    background-color: var(--twn-accent);
    color: var(--twn-text-dark);
    border-color: var(--twn-accent);
}

.twn-btn-primary:hover,
.twn-btn-primary:focus {
    background-color: var(--twn-accent-light);
    border-color: var(--twn-accent-light);
    color: var(--twn-text-dark);
}

.twn-btn-outline {
    background-color: transparent;
    color: var(--twn-accent);
    border-color: var(--twn-accent);
}

.twn-btn-outline:hover,
.twn-btn-outline:focus {
    background-color: var(--twn-accent);
    color: var(--twn-text-dark);
}

.twn-btn-white {
    background-color: var(--twn-bg-white);
    color: var(--twn-text-dark);
    border-color: var(--twn-bg-white);
}

.twn-btn-white:hover,
.twn-btn-white:focus {
    background-color: transparent;
    color: var(--twn-text-light);
}

/* Purple button - Support Us style */
.twn-btn-purple {
    background-color: var(--twn-purple);
    color: var(--twn-text-light);
    border-color: var(--twn-purple);
}

.twn-btn-purple:hover,
.twn-btn-purple:focus {
    background-color: var(--twn-purple-light);
    border-color: var(--twn-purple-light);
    color: var(--twn-text-light);
}

/* Header action buttons with icons */
.twn-header-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border-radius: 0;
    text-decoration: none;
}

.twn-header-btn svg,
.twn-header-btn i {
    font-size: 1.2em;
}

.twn-btn-support {
    background-color: transparent;
    color: var(--twn-text-light);
    border: none;
}

.twn-btn-support:hover {
    color: var(--twn-purple);
}

.twn-btn-tickets {
    background-color: var(--twn-accent);
    color: var(--twn-text-dark);
}

.twn-btn-tickets:hover {
    background-color: var(--twn-accent-light);
}

/* ==========================================================================
   Header Styles (Fallback when not using Elementor header)
   ========================================================================== */

.twn-site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    background-color: rgba(26, 26, 26, 0.95);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    padding: var(--twn-spacing-sm) 0;
    transition: all var(--twn-transition);
}

.twn-site-header.scrolled {
    padding: 0.5rem 0;
    box-shadow: var(--twn-shadow-lg);
}

.twn-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--twn-spacing-md);
}

.twn-logo img {
    height: 60px;
    width: auto;
    transition: height var(--twn-transition);
}

.scrolled .twn-logo img {
    height: 45px;
}

.smart-header {
    transition: transform 0.3s ease;
}

.smart-header.hide {
    transform: translateY(-100%);
}


/* Admin Bar Compatibility */
body.admin-bar .twn-site-header,
body.admin-bar .elementor-location-header,
body.admin-bar .elementor-sticky--active {
    top: 32px !important;
}

@media screen and (max-width: 782px) {

    body.admin-bar .twn-site-header,
    body.admin-bar .elementor-location-header,
    body.admin-bar .elementor-sticky--active {
        top: 46px !important;
    }
}

/* ==========================================================================
   Navigation
   ========================================================================== */

.twn-main-nav ul {
    display: flex;
    align-items: center;
    gap: var(--twn-spacing-md);
    list-style: none;
    margin: 0;
    padding: 0;
}

.twn-main-nav a {
    color: var(--twn-text-light);
    font-size: 0.875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.twn-main-nav a:hover,
.twn-main-nav a:focus {
    color: var(--twn-accent);
}

/* Mobile Menu Toggle (Managed by Elementor) */
.twn-menu-toggle {
    display: none !important;
}

/* ==========================================================================
   Footer Styles (Fallback when not using Elementor footer)
   ========================================================================== */

.twn-site-footer {
    background-color: var(--twn-bg-dark);
    color: var(--twn-text-light);
    padding: var(--twn-spacing-lg) 0 var(--twn-spacing-md);
}

.twn-footer-widgets {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--twn-spacing-lg);
    margin-bottom: var(--twn-spacing-lg);
}

.twn-footer-widget h4 {
    color: var(--twn-accent);
    margin-bottom: var(--twn-spacing-sm);
}

.twn-footer-bottom {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: var(--twn-spacing-sm);
    padding-top: var(--twn-spacing-md);
    border-top: 1px solid var(--twn-secondary);
}

.twn-social-links {
    display: flex;
    gap: var(--twn-spacing-sm);
}

.twn-social-links a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background-color: var(--twn-secondary);
    border-radius: 50%;
    color: var(--twn-text-light);
    transition: all var(--twn-transition);
}

.twn-social-links a:hover {
    background-color: var(--twn-accent);
    color: var(--twn-text-dark);
}

/* ==========================================================================
   Show Cards (for non-Elementor templates)
   ========================================================================== */

.twn-shows-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--twn-spacing-md);
}

.twn-show-card {
    position: relative;
    background-color: var(--twn-bg-dark);
    border-radius: var(--twn-border-radius-lg);
    overflow: hidden;
    transition: transform var(--twn-transition), box-shadow var(--twn-transition);
}

.twn-show-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--twn-shadow-lg);
}

.twn-show-card-image {
    position: relative;
    aspect-ratio: 3/4;
    overflow: hidden;
}

.twn-show-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--twn-transition);
}

.twn-show-card:hover .twn-show-card-image img {
    transform: scale(1.05);
}

.twn-show-card-content {
    padding: var(--twn-spacing-sm);
}

.twn-show-card-title {
    font-size: 1.25rem;
    color: var(--twn-text-light);
    margin-bottom: var(--twn-spacing-xs);
}

.twn-show-card-dates {
    color: var(--twn-accent);
    font-size: 0.875rem;
    font-weight: 600;
}

.twn-show-card-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--twn-spacing-md);
    background: linear-gradient(transparent, rgba(0, 0, 0, 0.9));
    color: var(--twn-text-light);
}

/* ==========================================================================
   Staff Grid
   ========================================================================== */

.twn-staff-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--twn-spacing-md);
}

.twn-staff-card {
    text-align: center;
}

.twn-staff-photo {
    width: 150px;
    height: 150px;
    border-radius: 50%;
    overflow: hidden;
    margin: 0 auto var(--twn-spacing-sm);
    border: 3px solid var(--twn-accent);
}

.twn-staff-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.twn-staff-name {
    font-size: 1.125rem;
    margin-bottom: var(--twn-spacing-xs);
}

.twn-staff-title {
    color: var(--twn-accent);
    font-size: 0.875rem;
    font-weight: 600;
}

/* ==========================================================================
   Sponsor Logos
   ========================================================================== */

.twn-sponsors-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: var(--twn-spacing-lg);
}

.twn-sponsor-logo {
    max-width: 150px;
    filter: grayscale(100%);
    opacity: 0.7;
    transition: all var(--twn-transition);
}

.twn-sponsor-logo:hover {
    filter: grayscale(0%);
    opacity: 1;
}

/* ==========================================================================
   Elementor Overrides & Compatibility
   ========================================================================== */

/* Fix Popup Submenu Behavior: Change Hover to Click/Accordion */
.elementor-location-popup .elementor-nav-menu--main,
.elementor-location-popup .elementor-nav-menu--dropdown {
    width: 100% !important;
}

.elementor-location-popup .elementor-nav-menu--main ul.elementor-nav-menu,
.elementor-location-popup .elementor-nav-menu--dropdown ul.elementor-nav-menu {
    flex-direction: column !important;
    align-items: center !important;
    width: 100% !important;
}

.elementor-location-popup .elementor-nav-menu--main .sub-menu,
.elementor-location-popup .elementor-nav-menu--dropdown .sub-menu {
    display: none;
    /* Hide by default for JS slideToggle */
    position: static !important;
    /* Force accordion style instead of absolute/hover */
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
    padding-left: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
    transition: none !important;
    text-align: center !important;
}

.elementor-location-popup .elementor-nav-menu--main .sub-menu li a,
.elementor-location-popup .elementor-nav-menu--dropdown .sub-menu li a {
    justify-content: center !important;
    padding: 10px 0 !important;
    color: #000000 !important;
}

.elementor-location-popup .elementor-nav-menu--main .menu-item-has-children>a,
.elementor-location-popup .elementor-nav-menu--dropdown .menu-item-has-children>a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    width: 100% !important;
    padding: 10px 20px !important;
    color: #000000 !important;
    /* Match live site black */
    background-color: transparent !important;
}

.elementor-location-popup .elementor-nav-menu--main .menu-item:not(.menu-item-has-children)>a,
.elementor-location-popup .elementor-nav-menu--dropdown .menu-item:not(.menu-item-has-children)>a {
    color: #000000 !important;
    background-color: transparent !important;
}

/* Ensure indicators are hidden as we add our own via CSS */
.elementor-location-popup .elementor-nav-menu--main .sub-arrow,
.elementor-location-popup .elementor-nav-menu--dropdown .sub-arrow,
.elementor-location-popup .elementor-menu-toggle {
    display: none !important;
}

/* Force menu to stay visible inside popups (prevent double hamburger) */
.elementor-location-popup .elementor-nav-menu--main {
    display: block !important;
}


.elementor-location-popup .elementor-nav-menu--main .menu-item-has-children>a:after,
.elementor-location-popup .elementor-nav-menu--dropdown .menu-item-has-children>a:after {
    content: '\f078';
    /* Chevron-down to match live site */
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    position: absolute !important;
    right: 20px !important;
    font-size: 12px;
    color: #000000 !important;
    background: transparent !important;
    transition: transform 0.3s ease;
}

.elementor-location-popup .elementor-nav-menu--main .twn-menu-item-active>a:after,
.elementor-location-popup .elementor-nav-menu--dropdown .twn-menu-item-active>a:after {
    transform: rotate(180deg);
}

/* Remove Elementor default pointer backgrounds */
.elementor-location-popup .elementor-nav-menu--main .elementor-item.elementor-item-active,
.elementor-location-popup .elementor-nav-menu--main .elementor-item:hover,
.elementor-location-popup .elementor-nav-menu--main .elementor-item:focus {
    background-color: transparent !important;
}

/* Ensure Elementor sections work well with theme */
.elementor-section.elementor-section-boxed>.elementor-container {
    max-width: 1200px;
}

/* Dark section helper class */
.elementor-section.twn-dark-section {
    background-color: var(--twn-bg-dark);
}

.elementor-section.twn-dark-section,
.elementor-section.twn-dark-section h1,
.elementor-section.twn-dark-section h2,
.elementor-section.twn-dark-section h3,
.elementor-section.twn-dark-section h4,
.elementor-section.twn-dark-section h5,
.elementor-section.twn-dark-section h6,
.elementor-section.twn-dark-section p {
    color: var(--twn-text-light);
}

/* Elementor button styling */
.elementor-button {
    font-family: var(--twn-font-body);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.elementor-main-swiper,
.twn-site-main {
    overflow-x: hidden;
}

.swiper-wrapper {
    will-change: transform;
}


/* ==========================================================================
   WordPress Core Styles
   ========================================================================== */

/* Alignments */
.alignleft {
    float: left;
    margin-right: var(--twn-spacing-sm);
}

.alignright {
    float: right;
    margin-left: var(--twn-spacing-sm);
}

.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.alignwide {
    max-width: calc(100% + 100px);
    margin-left: -50px;
    margin-right: -50px;
}

.alignfull {
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

/* Captions */
.wp-caption {
    max-width: 100%;
}

.wp-caption-text {
    font-size: 0.875rem;
    color: var(--twn-text-muted);
    padding: var(--twn-spacing-xs) 0;
}

/* Galleries */
.gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--twn-spacing-sm);
}

.gallery-item {
    margin: 0;
}

.gallery-item img {
    width: 100%;
    height: auto;
    border-radius: var(--twn-border-radius);
}

/* Screen reader text */
.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    word-wrap: normal !important;
}

.screen-reader-text:focus {
    background-color: #f1f1f1;
    border-radius: 3px;
    box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
    clip: auto !important;
    clip-path: none;
    color: #21759b;
    display: block;
    font-size: 0.875rem;
    font-weight: 700;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000;
}

/* Skip link */
.skip-link {
    position: absolute;
    left: -9999px;
    top: auto;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.skip-link:focus {
    display: block;
    left: 0;
    top: 0;
    width: auto;
    height: auto;
    padding: 15px 23px;
    background: #f1f1f1;
    color: #21759b;
    font-size: 1rem;
    z-index: 100001;
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {

    .twn-site-header,
    .twn-site-footer,
    .twn-menu-toggle,
    .elementor-location-header,
    .elementor-location-footer {
        display: none !important;
    }

    body {
        font-size: 12pt;
        color: #000;
        background: #fff;
    }

    a {
        color: #000;
        text-decoration: underline;
    }
}
/* ==========================================================================
   Cast & Creative Team Shortcodes
   ========================================================================== */

/* Cast Grid */
.twn-cast-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--twn-spacing-md);
    margin-bottom: var(--twn-spacing-lg);
}

.twn-cast-member {
    text-align: center;
}

.twn-cast-photo {
    width: 150px;
    height: 150px;
    margin: 0 auto var(--twn-spacing-sm);
    border-radius: 50%; /* Circle headshots */
    overflow: hidden;
    border: 2px solid var(--twn-accent); /* Optional brand border */
    background-color: var(--twn-bg-gray);
    display: flex; /* Centering for placeholder */
    align-items: center;
    justify-content: center;
}

.twn-cast-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--twn-transition);
}

.twn-cast-member:hover .twn-cast-photo img {
    transform: scale(1.05);
}

.twn-cast-name {
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 0.25rem;
    color: var(--twn-text-dark);
}
.twn-cast-info h4.twn-cast-name {
    color: #c9a227;
}

.twn-cast-role {
    font-size: 0.95rem;
    color: var(--twn-accent-dark); /* Or muted text */
    font-style: italic;
    line-height: 1.3;
}

.twn-cast-photo-placeholder {
    width: 100%;
    height: 100%;
    background-color: #ddd;
    background-image: url('data:image/svg+xml;utf8,<svg fill=\'%23999\' height=\'24\' viewBox=\'0 0 24 24\' width=\'24\' xmlns=\'http://www.w3.org/2000/svg\'><path d=\'M12 12c2.21 0 4-1.79 4-4s-1.79-4-4-4-4 1.79-4 4 1.79 4 4 4zm0 2c-2.67 0-8 1.34-8 4v2h16v-2c0-2.66-5.33-4-8-4z\'/></svg>');
    background-repeat: no-repeat;
    background-position: center;
    background-size: 50%;
}


/* Creative Team List */
.twn-creative-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1.5rem;
    margin-bottom: var(--twn-spacing-lg);
}

.twn-creative-member {
    display: flex;
    flex-direction: column; 
    min-width: 140px;
}

.twn-creative-role {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--twn-text-muted);
    margin-bottom: 0.2rem;
    font-weight: 600;
}

.twn-creative-name {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--twn-text-dark);
}

/* Dark mode adjustments */
.elementor-section.twn-dark-section .twn-cast-name,
.elementor-section.twn-dark-section .twn-creative-name {
    color: var(--twn-text-light);
}

.elementor-section.twn-dark-section .twn-cast-role,
.elementor-section.twn-dark-section .twn-creative-role {
   color: rgba(255, 255, 255, 0.7);
}

