/*
 Theme Name:   Vault Research Child
 Theme URI:    https://vaultresearch.store
 Description:  Vault Research child theme for Storefront. Applies navy/teal brand colors, Outfit + Lora fonts, and research-use styling.
 Author:       Vault Research
 Template:     storefront
 Version:      1.0.0
*/

/* ══ GOOGLE FONTS ══ */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Lora:ital,wght@0,400;0,600;1,400&family=JetBrains+Mono:wght@300;400;500&display=swap');

/* ══ VARIABLES ══ */
:root {
  --pv-navy:      #0b2545;
  --pv-navy-mid:  #134e8f;
  --pv-navy-lt:   #1d72c8;
  --pv-navy-pale: #e8f0fb;
  --pv-teal:      #0d8a7a;
  --pv-teal-lt:   #e4f5f2;
  --pv-gold:      #c8860a;
  --pv-gold-lt:   #fdf3e0;
  --pv-bg:        #f4f6f9;
  --pv-border:    #dde4ee;
  --pv-ink:       #0f1923;
  --pv-ink-mid:   #3d5166;
  --pv-ink-dim:   #7d93a8;
  --pv-sans:      'Outfit', sans-serif;
  --pv-serif:     'Lora', Georgia, serif;
  --pv-mono:      'JetBrains Mono', monospace;
  --pv-r:         10px;
}

/* ══ GLOBAL ══ */
body {
  font-family: var(--pv-sans);
  background: var(--pv-bg);
  color: var(--pv-ink);
}

h1, h2, h3, h4 {
  font-family: var(--pv-serif);
  color: var(--pv-navy);
  font-weight: 600;
}

a { color: var(--pv-navy-lt); }
a:hover { color: var(--pv-teal); }

/* ══ HEADER ══ */
.site-header {
  background: rgba(255,255,255,0.96) !important;
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--pv-border) !important;
  box-shadow: 0 1px 4px rgba(11,37,69,0.07) !important;
}

.site-title a {
  font-family: var(--pv-serif) !important;
  font-size: 1.3rem !important;
  font-style: italic;
  color: var(--pv-ink) !important;
  font-weight: 600 !important;
}

/* ══ NAV ══ */
.main-navigation ul li a {
  font-family: var(--pv-sans);
  font-size: 0.84rem;
  font-weight: 600;
  color: var(--pv-ink-mid);
  letter-spacing: 0.01em;
}

.main-navigation ul li a:hover,
.main-navigation ul li.current-menu-item > a {
  color: var(--pv-navy);
}

/* ══ BUTTONS ══ */
.button,
button[type="submit"],
input[type="submit"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: var(--pv-navy) !important;
  color: white !important;
  font-family: var(--pv-sans) !important;
  font-weight: 700 !important;
  border-radius: var(--pv-r) !important;
  border: none !important;
  letter-spacing: 0.01em;
  transition: background 0.2s, transform 0.15s;
}

.button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover {
  background: var(--pv-navy-mid) !important;
  transform: translateY(-1px);
}

.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce #respond input#submit.alt {
  background: linear-gradient(135deg, var(--pv-navy), var(--pv-navy-mid)) !important;
}

/* ══ PRODUCT CARDS ══ */
.woocommerce ul.products li.product {
  background: white;
  border: 1px solid var(--pv-border);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(11,37,69,0.08);
  transition: box-shadow 0.25s, transform 0.25s;
  padding: 0 !important;
}

.woocommerce ul.products li.product:hover {
  box-shadow: 0 12px 40px rgba(11,37,69,0.14);
  transform: translateY(-4px);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--pv-serif);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--pv-navy);
  padding: 0.8rem 1rem 0.2rem;
}

.woocommerce ul.products li.product .price {
  font-family: var(--pv-serif);
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--pv-navy);
  padding: 0 1rem;
}

.woocommerce ul.products li.product .button {
  margin: 0.5rem 1rem 1rem;
  width: calc(100% - 2rem);
  text-align: center;
}

/* ══ SINGLE PRODUCT ══ */
.woocommerce div.product .product_title {
  font-family: var(--pv-serif);
  font-size: 2rem;
  color: var(--pv-navy);
}

.woocommerce div.product p.price {
  font-family: var(--pv-serif);
  font-size: 1.8rem;
  color: var(--pv-navy);
}

.woocommerce div.product .woocommerce-product-details__short-description {
  font-size: 0.92rem;
  color: var(--pv-ink-mid);
  line-height: 1.75;
  border-left: 3px solid var(--pv-navy-lt);
  padding-left: 1rem;
  margin: 1rem 0;
}

/* Variation selector */
.woocommerce div.product form.cart .variations select {
  font-family: var(--pv-mono);
  font-size: 0.8rem;
  border: 1.5px solid var(--pv-border);
  border-radius: 8px;
  padding: 0.5rem 0.8rem;
  background: var(--pv-bg);
  color: var(--pv-ink);
}

/* ══ RUO BADGE ══ */
.pepvault-ruo-badge {
  display: inline-block;
  font-family: var(--pv-mono);
  font-size: 0.56rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  background: var(--pv-navy-pale);
  color: var(--pv-navy-mid);
  border: 1px solid #b8d0f5;
  padding: 2px 8px;
  border-radius: 20px;
  margin-bottom: 0.5rem;
}

/* ══ PRODUCT CATEGORY CHIPS ══ */
.posted_in a {
  font-family: var(--pv-mono);
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--pv-teal-lt);
  color: var(--pv-teal);
  padding: 2px 8px;
  border-radius: 20px;
  text-decoration: none;
}

/* ══ CART ══ */
.woocommerce-cart .cart_item td {
  border-bottom: 1px solid var(--pv-border) !important;
  vertical-align: middle;
}

.woocommerce-cart table.cart th {
  font-family: var(--pv-mono);
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--pv-ink-dim);
  font-weight: 500;
  background: var(--pv-bg);
}

.cart-collaterals .cart_totals {
  background: white;
  border: 1px solid var(--pv-border);
  border-radius: var(--pv-r);
  padding: 1.5rem;
}

.cart-collaterals .cart_totals h2 {
  font-size: 1rem;
  font-family: var(--pv-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pv-ink-dim);
  margin-bottom: 1rem;
}

/* ══ CHECKOUT ══ */
.woocommerce-checkout .woocommerce-checkout-review-order {
  background: white;
  border: 1px solid var(--pv-border);
  border-radius: var(--pv-r);
  padding: 1.5rem;
}

.woocommerce form .form-row label {
  font-family: var(--pv-mono);
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--pv-ink-mid);
  font-weight: 500;
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select,
.woocommerce form .form-row textarea {
  border: 1.5px solid var(--pv-border);
  border-radius: 8px;
  padding: 0.75rem 0.9rem;
  font-family: var(--pv-sans);
  font-size: 0.88rem;
  background: white;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--pv-navy-lt);
  box-shadow: 0 0 0 3px rgba(29,114,200,0.10);
  outline: none;
}

/* ══ NOTICES ══ */
.woocommerce-message {
  border-top-color: var(--pv-teal) !important;
  background: var(--pv-teal-lt) !important;
  color: var(--pv-ink);
}

.woocommerce-error {
  border-top-color: #e53e3e !important;
}

/* ══ RUO SITE-WIDE BANNER ══ */
.pepvault-ruo-bar {
  background: var(--pv-navy);
  color: rgba(255,255,255,0.8);
  font-family: var(--pv-mono);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  padding: 6px 1rem;
}

/* ══ FOOTER ══ */
.site-footer {
  background: var(--pv-navy) !important;
  color: rgba(255,255,255,0.5) !important;
}

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

.site-footer a:hover {
  color: white !important;
}

.site-footer .site-info {
  font-family: var(--pv-mono);
  font-size: 0.6rem;
  letter-spacing: 0.05em;
  color: rgba(255,255,255,0.25) !important;
}

/* ══ PURITY BAR (custom meta) ══ */
.pepvault-purity-bar {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin: 0.5rem 0;
}

.pepvault-purity-track {
  flex: 1;
  height: 4px;
  background: var(--pv-bg);
  border-radius: 2px;
  overflow: hidden;
}

.pepvault-purity-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--pv-teal), var(--pv-navy-lt));
  border-radius: 2px;
}

.pepvault-purity-label {
  font-family: var(--pv-mono);
  font-size: 0.62rem;
  color: var(--pv-teal);
  font-weight: 500;
}

/* ══ MOBILE ══ */
@media (max-width: 768px) {
  .woocommerce ul.products li.product {
    margin-bottom: 1rem !important;
  }

  .woocommerce div.product .product_title {
    font-size: 1.5rem;
  }

  .site-header .col-full {
    padding: 0 1rem;
  }
}

/* ============================================================
   VAULT RESEARCH — WooCommerce Cart & Checkout Styling
   ============================================================ */

/* -- Fonts & Base -- */
body.woocommerce-cart,
body.woocommerce-checkout,
body.woocommerce-account,
body.woocommerce {
  font-family: 'Outfit', 'Inter', sans-serif !important;
  background: #f4f6f9 !important;
  color: #0f1923 !important;
}

/* -- Hide default Storefront header/nav, use our top bar instead -- */
.site-header { background: #0b2545 !important; border-bottom: 1px solid #134e8f !important; }
.site-header .site-branding .site-title a,
.site-header .site-branding .site-description { color: #e8f0fb !important; }
.main-navigation ul li a { color: #c5d5e8 !important; font-family: 'Outfit', sans-serif !important; }
.main-navigation ul li a:hover { color: #ffffff !important; }
.site-header-cart .cart-contents { color: #e8f0fb !important; }
.site-header-cart .cart-contents:hover { color: #ffffff !important; }

/* -- Page layout -- */
.woocommerce-cart .entry-header,
.woocommerce-checkout .entry-header { display: none; }

.woocommerce #content,
.woocommerce-page #content { padding: 2rem 1rem !important; }

/* -- Buttons -- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce .cart .button,
.woocommerce .cart input.button {
  background: #0b2545 !important;
  color: #ffffff !important;
  font-family: 'Outfit', sans-serif !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  border-radius: 8px !important;
  border: none !important;
  padding: 0.75rem 1.5rem !important;
  transition: background 0.2s !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce .cart .button:hover {
  background: #134e8f !important;
  color: #ffffff !important;
}
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce #payment #place_order,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
  background: #1d72c8 !important;
  color: #ffffff !important;
  font-size: 1rem !important;
  padding: 0.9rem 2rem !important;
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce #payment #place_order:hover,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover {
  background: #134e8f !important;
}

/* -- Cart Table -- */
.woocommerce-cart table.cart { background: #ffffff !important; border-radius: 12px !important; overflow: hidden !important; box-shadow: 0 2px 12px rgba(11,37,69,0.08) !important; }
.woocommerce-cart table.cart thead { background: #0b2545 !important; }
.woocommerce-cart table.cart thead th { color: #e8f0fb !important; font-family: 'Outfit', sans-serif !important; font-weight: 600 !important; border: none !important; padding: 1rem !important; }
.woocommerce-cart table.cart td { border-color: #eef1f6 !important; padding: 1rem !important; vertical-align: middle !important; }
.woocommerce-cart table.cart .product-name a { color: #0b2545 !important; font-weight: 600 !important; font-family: 'Outfit', sans-serif !important; }
.woocommerce-cart table.cart .product-name a:hover { color: #1d72c8 !important; }
.woocommerce-cart .quantity input.qty { border: 2px solid #e8f0fb !important; border-radius: 6px !important; font-family: 'Outfit', sans-serif !important; color: #0f1923 !important; }

/* -- Cart Totals -- */
.cart-collaterals .cart_totals { background: #ffffff !important; border-radius: 12px !important; box-shadow: 0 2px 12px rgba(11,37,69,0.08) !important; padding: 1.5rem !important; }
.cart_totals h2 { font-family: 'Lora', serif !important; color: #0b2545 !important; font-size: 1.3rem !important; margin-bottom: 1rem !important; }
.cart_totals table { width: 100% !important; }
.cart_totals table th { color: #3d5166 !important; font-family: 'Outfit', sans-serif !important; font-weight: 500 !important; }
.cart_totals table td { color: #0f1923 !important; font-family: 'Outfit', sans-serif !important; font-weight: 600 !important; }
.cart_totals .order-total th,
.cart_totals .order-total td { color: #0b2545 !important; font-size: 1.1rem !important; border-top: 2px solid #e8f0fb !important; }
.wc-proceed-to-checkout { padding: 1rem 0 0 !important; }

/* -- Checkout Form -- */
.woocommerce-checkout #customer_details { background: #ffffff !important; border-radius: 12px !important; padding: 2rem !important; box-shadow: 0 2px 12px rgba(11,37,69,0.08) !important; }
.woocommerce-billing-fields h3,
.woocommerce-shipping-fields h3,
.woocommerce-checkout #order_review_heading { font-family: 'Lora', serif !important; color: #0b2545 !important; font-size: 1.2rem !important; }
.woocommerce form .form-row label { font-family: 'Outfit', sans-serif !important; color: #3d5166 !important; font-weight: 500 !important; font-size: 0.875rem !important; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  border: 2px solid #e8f0fb !important;
  border-radius: 8px !important;
  font-family: 'Outfit', sans-serif !important;
  color: #0f1923 !important;
  background: #f4f6f9 !important;
  padding: 0.6rem 0.8rem !important;
  transition: border-color 0.2s !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  border-color: #1d72c8 !important;
  background: #ffffff !important;
  outline: none !important;
}

/* -- Order Review box -- */
#order_review { background: #ffffff !important; border-radius: 12px !important; padding: 2rem !important; box-shadow: 0 2px 12px rgba(11,37,69,0.08) !important; }
#order_review table.shop_table { border-radius: 8px !important; overflow: hidden !important; }
#order_review table thead { background: #0b2545 !important; }
#order_review table thead th { color: #e8f0fb !important; font-family: 'Outfit', sans-serif !important; border: none !important; padding: 0.75rem 1rem !important; }
#order_review table td { border-color: #eef1f6 !important; font-family: 'Outfit', sans-serif !important; color: #0f1923 !important; }
#order_review .order-total td, #order_review .order-total th { font-weight: 700 !important; color: #0b2545 !important; font-size: 1.05rem !important; }

/* -- Payment box -- */
#payment { background: #ffffff !important; border-radius: 12px !important; padding: 1.5rem !important; box-shadow: 0 2px 12px rgba(11,37,69,0.08) !important; margin-top: 1.5rem !important; }
#payment .payment_methods li { font-family: 'Outfit', sans-serif !important; color: #0f1923 !important; }
#payment .payment_box { background: #e8f0fb !important; border-radius: 8px !important; color: #3d5166 !important; }

/* -- Notices -- */
.woocommerce-message, .woocommerce-info {
  background: #e4f5f2 !important;
  border-top-color: #0d8a7a !important;
  color: #0b2545 !important;
  font-family: 'Outfit', sans-serif !important;
}
.woocommerce-error {
  background: #fdf3e0 !important;
  border-top-color: #c8860a !important;
  color: #0b2545 !important;
  font-family: 'Outfit', sans-serif !important;
}

/* -- Footer -- */
.woocommerce-cart .site-footer,
.woocommerce-checkout .site-footer { background: #0b2545 !important; color: #c5d5e8 !important; }
.woocommerce-cart .site-footer a,
.woocommerce-checkout .site-footer a { color: #7eb3e8 !important; }

/* -- Responsive -- */
@media (max-width: 768px) {
  .woocommerce-cart table.cart thead { display: none; }
  .woocommerce-cart table.cart td { display: block; width: 100% !important; border-bottom: 1px solid #eef1f6 !important; }
  .cart-collaterals { margin-top: 1.5rem; }
}
