/*
Theme Name: Ffyngau
Theme URI: https://ffyngau.co.uk
Description: Bespoke Genesis child theme for Ffyngau, a premium functional mushroom brand from Wrexham, North Wales. Dark, earthy, premium.
Author: Alto for Maloney IT
Version: 1.0.0
Template: genesis
Text Domain: ffyngau
*/

:root {
	--c-bg:        #0C100C;
	--c-bg-alt:    #12180F;
	--c-panel:     #141B12;
	--c-forest:    #16301E;
	--c-forest-2:  #0F2416;
	--c-ink:       #070A07;
	--c-cream:     #EFE7D6;
	--c-cream-2:   #DCD3BE;
	--c-muted:     #9C9784;
	--c-copper:    #B87333;
	--c-copper-2:  #9C5F28;
	--c-amber:     #D9A24A;
	--c-amber-2:   #BE842F;
	--c-line:      rgba(239,231,214,0.12);
	--c-line-2:    rgba(239,231,214,0.22);
	--c-white:     #FFFFFF;

	--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, system-ui, sans-serif;
	--font-display: "Fraunces", Georgia, "Times New Roman", serif;

	--fs-xs: 0.8125rem;
	--fs-sm: 0.9375rem;
	--fs-base: 1.0625rem;
	--fs-lead: clamp(1.15rem, 0.6vw + 1rem, 1.4rem);
	--fs-h4: clamp(1.15rem, 0.7vw + 1rem, 1.4rem);
	--fs-h3: clamp(1.4rem, 1.4vw + 1rem, 1.95rem);
	--fs-h2: clamp(1.85rem, 2.6vw + 1rem, 2.7rem);
	--fs-h1: clamp(2.4rem, 4.4vw + 1rem, 3.9rem);

	--lh-tight: 1.1;
	--lh-snug: 1.3;
	--lh-normal: 1.65;
	--ls-tight: -0.02em;
	--ls-wide: 0.16em;

	--space-1: 0.25rem; --space-2: 0.5rem; --space-3: 0.75rem; --space-4: 1rem;
	--space-5: 1.5rem; --space-6: 2rem; --space-7: 3rem; --space-8: 4rem;
	--space-9: 6rem; --space-10: 8rem;

	--radius-sm: 4px; --radius: 8px; --radius-lg: 16px;
	--container: 1140px; --container-narrow: 760px; --container-wide: 1320px;
	--shadow: 0 10px 30px -12px rgba(0,0,0,0.6);
	--shadow-lg: 0 24px 60px -20px rgba(0,0,0,0.7);
	--ease: cubic-bezier(0.4,0,0.2,1); --dur: 220ms;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0; background: var(--c-bg); color: var(--c-cream);
	font-family: var(--font-sans); font-size: var(--fs-base); line-height: var(--lh-normal);
	-webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
h1, h2, h3, h4 { font-family: var(--font-display); color: var(--c-cream); line-height: var(--lh-snug); letter-spacing: var(--ls-tight); font-weight: 600; margin: 0 0 var(--space-4); }
h1 { font-size: var(--fs-h1); line-height: var(--lh-tight); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-h4); }
p { margin: 0 0 var(--space-4); }
a { color: var(--c-amber); text-decoration: none; transition: color var(--dur) var(--ease); }
a:hover { color: var(--c-copper); }
img { max-width: 100%; height: auto; display: block; }
strong { color: var(--c-white); font-weight: 600; }
ul, ol { line-height: var(--lh-normal); }

/* ---- Layout ---- */
.wrap { max-width: var(--container); margin-inline: auto; padding-inline: var(--space-5); }
.wrap-narrow { max-width: var(--container-narrow); margin-inline: auto; padding-inline: var(--space-5); }
.site-inner, .content-sidebar-wrap, .content { max-width: none; padding: 0; width: 100%; }
.section { padding-block: var(--space-9); }
@media (min-width:768px){ .section { padding-block: var(--space-10); } }
.section-alt { background: var(--c-bg-alt); }
.section-forest { background: linear-gradient(160deg, var(--c-forest) 0%, var(--c-forest-2) 100%); }
.section-panel { background: var(--c-panel); }
.wp-block-group.alignfull { width:100vw; max-width:100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }

/* singular page content gets the container automatically */
body:not(.home) .site-inner .entry-content > *,
body:not(.home) .site-inner .entry-header > * { } /* handled per-block via .wrap */

/* ---- Eyebrow / lead ---- */
.eyebrow { font-family: var(--font-sans); text-transform: uppercase; letter-spacing: var(--ls-wide); font-size: var(--fs-xs); font-weight: 700; color: var(--c-copper); margin-bottom: var(--space-4); display: inline-block; }
p.lead, .lead { font-size: var(--fs-lead); color: var(--c-cream-2); line-height: 1.5; }

/* ---- Header ---- */
.site-header { background: var(--c-ink); border-bottom: 1px solid var(--c-line); position: sticky; top: 0; z-index: 100; }
.site-header .wrap { display: flex; align-items: center; justify-content: space-between; gap: var(--space-5); padding-block: var(--space-4); }
.site-title { font-family: var(--font-display); font-size: 1.6rem; font-weight: 600; margin: 0; letter-spacing: var(--ls-tight); }
.site-title a { color: var(--c-cream); }
.site-title a:hover { color: var(--c-amber); }
.site-title .dot { color: var(--c-copper); }
.nav-primary ul { display: flex; gap: var(--space-5); list-style: none; margin: 0; padding: 0; align-items: center; }
.nav-primary a { color: var(--c-cream-2); font-size: var(--fs-sm); font-weight: 500; }
.nav-primary a:hover, .nav-primary .current-menu-item > a { color: var(--c-amber); }
.nav-primary .menu-item-has-children { position: relative; }
.nav-primary .sub-menu { position: absolute; top: 100%; left: 0; background: var(--c-panel); border: 1px solid var(--c-line); border-radius: var(--radius); padding: var(--space-3); min-width: 210px; flex-direction: column; gap: var(--space-1); display: none; box-shadow: var(--shadow); z-index: 120; }
.nav-primary .menu-item-has-children:hover > .sub-menu, .nav-primary .sub-menu.is-open { display: flex; }
.nav-primary .sub-menu a { display: block; padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm); }
.nav-primary .sub-menu a:hover { background: var(--c-forest); color: var(--c-amber); }
.menu-toggle { display: none; background: transparent; border: 1px solid var(--c-line-2); color: var(--c-cream); border-radius: var(--radius-sm); padding: var(--space-2) var(--space-3); font-size: var(--fs-sm); cursor: pointer; }
@media (max-width: 900px){
	.menu-toggle { display: inline-block; }
	.nav-primary { display: none; flex-basis: 100%; }
	.nav-primary.is-open { display: block; }
	.nav-primary ul { flex-direction: column; align-items: flex-start; gap: var(--space-2); width: 100%; padding-top: var(--space-4); }
	.nav-primary .sub-menu { position: static; display: flex; border: 0; box-shadow: none; padding-left: var(--space-4); background: transparent; }
	.site-header .wrap { flex-wrap: wrap; }
}

/* ---- Hero ---- */
.hero, .page-hero {
	position: relative; background: var(--c-ink); color: var(--c-cream); overflow: hidden;
	background-image: radial-gradient(circle at 78% 18%, rgba(184,115,51,0.16), transparent 46%), linear-gradient(165deg, #0B140D 0%, #0A0D09 60%, var(--c-ink) 100%);
}
.hero { padding-block: clamp(var(--space-9), 12vw, 9rem); }
.page-hero { padding-block: var(--space-9); }
.hero h1 { max-width: 18ch; margin-bottom: var(--space-5); }
.hero .lead, .page-hero .lead { max-width: 60ch; color: rgba(239,231,214,0.86); margin-bottom: var(--space-6); }
.hero .eyebrow, .page-hero .eyebrow { color: var(--c-amber); }
.page-hero h1 { max-width: 22ch; }
.hero-actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }

/* ---- Buttons ---- */
.wp-block-button__link, .btn, .button {
	display: inline-block; background: var(--c-amber); color: var(--c-ink) !important; font-family: var(--font-sans);
	font-weight: 700; font-size: var(--fs-sm); letter-spacing: 0.01em; padding: var(--space-3) var(--space-6);
	border-radius: var(--radius-sm); border: 0; cursor: pointer; transition: background var(--dur) var(--ease), transform var(--dur) var(--ease); text-decoration: none;
}
.wp-block-button__link:hover, .btn:hover, .button:hover { background: var(--c-copper); color: var(--c-ink) !important; transform: translateY(-1px); }
.wp-block-button.is-style-outline .wp-block-button__link, .btn-outline {
	background: transparent; color: var(--c-cream) !important; border: 1px solid var(--c-line-2);
}
.wp-block-button.is-style-outline .wp-block-button__link:hover, .btn-outline:hover { background: transparent; border-color: var(--c-amber); color: var(--c-amber) !important; }

/* ---- Cards / grids ---- */
.feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap: var(--space-5); margin-top: var(--space-6); }
.card { background: var(--c-panel); border: 1px solid var(--c-line); border-top: 3px solid var(--c-copper); border-radius: var(--radius); padding: var(--space-6); transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); height: 100%; }
.card:hover { transform: translateY(-3px); border-color: var(--c-line-2); box-shadow: var(--shadow); }
.card h3 { font-size: var(--fs-h4); margin-bottom: var(--space-3); color: var(--c-cream); }
.card p:last-child { margin-bottom: 0; }
.card .eyebrow { color: var(--c-amber); }
.card-link { color: var(--c-amber); font-weight: 600; display: inline-flex; gap: var(--space-2); margin-top: var(--space-3); }
.card-link::after { content: "\2192"; transition: transform var(--dur) var(--ease); }
.card-link:hover::after { transform: translateX(3px); }

/* product highlight strip */
.product-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: var(--space-5); margin-top: var(--space-6); }

/* ---- Stat / spec rows ---- */
.spec-list { list-style: none; margin: var(--space-5) 0 0; padding: 0; display: grid; gap: var(--space-2); }
.spec-list li { padding-left: var(--space-5); position: relative; }
.spec-list li::before { content: "\2022"; color: var(--c-copper); position: absolute; left: var(--space-2); font-weight: 700; }

/* ---- CTA banner ---- */
.cta-banner { background: linear-gradient(160deg, var(--c-forest) 0%, var(--c-forest-2) 100%); border: 1px solid var(--c-line); border-radius: var(--radius-lg); padding: clamp(var(--space-6), 5vw, var(--space-9)); text-align: center; }
.cta-banner h2 { margin-bottom: var(--space-3); }
.cta-banner .lead { margin-left: auto; margin-right: auto; max-width: 52ch; }

/* ---- Disclaimer / supplement note ---- */
.disclaimer { background: var(--c-bg-alt); border: 1px solid var(--c-line); border-left: 3px solid var(--c-copper); border-radius: var(--radius-sm); padding: var(--space-5); font-size: var(--fs-sm); color: var(--c-muted); }
.disclaimer strong { color: var(--c-cream-2); }

/* ---- Email capture / forms ---- */
.signup { background: var(--c-panel); border: 1px solid var(--c-line); border-radius: var(--radius-lg); padding: clamp(var(--space-6), 5vw, var(--space-8)); }
.wpforms-container input[type=text], .wpforms-container input[type=email], .wpforms-container textarea {
	background: var(--c-bg) !important; border: 1px solid var(--c-line-2) !important; color: var(--c-cream) !important;
	border-radius: var(--radius-sm) !important; padding: var(--space-3) !important; font-family: var(--font-sans) !important;
}
.wpforms-container input::placeholder, .wpforms-container textarea::placeholder { color: var(--c-muted) !important; }
.wpforms-container button[type=submit] { background: var(--c-amber) !important; color: var(--c-ink) !important; border: 0 !important; font-weight: 700 !important; border-radius: var(--radius-sm) !important; padding: var(--space-3) var(--space-6) !important; cursor: pointer; }
.wpforms-container button[type=submit]:hover { background: var(--c-copper) !important; }
.wpforms-field-label { color: var(--c-cream-2) !important; }

/* ---- Tables ---- */
.wp-block-table table { width: 100%; border-collapse: collapse; }
.wp-block-table td, .wp-block-table th { border: 1px solid var(--c-line); padding: var(--space-3) var(--space-4); text-align: left; }
.wp-block-table th { color: var(--c-cream); background: var(--c-bg-alt); }

/* ---- Footer ---- */
.site-footer { background: var(--c-ink); border-top: 1px solid var(--c-line); padding-block: var(--space-8) var(--space-6); color: var(--c-muted); font-size: var(--fs-sm); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: var(--space-7); }
@media (max-width:768px){ .footer-grid { grid-template-columns: 1fr; gap: var(--space-6); } }
.site-footer h4 { font-family: var(--font-sans); text-transform: uppercase; letter-spacing: var(--ls-wide); font-size: var(--fs-xs); color: var(--c-cream-2); margin-bottom: var(--space-4); }
.site-footer ul { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--space-2); }
.site-footer a { color: var(--c-muted); }
.site-footer a:hover { color: var(--c-amber); }
.footer-brand strong { font-family: var(--font-display); font-size: 1.4rem; color: var(--c-cream); display: block; margin-bottom: var(--space-3); }
.footer-legal { margin-top: var(--space-7); padding-top: var(--space-5); border-top: 1px solid var(--c-line); font-size: var(--fs-xs); color: var(--c-muted); }

/* ---- WooCommerce minimal (shop hidden for now) ---- */
.woocommerce .wrap-narrow, .woocommerce-page .entry-content { color: var(--c-cream); }
.woocommerce ul.products { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: var(--space-5); list-style: none; padding: 0; }
.woocommerce ul.products li.product { background: var(--c-panel); border: 1px solid var(--c-line); border-radius: var(--radius); padding: var(--space-5); }
.woocommerce .price, .woocommerce-Price-amount { color: var(--c-amber); font-weight: 700; }

/* skip link */
.skip-link { position: absolute; left: -9999px; }
.skip-link:focus { left: var(--space-4); top: var(--space-4); background: var(--c-amber); color: var(--c-ink); padding: var(--space-2) var(--space-4); z-index: 200; border-radius: var(--radius-sm); }

/* print */
@media print { .site-header, .site-footer, .menu-toggle { display: none; } body { background:#fff; color:#000; } }
