/* Goldknopf — minimal Judaica theme. RTL-first via CSS logical properties. */

:root {
    --gold: #b08d3e;
    --gold-strong: #9a7930;
    --gold-soft: #e8d9b0;
    --silver: #a9afb8;
    --silver-soft: #e8eaee;
    --brown: #4a3527;
    --brown-deep: #2c2014;
    --ink: #382d23;
    --muted: #8a7c6c;
    --cream: #faf7f1;
    --paper: #ffffff;
    --line: #e8e0d2;
    --serif: 'Frank Ruhl Libre', Georgia, serif;
    --sans: 'Heebo', Arial, sans-serif;
    --radius: 6px;
    --shadow: 0 8px 28px rgba(60, 42, 20, 0.08);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    font-family: var(--sans);
    font-weight: 400;
    font-size: 16px;
    line-height: 1.7;
    color: var(--ink);
    background: var(--cream);
}
h1, h2, h3, h4 { font-family: var(--serif); color: var(--brown); line-height: 1.3; margin: 0 0 .5em; }
a { color: var(--gold-strong); text-decoration: none; transition: color .2s; }
a:hover { color: var(--brown); }
img { max-width: 100%; height: auto; display: block; }

.gk-container { max-width: 1200px; margin-inline: auto; padding-inline: 20px; }

/* Buttons */
.gk-btn {
    display: inline-block;
    padding: 12px 30px;
    border-radius: var(--radius);
    font-family: var(--sans);
    font-weight: 500;
    font-size: 15px;
    letter-spacing: .02em;
    border: 1px solid transparent;
    cursor: pointer;
    transition: all .2s;
}
.gk-btn-gold { background: var(--gold); color: #fff; }
.gk-btn-gold:hover { background: var(--gold-strong); color: #fff; }
.gk-btn-brown { background: var(--brown); color: #fff; }
.gk-btn-brown:hover { background: var(--brown-deep); color: #fff; }
.gk-btn-line { background: transparent; border-color: var(--gold); color: var(--gold-strong); }
.gk-btn-line:hover { background: var(--gold); color: #fff; }
.gk-btn-line-light { background: transparent; border-color: rgba(255,255,255,.5); color: #fff; }
.gk-btn-line-light:hover { border-color: var(--gold-soft); color: var(--gold-soft); }

/* Topbar */
.gk-topbar { background: var(--brown-deep); color: var(--gold-soft); font-size: 13px; }
.gk-topbar-inner { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding-block: 7px; flex-wrap: wrap; }
.gk-topbar-phone { color: var(--gold-soft); font-weight: 500; }
.gk-topbar-phone:hover { color: #fff; }

/* Header */
.gk-header { background: var(--paper); border-block-end: 1px solid var(--line); position: sticky; top: 0; z-index: 50; }
.gk-header-inner { display: flex; align-items: center; gap: 28px; min-height: 76px; }
.gk-brand { flex-shrink: 0; }
.gk-brand img { max-height: 56px; width: auto; }
.gk-brand-text { display: flex; flex-direction: column; line-height: 1.2; }
.gk-brand-name { font-family: var(--serif); font-size: 26px; font-weight: 700; color: var(--brown); letter-spacing: .02em; }
.gk-brand-tag { font-size: 11px; color: var(--gold-strong); letter-spacing: .25em; }
.gk-nav { flex: 1; }
.gk-menu { list-style: none; margin: 0; padding: 0; display: flex; gap: 4px; flex-wrap: wrap; }
.gk-menu > li { position: relative; }
.gk-menu > li > a {
    display: block; padding: 26px 14px; color: var(--ink); font-weight: 500; font-size: 15px;
    border-block-end: 2px solid transparent;
}
.gk-menu > li > a:hover,
.gk-menu > li.current-menu-item > a { color: var(--gold-strong); border-block-end-color: var(--gold); }
.gk-menu .sub-menu {
    list-style: none; margin: 0; padding: 8px 0;
    position: absolute; inset-block-start: 100%; inset-inline-start: 0;
    min-width: 230px; background: var(--paper); border: 1px solid var(--line);
    border-radius: 0 0 var(--radius) var(--radius); box-shadow: var(--shadow);
    opacity: 0; visibility: hidden; transform: translateY(6px); transition: all .18s;
    z-index: 60;
}
.gk-menu > li:hover > .sub-menu,
.gk-menu > li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: none; }
.gk-menu .sub-menu a { display: block; padding: 8px 18px; color: var(--ink); font-size: 14px; }
.gk-menu .sub-menu a:hover { color: var(--gold-strong); background: var(--cream); }

.gk-header-actions { display: flex; align-items: center; gap: 14px; }
.gk-cart-link { position: relative; color: var(--brown); display: inline-flex; padding: 6px; }
.gk-cart-link:hover { color: var(--gold-strong); }
.gk-cart-count {
    position: absolute; inset-block-start: -2px; inset-inline-end: -4px;
    background: var(--gold); color: #fff; font-size: 10px; font-weight: 700;
    min-width: 16px; height: 16px; line-height: 16px; text-align: center; border-radius: 99px; padding-inline: 3px;
}

/* Mobile nav */
.gk-nav-toggle { display: none; background: none; border: 0; padding: 8px; cursor: pointer; margin-inline-start: auto; }
.gk-nav-toggle span { display: block; width: 22px; height: 2px; background: var(--brown); margin: 5px 0; transition: all .2s; }

@media (max-width: 920px) {
    .gk-nav-toggle { display: block; }
    .gk-nav {
        display: none; position: absolute; inset-inline: 0; inset-block-start: 100%;
        background: var(--paper); border-block-end: 1px solid var(--line); box-shadow: var(--shadow);
    }
    .gk-header.nav-open .gk-nav { display: block; }
    .gk-menu { flex-direction: column; gap: 0; padding-block: 8px; }
    .gk-menu > li > a { padding: 12px 22px; border-block-end: 0; }
    .gk-menu .sub-menu {
        position: static; opacity: 1; visibility: visible; transform: none;
        box-shadow: none; border: 0; padding-inline-start: 16px;
    }
}

/* Hero */
.gk-hero {
    background:
        radial-gradient(ellipse at 70% 20%, rgba(176, 141, 62, .28), transparent 55%),
        radial-gradient(ellipse at 20% 90%, rgba(169, 175, 184, .14), transparent 50%),
        linear-gradient(160deg, var(--brown-deep) 0%, #3d2c1a 70%, var(--brown) 100%);
    color: #f4ede0;
    text-align: center;
}
.gk-hero-inner { padding-block: 96px 104px; max-width: 820px; }
.gk-hero-kicker {
    color: var(--gold-soft); letter-spacing: .35em; font-size: 13px; font-weight: 500;
    text-transform: uppercase; margin: 0 0 18px;
}
.gk-hero-kicker::before, .gk-hero-kicker::after { content: '—'; color: var(--gold); margin-inline: 12px; }
.gk-hero-title { color: #fff; font-size: clamp(30px, 4.6vw, 50px); font-weight: 700; margin-block-end: 18px; }
.gk-hero-sub { font-size: 18px; font-weight: 300; color: #e3d9c8; max-width: 640px; margin-inline: auto; }
.gk-hero-actions { margin-block-start: 34px; display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* Sections */
.gk-section { padding-block: 72px; }
.gk-section-alt { background: var(--paper); border-block: 1px solid var(--line); }
.gk-section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin-block-end: 34px; }
.gk-section-head h2 { font-size: 30px; margin: 0; position: relative; padding-block-end: 12px; }
.gk-section-head h2::after {
    content: ''; position: absolute; inset-block-end: 0; inset-inline-start: 0;
    width: 56px; height: 3px; background: linear-gradient(90deg, var(--gold), var(--gold-soft));
}
.gk-section-link { font-weight: 500; font-size: 15px; white-space: nowrap; }

/* Category grid */
.gk-cat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.gk-cat-card {
    background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
    overflow: hidden; transition: all .25s; display: flex; flex-direction: column;
}
.gk-cat-card:hover { box-shadow: var(--shadow); transform: translateY(-3px); border-color: var(--gold-soft); }
.gk-cat-img { aspect-ratio: 1; background: var(--silver-soft); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.gk-cat-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.gk-cat-card:hover .gk-cat-img img { transform: scale(1.05); }
.gk-cat-placeholder { font-size: 42px; color: var(--silver); }
.gk-cat-meta { padding: 14px 16px 16px; }
.gk-cat-name { display: block; font-family: var(--serif); font-weight: 500; font-size: 17px; color: var(--brown); }
.gk-cat-count { font-size: 13px; color: var(--muted); }

/* Product cards (front page) */
.gk-prod-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.gk-prod-card {
    background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
    overflow: hidden; transition: all .25s; display: flex; flex-direction: column;
}
.gk-prod-card:hover { box-shadow: var(--shadow); transform: translateY(-3px); border-color: var(--gold-soft); }
.gk-prod-img { aspect-ratio: 1; overflow: hidden; background: #fff; }
.gk-prod-img img { width: 100%; height: 100%; object-fit: contain; transition: transform .4s; }
.gk-prod-card:hover .gk-prod-img img { transform: scale(1.04); }
.gk-prod-meta { padding: 14px 16px 18px; border-block-start: 1px solid var(--line); }
.gk-prod-name {
    display: block; font-size: 15px; font-weight: 500; color: var(--ink);
    overflow: hidden; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; min-height: 3.2em;
}
.gk-prod-cta { font-size: 13px; color: var(--gold-strong); font-weight: 500; }

@media (max-width: 920px) { .gk-cat-grid, .gk-prod-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; } }

/* Craft / values */
.gk-craft { display: grid; grid-template-columns: 1.1fr .9fr; gap: 56px; align-items: start; }
.gk-craft-text h2 { font-size: 30px; }
.gk-craft-text p { color: var(--ink); }
.gk-craft-text .gk-btn { margin-block-start: 10px; }
.gk-values { display: grid; gap: 18px; }
.gk-value {
    background: var(--paper); border: 1px solid var(--line); border-inline-start: 3px solid var(--gold);
    border-radius: var(--radius); padding: 18px 22px;
}
.gk-value h3 { font-size: 18px; margin: 0 0 4px; }
.gk-value p { margin: 0; font-size: 14px; color: var(--muted); }
.gk-value-icon { color: var(--gold); font-size: 18px; }
@media (max-width: 920px) { .gk-craft { grid-template-columns: 1fr; gap: 32px; } }

/* CTA strip */
.gk-cta-strip { background: linear-gradient(135deg, var(--brown) 0%, var(--brown-deep) 100%); padding-block: 48px; }
.gk-cta-inner { display: flex; align-items: center; justify-content: space-between; gap: 22px; flex-wrap: wrap; }
.gk-cta-inner h2 { color: #fff; margin: 0; font-size: 24px; }

/* Footer */
.gk-footer { background: var(--brown-deep); color: #cfc4b4; font-size: 14px; }
.gk-footer a { color: #cfc4b4; }
.gk-footer a:hover { color: var(--gold-soft); }
.gk-footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 36px; padding-block: 56px 40px; }
.gk-footer-brand { font-family: var(--serif); font-size: 24px; font-weight: 700; color: var(--gold-soft); margin-block-end: 8px; }
.gk-footer-col h3 {
    color: #fff; font-size: 15px; font-family: var(--sans); font-weight: 500;
    letter-spacing: .06em; margin-block-end: 14px; padding-block-end: 8px; position: relative;
}
.gk-footer-col h3::after { content: ''; position: absolute; inset-block-end: 0; inset-inline-start: 0; width: 28px; height: 2px; background: var(--gold); }
.gk-footer-col h3 a { color: #fff; }
.gk-footer-col h3 a:hover { color: var(--gold-soft); }
.gk-footer-menu { list-style: none; margin: 0; padding: 0; }
.gk-footer-menu li { margin-block-end: 8px; }
.gk-footer-bottom { border-block-start: 1px solid rgba(232, 217, 176, .15); padding-block: 16px; font-size: 13px; color: #9a8d7b; }
@media (max-width: 920px) { .gk-footer-grid { grid-template-columns: 1fr 1fr; gap: 28px; } }
@media (max-width: 560px) { .gk-footer-grid { grid-template-columns: 1fr; } }

/* Generic content */
.gk-content { padding-block: 56px; }
.gk-page-head h1 { font-size: 34px; position: relative; padding-block-end: 14px; margin-block-end: 28px; }
.gk-page-head h1::after {
    content: ''; position: absolute; inset-block-end: 0; inset-inline-start: 0;
    width: 56px; height: 3px; background: linear-gradient(90deg, var(--gold), var(--gold-soft));
}
.gk-entry { max-width: 820px; }
.gk-post-card { background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius); padding: 26px; margin-block-end: 22px; }
.gk-pagination { margin-block-start: 30px; }

/* ============ WooCommerce ============ */
.gk-woo-main { padding-block: 48px 72px; }

.woocommerce-products-header__title.page-title,
.gk-woo-main h1.page-title {
    font-family: var(--serif); color: var(--brown); font-size: 34px;
    position: relative; padding-block-end: 14px; margin-block-end: 10px;
}
.gk-woo-main h1.page-title::after {
    content: ''; position: absolute; inset-block-end: 0; inset-inline-start: 0;
    width: 56px; height: 3px; background: linear-gradient(90deg, var(--gold), var(--gold-soft));
}
.term-description { color: var(--muted); max-width: 760px; margin-block-end: 10px; }

.woocommerce-result-count { color: var(--muted); font-size: 14px; }
.woocommerce-ordering select {
    border: 1px solid var(--line); border-radius: var(--radius); padding: 8px 12px;
    background: var(--paper); color: var(--ink); font-family: var(--sans);
}

/* Product loop */
.woocommerce ul.products { margin-block-start: 24px; }
.woocommerce ul.products li.product {
    background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
    overflow: hidden; transition: all .25s; text-align: center; padding-block-end: 18px;
}
.woocommerce ul.products li.product:hover { box-shadow: var(--shadow); transform: translateY(-3px); border-color: var(--gold-soft); }
.woocommerce ul.products li.product a img { margin: 0; aspect-ratio: 1; object-fit: contain; background: #fff; }
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 {
    font-family: var(--sans); font-size: 15px !important; font-weight: 500; color: var(--ink);
    padding: 14px 14px 6px;
}
.woocommerce ul.products li.product .price { color: var(--gold-strong); font-weight: 500; }
.woocommerce ul.products li.product .button,
.gk-loop-view {
    background: transparent !important; border: 1px solid var(--gold) !important;
    color: var(--gold-strong) !important; border-radius: var(--radius) !important;
    font-weight: 500 !important; padding: 8px 22px !important; margin-block-start: 6px !important;
    transition: all .2s !important;
}
.woocommerce ul.products li.product .button:hover,
.gk-loop-view:hover { background: var(--gold) !important; color: #fff !important; }
.woocommerce nav.woocommerce-pagination ul { border: 0; }
.woocommerce nav.woocommerce-pagination ul li { border: 0; margin-inline: 3px; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
    border: 1px solid var(--line); border-radius: var(--radius); padding: 9px 15px;
    color: var(--ink); background: var(--paper);
}
.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li a:hover { background: var(--gold); color: #fff; border-color: var(--gold); }

/* Breadcrumb */
.woocommerce .woocommerce-breadcrumb { color: var(--muted); font-size: 13px; margin-block-end: 22px; }
.woocommerce .woocommerce-breadcrumb a { color: var(--gold-strong); }

/* Single product */
.woocommerce div.product .product_title { font-family: var(--serif); color: var(--brown); font-size: 30px; }
/* Title spans full width above the gallery image + summary form. */
.woocommerce div.product h1.gk-product-title {
    clear: both; width: 100%; float: none;
    margin: 0 0 24px; text-align: center; font-size: 34px;
}
.woocommerce div.product p.price { color: var(--gold-strong); font-size: 22px; }
.woocommerce div.product .woocommerce-product-details__short-description { color: var(--ink); }
.woocommerce div.product div.images { border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; background: #fff; }
/* Automatic zoom-in on hover over the product image. */
.woocommerce div.product div.images .woocommerce-product-gallery__image { overflow: hidden; }
.woocommerce div.product div.images .woocommerce-product-gallery__image img {
    transition: transform .5s ease; cursor: zoom-in; transform-origin: center center;
}
.woocommerce div.product div.images .woocommerce-product-gallery__image:hover img {
    transform: scale(1.8);
}
.woocommerce div.product .product_meta { border-block-start: 1px solid var(--line); padding-block-start: 14px; color: var(--muted); font-size: 14px; }
.woocommerce div.product .product_meta a { color: var(--gold-strong); }
/* Product quote-request form */
.gk-quote { margin-block: 22px 8px; }
.gk-quote-form {
    background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
    padding: 24px 24px 26px; box-shadow: var(--shadow);
}
.gk-quote-title { font-size: 21px; margin: 0 0 18px; color: var(--brown); }
.gk-quote-components {
    border: 1px solid var(--gold-soft); border-radius: var(--radius);
    background: var(--cream); padding: 14px 16px 4px; margin: 0 0 18px;
}
.gk-quote-components legend {
    font-family: var(--sans); font-weight: 500; font-size: 14px; color: var(--gold-strong);
    padding-inline: 8px;
}
.gk-field { margin-block-end: 14px; }
.gk-field label { display: block; font-size: 14px; font-weight: 500; color: var(--ink); margin-block-end: 6px; }
.gk-req { color: var(--gold-strong); }
.gk-field input, .gk-field select, .gk-field textarea {
    width: 100%; border: 1px solid var(--line); border-radius: var(--radius);
    padding: 11px 14px; font-family: var(--sans); font-size: 15px; color: var(--ink);
    background: var(--paper);
}
.gk-field select { cursor: pointer; }
.gk-field input:focus, .gk-field select:focus, .gk-field textarea:focus {
    outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(176, 141, 62, .15);
}
.gk-field .gk-invalid, .gk-invalid { border-color: #c0563f !important; box-shadow: 0 0 0 3px rgba(192, 86, 63, .12); }
.gk-quote-error {
    background: #fbeae6; border: 1px solid #e6b8ab; color: #a23a22;
    border-radius: var(--radius); padding: 10px 14px; font-size: 14px; margin: 4px 0 14px;
}
.gk-quote-submit { width: 100%; margin-block-start: 4px; border: 0; }
.gk-quote-submit:disabled { opacity: .65; cursor: default; }
.gk-quote-call {
    display: block; text-align: center; margin-block-start: 14px; font-size: 14px;
    color: var(--gold-strong); font-weight: 500;
}
.gk-quote-thanks {
    background: var(--paper); border: 1px solid var(--gold-soft); border-radius: var(--radius);
    box-shadow: var(--shadow); padding: 40px 28px; text-align: center;
}
.gk-quote-thanks-icon { font-size: 38px; color: var(--gold); margin-block-end: 8px; }
.gk-quote-thanks h2 { font-size: 24px; margin: 0 0 8px; }
.gk-quote-thanks p { color: var(--muted); margin: 0 0 20px; }
/* Description + related products always drop below the full-height image float. */
.gk-product-desc,
.woocommerce div.product .related.products,
.woocommerce div.product .up-sells { clear: both; width: 100%; }
.gk-product-desc { margin-block-start: 44px; }
.gk-product-desc h2 {
    font-family: var(--serif); color: var(--brown); font-size: 24px;
    position: relative; padding-block-end: 12px; margin-block-end: 18px;
}
.gk-product-desc h2::after {
    content: ''; position: absolute; inset-block-end: 0; inset-inline-start: 0;
    width: 48px; height: 3px; background: linear-gradient(90deg, var(--gold), var(--gold-soft));
}
.gk-header-cta { padding: 9px 20px; font-size: 14px; }

/* ===== Contact page ===== */
.gk-contact-hero {
    background:
        radial-gradient(ellipse at 75% 15%, rgba(176, 141, 62, .30), transparent 55%),
        linear-gradient(160deg, var(--brown-deep) 0%, #3d2c1a 70%, var(--brown) 100%);
    color: #f4ede0; text-align: center; padding-block: 64px 70px;
}
.gk-contact-hero h1 { color: #fff; font-size: clamp(28px, 4vw, 42px); margin: 0 0 12px; }
.gk-contact-hero p { color: #e3d9c8; font-weight: 300; font-size: 18px; max-width: 560px; margin-inline: auto; }
.gk-contact { padding-block: 56px 72px; }
.gk-contact-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 44px; align-items: start; }
@media (max-width: 880px) { .gk-contact-grid { grid-template-columns: 1fr; gap: 32px; } }

.gk-info-card {
    display: flex; align-items: center; gap: 14px;
    background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
    padding: 16px 18px; margin-block-end: 12px;
    transition: border-color .2s, box-shadow .2s, transform .2s;
}
.gk-info-card:hover { border-color: var(--gold-soft); box-shadow: var(--shadow); transform: translateY(-1px); }
.gk-info-icon {
    flex: 0 0 44px; width: 44px; height: 44px; border-radius: 50%;
    background: linear-gradient(150deg, var(--cream), #f3ead4);
    border: 1px solid var(--gold-soft);
    display: flex; align-items: center; justify-content: center; color: var(--gold-strong);
}
/* Defensive: never let the inline SVG icons balloon, even if a cached or
   conflicting stylesheet drops the dimension rule. */
.gk-info-icon svg { width: 22px !important; height: 22px !important; flex: none; max-width: 22px; }
.gk-info-card > div { min-width: 0; }
.gk-info-label { display: block; font-size: 12px; letter-spacing: .03em; text-transform: uppercase; color: var(--muted); margin-block-end: 2px; }
.gk-info-value { display: block; font-size: 16px; font-weight: 500; color: var(--ink); word-break: break-word; }
.gk-info-value a { color: var(--gold-strong); }
.gk-info-value a:hover { color: var(--brown); }
.gk-hours {
    background: var(--paper); border: 1px solid var(--line); border-inline-start: 3px solid var(--gold);
    border-radius: var(--radius); padding: 18px 20px; margin-block-start: 6px;
}
.gk-hours h3 { font-size: 18px; margin: 0 0 12px; }
.gk-hours ul { list-style: none; margin: 0; padding: 0; }
.gk-hours li { display: flex; justify-content: space-between; gap: 16px; padding-block: 8px; border-block-end: 1px solid var(--line); font-size: 15px; }
.gk-hours li:last-child { border-block-end: 0; }
.gk-hours li span:first-child { color: var(--muted); }
.gk-hours li span:last-child { color: var(--gold-strong); font-weight: 500; white-space: nowrap; }

.gk-contact-form-wrap {
    background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
    box-shadow: var(--shadow); padding: 32px 30px 34px;
}
.gk-contact-form-wrap h2 { font-size: 26px; margin: 0 0 6px; }
.gk-contact-form-sub { color: var(--muted); margin: 0 0 22px; }
.gk-contact-form-wrap .wpcf7 p { margin: 0 0 16px; }
.gk-contact-form-wrap label { display: block; font-weight: 500; font-size: 14px; color: var(--ink); margin-block-end: 6px; }
.gk-contact-form-wrap br { display: none; }
.gk-contact-form-wrap .wpcf7-form-control-wrap { display: block; }
.gk-contact-form-wrap input[type="text"],
.gk-contact-form-wrap input[type="email"],
.gk-contact-form-wrap input[type="tel"],
.gk-contact-form-wrap input[type="url"],
.gk-contact-form-wrap input[type="number"],
.gk-contact-form-wrap textarea {
    width: 100%; box-sizing: border-box;
    font-family: var(--sans); font-size: 15px; color: var(--ink);
    background: var(--cream); border: 1px solid var(--line); border-radius: var(--radius);
    padding: 12px 14px; transition: border-color .2s, box-shadow .2s, background .2s;
}
.gk-contact-form-wrap textarea { min-height: 130px; resize: vertical; line-height: 1.6; }
.gk-contact-form-wrap input:focus,
.gk-contact-form-wrap textarea:focus {
    outline: none; background: var(--paper);
    border-color: var(--gold); box-shadow: 0 0 0 3px rgba(176, 141, 62, .15);
}
.gk-contact-form-wrap input::placeholder,
.gk-contact-form-wrap textarea::placeholder { color: var(--muted); }
.gk-contact-form-wrap input[type="submit"],
.gk-contact-form-wrap .wpcf7-submit {
    width: 100%; margin-block-start: 6px; cursor: pointer;
    font-family: var(--sans); font-size: 16px; font-weight: 500; color: #fff;
    background: linear-gradient(135deg, var(--gold), var(--gold-strong));
    border: 0; border-radius: var(--radius); padding: 14px 24px;
    transition: filter .2s, transform .1s, box-shadow .2s;
}
.gk-contact-form-wrap input[type="submit"]:hover,
.gk-contact-form-wrap .wpcf7-submit:hover { filter: brightness(1.06); box-shadow: var(--shadow); }
.gk-contact-form-wrap input[type="submit"]:active,
.gk-contact-form-wrap .wpcf7-submit:active { transform: translateY(1px); }
.gk-contact-form-wrap .wpcf7-spinner { margin-block-start: 10px; }

.woocommerce div.product .woocommerce-tabs ul.tabs { padding: 0; margin-block-start: 36px; }
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border-color: var(--line); }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
    background: var(--cream); border: 1px solid var(--line); border-radius: var(--radius) var(--radius) 0 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active { background: var(--paper); border-block-end-color: var(--paper); }
.woocommerce div.product .woocommerce-tabs ul.tabs li a { color: var(--muted); font-weight: 500; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--brown); }
.woocommerce div.product .woocommerce-tabs .panel { background: var(--paper); border: 1px solid var(--line); border-block-start: 0; border-radius: 0 0 var(--radius) var(--radius); padding: 24px; }

.woocommerce .related.products > h2,
.woocommerce .up-sells > h2 {
    font-family: var(--serif); color: var(--brown); font-size: 26px;
    position: relative; padding-block-end: 12px; margin-block: 40px 22px;
}
.woocommerce .related.products > h2::after,
.woocommerce .up-sells > h2::after {
    content: ''; position: absolute; inset-block-end: 0; inset-inline-start: 0;
    width: 48px; height: 3px; background: linear-gradient(90deg, var(--gold), var(--gold-soft));
}

/* Forms & buttons (Woo general) */
.woocommerce #respond input#submit, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit.alt, .woocommerce a.button.alt, .woocommerce button.button.alt, .woocommerce input.button.alt {
    background-color: var(--gold); color: #fff; border-radius: var(--radius); font-weight: 500;
}
.woocommerce #respond input#submit:hover, .woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce a.button.alt:hover, .woocommerce button.button.alt:hover, .woocommerce input.button.alt:hover {
    background-color: var(--gold-strong); color: #fff;
}
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce form .form-row select {
    border: 1px solid var(--line); border-radius: var(--radius); padding: 10px 14px; background: var(--paper);
}
.woocommerce-message, .woocommerce-info { border-block-start-color: var(--gold); }
.woocommerce-message::before, .woocommerce-info::before { color: var(--gold); }

/* Contact Form 7 */
.wpcf7 input[type="text"], .wpcf7 input[type="email"], .wpcf7 input[type="tel"], .wpcf7 textarea, .wpcf7 select {
    width: 100%; border: 1px solid var(--line); border-radius: var(--radius); padding: 11px 14px;
    background: var(--paper); font-family: var(--sans); font-size: 15px; color: var(--ink);
}
.wpcf7 input[type="submit"] {
    background: var(--gold); color: #fff; border: 0; border-radius: var(--radius);
    padding: 12px 34px; font-weight: 500; font-size: 15px; cursor: pointer;
}
.wpcf7 input[type="submit"]:hover { background: var(--gold-strong); }

/* ===== About page ===== */
.gk-about-hero {
    background:
        radial-gradient(ellipse at 75% 15%, rgba(176, 141, 62, .30), transparent 55%),
        linear-gradient(160deg, var(--brown-deep) 0%, #3d2c1a 70%, var(--brown) 100%);
    background-size: cover; background-position: center;
    color: #f4ede0; text-align: center;
}
.gk-about-hero.has-img { background-size: cover; background-position: center; }
.gk-about-hero-inner { padding-block: 88px 92px; max-width: 820px; }
.gk-about-hero h1 { color: #fff; font-size: clamp(32px, 5vw, 50px); margin: 6px 0 14px; }
.gk-about-hero-tagline {
    color: var(--gold-soft); font-family: var(--serif); font-weight: 500;
    font-size: clamp(18px, 2.4vw, 24px); margin: 0;
}

.gk-about-intro { max-width: 860px; text-align: center; }
.gk-about-intro p { font-size: 18px; color: var(--ink); margin-block-end: 18px; }
.gk-about-intro p:last-child { margin-block-end: 0; }

.gk-about-lead { max-width: 860px; margin-block-end: 36px; }
.gk-about-lead p { font-size: 17px; color: var(--ink); margin-block-end: 14px; }

.gk-about-features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.gk-about-feature {
    background: var(--paper); border: 1px solid var(--line);
    border-block-start: 3px solid var(--gold);
    border-radius: var(--radius); padding: 26px 24px;
    transition: box-shadow .25s, transform .25s, border-color .25s;
}
.gk-about-feature:hover { box-shadow: var(--shadow); transform: translateY(-3px); }
.gk-about-feature-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 46px; height: 46px; border-radius: 50%;
    background: linear-gradient(150deg, var(--cream), #f3ead4);
    border: 1px solid var(--gold-soft); color: var(--gold-strong);
    font-size: 20px; margin-block-end: 14px;
}
.gk-about-feature h3 { font-size: 20px; margin: 0 0 8px; }
.gk-about-feature p { margin: 0; color: var(--muted); font-size: 15px; }
@media (max-width: 920px) { .gk-about-features { grid-template-columns: 1fr; gap: 16px; } }

.gk-about-quote-band {
    background: linear-gradient(135deg, var(--brown) 0%, var(--brown-deep) 100%);
    padding-block: 56px; text-align: center;
}
.gk-about-quote { margin: 0; max-width: 760px; margin-inline: auto; position: relative; }
.gk-about-quote-mark {
    display: block; font-family: var(--serif); color: var(--gold);
    font-size: 64px; line-height: .6; margin-block-end: 8px;
}
.gk-about-quote p {
    font-family: var(--serif); color: var(--gold-soft); font-weight: 700;
    font-size: clamp(26px, 4vw, 36px); margin: 0 0 14px;
}
.gk-about-quote cite {
    display: block; font-style: normal; color: #e3d9c8; font-weight: 300;
    font-size: 18px; line-height: 1.7;
}

/* Values rendered as an even 3-up row (reused on the about page). */
.gk-values-row { grid-template-columns: repeat(3, 1fr); }
.gk-values-row .gk-value { padding: 24px 24px 22px; }
.gk-values-row .gk-value h3 { font-size: 19px; margin-block: 6px 8px; }
.gk-values-row .gk-value p { font-size: 14px; }
@media (max-width: 920px) { .gk-values-row { grid-template-columns: 1fr; } }
