/*
Theme Name: NOUR Labs
Theme URI: https://nour-labs.com
Author: NOUR Labs
Description: NOUR Labs — research-grade peptide store. Custom WooCommerce theme (cream/ink/red, Manrope + Space Mono). Pairs with the woocommerce-products.csv import.
Version: 1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
WC requires at least: 7.0
WC tested up to: 9.0
License: GPL-2.0-or-later
Text Domain: nour
*/

:root{
  --bg:#f4f1e9; --bg2:#faf7f1; --ink:#14140f; --ink2:#3a382f; --mut:#807961;
  --line:#e7e1d2; --line2:#efe9da; --card:#fff; --red:#b41e1e; --ok:#1f7a4d;
  --sans:'Manrope',system-ui,sans-serif; --mono:'Space Mono',ui-monospace,monospace;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.5}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:clamp(48px,7vw,92px) 0}
.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--mut)}
.eyebrow .dot,.wm .dot{color:var(--red)}
h1,h2,h3{letter-spacing:-0.03em;line-height:1.04;font-weight:800}
.h1{font-size:clamp(40px,7vw,78px)}
.h2{font-size:clamp(28px,4.4vw,48px)}
.lead{font-size:clamp(16px,1.7vw,19px);color:var(--ink2);line-height:1.6;max-width:62ch}
.wm{font-family:var(--sans);font-weight:800;letter-spacing:-0.05em}

/* header */
.nav{position:sticky;top:0;z-index:50;background:rgba(244,241,233,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav-brand{display:flex;align-items:baseline;gap:8px}
.nav-brand .wm{font-size:22px}
.nav-brand .labs{font-family:var(--mono);font-size:9px;letter-spacing:.34em;color:var(--mut)}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none}
.nav-links a{font-weight:600;font-size:14.5px;color:var(--ink2)}
.nav-links a:hover{color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-cart{position:relative;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:9px;border:1.5px solid var(--line);background:#fff;color:var(--ink)}
.nav-cart:hover{border-color:var(--ink)}
.nav-cart .cnt{position:absolute;top:-7px;right:-7px;min-width:19px;height:19px;padding:0 5px;border-radius:10px;background:var(--red);color:#fff;font-family:var(--mono);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}
.btn,.button,a.button,button.button,.woocommerce a.button,.woocommerce button.button,.woocommerce #respond input#submit,.woocommerce input.button{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--sans);font-weight:700;font-size:14.5px;
  padding:13px 22px;border-radius:9px;border:1.5px solid transparent;cursor:pointer;transition:.18s;background:var(--ink);color:var(--bg2);line-height:1}
.btn:hover,.button:hover,.woocommerce a.button:hover,.woocommerce button.button:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(20,20,15,.22);background:var(--ok);color:#fff}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink)}

/* hero */
.hero{border-bottom:1px solid var(--line);overflow:hidden}
.hero-in{text-align:center;padding:clamp(40px,6vw,76px) 24px clamp(10px,2vw,20px);max-width:900px;margin:0 auto}
.hero .idx{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--mut);display:flex;gap:14px;align-items:center;justify-content:center}
.hero .idx span{width:46px;height:1px;background:var(--line)}
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg2)}
.trust .wrap{display:flex;gap:18px 34px;justify-content:space-between;flex-wrap:wrap;padding:16px 24px;font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;color:var(--ink2)}

/* WooCommerce product grid */
.woocommerce ul.products{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:0;padding:0;list-style:none}
.woocommerce ul.products li.product{margin:0;width:auto;float:none;background:#fff;border:1px solid var(--line);border-radius:11px;overflow:hidden;transition:.2s;text-align:left}
.woocommerce ul.products li.product:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(20,20,15,.12);border-color:#dcd4c2}
.woocommerce ul.products li.product a img{margin:0;background:linear-gradient(170deg,#f1eee6,#fff);padding:18px 10px 6px}
.woocommerce ul.products li.product .woocommerce-loop-product__title{font-weight:800;font-size:16px;letter-spacing:-0.02em;padding:14px 16px 2px;color:var(--ink)}
.woocommerce ul.products li.product .price{display:block;padding:0 16px;font-family:var(--sans)!important;font-weight:800;font-size:18px;color:var(--ink)!important;margin:6px 0}
.woocommerce ul.products li.product .price del{color:var(--mut)!important;font-weight:400;opacity:.6}
.woocommerce ul.products li.product .button{margin:8px 16px 18px}
.woocommerce .star-rating{display:none}

/* single product + cart + checkout */
.woocommerce div.product .product_title{font-size:clamp(32px,5vw,52px);font-weight:800;letter-spacing:-0.03em}
.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--ink);font-family:var(--sans);font-weight:800;font-size:26px}
.woocommerce-message,.woocommerce-info,.woocommerce-error{border-top-color:var(--ok)}
.woocommerce #content,.woocommerce-page{}
.nour-shell{max-width:var(--maxw);margin:0 auto;padding:clamp(28px,4vw,52px) 24px}

/* footer */
.foot{background:var(--ink);color:#cfc8b8;padding:56px 0 28px;margin-top:40px}
.foot a{color:#cfc8b8}.foot a:hover{color:#fff}
.foot .wrap{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot .wm{font-size:26px;color:#faf7f1}
.foot .ruo{max-width:var(--maxw);margin:34px auto 0;padding:20px 24px 0;border-top:1px solid #2a2722;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:#8a8270}

@media(max-width:860px){.nav-links{display:none}.woocommerce ul.products{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.woocommerce ul.products{grid-template-columns:1fr}}

/* age gate */
#nour-agegate{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;padding:22px;background:rgba(20,20,15,.55);backdrop-filter:blur(8px)}
#nour-agegate .ag-card{background:#faf7f1;border:1px solid var(--line);border-radius:16px;max-width:400px;width:100%;text-align:center;padding:40px 32px 30px;box-shadow:0 30px 80px -20px rgba(20,20,15,.5)}
#nour-agegate .ag-wm{font-weight:800;letter-spacing:-0.055em;font-size:46px;color:var(--ink);display:flex;justify-content:center;align-items:baseline;gap:11px;line-height:1}
#nour-agegate .ag-wm span{color:var(--red)}
#nour-agegate .ag-wm em{font-family:var(--mono);font-style:normal;font-size:13px;letter-spacing:.34em;color:var(--mut)}
#nour-agegate .ag-h{font-size:21px;font-weight:800;letter-spacing:-0.02em;margin:26px 0 24px;line-height:1.25}
#nour-agegate .ag-actions{display:flex;gap:12px}
#nour-agegate .ag-btn{flex:1;font-family:var(--sans);font-weight:700;font-size:15px;border-radius:9px;padding:14px;cursor:pointer;border:1.5px solid transparent}
#nour-agegate .ag-yes{background:var(--ink);color:#faf7f1}
#nour-agegate .ag-no{background:#fff;color:var(--ink2);border-color:var(--line)}

/* ===== Ported static-site components (homepage parity) ===== */
.display{font-weight:800;letter-spacing:-0.045em;line-height:.94}
.h1.display{font-size:clamp(42px,7vw,86px)}
.btn-light{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-light:hover{border-color:var(--ink);background:#fff;color:var(--ink);box-shadow:0 8px 20px rgba(20,20,15,.10)}
.btn-sm{padding:9px 15px;font-size:13px}
.btn-onlight{background:#fff;color:#1a1814}
.eyebrow .dot{color:var(--red)}
.rule-head{display:flex;align-items:center;gap:16px;margin-bottom:26px}
.rule-head .idx{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--mut)}
.rule-head .ln{flex:1;height:1px;background:var(--line)}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px}
.pad{padding:clamp(20px,3vw,34px)}
.grid{display:grid;gap:20px}
.g2{grid-template-columns:1fr 1fr}
@media(max-width:860px){.g2{grid-template-columns:1fr}}
.feat{display:flex;gap:15px;align-items:flex-start}
.feat .ic{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#fff;border:1px solid var(--line);color:#5b5443}
.feat h3{font-size:17px;font-weight:800;letter-spacing:-0.01em}
.feat p{font-size:14px;color:var(--ink2);margin-top:4px;line-height:1.5}
.badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#2f6d44;background:#e9f4ed;border:1px solid #c7e4d2;border-radius:5px;padding:5px 11px}

/* hero vial lineup */
.lineup{position:relative;display:flex;align-items:flex-end;justify-content:center;max-width:1400px;margin:0 auto;padding:0 12px 18px}
.lineup-v:hover{transform:translateY(-18px);z-index:20;filter:drop-shadow(0 24px 22px rgba(20,20,15,.30))}
@media(max-width:700px){
  .lineup{justify-content:center;align-items:flex-end;padding:0 8px 16px;overflow:hidden}
  .lineup-v{margin:0 -1.4%!important}
  .lineup-v img{height:clamp(104px,29vw,165px)!important}
}
@media(max-width:380px){.lineup-v img{height:clamp(92px,26vw,140px)!important}}

/* ===== Shop grid polish: full vial visible, aligned cards ===== */
.woocommerce ul.products li.product{display:flex;flex-direction:column;height:100%}
.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product a img.attachment-large{
  height:250px!important;width:100%!important;object-fit:contain!important;
  background:linear-gradient(170deg,#f1eee6,#fff);padding:16px 12px;margin:0}
.woocommerce ul.products li.product .woocommerce-loop-product__title{
  min-height:2.8em;display:flex;align-items:flex-start;font-size:15px;line-height:1.25;padding:14px 16px 0}
.woocommerce ul.products li.product .price{padding:0 16px;margin:8px 0 0}
.woocommerce ul.products li.product .button{margin:14px 16px 18px;margin-top:auto;align-self:flex-start}

/* ===== Single product page polish ===== */
.woocommerce div.product{padding-top:8px}
.woocommerce div.product .woocommerce-product-gallery{margin-bottom:24px}
.woocommerce div.product .woocommerce-product-gallery img{
  max-height:540px!important;width:auto!important;margin:0 auto!important;object-fit:contain!important;
  background:linear-gradient(170deg,#f1eee6,#fff);border-radius:14px}
.woocommerce div.product .product_title{margin-bottom:8px}
.single_add_to_cart_button,
.woocommerce div.product form.cart .button,
.woocommerce a.button.alt,.woocommerce button.button.alt,.woocommerce input.button.alt{
  background:var(--ink)!important;color:var(--bg2)!important;border-color:var(--ink)!important}
.single_add_to_cart_button:hover,.woocommerce a.button.alt:hover{background:var(--ok)!important;color:#fff!important}
.woocommerce div.product form.cart .quantity .qty{padding:11px;border:1.5px solid var(--line);border-radius:9px;width:64px;background:#fff}
.btn,.button{white-space:nowrap}

/* ===== Shop grid hard-fix: clean 3-col grid, no WC float/clearfix cells ===== */
.woocommerce ul.products,.woocommerce-page ul.products{
  display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:22px!important;margin:0!important;padding:0!important}
.woocommerce ul.products:before,.woocommerce ul.products:after,
.woocommerce-page ul.products:before,.woocommerce-page ul.products:after{content:none!important;display:none!important}
.woocommerce ul.products li.product,.woocommerce-page ul.products li.product{
  width:auto!important;max-width:none!important;float:none!important;clear:none!important;margin:0!important}
.woocommerce ul.products li.product a img{height:230px!important;width:100%!important;object-fit:contain!important}
@media(max-width:900px){.woocommerce ul.products,.woocommerce-page ul.products{grid-template-columns:repeat(2,minmax(0,1fr))!important}}
@media(max-width:540px){.woocommerce ul.products,.woocommerce-page ul.products{grid-template-columns:1fr!important}}

/* ===== Single product: COA card ===== */
.nour-coa{margin:38px 0 8px;clear:both}
.coa-card{padding:clamp(22px,3vw,32px)}
.coa-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.coa-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 32px}
.coa-row{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--line2)}
.coa-k{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--mut)}
.coa-v{font-size:14px;font-weight:600;color:var(--ink);text-align:right}
.coa-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}
.coa-note{color:var(--ink2);font-size:15px;line-height:1.6;max-width:62ch}
.coa-progress{background:var(--bg2)}
@media(max-width:680px){.coa-grid{grid-template-columns:1fr}}

/* ===== Member rewards banner (shop + product + home) — bold/compact ===== */
.nour-rr{background:var(--red);border-radius:12px;padding:20px clamp(18px,2.4vw,28px);color:#fff;max-width:1180px;margin:0 auto 24px;box-shadow:0 14px 30px -16px rgba(180,30,30,.5)}
.nour-rr--home{margin:0 auto}
.nour-rr-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#ffd9d2}
.nour-rr-title{font-family:var(--sans);font-size:clamp(20px,2.4vw,27px);font-weight:800;letter-spacing:-.02em;line-height:1.08;margin:7px 0 5px;color:#fff}
.nour-rr-title span{background:#fff;color:var(--red);padding:0 8px;border-radius:6px;display:inline-block}
.nour-rr-sub{font-size:13px;color:#fbe3df;margin:0 0 15px;max-width:56ch}
.nour-rr-grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid rgba(255,255,255,.26);border-bottom:1px solid rgba(255,255,255,.26)}
.nour-rr-item{padding:12px 18px;border-left:1px solid rgba(255,255,255,.26)}
.nour-rr-item:first-child{border-left:0;padding-left:0}
.nour-rr-num{font-family:var(--sans);font-size:26px;font-weight:800;letter-spacing:-.02em;line-height:1;color:#fff}
.nour-rr-num span{font-size:13px;font-weight:700;color:#ffd9d2}
.nour-rr-lbl{margin-top:5px;font-size:11.5px;color:#fbe3df;line-height:1.3}
.nour-rr-cta{display:inline-block;margin-top:15px;background:var(--ink);color:#fff;font-weight:700;font-size:13px;padding:10px 18px;border-radius:8px;text-decoration:none}
.nour-rr-cta:hover{background:#000}
@media(max-width:620px){.nour-rr-grid{grid-template-columns:1fr 1fr}.nour-rr-item{padding:12px 14px}.nour-rr-item:nth-child(odd){border-left:0;padding-left:0}.nour-rr-item:nth-child(3),.nour-rr-item:nth-child(4){border-top:1px solid rgba(255,255,255,.26)}}

/* ===== Language switch ===== */
.lang-switch{display:inline-flex;border:1.5px solid var(--line);border-radius:9px;overflow:hidden;background:#fff}
.lang-btn{appearance:none;border:0;background:transparent;cursor:pointer;font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.05em;color:var(--mut);padding:9px 11px;line-height:1}
.lang-btn+.lang-btn{border-left:1.5px solid var(--line)}
.lang-btn.active{background:var(--ink);color:#fff}
.lang-btn:hover:not(.active){color:var(--ink)}

/* ===== Mobile hamburger + menu ===== */
.nav-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;border:1.5px solid var(--line);border-radius:9px;background:#fff;cursor:pointer;padding:0}
.nav-burger span{display:block;width:18px;height:2px;background:var(--ink);margin:0 auto;transition:transform .2s,opacity .2s}
.nav-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.is-open span:nth-child(2){opacity:0}
.nav-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;flex-direction:column;padding:8px 24px 18px;border-top:1px solid var(--line);background:rgba(244,241,233,.98)}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:13px 4px;font-weight:600;font-size:16px;color:var(--ink2);border-bottom:1px solid var(--line)}
.mobile-menu a:hover{color:var(--ink)}
.mobile-menu .mm-shop{color:#fff;background:var(--ink);border:0;border-radius:10px;text-align:center;margin-top:12px}
.mobile-menu .mm-lang{margin-top:16px;align-self:flex-start}
@media(max-width:860px){.nav-burger{display:flex}.nav-shop{display:none}.nav-cta>.lang-switch{display:none}}

/* ===== Hide Google Translate UI (banner bar + tooltips) ===== */
iframe.skiptranslate,.goog-te-banner-frame,.VIpgJd-ZVi9od-ORHb-OEVmcd{display:none!important;visibility:hidden!important}
body{top:0!important;position:static!important}
.goog-te-gadget{font-size:0!important;height:0;overflow:hidden}
#goog-gt-tt,.goog-te-balloon-frame,.goog-tooltip{display:none!important}
.goog-text-highlight{background:none!important;box-shadow:none!important;color:inherit!important}
