/* ==========================================================================
   VenuesLive Procurement — assets/css/style.css
   Single compiled stylesheet. Sections:
     1. Base reset
     2. Typography
     3. Layout utilities
     4. Header (fixed, shrink-on-scroll)
     5. Navigation & hamburger drawer
     6. Footer
     7. Page templates (page header, page content)
     8. Tender table (homepage shortcode)
     9. Tender single view
    10. Forms (Gravity Forms overrides)
    11. Responsive breakpoints
   ========================================================================== */

/* --------------------------------------------------------------------------
   1. Base reset
   -------------------------------------------------------------------------- */

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

body {
	margin: 0;
}

img,
svg,
video {
	max-width: 100%;
	height: auto;
}

/* --------------------------------------------------------------------------
   2. Typography
   -------------------------------------------------------------------------- */

a {
	color: var(--wp--preset--color--primary);
	text-decoration: underline;
}

a:hover {
	color: var(--wp--preset--color--accent);
}

h1, h2, h3, h4, h5, h6 {
	margin-top: 0;
}

h1 {
	font-family: var(--wp--preset--font-family--body);
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.2;
}

h2 {
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.75rem;
	font-weight: 700;
	line-height: 1.2;
}

h3 {
	font-family: var(--wp--preset--font-family--body);
	font-size: 1.125rem;
	font-weight: 700;
	line-height: 1.2;
}

h4 {
	font-family: var(--wp--preset--font-family--body);
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.2;
}

h5 {
	font-family: var(--wp--preset--font-family--body);
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 1.3;
}

h6 {
	font-family: var(--wp--preset--font-family--body);
	font-size: 0.75rem;
	font-weight: 700;
	line-height: 1.3;
}

/* --------------------------------------------------------------------------
   2b. Buttons
   -------------------------------------------------------------------------- */

/* Default button — outline style matching venueslive-staging */
.wp-block-button__link,
.wp-element-button {
	background-color: transparent;
	border: 2px solid var(--wp--preset--color--primary);
	color: var(--wp--preset--color--primary);
	text-decoration: none;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.wp-block-button__link:hover,
.wp-element-button:hover {
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--bg);
}

/* --------------------------------------------------------------------------
   3. Layout utilities
   -------------------------------------------------------------------------- */

/* Sticky footer — page fills full viewport height so footer stays at the bottom
   on short pages. The main element grows to consume all remaining space. */
.wp-site-blocks {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	padding-top: var(--header-height, 80px);
}

.site-main {
	flex: 1;
	padding-inline: max(2rem, calc((100% - 1310px) / 2));
}

/* --------------------------------------------------------------------------
   4. Header (fixed, shrink-on-scroll)
   -------------------------------------------------------------------------- */

/* SVG logo — needs height-based sizing; SVGs have no intrinsic dimensions.
   The anchor must be flex so the img fills the explicit container height. */
.wp-block-site-logo {
	flex-shrink: 0;
}

.wp-block-site-logo a {
	display: flex;
	align-items: center;
	line-height: 0;
	height: 100%;
}

.wp-block-site-logo img {
	display: block;
	width: auto;
	height: 100%;
	max-width: 200px;
	object-fit: contain;
	object-position: left center;
}

/* Explicit container height — gives the SVG img a reference dimension */
.site-header .wp-block-site-logo {
	height: 44px;
}

.site-header {
	position: fixed !important;
	top: var(--wp-admin--admin-bar--height, 0px) !important;
	left: 0 !important;
	right: 0 !important;
	z-index: 100;
	width: 100%;
	background-color: var(--wp--preset--color--primary);
	padding-inline: max(2rem, calc((100% - 1310px) / 2));
	height: 80px;
	display: flex !important;
	align-items: center;
	justify-content: space-between;
	transition: height 0.3s ease, box-shadow 0.3s ease;
}

.site-header.is-shrunk {
	height: 60px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

/* --------------------------------------------------------------------------
   5. Navigation & hamburger drawer
   -------------------------------------------------------------------------- */

/* Desktop nav links — white on dark header */
.site-header .wp-block-navigation a,
.site-header .wp-block-navigation .wp-block-navigation-item__content {
	color: var(--wp--preset--color--bg);
	text-decoration: none;
	font-weight: 700;
	font-size: var(--wp--preset--font-size--sm);
	padding-inline: 0.75rem;
}

.site-header .wp-block-navigation a:hover,
.site-header .wp-block-navigation .wp-block-navigation-item__content:hover {
	color: var(--wp--preset--color--accent);
}

/* Dynamic greeting — non-clickable, visually subdued */
.site-header .vl-nav-greeting .wp-block-navigation-item__content {
	opacity: 0.7;
	font-weight: 400;
	pointer-events: none;
	cursor: default;
}

/* Scroll lock — scoped by .is-menu-open so safe outside the media query */
body:has(.wp-block-navigation__responsive-container.is-menu-open) {
	overflow: hidden;
}

/* Hamburger breakpoint override: WP default shows full nav above 782px.
   Override that range so burger appears from 782px up to 1100px. */
@media (min-width: 783px) and (max-width: 1100px) {
	.site-header .wp-block-navigation__responsive-container:not(.is-menu-open) {
		display: none !important;
	}
	.site-header .wp-block-navigation__responsive-container-open {
		display: flex !important;
		color: var(--wp--preset--color--bg);
	}
}

/* Hamburger icon and close button colours */
.site-header .wp-block-navigation__responsive-container-open,
.site-header .wp-block-navigation__responsive-container-open svg {
	color: var(--wp--preset--color--bg);
	fill: var(--wp--preset--color--bg);
}

.site-header .wp-block-navigation__responsive-container-open:hover {
	color: var(--wp--preset--color--accent);
}

@media (max-width: 1100px) {

	/* Backdrop */
	.site-header .wp-block-navigation__responsive-close {
		position: fixed !important;
		inset: 0 !important;
		background: rgba(0, 0, 0, 0.5) !important;
		z-index: 9998 !important;
	}

	/* Container — transparent full-viewport wrapper */
	.site-header .wp-block-navigation__responsive-container.is-menu-open {
		position: fixed !important;
		inset: 0 !important;
		width: 100% !important;
		height: 100% !important;
		background: none !important;
		z-index: 9998 !important;
		box-shadow: none !important;
		padding: 0 !important;
		overflow: visible !important;
	}

	/* Drawer panel — slides in from right */
	.site-header .wp-block-navigation__responsive-dialog {
		position: fixed !important;
		top: var(--wp-admin--admin-bar--height, 0px) !important;
		right: 0 !important;
		bottom: 0 !important;
		left: auto !important;
		width: 300px !important;
		max-width: 85vw !important;
		background: var(--wp--preset--color--primary) !important;
		z-index: 9999 !important;
		overflow-y: auto !important;
		padding: var(--header-height, 80px) 2rem 2rem !important;
		box-shadow: -4px 0 24px rgba(0, 0, 0, 0.3) !important;
		animation: site-drawer-in 0.25s ease-out !important;
		display: flex !important;
		flex-direction: column !important;
	}

	@keyframes site-drawer-in {
		from { transform: translateX(100%); }
		to   { transform: translateX(0); }
	}

	/* Close button — absolute inside dialog so it slides with the drawer */
	.site-header .wp-block-navigation__responsive-container-close {
		position: absolute !important;
		top: 0 !important;
		right: 0 !important;
		bottom: auto !important;
		left: auto !important;
		width: 4rem !important;
		height: var(--header-height, 80px) !important;
		margin: 0 !important;
		padding: 0 !important;
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		z-index: 1 !important;
		background: transparent !important;
		border: 0 !important;
		cursor: pointer !important;
		color: var(--wp--preset--color--bg) !important;
	}

	/* Nav container — stack items vertically in drawer */
	.site-header .is-menu-open .wp-block-navigation__container {
		flex-direction: column !important;
		align-items: stretch !important;
		width: 100% !important;
		gap: 0 !important;
	}

	.site-header .is-menu-open .wp-block-navigation-item {
		width: 100% !important;
	}

}

/* Nav item links in open drawer */
.site-header .is-menu-open .wp-block-navigation-item__content {
	display: block !important;
	width: 100% !important;
	padding: 0.875rem 0 !important;
	text-align: left !important;
	color: var(--wp--preset--color--bg) !important;
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

/* --------------------------------------------------------------------------
   6. Footer
   -------------------------------------------------------------------------- */

.site-footer {
	padding: 1.25rem 2rem;
}

.site-footer__copy {
	font-size: var(--wp--preset--font-size--xs);
	margin: 0;
	opacity: 0.7;
}

/* --------------------------------------------------------------------------
   7. Page templates
   -------------------------------------------------------------------------- */

.page-header {
	padding: 3rem 0 1.5rem;
}

.page-header__title,
.page-header .wp-block-post-title,
.page-header .wp-block-heading {
	margin: 0;
	color: var(--wp--preset--color--primary);
}

.page-content {
	padding: 0 0 3rem;
}

/* --------------------------------------------------------------------------
   8. Tender table (homepage — [open_tenders_table] shortcode output)
   -------------------------------------------------------------------------- */

.tender-table__heading {
	margin-top: 2.5rem;
	margin-bottom: 1rem;
	font-size: var(--wp--preset--font-size--xl);
	color: var(--wp--preset--color--heading);
}

.tender-table__heading:first-child {
	margin-top: 0;
}

.tender-table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--wp--preset--font-size--sm);
	margin-bottom: 3rem;
}

.tender-table thead {
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--bg);
}

.tender-table th {
	padding: 0.875rem 1rem;
	text-align: left;
	font-weight: 700;
	font-size: var(--wp--preset--font-size--xs);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	white-space: nowrap;
}

.tender-table td {
	padding: 0.875rem 1rem;
	border-bottom: 1px solid var(--wp--preset--color--border);
	vertical-align: top;
	color: var(--wp--preset--color--body);
}

.tender-table tbody tr:last-child td {
	border-bottom: none;
}

.tender-table tbody tr:nth-child(even) td {
	background-color: #f8f8fb;
}

.tender-table tbody tr:hover td {
	background-color: #f0f0f5;
}

.tender-table td a {
	display: inline-block;
	background-color: transparent;
	border: 2px solid var(--wp--preset--color--primary);
	color: var(--wp--preset--color--primary);
	font-family: var(--wp--preset--font-family--body);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 700;
	text-decoration: none;
	padding: 0.6em 1.4em;
	border-radius: 0;
	transition: background-color 0.2s ease, color 0.2s ease;
}

.tender-table td a:hover {
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--bg);
}

/* Date cells render as empty until JS fills them; reserve min-width to prevent layout shift */
.tender-table .date-cell {
	min-width: 160px;
}

/* Responsive table — scroll horizontally on narrow viewports */
.tender-table {
	display: block;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.tender-table thead,
.tender-table tbody,
.tender-table tr {
	display: table;
	width: 100%;
	table-layout: fixed;
}

/* Reset display:block on wider viewports */
@media (min-width: 700px) {
	.tender-table {
		display: table;
		overflow-x: visible;
	}
	.tender-table thead,
	.tender-table tbody,
	.tender-table tr {
		display: table-row-group;
		width: auto;
		table-layout: auto;
	}
	.tender-table tr {
		display: table-row;
	}
}

/* --------------------------------------------------------------------------
   9. Tender single view
   -------------------------------------------------------------------------- */

.tender-layout {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: 3rem;
	align-items: start;
}

.tender-meta {
	list-style: none;
	margin: 0;
	padding: 0;
}

.tender-meta li {
	display: grid;
	grid-template-columns: 160px 1fr;
	gap: 1rem;
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--wp--preset--color--border);
	font-size: var(--wp--preset--font-size--sm);
}

.tender-meta__label {
	font-weight: 700;
	color: var(--wp--preset--color--muted);
	text-transform: uppercase;
	font-size: var(--wp--preset--font-size--xs);
	letter-spacing: 0.05em;
}

.tender-documents-panel {
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--bg);
	padding: 2rem;
	border-radius: 0;
}

.tender-documents-panel h3 {
	color: var(--wp--preset--color--bg);
	margin-top: 0;
}

.tender-doc-list {
	list-style: none;
	margin: 0 0 1.5rem;
	padding: 0;
}

.tender-doc-item {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.625rem 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.tender-doc-item label {
	cursor: pointer;
	font-size: var(--wp--preset--font-size--sm);
	flex: 1;
}

.tender-doc-size {
	display: block;
	opacity: 0.6;
	font-size: 0.8em;
}

.tender-doc-link {
	margin-left: auto;
	color: var(--wp--preset--color--accent);
	font-size: 1.25rem;
	text-decoration: none;
	flex-shrink: 0;
}

.tender-doc-link:hover {
	color: var(--wp--preset--color--accent);
	opacity: 0.75;
}

.tender-doc-empty {
	opacity: 0.7;
	font-size: var(--wp--preset--font-size--sm);
}

.tender-doc-note {
	font-size: var(--wp--preset--font-size--xs);
	opacity: 0.85;
	margin-top: 1.5rem;
}

.tender-doc-note a {
	color: var(--wp--preset--color--accent);
}

.tender-doc-item input[type="checkbox"] {
	flex-shrink: 0;
	width: 1.125rem;
	height: 1.125rem;
	accent-color: var(--wp--preset--color--accent);
}

.tender-download-btn {
	display: block;
	width: 100%;
	padding: 0.75rem 1.5rem;
	background: var(--wp--preset--color--accent);
	color: var(--wp--preset--color--primary);
	font-weight: 700;
	font-size: var(--wp--preset--font-size--sm);
	text-align: center;
	border: 0;
	cursor: pointer;
	text-decoration: none;
	transition: opacity 0.2s ease;
}

.tender-download-btn:disabled,
.tender-download-btn[disabled] {
	opacity: 0.4;
	cursor: not-allowed;
}

.tender-download-btn:not(:disabled):hover {
	opacity: 0.85;
}

.tender-select-all {
	background: none;
	border: 0;
	color: var(--wp--preset--color--accent);
	font-size: var(--wp--preset--font-size--xs);
	cursor: pointer;
	padding: 0;
	margin-bottom: 0.75rem;
	text-decoration: underline;
}

.tender-response-section {
	margin-top: 3rem;
	padding-top: 3rem;
	border-top: 2px solid var(--wp--preset--color--border);
}

@media (max-width: 900px) {
	.tender-layout {
		grid-template-columns: 1fr;
	}
	.tender-documents-panel {
		order: -1;
	}
}

/* --------------------------------------------------------------------------
   9. Gravity Forms overrides
   -------------------------------------------------------------------------- */

.gform_wrapper .gform_title {
	font-family: var(--wp--preset--font-family--body);
}

.gform_wrapper input[type="text"],
.gform_wrapper input[type="email"],
.gform_wrapper input[type="tel"],
.gform_wrapper input[type="url"],
.gform_wrapper input[type="number"],
.gform_wrapper input[type="password"],
.gform_wrapper select,
.gform_wrapper textarea {
	border: 1px solid var(--wp--preset--color--border) !important;
	border-radius: 0 !important;
	font-family: var(--wp--preset--font-family--body) !important;
	font-size: var(--wp--preset--font-size--sm) !important;
	padding: 0.625rem 0.875rem !important;
	width: 100% !important;
	background: #fff !important;
	color: var(--wp--preset--color--body) !important;
}

.gform_wrapper input:focus,
.gform_wrapper select:focus,
.gform_wrapper textarea:focus {
	outline: 2px solid var(--wp--preset--color--accent) !important;
	outline-offset: 0 !important;
}

.gform_wrapper .gform_submit_button,
.gform_wrapper .gform_next_button,
.gform_wrapper .gform_previous_button {
	background: var(--wp--preset--color--accent) !important;
	color: var(--wp--preset--color--primary) !important;
	border: 0 !important;
	border-radius: 0 !important;
	padding: 0.65em 1.6em !important;
	font-weight: 700 !important;
	font-family: var(--wp--preset--font-family--body) !important;
	font-size: var(--wp--preset--font-size--sm) !important;
	cursor: pointer !important;
}

.gform_wrapper .gform_submit_button:hover {
	opacity: 0.85 !important;
}

.gform_wrapper .gfield_label {
	font-weight: 700 !important;
	font-size: var(--wp--preset--font-size--sm) !important;
	color: var(--wp--preset--color--heading) !important;
}

.gform_wrapper .gfield_required {
	color: var(--wp--preset--color--accent) !important;
}

/* --------------------------------------------------------------------------
   10. Responsive breakpoints
   -------------------------------------------------------------------------- */

@media (max-width: 768px) {

	.site-header {
		height: 64px;
	}

	.site-header.is-shrunk {
		height: 56px;
	}

}
