/*
 Theme Name:   Art With A History Child
 Theme URI:    https://packagegallery.com
 Description:  Child theme for Art With A History — built on Astra
 Author:       Art With A History
 Template:     astra
 Version:      1.1.0
 Text Domain:  awah-child
*/

/* ============================================================
   BRAND TOKENS
   ============================================================ */

:root {
    --copper:      #C49A6C;
    --copper-lt:   #E8C9A8;
    --copper-dk:   #9E7A50;
    --black:       #1C1C1C;
    --white:       #FFFFFF;
    --off-white:   #FAF8F5;
    --sand:        #F3EDE4;
    --border:      #E0D5C8;
    --text:        #3D3530;
    --muted:       #9C8E82;
    --font-head:   'Cormorant Garamond', Georgia, serif;
    --font-body:   'Jost', 'Helvetica Neue', Arial, sans-serif;
}

/* ============================================================
   FORCE FULL WIDTH — override all Astra container constraints
   ============================================================ */

/* Remove Astra's max-width restrictions site-wide */
.ast-container,
.ast-article-inner,
.ast-grid-right-inner,
.ast-grid-left-inner,
.ast-grid-center-inner,
#primary,
#secondary,
.ast-primary-content-area,
.site-content .ast-container {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* The main wrapping container — set a generous max-width */
.entry-content,
.ast-article-post,
.post-type-archive .site-content,
.page .site-content {
    max-width: 100% !important;
    width: 100% !important;
}

/* Content padding — breathing room on left/right */
.entry-content {
    padding-left: 48px !important;
    padding-right: 48px !important;
}

/* Single artwork and artist — extra generous */
.single-artwork .entry-content,
.single-artist .entry-content {
    padding-left: 60px !important;
    padding-right: 60px !important;
    max-width: 1400px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Gallery pages */
.page .entry-content {
    padding-left: 48px !important;
    padding-right: 48px !important;
    max-width: 1400px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Kill Astra sidebar — force full single column */
#secondary,
.ast-sidebar-wrap,
.widget-area {
    display: none !important;
}

#primary,
.ast-primary-content-area {
    width: 100% !important;
    float: none !important;
    flex: none !important;
}

/* Astra header container */
.main-header-bar .ast-container,
.ast-primary-header-bar .ast-container {
    max-width: 1400px !important;
    padding-left: 48px !important;
    padding-right: 48px !important;
    margin: 0 auto !important;
}

/* ============================================================
   BASE
   ============================================================ */

body {
    font-family: var(--font-body) !important;
    color: var(--text) !important;
    background-color: var(--off-white) !important;
    -webkit-font-smoothing: antialiased;
    font-size: 16px !important;
    line-height: 1.7 !important;
}

/* ============================================================
   TYPOGRAPHY — bigger, more readable
   ============================================================ */

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-head) !important;
    color: var(--black) !important;
    line-height: 1.2 !important;
}

h1 { font-size: 52px !important; font-weight: 300 !important; letter-spacing: 1px !important; }
h2 { font-size: 38px !important; font-weight: 400 !important; }
h3 { font-size: 26px !important; font-weight: 500 !important; }

p {
    font-size: 16px !important;
    line-height: 1.8 !important;
    color: var(--text) !important;
}

a {
    color: var(--copper-dk) !important;
    text-decoration: none !important;
    transition: color 0.2s !important;
}
a:hover { color: var(--copper) !important; }

/* ============================================================
   HEADER
   ============================================================ */

#masthead,
.site-header,
.ast-primary-header-bar,
.main-header-bar {
    background-color: var(--white) !important;
    border-bottom: 1px solid var(--border) !important;
    box-shadow: none !important;
}

/* Logo */
.custom-logo,
.ast-site-identity img {
    max-height: 80px !important;
    width: auto !important;
}

/* Site title text fallback */
.site-title,
.site-title a {
    font-family: var(--font-body) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    letter-spacing: 4px !important;
    text-transform: uppercase !important;
    color: var(--black) !important;
}

/* Navigation links */
.ast-primary-header-bar .main-header-bar-navigation .menu-item a,
#site-navigation .menu-item a,
.main-navigation ul li a {
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: var(--black) !important;
    padding: 12px 18px !important;
    transition: color 0.2s !important;
}

.ast-primary-header-bar .main-header-bar-navigation .menu-item a:hover,
#site-navigation .menu-item a:hover,
.main-navigation ul li a:hover {
    color: var(--copper) !important;
    text-decoration: none !important;
}

.main-navigation .current-menu-item > a,
.main-navigation .current_page_item > a {
    color: var(--copper) !important;
}

/* ============================================================
   GALLERY PAGE HEADER
   ============================================================ */

.pg-gallery-page-header {
    padding: 64px 0 44px;
    margin-bottom: 48px;
    text-align: center;
    border-bottom: 1px solid var(--border);
}

.pg-gallery-page-header h1 {
    font-family: var(--font-head) !important;
    font-size: 54px !important;
    font-weight: 300 !important;
    letter-spacing: 5px !important;
    text-transform: uppercase !important;
    color: var(--black) !important;
    margin: 0 0 12px !important;
}

.pg-gallery-page-header p {
    font-family: var(--font-body) !important;
    font-size: 12px !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
    margin: 0 !important;
}

.pg-gallery-page-header::after {
    content: '';
    display: block;
    width: 48px;
    height: 2px;
    background: var(--copper);
    margin: 24px auto 0;
}

/* ============================================================
   GALLERY GRID
   ============================================================ */

.pg-gallery-grid {
    display: grid !important;
    gap: 32px !important;
    margin: 0 0 64px !important;
}

.pg-cols-2 { grid-template-columns: repeat(2, 1fr) !important; }
.pg-cols-3 { grid-template-columns: repeat(3, 1fr) !important; }
.pg-cols-4 { grid-template-columns: repeat(4, 1fr) !important; }

@media (max-width: 1024px) {
    .pg-cols-3,
    .pg-cols-4 { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 640px) {
    .pg-cols-2,
    .pg-cols-3,
    .pg-cols-4 { grid-template-columns: 1fr !important; }
}

/* Card */
.pg-gallery-item {
    background: var(--white);
    border: 1px solid var(--border);
    overflow: hidden;
    transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.pg-gallery-item:hover {
    box-shadow: 0 12px 48px rgba(196, 154, 108, 0.22);
    transform: translateY(-4px);
}

.pg-gallery-link {
    display: block !important;
    text-decoration: none !important;
    color: inherit !important;
}

.pg-gallery-image {
    aspect-ratio: 1;
    overflow: hidden;
    background: var(--sand);
    display: flex;
    align-items: center;
    justify-content: center;
}

.pg-gallery-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.5s ease;
}

.pg-gallery-item:hover .pg-gallery-image img {
    transform: scale(1.06);
}

.pg-no-image {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-body);
    font-size: 11px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--muted);
    background: var(--sand);
}

.pg-gallery-caption {
    padding: 20px 22px 24px;
    border-top: 1px solid var(--border);
}

.pg-artwork-title {
    font-family: var(--font-head) !important;
    font-size: 20px !important;
    font-weight: 500 !important;
    font-style: italic !important;
    color: var(--black) !important;
    margin: 0 0 6px !important;
    line-height: 1.3 !important;
}

.pg-artwork-artist {
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
    margin: 0 0 5px !important;
}

.pg-artwork-medium {
    font-family: var(--font-body) !important;
    font-size: 13px !important;
    font-style: italic !important;
    color: var(--muted) !important;
    margin: 0 0 8px !important;
}

.pg-artwork-price {
    font-family: var(--font-body) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--black) !important;
    margin: 8px 0 0 !important;
}

/* ============================================================
   STATUS BADGES
   ============================================================ */

.pg-status-badge {
    display: inline-block !important;
    padding: 4px 12px !important;
    font-family: var(--font-body) !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    border: 1px solid currentColor !important;
    margin-top: 8px !important;
    background: transparent !important;
}

.pg-status-available    { color: var(--copper-dk) !important; background: rgba(196,154,108,0.08) !important; }
.pg-status-sold         { color: var(--muted) !important; }
.pg-status-not-for-sale { color: var(--muted) !important; }
.pg-status-on-loan      { color: #6B8FA3 !important; background: rgba(107,143,163,0.08) !important; }
.pg-status-reserved     { color: #A3826B !important; background: rgba(163,130,107,0.08) !important; }

/* ============================================================
   SINGLE ARTWORK PAGE
   ============================================================ */

.single-artwork .entry-header,
.single-artwork .ast-article-single-meta,
.single-artwork .post-meta,
.single-artwork .ast-post-format-standard-image,
.single-artwork .page-header {
    display: none !important;
}

.single-artwork .entry-content {
    padding: 0 60px !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
}

.pg-single-artwork {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 80px !important;
    margin: 52px 0 80px !important;
    align-items: start !important;
}

@media (max-width: 960px) {
    .pg-single-artwork {
        grid-template-columns: 1fr !important;
        gap: 48px !important;
    }
}

/* Image — sticky as you scroll */
.pg-artwork-main-image {
    position: sticky !important;
    top: 40px !important;
}

.pg-artwork-main-image img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
    cursor: zoom-in;
    box-shadow: 0 8px 40px rgba(0,0,0,0.12) !important;
}

/* Data panel */
.pg-artwork-data-panel {
    padding: 8px 0 0;
}

.pg-artwork-data-title {
    font-family: var(--font-head) !important;
    font-size: 48px !important;
    font-weight: 300 !important;
    font-style: italic !important;
    letter-spacing: 0.5px !important;
    color: var(--black) !important;
    margin: 0 0 8px !important;
    line-height: 1.15 !important;
}

.pg-artwork-data-artist {
    font-family: var(--font-body) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
    margin: 0 0 36px !important;
}

.pg-artwork-data-artist a {
    color: var(--muted) !important;
}
.pg-artwork-data-artist a:hover {
    color: var(--copper) !important;
}

/* Detail list */
.pg-detail-list {
    list-style: none !important;
    margin: 0 0 32px !important;
    padding: 0 !important;
    border-top: 1px solid var(--border) !important;
}

.pg-detail-list li {
    display: flex !important;
    gap: 20px !important;
    padding: 14px 0 !important;
    border-bottom: 1px solid var(--border) !important;
    align-items: baseline !important;
}

.pg-detail-label {
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
    min-width: 130px !important;
    flex-shrink: 0 !important;
}

.pg-detail-value {
    font-family: var(--font-body) !important;
    font-size: 16px !important;
    color: var(--black) !important;
}

/* Inquiry button */
.pg-inquiry-btn {
    display: inline-block !important;
    padding: 16px 40px !important;
    background: transparent !important;
    color: var(--copper-dk) !important;
    border: 1.5px solid var(--copper) !important;
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    transition: background 0.25s, color 0.25s !important;
    margin-top: 12px !important;
    cursor: pointer !important;
}

.pg-inquiry-btn:hover {
    background: var(--copper) !important;
    color: var(--white) !important;
}

/* Description */
.pg-artwork-description {
    margin-top: 40px !important;
    padding-top: 32px !important;
    border-top: 1px solid var(--border) !important;
}

.pg-artwork-description h3 {
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
    margin: 0 0 20px !important;
}

.pg-artwork-description p {
    font-size: 16px !important;
    line-height: 1.9 !important;
    color: var(--text) !important;
}

/* Provenance */
.pg-artwork-provenance {
    margin-top: 32px !important;
    padding: 24px 28px !important;
    background: var(--sand) !important;
    border: none !important;
    border-left: 3px solid var(--copper) !important;
}

.pg-artwork-provenance h3 {
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
    margin: 0 0 14px !important;
}

.pg-artwork-provenance p {
    font-size: 15px !important;
    line-height: 1.8 !important;
    color: var(--text) !important;
    margin: 0 !important;
}

/* Location history */
.pg-location-history {
    margin-top: 32px !important;
}

.pg-location-history h3 {
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
    margin: 0 0 16px !important;
    padding-top: 32px !important;
    border-top: 1px solid var(--border) !important;
}

.pg-location-table {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 15px !important;
}

.pg-location-table th {
    text-align: left !important;
    padding: 11px 16px !important;
    background: var(--sand) !important;
    border-bottom: 1px solid var(--border) !important;
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
}

.pg-location-table td {
    padding: 12px 16px !important;
    border-bottom: 1px solid var(--border) !important;
    color: var(--text) !important;
    font-size: 15px !important;
}

.pg-location-table tr:last-child td {
    border-bottom: none !important;
}

/* ============================================================
   SINGLE ARTIST PAGE
   ============================================================ */

.single-artist .entry-header,
.single-artist .ast-article-single-meta {
    display: none !important;
}

.single-artist .entry-content {
    padding: 0 60px !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
}

.pg-artist-bio {
    max-width: 1000px;
    margin: 48px auto;
}

.pg-artist-photo img {
    float: right;
    margin: 0 0 32px 48px;
    max-width: 240px;
    box-shadow: 0 6px 28px rgba(0,0,0,0.1);
}

.pg-artist-name {
    font-family: var(--font-head) !important;
    font-size: 54px !important;
    font-weight: 300 !important;
    letter-spacing: 1px !important;
    color: var(--black) !important;
    margin: 0 0 10px !important;
}

.pg-artist-meta {
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
    margin: 0 0 20px !important;
}

.pg-artist-web a {
    font-size: 14px !important;
    color: var(--copper-dk) !important;
    border-bottom: 1px solid var(--copper-lt);
    padding-bottom: 2px;
}

.pg-artist-content {
    font-size: 16px !important;
    line-height: 1.9 !important;
    color: var(--text) !important;
    margin-top: 32px;
    clear: both;
}

/* Artist grid card — portrait aspect ratio */
.pg-artist-card .pg-gallery-image {
    aspect-ratio: 3 / 4 !important;
}
.pg-artist-card .pg-gallery-image img {
    object-position: top center !important;
}
.pg-artist-card-name {
    font-family: var(--font-head) !important;
    font-size: 22px !important;
    font-weight: 500 !important;
    font-style: italic !important;
    color: var(--black) !important;
    margin: 0 0 6px !important;
}
.pg-artist-work-count {
    font-family: var(--font-body) !important;
    font-size: 12px !important;
    color: var(--muted) !important;
    margin: 4px 0 0 !important;
    font-style: italic !important;
}

.pg-artist-works {
    margin-top: 64px;
}

.pg-artist-works h2 {
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
    margin: 0 0 32px !important;
    padding-bottom: 18px !important;
    border-bottom: 1px solid var(--border) !important;
}

/* ============================================================
   BREADCRUMBS
   ============================================================ */

.ast-breadcrumbs-wrapper {
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
    padding: 18px 0 !important;
    border-bottom: 1px solid var(--border) !important;
    margin-bottom: 36px !important;
}

.ast-breadcrumbs-wrapper a {
    color: var(--muted) !important;
}
.ast-breadcrumbs-wrapper a:hover {
    color: var(--copper) !important;
}

/* ============================================================
   BUTTONS
   ============================================================ */

.wp-block-button .wp-block-button__link,
input[type="submit"],
button[type="submit"],
.ast-button,
.button {
    background: var(--copper) !important;
    color: var(--white) !important;
    border: 1.5px solid var(--copper) !important;
    border-radius: 0 !important;
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    padding: 14px 32px !important;
    transition: background 0.2s, border-color 0.2s !important;
    cursor: pointer !important;
}

.wp-block-button .wp-block-button__link:hover,
input[type="submit"]:hover,
button[type="submit"]:hover,
.button:hover {
    background: var(--copper-dk) !important;
    border-color: var(--copper-dk) !important;
    color: var(--white) !important;
}

/* ============================================================
   FOOTER
   ============================================================ */

#colophon,
.site-footer,
.ast-small-footer,
.footer-bar-wrap {
    background: var(--black) !important;
    color: rgba(255,255,255,0.5) !important;
    font-family: var(--font-body) !important;
    font-size: 11px !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    text-align: center !important;
    padding: 36px 0 !important;
    border-top: none !important;
}

#colophon::before,
.site-footer::before {
    content: '';
    display: block;
    width: 48px;
    height: 2px;
    background: var(--copper);
    margin: 0 auto 24px;
}

#colophon a,
.site-footer a {
    color: rgba(255,255,255,0.7) !important;
}

/* ============================================================
   FILTER BAR
   ============================================================ */

.pg-filter-bar {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 36px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--border);
}

.pg-filter-bar select,
.pg-filter-bar input {
    font-family: var(--font-body);
    font-size: 12px;
    letter-spacing: 1px;
    padding: 10px 16px;
    border: 1px solid var(--border);
    background: var(--white);
    color: var(--text);
    appearance: none;
    border-radius: 0;
}

.pg-filter-bar select:focus,
.pg-filter-bar input:focus {
    border-color: var(--copper);
    outline: none;
    box-shadow: 0 0 0 2px rgba(196,154,108,0.15);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 768px) {
    .entry-content,
    .single-artwork .entry-content,
    .single-artist .entry-content,
    .page .entry-content {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }

    .main-header-bar .ast-container,
    .ast-primary-header-bar .ast-container {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }

    .pg-gallery-page-header        { padding: 40px 0 28px !important; }
    .pg-gallery-page-header h1     { font-size: 34px !important; letter-spacing: 3px !important; }
    .pg-artwork-data-title         { font-size: 34px !important; }
    .pg-artist-name                { font-size: 38px !important; }
    .pg-artist-photo img           { float: none !important; max-width: 160px !important; margin: 0 0 24px !important; }
    .pg-detail-label               { min-width: 100px !important; }
    .pg-single-artwork             { gap: 36px !important; margin: 32px 0 48px !important; }
}