/*
Theme Name: Flatsome Child
Description: This is a child theme for Flatsome Theme
Author: UX Themes
Template: flatsome
Version: 3.0
*/

/* ============================================
   TAKUMI US — Clean & Bold Design System
   White base · Charcoal text · Orange accents
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;500;600;700&family=Inter:wght@300;400;500;600&family=Montserrat:wght@400;500;600;700&display=swap');

/* ── Variables ── */
:root {
  --orange:     #E8620A;
  --orange-dk:  #C4520A;
  --charcoal:   #111111;
  --charcoal-2: #333333;
  --bg:         #F5F5F3;
  --white:      #FFFFFF;
  --grey:       #666666;
  --grey-lt:    #E5E7EB;
  --font-head:  'Oswald', sans-serif;
  --font-body:  'Inter', sans-serif;
  --font-label: 'Montserrat', sans-serif;
}

/* ── Global ── */
body {
  font-family: var(--font-body) !important;
  background-color: var(--white) !important;
  color: var(--charcoal-2) !important;
  font-weight: 400;
}

/* ── Headings ── */
h1, h2, h3, h4, h5, h6,
.entry-title, .product_title, .page-title {
  font-family: var(--font-head) !important;
  font-weight: 700 !important;
  letter-spacing: 0.03em !important;
  text-transform: uppercase !important;
  color: var(--charcoal) !important;
}

h1 { font-size: clamp(2.2rem, 5vw, 4rem) !important; }
h2 { font-size: clamp(1.6rem, 4vw, 2.8rem) !important; }
h3 { font-size: clamp(1.2rem, 3vw, 1.9rem) !important; }

/* ── Header ── */
#header, .header, header.header {
  background-color: var(--white) !important;
  border-bottom: 3px solid var(--orange) !important;
  box-shadow: 0 1px 12px rgba(0,0,0,0.07) !important;
}

.nav-top .logo a, .header-logo a,
.logo img + span, .logo-text {
  font-family: var(--font-head) !important;
  font-size: 1.6rem !important;
  color: var(--charcoal) !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

nav a, .nav-top a, #main-nav a,
.header-nav a {
  font-family: var(--font-label) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--charcoal-2) !important;
  font-weight: 600 !important;
}

nav a:hover, .nav-top a:hover, #main-nav a:hover {
  color: var(--orange) !important;
}

/* ── Buttons ── */
.button,
a.button,
input[type="submit"],
.wc-block-components-button {
  background-color: var(--orange) !important;
  color: var(--white) !important;
  border: none !important;
  font-family: var(--font-label) !important;
  font-size: 0.68rem !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  padding: 9px 22px !important;
  border-radius: 2px !important;
  transition: background 0.2s ease, color 0.2s ease !important;
  cursor: pointer !important;
  display: inline-block !important;
}

.button:hover,
a.button:hover,
input[type="submit"]:hover,
.wc-block-components-button:hover {
  background-color: var(--charcoal) !important;
  color: var(--white) !important;
}

/* Add to Cart — shop/archive loop */
.woocommerce ul.products li.product .button,
a.add_to_cart_button {
  font-size: 0.63rem !important;
  padding: 7px 16px !important;
  letter-spacing: 0.1em !important;
}

/* Add to Cart — single product page */
.single_add_to_cart_button,
button.single_add_to_cart_button {
  background-color: var(--orange) !important;
  padding: 11px 32px !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.14em !important;
  min-width: 160px !important;
  width: auto !important;
}

.single_add_to_cart_button:hover,
button.single_add_to_cart_button:hover {
  background-color: var(--charcoal) !important;
}

/* Buy Now button */
.woocommerce-buy-now-button,
.buynow-button,
a.buynow-button {
  background-color: var(--charcoal) !important;
  padding: 11px 32px !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.14em !important;
  min-width: 160px !important;
}

.woocommerce-buy-now-button:hover,
.buynow-button:hover {
  background-color: var(--orange) !important;
}

.button.alt, .button.secondary {
  background-color: var(--charcoal) !important;
}
.button.alt:hover { background-color: var(--orange) !important; }

/* ── Product Cards ── */
li.product {
  background: var(--white) !important;
  border: 1px solid var(--grey-lt) !important;
  border-bottom: 3px solid transparent !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease !important;
  border-radius: 2px !important;
}

li.product:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 8px 28px rgba(0,0,0,0.10) !important;
  border-bottom-color: var(--orange) !important;
}

.woocommerce-loop-product__title,
h2.woocommerce-loop-product__title {
  font-family: var(--font-head) !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  color: var(--charcoal) !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  line-height: 1.3 !important;
}

.price, .woocommerce-Price-amount {
  color: var(--orange) !important;
  font-family: var(--font-label) !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
}

/* ── Product Page ── */
.product_title {
  font-size: clamp(1.6rem, 4vw, 2.8rem) !important;
  line-height: 1.1 !important;
  border-bottom: 3px solid var(--orange);
  padding-bottom: 12px;
  margin-bottom: 16px !important;
  color: var(--charcoal) !important;
}

.woocommerce-product-details__short-description {
  font-size: 1rem !important;
  line-height: 1.8 !important;
  color: var(--grey) !important;
  border-left: 4px solid var(--orange);
  padding-left: 16px;
  margin: 20px 0 !important;
}

.woocommerce-tabs .tabs li a {
  font-family: var(--font-label) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  color: var(--charcoal-2) !important;
}

.woocommerce-tabs .tabs li.active a {
  color: var(--orange) !important;
  border-bottom: 2px solid var(--orange) !important;
}

/* ── Category / Archive ── */
.archive-title, .woocommerce-products-header__title {
  font-family: var(--font-head) !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  color: var(--charcoal) !important;
  letter-spacing: 0.05em !important;
}

/* ── Breadcrumbs ── */
.woocommerce-breadcrumb, .woocommerce-breadcrumb a {
  font-family: var(--font-label) !important;
  font-size: 0.68rem !important;
  letter-spacing: 0.1em !important;
  color: var(--grey) !important;
  text-transform: uppercase !important;
}

/* ── Sale Badge ── */
.onsale {
  background-color: var(--orange) !important;
  color: var(--white) !important;
  font-family: var(--font-label) !important;
  font-size: 0.62rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
  border-radius: 2px !important;
  padding: 4px 8px !important;
}

/* ── Shop Filters ── */
.woocommerce-ordering select, .orderby {
  font-family: var(--font-label) !important;
  font-size: 0.72rem !important;
  border: 1px solid var(--grey-lt) !important;
  color: var(--charcoal-2) !important;
}

.woocommerce-result-count {
  font-family: var(--font-label) !important;
  font-size: 0.68rem !important;
  letter-spacing: 0.08em !important;
  color: var(--grey) !important;
}

/* ── Widget Titles ── */
.widget-title, .widgettitle {
  font-family: var(--font-head) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--charcoal) !important;
  border-bottom: 2px solid var(--orange) !important;
  padding-bottom: 8px !important;
}

/* ── Footer ── */
footer, #footer {
  background-color: var(--charcoal) !important;
  color: rgba(255,255,255,0.70) !important;
  border-top: 3px solid var(--orange) !important;
}

footer a, #footer a { color: var(--orange) !important; }
footer a:hover, #footer a:hover { color: var(--white) !important; }

footer h3, footer h4, #footer h3, #footer h4 {
  color: var(--white) !important;
  font-family: var(--font-label) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
}

/* ── Inputs ── */
input[type="text"], input[type="email"],
input[type="password"], textarea, select {
  border: 1px solid var(--grey-lt) !important;
  border-radius: 2px !important;
  font-family: var(--font-body) !important;
  color: var(--charcoal-2) !important;
}

input:focus, textarea:focus, select:focus {
  border-color: var(--orange) !important;
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(232,98,10,0.15) !important;
}

/* ── Quantity Input ── */
.quantity input[type=number] {
  border: 2px solid var(--grey-lt) !important;
  font-family: var(--font-label) !important;
  font-weight: 600 !important;
  color: var(--charcoal) !important;
}

/* ── Mobile ── */
@media only screen and (max-width: 48em) {
  h1 { font-size: 2.2rem !important; }
  h2 { font-size: 1.6rem !important; }
  .product_title { font-size: 1.6rem !important; }
}

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--orange); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--charcoal); }

/* ── Dark section form inputs ── */
.dark-form input[type="text"],
.dark-form input[type="email"],
.dark-form input[type="password"] {
  background: rgba(255,255,255,0.08) !important;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
}
.dark-form input::placeholder {
  color: rgba(255,255,255,0.35) !important;
}
.dark-form input:focus {
  background: rgba(255,255,255,0.13) !important;
  border-color: var(--orange) !important;
  box-shadow: 0 0 0 2px rgba(232,98,10,0.25) !important;
}


/* ── BUTTON OVERRIDE — beats Flatsome inline CSS ── */
:root {
  --add-to-cart-rounded-corners-radius: 2px !important;
  --rounded-corners-radius: 2px !important;
}

/* Reset ALL button radius — override plugin 16px pill shape */
.button, a.button, button,
.single_add_to_cart_button,
.ux-buy-now-button,
.add_to_cart_button,
input[type="submit"],
.wc-block-components-button {
  border-radius: 2px !important;
}

/* Add to Cart — correct color + size */
.add_to_cart_button.button,
a.add_to_cart_button,
.woocommerce ul.products li.product a.button,
.product_type_simple.add_to_cart_button {
  background-color: #E8620A !important;
  color: #ffffff !important;
  border-radius: 2px !important;
  font-size: 0.65rem !important;
  padding: 7px 16px !important;
  letter-spacing: 0.1em !important;
  font-weight: 600 !important;
  width: auto !important;
  min-width: unset !important;
  height: auto !important;
}

.add_to_cart_button.button:hover,
a.add_to_cart_button:hover {
  background-color: #111111 !important;
}

/* Single product Add to Cart */
.single_add_to_cart_button.button.alt,
button.single_add_to_cart_button {
  background-color: #E8620A !important;
  color: #ffffff !important;
  border-radius: 2px !important;
  font-size: 0.72rem !important;
  padding: 11px 32px !important;
  width: auto !important;
  height: auto !important;
  min-width: 160px !important;
  max-width: 260px !important;
  letter-spacing: 0.14em !important;
}

.single_add_to_cart_button.button.alt:hover,
button.single_add_to_cart_button:hover {
  background-color: #111111 !important;
}

/* Buy Now button */
.ux-buy-now-button.button.primary,
.ux-buy-now-button {
  background-color: #111111 !important;
  color: #ffffff !important;
  border-radius: 2px !important;
  font-size: 0.72rem !important;
  padding: 11px 32px !important;
  width: auto !important;
  height: auto !important;
  min-width: 160px !important;
  max-width: 260px !important;
  letter-spacing: 0.14em !important;
}

.ux-buy-now-button.button.primary:hover,
.ux-buy-now-button:hover {
  background-color: #E8620A !important;
}

/* Fix request quote button — was 510px wide */
a.add-request-quote-button.button {
  width: auto !important;
  height: auto !important;
  padding: 9px 22px !important;
}

/* Quantity +/- buttons — never orange */
.ux-quantity__button--minus,
.ux-quantity__button--plus,
.quantity .plus,
.quantity .minus {
  background-color: #f5f5f3 !important;
  color: #111111 !important;
  border: 1px solid #E5E7EB !important;
  padding: 6px 10px !important;
  width: auto !important;
  height: auto !important;
}

.ux-quantity__button--minus:hover,
.ux-quantity__button--plus:hover {
  background-color: #E8620A !important;
  color: #ffffff !important;
  border-color: #E8620A !important;
}
