/*
Theme Name:     Bri's Tees
Theme URI:      https://bri-tees.com
Description:    Custom child theme for Bri's Tees — a boutique print-on-demand storefront. Brand palette of marigold, powder blue, cream, and navy paired with Fraunces (display) and Manrope (text). Built on Kadence.
Author:         Blue Punch Buggy Inc.
Author URI:     https://blakefindell.com
Template:       kadence
Version:        0.1.0
Requires at least: 6.0
Tested up to:   6.9
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:    bristees-child
*/

/* ─────────────────────────────────────────────────────────────
   1. Brand tokens
   ───────────────────────────────────────────────────────────── */

:root {
    /* — Palette — */
    --bt-marigold:        #E8C547;   /* logo yellow */
    --bt-marigold-deep:   #C9A627;   /* hover / pressed */
    --bt-marigold-soft:   #F4DC85;   /* tints, hover bg */
    --bt-blue:            #CDE0EE;   /* logo brushstroke */
    --bt-blue-deep:       #9FC4DD;   /* deeper blue for accents */
    --bt-blue-ink:        #4A7BA0;   /* text on cream */
    --bt-cream:           #FAF6EC;   /* primary background */
    --bt-cream-warm:      #F0E8D4;   /* secondary section bg */
    --bt-cream-deep:      #E8DEC4;   /* tertiary, dividers */
    --bt-navy:            #2A3550;   /* dark brand accent */
    --bt-navy-deep:       #1B2236;   /* darker, footer */
    --bt-ink:             #1A1A1A;   /* primary text */
    --bt-text:            #2A2A26;   /* body text */
    --bt-muted:           #6B6B60;   /* meta, captions */
    --bt-line:            rgba(26, 26, 26, 0.08);
    --bt-line-strong:     rgba(26, 26, 26, 0.16);

    /* — Typography — */
    --bt-font-display:    'Fraunces', 'Playfair Display', Georgia, serif;
    --bt-font-body:       'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

    /* — Spacing & shape — */
    --bt-radius-sm:       3px;
    --bt-radius:          6px;
    --bt-radius-lg:       12px;
    --bt-radius-xl:       20px;

    /* — Shadows (warm-tinted, not pure black) — */
    --bt-shadow-sm:       0 1px 3px rgba(74, 56, 20, 0.06), 0 1px 2px rgba(74, 56, 20, 0.04);
    --bt-shadow-md:       0 4px 16px rgba(74, 56, 20, 0.08), 0 2px 6px rgba(74, 56, 20, 0.05);
    --bt-shadow-lg:       0 12px 36px rgba(74, 56, 20, 0.10), 0 4px 12px rgba(74, 56, 20, 0.06);
    --bt-shadow-marigold: 0 6px 20px rgba(232, 197, 71, 0.35);

    /* — Motion — */
    --bt-ease:            cubic-bezier(0.4, 0, 0.2, 1);
    --bt-ease-out:        cubic-bezier(0.16, 1, 0.3, 1);
    --bt-transition:      0.22s var(--bt-ease);
    --bt-transition-slow: 0.45s var(--bt-ease-out);
}

/* ─────────────────────────────────────────────────────────────
   2. Base — paper-textured background, type defaults
   ───────────────────────────────────────────────────────────── */

html {
    scroll-behavior: smooth;
}

body {
    font-family: var(--bt-font-body);
    color: var(--bt-text);
    font-weight: 400;
    line-height: 1.7;
    /* Cream base + extremely subtle paper grain so the background has depth */
    background-color: var(--bt-cream);
    background-image:
        radial-gradient(ellipse 1200px 500px at 80% -10%, rgba(232, 197, 71, 0.06), transparent 60%),
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.45  0 0 0 0 0.35  0 0 0 0 0.18  0 0 0 0.045 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
    background-attachment: fixed, fixed;
}

h1, h2, h3, h4, h5, h6,
.entry-title,
.product_title,
.woocommerce-loop-product__title {
    font-family: var(--bt-font-display);
    color: var(--bt-ink);
    font-weight: 600;
    line-height: 1.15;
    letter-spacing: -0.01em;
    /* Fraunces optical-size axis — soft, slightly warm display feel */
    font-variation-settings: "opsz" 144, "SOFT" 50;
}

h1, .entry-title { font-weight: 700; letter-spacing: -0.015em; }

p { margin-bottom: 1.1rem; }

a {
    color: var(--bt-blue-ink);
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
    transition: color var(--bt-transition);
}

a:hover,
a:focus-visible {
    color: var(--bt-marigold-deep);
}

::selection {
    background: var(--bt-marigold);
    color: var(--bt-ink);
}

/* ─────────────────────────────────────────────────────────────
   3. Site header
   ───────────────────────────────────────────────────────────── */

.site-header,
.site-header-wrap {
    background: rgba(250, 246, 236, 0.85);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-bottom: 1px solid var(--bt-line);
}

.site-branding .site-title,
.site-branding .site-title a,
.site-title a {
    font-family: var(--bt-font-display);
    font-weight: 700;
    color: var(--bt-ink);
    letter-spacing: -0.02em;
    font-size: clamp(1.4rem, 2.5vw, 1.8rem);
}

.site-description {
    font-family: var(--bt-font-body);
    color: var(--bt-muted);
    font-size: 0.78rem;
    letter-spacing: 0.04em;
}

/* — Primary nav — */
.main-navigation .menu > li > a,
.main-navigation .header-menu-container .menu > li > a {
    font-family: var(--bt-font-body);
    font-weight: 500;
    font-size: 0.92rem;
    text-transform: none;
    letter-spacing: 0.01em;
    color: var(--bt-text);
    transition: color var(--bt-transition);
}

.main-navigation .menu > li > a:hover,
.main-navigation .menu > li.current-menu-item > a {
    color: var(--bt-marigold-deep);
}

/* Cart count bubble */
.header-cart-button .header-cart-total {
    background: var(--bt-marigold);
    color: var(--bt-ink);
    font-family: var(--bt-font-body);
    font-weight: 700;
    border: 2px solid var(--bt-cream);
}

/* ─────────────────────────────────────────────────────────────
   4. Buttons
   ───────────────────────────────────────────────────────────── */

.button,
.wp-block-button__link,
button[type="submit"]:not(.search-submit),
input[type="submit"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce-page a.button {
    background: var(--bt-marigold);
    color: var(--bt-ink) !important;
    font-family: var(--bt-font-body);
    font-weight: 600;
    font-size: 0.88rem;
    letter-spacing: 0.03em;
    border: none;
    border-radius: var(--bt-radius);
    padding: 0.85rem 1.85rem;
    box-shadow: var(--bt-shadow-sm);
    transition:
        background var(--bt-transition),
        transform var(--bt-transition),
        box-shadow var(--bt-transition);
    text-decoration: none;
    cursor: pointer;
}

.button:hover,
.wp-block-button__link:hover,
button[type="submit"]:not(.search-submit):hover,
input[type="submit"]:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce-page a.button:hover {
    background: var(--bt-marigold-deep);
    transform: translateY(-1px);
    box-shadow: var(--bt-shadow-marigold);
}

.button:active,
.woocommerce a.button:active,
.woocommerce button.button:active {
    transform: translateY(0);
    box-shadow: var(--bt-shadow-sm);
}

/* — Secondary / alt — */
.button.alt,
.button.secondary,
.woocommerce a.button.alt,
.woocommerce button.button.alt {
    background: var(--bt-navy);
    color: var(--bt-cream) !important;
    box-shadow: 0 4px 14px rgba(42, 53, 80, 0.25);
}

.button.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
    background: var(--bt-navy-deep);
    box-shadow: 0 8px 22px rgba(42, 53, 80, 0.35);
}

/* — Ghost / outline — */
.button.outline {
    background: transparent;
    color: var(--bt-ink) !important;
    border: 1.5px solid var(--bt-ink);
    box-shadow: none;
}

.button.outline:hover {
    background: var(--bt-ink);
    color: var(--bt-cream) !important;
    box-shadow: var(--bt-shadow-md);
}

/* ─────────────────────────────────────────────────────────────
   5. WooCommerce — shop archive
   ───────────────────────────────────────────────────────────── */

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
    background: #fff;
    border-radius: var(--bt-radius-lg);
    padding: 0;
    overflow: hidden;
    box-shadow: var(--bt-shadow-sm);
    transition:
        transform var(--bt-transition),
        box-shadow var(--bt-transition);
}

.woocommerce ul.products li.product:hover {
    transform: translateY(-3px);
    box-shadow: var(--bt-shadow-md);
}

.woocommerce ul.products li.product a img {
    border-radius: 0;
    margin: 0 0 0.5rem;
    transition: transform var(--bt-transition-slow);
}

.woocommerce ul.products li.product:hover a img {
    transform: scale(1.03);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-family: var(--bt-font-display);
    font-weight: 600;
    font-size: 1.1rem;
    color: var(--bt-ink);
    padding: 0.25rem 1.1rem 0.4rem;
    line-height: 1.25;
}

.woocommerce ul.products li.product .price {
    color: var(--bt-navy);
    font-family: var(--bt-font-body);
    font-weight: 600;
    font-size: 1rem;
    padding: 0 1.1rem 1.1rem;
    display: block;
}

.woocommerce ul.products li.product .price del {
    color: var(--bt-muted);
    opacity: 0.55;
    margin-right: 0.4rem;
}

.woocommerce ul.products li.product .price ins {
    color: var(--bt-marigold-deep);
    font-weight: 700;
    background: none;
    text-decoration: none;
}

/* — Sale badge: turn the default circle into a flat brand pill — */
.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale {
    background: var(--bt-ink);
    color: var(--bt-marigold);
    font-family: var(--bt-font-body);
    font-weight: 700;
    font-size: 0.68rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    border-radius: var(--bt-radius-sm);
    padding: 0.4rem 0.75rem;
    box-shadow: var(--bt-shadow-sm);
    min-height: auto;
    min-width: auto;
    line-height: 1;
    top: 0.85rem;
    left: 0.85rem;
    right: auto;
    margin: 0;
}

/* — Loop add-to-cart button (smaller pill on cards) — */
.woocommerce ul.products li.product .button {
    display: block;
    margin: 0 1.1rem 1.1rem;
    padding: 0.7rem 1.2rem;
    font-size: 0.82rem;
    text-align: center;
    border-radius: var(--bt-radius);
}

/* ─────────────────────────────────────────────────────────────
   6. WooCommerce — single product
   ───────────────────────────────────────────────────────────── */

.woocommerce div.product .product_title {
    font-family: var(--bt-font-display);
    font-weight: 600;
    color: var(--bt-ink);
    line-height: 1.1;
    letter-spacing: -0.015em;
    margin-bottom: 0.6rem;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price {
    color: var(--bt-navy);
    font-family: var(--bt-font-display);
    font-weight: 600;
    font-size: 1.85rem;
    margin-bottom: 1.5rem;
}

.woocommerce div.product .woocommerce-product-rating {
    margin-bottom: 1.25rem;
}

.woocommerce div.product .woocommerce-product-details__short-description {
    font-family: var(--bt-font-body);
    color: var(--bt-text);
    line-height: 1.75;
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px dashed var(--bt-line-strong);
}

.woocommerce div.product form.cart {
    margin-bottom: 2rem;
}

.woocommerce div.product form.cart .quantity {
    margin-right: 0.75rem;
}

.woocommerce .quantity .qty {
    border: 1.5px solid var(--bt-line-strong);
    border-radius: var(--bt-radius);
    padding: 0.7rem 0.5rem;
    font-family: var(--bt-font-body);
    font-weight: 600;
    background: #fff;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
    border-bottom: 1px solid var(--bt-line);
    padding: 0;
    margin-bottom: 2rem;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
    background: transparent;
    border: none;
    border-radius: 0;
    margin: 0;
    padding: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    padding: 1rem 1.5rem 1rem 0;
    font-family: var(--bt-font-body);
    font-weight: 500;
    color: var(--bt-muted);
    text-transform: none;
    letter-spacing: 0.02em;
    transition: color var(--bt-transition);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
    color: var(--bt-ink);
    font-weight: 600;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active::after {
    content: '';
    display: block;
    width: 32px;
    height: 2px;
    background: var(--bt-marigold);
    margin-top: -2px;
}

/* ─────────────────────────────────────────────────────────────
   7. WooCommerce — cart, checkout, account, notices
   ───────────────────────────────────────────────────────────── */

.woocommerce-cart .cart_totals h2,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout h3,
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
    font-family: var(--bt-font-display);
    color: var(--bt-ink);
    margin-bottom: 1rem;
}

.woocommerce table.shop_table,
.woocommerce-page table.shop_table {
    border-radius: var(--bt-radius-lg);
    border: 1px solid var(--bt-line);
    border-collapse: separate;
    border-spacing: 0;
    background: #fff;
    box-shadow: var(--bt-shadow-sm);
    overflow: hidden;
}

.woocommerce table.shop_table th {
    background: var(--bt-cream-warm);
    font-family: var(--bt-font-body);
    font-weight: 600;
    color: var(--bt-ink);
    letter-spacing: 0.02em;
}

/* — Notices: success, info, error — */
.woocommerce-message,
.woocommerce-info {
    border-top: 3px solid var(--bt-marigold) !important;
    background: var(--bt-cream-warm);
    border-radius: var(--bt-radius);
    color: var(--bt-text);
    box-shadow: var(--bt-shadow-sm);
}

.woocommerce-message::before,
.woocommerce-info::before {
    color: var(--bt-marigold-deep);
}

.woocommerce-error {
    border-top: 3px solid #C94545 !important;
    background: #FBEEEE;
    border-radius: var(--bt-radius);
    color: #5B1F1F;
    box-shadow: var(--bt-shadow-sm);
}

.woocommerce-error::before {
    color: #C94545;
}

/* — Form inputs (checkout, account, contact) — */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.select2-container--default .select2-selection--single {
    border: 1.5px solid var(--bt-line-strong);
    border-radius: var(--bt-radius);
    padding: 0.75rem 0.95rem;
    font-family: var(--bt-font-body);
    font-size: 0.95rem;
    color: var(--bt-text);
    background: #fff;
    transition:
        border-color var(--bt-transition),
        box-shadow var(--bt-transition);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus,
.select2-container--default.select2-container--focus .select2-selection--single {
    border-color: var(--bt-marigold-deep);
    box-shadow: 0 0 0 3px rgba(232, 197, 71, 0.18);
    outline: none;
}

.woocommerce form .form-row label {
    font-family: var(--bt-font-body);
    font-weight: 500;
    font-size: 0.82rem;
    letter-spacing: 0.02em;
    color: var(--bt-text);
    margin-bottom: 0.35rem;
}

/* ─────────────────────────────────────────────────────────────
   8. Footer
   ───────────────────────────────────────────────────────────── */

.site-footer,
.site-footer-wrap,
.footer-widget-area,
.site-footer .site-info {
    background: var(--bt-navy);
    color: rgba(250, 246, 236, 0.78);
}

.site-footer h2,
.site-footer h3,
.site-footer h4,
.site-footer .widget-title {
    color: var(--bt-cream);
    font-family: var(--bt-font-display);
    font-weight: 600;
}

.site-footer a {
    color: var(--bt-marigold-soft);
    text-decoration: none;
    transition: color var(--bt-transition);
}

.site-footer a:hover {
    color: var(--bt-marigold);
}

.site-footer .site-info {
    border-top: 1px solid rgba(250, 246, 236, 0.08);
    font-size: 0.82rem;
    color: rgba(250, 246, 236, 0.55);
}

/* ─────────────────────────────────────────────────────────────
   9. Brushstroke motif — recurring brand element
   ───────────────────────────────────────────────────────────── */

/* Underlay brushstroke behind any inline element */
.bt-brushstroke {
    position: relative;
    display: inline-block;
    isolation: isolate;
}

.bt-brushstroke::before {
    content: '';
    position: absolute;
    inset: -8% -6% -8% -6%;
    background-image: url('assets/images/brushstroke.svg');
    background-size: 100% 100%;
    background-repeat: no-repeat;
    z-index: -1;
    opacity: 0.92;
    pointer-events: none;
}

/* Section divider — horizontal brushstroke as a quiet rule */
.bt-divider {
    height: 22px;
    width: 100%;
    max-width: 280px;
    background-image: url('assets/images/brushstroke.svg');
    background-size: 100% 100%;
    background-repeat: no-repeat;
    background-position: center;
    margin: 2.5rem auto;
    opacity: 0.65;
}

/* Hand-drawn underline accent */
.bt-underline {
    background-image: url('assets/images/brushstroke.svg');
    background-size: 100% 0.55em;
    background-repeat: no-repeat;
    background-position: 0 88%;
    padding: 0 0.15em 0.05em;
}

/* ─────────────────────────────────────────────────────────────
   10. Utility classes
   ───────────────────────────────────────────────────────────── */

.bt-text-marigold { color: var(--bt-marigold-deep); }
.bt-text-blue     { color: var(--bt-blue-ink); }
.bt-text-navy     { color: var(--bt-navy); }
.bt-text-muted    { color: var(--bt-muted); }

.bt-bg-marigold   { background: var(--bt-marigold); }
.bt-bg-blue       { background: var(--bt-blue); }
.bt-bg-cream      { background: var(--bt-cream); }
.bt-bg-cream-warm { background: var(--bt-cream-warm); }
.bt-bg-navy       { background: var(--bt-navy); color: var(--bt-cream); }
.bt-bg-navy a     { color: var(--bt-marigold-soft); }

.bt-display       { font-family: var(--bt-font-display); }
.bt-sans          { font-family: var(--bt-font-body); }
.bt-italic        { font-style: italic; }

.bt-eyebrow {
    font-family: var(--bt-font-body);
    font-weight: 600;
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--bt-marigold-deep);
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
}

.bt-eyebrow::before {
    content: '';
    width: 24px;
    height: 1px;
    background: var(--bt-marigold-deep);
}

/* ─────────────────────────────────────────────────────────────
   11. Reduced-motion respect
   ───────────────────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.001ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.001ms !important;
        scroll-behavior: auto !important;
    }
}
