/*
Theme Name: HaveBien
Theme URI: https://havebien.dk
Author: Kristina Thorsen
Author URI: https://havebien.dk
Description: Bæredygtigt biavlerudstyr — varmt, naturligt og personligt tema til HaveBien.
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: havebien
*/

@import url('https://fonts.googleapis.com/css2?family=Crimson+Pro:ital,wght@0,300;0,400;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500&family=Great+Vibes&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --cream:    #F7F2E8;
  --cream2:   #EDE8DA;
  --cream3:   #DDD8C8;
  --forest:   #3A5C3A;
  --forest2:  #2A4A2A;
  --forest3:  #1A3A1A;
  --forest-l: #C8D8C0;
  --forest-ll:#E4EDE0;
  --gold:     #8B6914;
  --gold2:    #C4980A;
  --gold3:    #F0D878;
  --gold-l:   #F5ECC8;
  --brown:    #3A2A14;
  --brown2:   #6B5030;
  --brown3:   #9A7A50;
  --pink:     #D4A8A8;
  --pink-l:   #EDD8D8;
}

html { scroll-behavior: smooth; }
body { font-family: 'Crimson Pro', Georgia, serif; background: var(--cream); color: var(--brown); line-height: 1.7; font-size: 18px; }

/* ── NAV ── */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--cream);
  border-top: 4px solid var(--forest3);
  border-bottom: 4px solid var(--forest3);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.6rem 4rem;
}
.site-branding a { display: flex; align-items: center; text-decoration: none; }
.main-navigation ul { display: flex; gap: 2.5rem; list-style: none; align-items: center; margin: 0; padding: 0; }
.main-navigation a { text-decoration: none; color: var(--forest2); font-family: 'DM Sans', sans-serif; font-size: 0.75rem; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 400; transition: color 0.2s; }
.main-navigation a:hover { color: var(--forest); }
.nav-cta > a { background: var(--forest) !important; color: var(--cream) !important; padding: 0.45rem 1.2rem; border: 1px solid var(--forest) !important; }
.nav-cta > a:hover { background: var(--forest2) !important; }

/* Cart icon in nav */
.cart-btn {
  background: none; border: none; cursor: pointer;
  color: var(--forest2); position: relative;
  padding: 0.3rem; display: flex; align-items: center;
  transition: color 0.2s;
}
.cart-btn:hover { color: var(--forest); }
.cart-count {
  position: absolute; top: -4px; right: -6px;
  background: var(--gold2); color: white;
  font-family: 'DM Sans', sans-serif; font-size: 0.62rem;
  font-weight: 500; width: 17px; height: 17px;
  border-radius: 50%; display: flex; align-items: center;
  justify-content: center;
}

/* ── TRUST BAR ── */
.trust-bar {
  background: var(--forest2);
  display: flex; align-items: center; justify-content: center;
  flex-wrap: wrap; border-bottom: 3px solid var(--gold2);
}
.trust-item {
  display: flex; align-items: center; gap: 0.6rem;
  font-family: 'DM Sans', sans-serif; font-size: 0.68rem;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--forest-l); padding: 0.85rem 2rem;
  border-right: 1px solid rgba(200,216,192,0.15);
}
.trust-item:last-child { border-right: none; }
.trust-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--gold2); flex-shrink: 0; }

/* ── HERO ── */
.hero-section { display: grid; grid-template-columns: 55% 45%; min-height: 88vh; }
.hero-left {
  background: var(--cream);
  padding: 6rem 4rem 5rem 5rem;
  display: flex; flex-direction: column; justify-content: center;
  position: relative; overflow: hidden;
  border-right: 3px solid var(--forest);
}
.hero-left::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 4px; background: var(--gold2); }
.hero-tag {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: var(--forest); color: var(--forest-l);
  font-family: 'DM Sans', sans-serif; font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 0.3rem 0.9rem; width: fit-content; margin-bottom: 2rem;
}
.hero-title { font-family: 'Crimson Pro', serif; font-size: 3.8rem; font-weight: 300; line-height: 1.08; color: var(--brown); margin-bottom: 1.3rem; }
.hero-title em { font-style: italic; color: var(--forest); font-weight: 300; }
.hero-sub { font-size: 1.05rem; color: var(--brown2); max-width: 400px; margin-bottom: 2.5rem; line-height: 1.75; font-weight: 300; }
.btn-primary { display: inline-block; background: var(--forest); color: var(--cream); padding: 0.8rem 2rem; font-family: 'DM Sans', sans-serif; font-size: 0.8rem; text-decoration: none; letter-spacing: 0.1em; text-transform: uppercase; transition: background 0.25s; width: fit-content; }
.btn-primary:hover { background: var(--forest2); color: var(--cream); }
.hero-right {
  background: var(--forest);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 4rem; gap: 2rem; position: relative; overflow: hidden;
}
.hero-right::before { content: ''; position: absolute; top: -100px; right: -100px; width: 350px; height: 350px; border-radius: 50%; border: 60px solid rgba(200,216,192,0.08); }
.hero-right::after { content: ''; position: absolute; bottom: -80px; left: -80px; width: 250px; height: 250px; border-radius: 50%; border: 40px solid rgba(200,216,192,0.06); }
.hero-quote { position: relative; z-index: 2; text-align: center; max-width: 280px; }
.hero-divider { width: 50px; height: 1px; background: var(--gold2); margin: 0 auto 1.2rem; }
.hero-quote p { font-family: 'Crimson Pro', serif; font-style: italic; font-size: 1.1rem; color: var(--forest-l); line-height: 1.6; font-weight: 300; }
.hero-quote cite { display: block; font-family: 'DM Sans', sans-serif; font-size: 0.68rem; color: var(--gold3); margin-top: 0.7rem; font-style: normal; letter-spacing: 0.1em; text-transform: uppercase; }

/* ── SHARED ── */
.section-padded { padding: 5rem; }
.section-eyebrow { font-family: 'DM Sans', sans-serif; font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold); margin-bottom: 0.6rem; }
h2 { font-family: 'Crimson Pro', serif; font-size: 2.6rem; font-weight: 300; line-height: 1.2; color: var(--brown); margin-bottom: 0.5rem; }
h2 em { font-style: italic; color: var(--forest); }
.section-intro { font-size: 1rem; color: var(--brown2); max-width: 520px; line-height: 1.75; margin-bottom: 3rem; font-weight: 300; }

/* ── PRODUCTS ── */
.products-section { background: var(--cream2); }
.products-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 2rem; }
.btn-outline { display: inline-block; border: 1.5px solid var(--forest); color: var(--forest); padding: 0.6rem 1.4rem; font-family: 'DM Sans', sans-serif; font-size: 0.75rem; text-decoration: none; letter-spacing: 0.08em; text-transform: uppercase; transition: all 0.2s; }
.btn-outline:hover { background: var(--forest); color: var(--cream); }

/* WooCommerce product grid */
.woocommerce ul.products { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 1.2rem !important; margin: 0 !important; padding: 0 !important; list-style: none !important; }
.woocommerce ul.products li.product { background: var(--cream); border: 1px solid var(--cream3); overflow: hidden; transition: transform 0.25s, box-shadow 0.25s; margin: 0 !important; padding: 0 !important; }
.woocommerce ul.products li.product:hover { transform: translateY(-4px); box-shadow: 0 10px 28px rgba(26,58,26,0.12); }
.woocommerce ul.products li.product img { width: 100%; height: 180px; object-fit: cover; display: block; }
.woocommerce ul.products li.product .woocommerce-loop-product__title { font-family: 'Crimson Pro', serif; font-size: 1.1rem; font-weight: 400; color: var(--brown); padding: 1rem 1.1rem 0.3rem; margin: 0; }
.woocommerce ul.products li.product .price { font-family: 'Crimson Pro', serif; font-size: 1.1rem; color: var(--forest); padding: 0 1.1rem 0.8rem; display: block; }
.woocommerce ul.products li.product .button { display: block; width: calc(100% - 2.2rem); margin: 0 1.1rem 1.1rem; background: transparent; border: 1.5px solid var(--forest); color: var(--forest); padding: 0.5rem; font-family: 'DM Sans', sans-serif; font-size: 0.72rem; letter-spacing: 0.08em; text-transform: uppercase; text-align: center; cursor: pointer; transition: all 0.2s; text-decoration: none; }
.woocommerce ul.products li.product .button:hover { background: var(--forest); color: var(--cream); }

/* WooCommerce single product */
.woocommerce div.product { padding: 4rem 5rem; }
.woocommerce div.product .product_title { font-family: 'Crimson Pro', serif; font-size: 2.4rem; font-weight: 300; color: var(--brown); }
.woocommerce div.product p.price { font-family: 'Crimson Pro', serif; font-size: 1.6rem; color: var(--forest); }
.woocommerce div.product .single_add_to_cart_button { background: var(--forest) !important; color: var(--cream) !important; border: none !important; padding: 0.8rem 2rem !important; font-family: 'DM Sans', sans-serif !important; font-size: 0.8rem !important; letter-spacing: 0.1em !important; text-transform: uppercase !important; border-radius: 0 !important; }
.woocommerce div.product .single_add_to_cart_button:hover { background: var(--forest2) !important; }

/* WooCommerce cart & checkout */
.woocommerce table.shop_table { font-family: 'Crimson Pro', serif; }
.woocommerce .cart-collaterals .cart_totals h2,
.woocommerce #order_review_heading { font-family: 'Crimson Pro', serif; font-weight: 300; }
.woocommerce .checkout_coupon .button,
.woocommerce .wc-proceed-to-checkout .checkout-button { background: var(--forest) !important; color: var(--cream) !important; border-radius: 0 !important; font-family: 'DM Sans', sans-serif !important; letter-spacing: 0.08em !important; text-transform: uppercase !important; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea { border: 1px solid var(--cream3); border-bottom: 2px solid var(--forest); background: var(--cream2); font-family: 'Crimson Pro', serif; font-size: 1rem; border-radius: 0; }
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus { border-bottom-color: var(--gold2); outline: none; }

/* ── VALUES ── */
.values-section { background: var(--cream); }
.values-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: start; }
.values-visual { background: var(--forest); padding: 3rem; position: relative; overflow: hidden; }
.values-visual::before { content: ''; position: absolute; top: -60px; right: -60px; width: 220px; height: 220px; border-radius: 50%; border: 50px solid rgba(200,216,192,0.08); }
.values-visual-eyebrow { font-family: 'DM Sans', sans-serif; font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold3); margin-bottom: 0.8rem; }
.values-visual h3 { font-family: 'Crimson Pro', serif; font-size: 1.9rem; font-weight: 300; color: var(--cream); line-height: 1.25; margin-bottom: 1.2rem; }
.values-visual h3 em { font-style: italic; color: var(--gold3); }
.values-visual p { font-size: 0.95rem; color: var(--forest-l); line-height: 1.75; margin-bottom: 2rem; font-weight: 300; }
.cert-list { display: flex; flex-direction: column; gap: 0.8rem; }
.cert-item { display: flex; align-items: flex-start; gap: 0.8rem; }
.cert-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold2); flex-shrink: 0; margin-top: 0.55rem; }
.cert-text { font-size: 0.88rem; color: var(--forest-l); line-height: 1.5; font-weight: 300; }
.values-right { display: flex; flex-direction: column; gap: 1.3rem; padding-top: 0.5rem; }
.value-row { display: flex; gap: 1.2rem; align-items: flex-start; padding: 1.4rem; background: var(--cream2); border: 1px solid var(--cream3); border-left: 3px solid var(--forest); transition: transform 0.2s; }
.value-row:hover { transform: translateX(5px); }
.value-icon-wrap { width: 44px; height: 44px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 1.4rem; background: var(--forest-ll); }
.value-text-wrap h3 { font-family: 'Crimson Pro', serif; font-size: 1.15rem; font-weight: 400; color: var(--brown); margin-bottom: 0.25rem; }
.value-text-wrap p { font-size: 0.88rem; color: var(--brown2); line-height: 1.6; font-weight: 300; }

/* ── ABOUT ── */
.about-section { background: var(--cream2); display: grid; grid-template-columns: 1fr 1fr; }
.about-left { padding: 6rem 4rem 6rem 5rem; display: flex; flex-direction: column; justify-content: center; }
.about-left .section-eyebrow { color: var(--gold); }
.about-text { font-size: 1rem; color: var(--brown2); line-height: 1.8; margin-bottom: 1rem; font-weight: 300; }
.about-right { background: var(--forest); display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 5rem 4rem; gap: 2.5rem; position: relative; overflow: hidden; }
.about-right::after { content: '🍯'; position: absolute; right: -20px; bottom: -40px; font-size: 12rem; opacity: 0.06; line-height: 1; }
.blockquote { position: relative; padding: 2rem 2rem 2rem 2.5rem; background: rgba(255,255,255,0.07); border-left: 3px solid var(--gold2); }
.blockquote p { font-family: 'Crimson Pro', serif; font-style: italic; font-size: 1.3rem; color: var(--cream); line-height: 1.6; font-weight: 300; }
.blockquote cite { display: block; font-family: 'DM Sans', sans-serif; font-size: 0.68rem; color: var(--gold3); margin-top: 0.8rem; font-style: normal; letter-spacing: 0.1em; text-transform: uppercase; }
.founder-card { background: rgba(255,255,255,0.08); padding: 1.4rem; width: 100%; display: flex; gap: 1rem; align-items: center; border-left: 3px solid var(--gold2); }
.founder-avatar { width: 50px; height: 50px; border-radius: 50%; flex-shrink: 0; background: var(--forest2); border: 2px solid var(--gold2); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; }
.founder-name { font-family: 'Crimson Pro', serif; font-size: 1.1rem; color: var(--cream); font-weight: 400; }
.founder-title { font-family: 'DM Sans', sans-serif; font-size: 0.68rem; color: var(--gold3); margin-top: 0.2rem; letter-spacing: 0.08em; text-transform: uppercase; }

/* ── CONTACT ── */
.contact-section { background: var(--cream); }
.contact-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; }
.contact-form label { font-family: 'DM Sans', sans-serif; font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--brown2); display: block; margin-bottom: 0.35rem; }
.contact-form .form-group { margin-bottom: 1.1rem; }
.contact-form input[type=text],
.contact-form input[type=email],
.contact-form textarea { width: 100%; padding: 0.8rem 1rem; border: 1px solid var(--cream3); border-bottom: 2px solid var(--forest); background: var(--cream2); font-family: 'Crimson Pro', serif; font-size: 1rem; color: var(--brown); outline: none; transition: border-color 0.2s; border-radius: 0; }
.contact-form input:focus,
.contact-form textarea:focus { border-bottom-color: var(--gold2); background: var(--cream); }
.contact-form textarea { height: 130px; resize: vertical; }
.btn-send { background: var(--forest); color: var(--cream); border: none; padding: 0.85rem 2rem; font-family: 'DM Sans', sans-serif; font-size: 0.78rem; cursor: pointer; letter-spacing: 0.1em; text-transform: uppercase; transition: background 0.2s; margin-top: 0.5rem; }
.btn-send:hover { background: var(--forest2); }
.contact-info-col { display: flex; flex-direction: column; gap: 1.5rem; }
.contact-info-col h3 { font-family: 'Crimson Pro', serif; font-size: 1.6rem; font-weight: 300; color: var(--brown); margin-bottom: 0.4rem; }
.contact-info-col > p { font-size: 0.95rem; color: var(--brown2); line-height: 1.7; font-weight: 300; }
.contact-detail { display: flex; align-items: flex-start; gap: 1rem; padding: 1.1rem 1.3rem; background: var(--cream2); border-left: 3px solid var(--forest); }
.contact-detail-icon { font-size: 1.2rem; flex-shrink: 0; margin-top: 0.1rem; }
.contact-detail-label { font-family: 'DM Sans', sans-serif; font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--brown3); margin-bottom: 0.2rem; }
.contact-detail-val { font-size: 0.95rem; color: var(--brown); }

/* ── FOOTER ── */
.site-footer { background: var(--forest3); padding: 2.5rem 5rem; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; border-top: 3px solid var(--gold2); }
.footer-logo { font-family: 'Great Vibes', cursive; font-size: 1.8rem; color: var(--cream); }
.footer-nav ul { display: flex; gap: 2rem; list-style: none; margin: 0; padding: 0; }
.footer-nav a { font-family: 'DM Sans', sans-serif; font-size: 0.7rem; color: var(--forest-l); text-decoration: none; letter-spacing: 0.1em; text-transform: uppercase; transition: color 0.2s; }
.footer-nav a:hover { color: var(--gold3); }
.footer-copy { font-family: 'DM Sans', sans-serif; font-size: 0.68rem; color: var(--forest); letter-spacing: 0.05em; }

@keyframes fadeUp { from { opacity: 0; transform: translateY(18px); } to { opacity: 1; transform: translateY(0); } }
.hero-left > * { animation: fadeUp 0.7s ease both; }
