/* ================================================================
   FF Public Archive — Editorial fashion design
   v2.8.0 — Castings & Jobs MVP frontend
   ================================================================ */

:root {
	--ff-pub-paper: #FAFAF7;
	--ff-pub-ink: #1A1A1A;
	--ff-pub-ink-soft: #4A4A4A;
	--ff-pub-muted: #888;
	--ff-pub-line: #E5E1D8;
	--ff-pub-gold: #C9A876;
	--ff-pub-gold-dark: #A0844F;
	--ff-pub-accent: #1A1A1A;
	--ff-pub-font-display: 'Cormorant Garamond', 'EB Garamond', Georgia, serif;
	--ff-pub-font-body: -apple-system, BlinkMacSystemFont, 'Segoe UI', Inter, sans-serif;
}

.ff-pub-archive,
.ff-pub-detail {
	background: var(--ff-pub-paper);
	color: var(--ff-pub-ink);
	font-family: var(--ff-pub-font-body);
	min-height: 100vh;
	padding: 40px 32px;
	max-width: 1400px;
	margin: 0 auto;
}

.ff-pub-archive[dir="rtl"],
.ff-pub-detail[dir="rtl"] { text-align: right; }

/* HEADER */
.ff-pub-header {
	border-bottom: 1px solid var(--ff-pub-line);
	padding-bottom: 24px;
	margin-bottom: 32px;
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	gap: 24px;
	flex-wrap: wrap;
}
.ff-pub-title {
	font-family: var(--ff-pub-font-display);
	font-size: clamp(36px, 5vw, 56px);
	font-weight: 400;
	line-height: 1;
	letter-spacing: -0.02em;
	margin: 0;
}
.ff-pub-title em {
	font-style: italic;
	color: var(--ff-pub-gold-dark);
	font-weight: 400;
}
.ff-pub-count {
	font-size: 13px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--ff-pub-muted);
}
.ff-pub-count strong {
	font-family: var(--ff-pub-font-display);
	font-size: 24px;
	color: var(--ff-pub-ink);
	font-weight: 400;
}

/* MAIN GRID */
.ff-pub-main {
	display: grid;
	grid-template-columns: 240px 1fr;
	gap: 40px;
}

@media (max-width: 768px) {
	.ff-pub-main { grid-template-columns: 1fr; }
}

/* FILTERS */
.ff-pub-filters {
	border-right: 1px solid var(--ff-pub-line);
	padding-right: 24px;
}
.ff-pub-archive[dir="rtl"] .ff-pub-filters { border-right: 0; border-left: 1px solid var(--ff-pub-line); padding-right: 0; padding-left: 24px; }

.ff-pub-filter-group {
	margin-bottom: 24px;
	border-bottom: 1px solid var(--ff-pub-line);
	padding-bottom: 16px;
}
.ff-pub-filter-group h3 {
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--ff-pub-muted);
	font-weight: 600;
	margin-bottom: 10px;
}
.ff-pub-filters select,
.ff-pub-filters input {
	width: 100%;
	padding: 8px 10px;
	border: 1px solid var(--ff-pub-line);
	background: white;
	font-family: var(--ff-pub-font-body);
	font-size: 13px;
	color: var(--ff-pub-ink);
	border-radius: 0;
}

.ff-pub-filter-actions {
	display: flex;
	gap: 8px;
	margin-top: 16px;
}
.ff-btn-dark {
	background: var(--ff-pub-ink);
	color: white;
	border: 0;
	padding: 10px 18px;
	font-family: var(--ff-pub-font-body);
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	cursor: pointer;
	font-weight: 600;
	transition: background 0.15s;
}
.ff-btn-dark:hover { background: var(--ff-pub-gold-dark); }
.ff-btn-ghost {
	background: transparent;
	color: var(--ff-pub-muted);
	border: 1px solid var(--ff-pub-line);
	padding: 10px 18px;
	font-size: 11px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	font-weight: 600;
	text-decoration: none;
	display: inline-block;
}

/* GRID CARDS */
.ff-pub-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 32px 24px;
}
.ff-pub-empty {
	padding: 60px;
	text-align: center;
	color: var(--ff-pub-muted);
	font-family: var(--ff-pub-font-display);
	font-style: italic;
	font-size: 18px;
}

.ff-pub-card {
	background: white;
	border: 1px solid var(--ff-pub-line);
	transition: transform 0.2s, box-shadow 0.2s;
}
.ff-pub-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 8px 24px rgba(0,0,0,0.08);
	border-color: var(--ff-pub-gold);
}
.ff-pub-card-link {
	display: block;
	text-decoration: none;
	color: inherit;
}
.ff-pub-card-image {
	aspect-ratio: 3/4;
	background-size: cover;
	background-position: center;
	position: relative;
}
.ff-pub-card-badge {
	position: absolute;
	top: 12px;
	right: 12px;
	background: var(--ff-pub-gold);
	color: white;
	padding: 4px 10px;
	font-size: 10px;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	font-weight: 700;
}
.ff-pub-card-content {
	padding: 20px;
}
.ff-pub-card-meta {
	display: flex;
	justify-content: space-between;
	font-size: 10px;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	color: var(--ff-pub-muted);
	margin-bottom: 10px;
}
.ff-pub-card-title {
	font-family: var(--ff-pub-font-display);
	font-size: 22px;
	line-height: 1.2;
	font-weight: 400;
	margin: 0 0 16px;
	letter-spacing: -0.01em;
}
.ff-pub-card-foot {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	font-size: 12px;
}
.ff-pub-card-location {
	color: var(--ff-pub-muted);
}
.ff-rate-amount {
	color: var(--ff-pub-gold-dark);
	font-weight: 600;
}
.ff-rate-tfp, .ff-rate-quote {
	color: var(--ff-pub-muted);
	font-style: italic;
}

/* PAGINATION */
.ff-pub-pagination {
	display: flex;
	justify-content: center;
	gap: 8px;
	margin-top: 40px;
	padding: 24px 0;
	border-top: 1px solid var(--ff-pub-line);
}
.ff-pub-pagination a {
	width: 36px;
	height: 36px;
	border: 1px solid var(--ff-pub-line);
	background: white;
	color: var(--ff-pub-ink);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 13px;
	font-weight: 600;
}
.ff-pub-pagination a.current {
	background: var(--ff-pub-ink);
	color: white;
	border-color: var(--ff-pub-ink);
}

/* ================================================================
   DETAIL PAGE
   ================================================================ */

.ff-pub-back {
	margin-bottom: 24px;
}
.ff-pub-back a {
	color: var(--ff-pub-muted);
	font-size: 12px;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	text-decoration: none;
	font-weight: 600;
}
.ff-pub-back a:hover { color: var(--ff-pub-ink); }

.ff-pub-hero {
	padding: 80px 60px;
	color: white;
	margin: 0 -32px 40px;
	position: relative;
}
.ff-pub-hero-content {
	max-width: 900px;
	margin: 0 auto;
}
.ff-pub-hero-meta {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
	margin-bottom: 20px;
}
.ff-pub-hero-meta .badge {
	background: rgba(255,255,255,0.15);
	color: white;
	padding: 5px 12px;
	font-size: 10px;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	font-weight: 600;
	border-radius: 0;
}
.ff-pub-hero-meta .badge.featured { background: var(--ff-pub-gold); }
.ff-pub-hero-meta > span:not(.badge) { color: rgba(255,255,255,0.8); font-size: 13px; }
.ff-pub-hero h1 {
	font-family: var(--ff-pub-font-display);
	font-size: clamp(36px, 5vw, 60px);
	font-weight: 400;
	line-height: 1.1;
	letter-spacing: -0.02em;
	margin: 0;
}

.ff-pub-detail-grid {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 60px;
}
@media (max-width: 768px) {
	.ff-pub-detail-grid { grid-template-columns: 1fr; gap: 40px; }
	.ff-pub-hero { padding: 60px 24px; margin: 0 -32px 32px; }
}

.ff-section {
	margin-bottom: 40px;
	padding-bottom: 32px;
	border-bottom: 1px solid var(--ff-pub-line);
}
.ff-section:last-child { border-bottom: 0; }
.ff-section h2 {
	font-family: var(--ff-pub-font-display);
	font-size: 28px;
	font-weight: 400;
	margin: 0 0 16px;
	font-style: italic;
}
.ff-section p {
	font-size: 15px;
	line-height: 1.7;
	color: var(--ff-pub-ink-soft);
}

.ff-criteria {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 20px;
	background: white;
	padding: 24px;
	border: 1px solid var(--ff-pub-line);
}
.ff-criterion {
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.ff-criterion-label {
	font-size: 10px;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	color: var(--ff-pub-muted);
	font-weight: 600;
}
.ff-criterion-value {
	font-family: var(--ff-pub-font-display);
	font-size: 20px;
	color: var(--ff-pub-ink);
}

/* SIDE CTA */
.ff-pub-side {
	position: sticky;
	top: 24px;
	align-self: start;
}
.ff-cta-block {
	background: white;
	border: 1px solid var(--ff-pub-line);
	padding: 28px;
	margin-bottom: 20px;
}
.ff-cta-block h3 {
	font-family: var(--ff-pub-font-display);
	font-size: 26px;
	font-weight: 400;
	margin: 0 0 8px;
}
.ff-cta-block p {
	font-size: 13px;
	color: var(--ff-pub-muted);
	margin-bottom: 20px;
}
.ff-btn-primary {
	background: var(--ff-pub-gold);
	color: white;
	border: 0;
	padding: 14px 24px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	cursor: pointer;
	width: 100%;
	margin-bottom: 8px;
	display: block;
	text-align: center;
	text-decoration: none;
	transition: background 0.15s;
}
.ff-btn-primary:hover { background: var(--ff-pub-gold-dark); }
.ff-btn {
	background: white;
	color: var(--ff-pub-ink);
	border: 1px solid var(--ff-pub-line);
	padding: 12px 20px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	cursor: pointer;
	width: 100%;
	margin-bottom: 8px;
	display: block;
	text-align: center;
}
.ff-btn:hover { border-color: var(--ff-pub-ink); }
.ff-icon-btn {
	background: transparent;
	color: var(--ff-pub-muted);
	border: 0;
	padding: 10px;
	font-size: 12px;
	cursor: pointer;
	width: 100%;
	text-align: center;
}
.ff-warn {
	background: #FEF3C7;
	color: #92400E;
	padding: 12px;
	font-size: 12px;
	text-align: center;
}

.ff-recruiter-card {
	background: white;
	border: 1px solid var(--ff-pub-line);
	padding: 20px;
}
.ff-recruiter-card h4 {
	font-size: 10px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--ff-pub-muted);
	font-weight: 600;
	margin: 0 0 12px;
}
.ff-recruiter-info {
	display: flex;
	gap: 12px;
	align-items: center;
}
.ff-recruiter-avatar {
	width: 44px;
	height: 44px;
	background: var(--ff-pub-ink);
	color: white;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
}
.ff-recruiter-name {
	font-family: var(--ff-pub-font-display);
	font-size: 18px;
}
.ff-badge-verified {
	display: inline-block;
	background: #D1FAE5;
	color: #065F46;
	padding: 2px 8px;
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.04em;
	margin-top: 4px;
}

/* MODALS */
.ff-modal {
	position: fixed;
	inset: 0;
	background: rgba(0,0,0,0.6);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 9999;
}
.ff-modal-content {
	background: white;
	padding: 32px;
	border-radius: 0;
	max-width: 500px;
	width: 90%;
	max-height: 90vh;
	overflow: auto;
}
.ff-modal-content h3 {
	font-family: var(--ff-pub-font-display);
	font-size: 28px;
	font-weight: 400;
	margin: 0 0 12px;
}
.ff-modal-content textarea {
	width: 100%;
	border: 1px solid var(--ff-pub-line);
	padding: 12px;
	font-family: var(--ff-pub-font-body);
	font-size: 14px;
	resize: vertical;
	min-height: 100px;
	box-sizing: border-box;
	margin-top: 12px;
}
.ff-report-reasons {
	display: flex;
	flex-direction: column;
	gap: 8px;
	margin: 16px 0;
}
.ff-report-reasons label {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	border: 1px solid var(--ff-pub-line);
	cursor: pointer;
	font-size: 13px;
}
.ff-report-reasons label:hover { border-color: var(--ff-pub-ink); }
.ff-modal-actions {
	display: flex;
	gap: 12px;
	justify-content: flex-end;
	margin-top: 20px;
}
.ff-btn-danger {
	background: #DC2626;
	color: white;
	border: 0;
	padding: 12px 24px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.10em;
	text-transform: uppercase;
	cursor: pointer;
}

/* RTL specifics */
.ff-pub-detail[dir="rtl"] .ff-pub-card-meta { text-align: right; }
.ff-pub-detail[dir="rtl"] .ff-pub-hero { text-align: right; }
.ff-pub-detail[dir="rtl"] .ff-pub-back a::before { content: ""; }
.ff-pub-detail[dir="rtl"] .ff-pub-back a::after { content: " →"; }

/* ================================================================
   MOBILE RESPONSIVE (v2.8.0-hotfix8)
   ================================================================ */

/* Tablet ≤ 1024px */
@media (max-width: 1024px) {
	.ff-pub-archive,
	.ff-pub-detail {
		padding: 32px 24px;
	}
	.ff-pub-main {
		grid-template-columns: 200px 1fr;
		gap: 28px;
	}
	.ff-pub-grid {
		gap: 24px 18px;
	}
}

/* Mobile ≤ 768px */
@media (max-width: 768px) {
	.ff-pub-archive,
	.ff-pub-detail {
		padding: 20px 16px;
	}

	/* Header stacks vertically */
	.ff-pub-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 12px;
		padding-bottom: 16px;
		margin-bottom: 20px;
	}
	.ff-pub-title {
		font-size: 32px;
	}

	/* Main grid: filters become a top accordion */
	.ff-pub-main {
		grid-template-columns: 1fr;
		gap: 20px;
	}
	.ff-pub-filters {
		border-right: 0;
		border-bottom: 1px solid var(--ff-pub-line);
		padding-right: 0;
		padding-bottom: 16px;
	}
	.ff-pub-archive[dir="rtl"] .ff-pub-filters {
		border-left: 0;
		padding-left: 0;
	}
	.ff-pub-filter-group {
		padding-bottom: 12px;
		margin-bottom: 14px;
	}

	/* Cards: 1-2 columns max */
	.ff-pub-grid {
		grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
		gap: 20px 14px;
	}
	.ff-pub-card-image {
		aspect-ratio: 4/5;  /* Less tall on mobile */
	}
	.ff-pub-card-title {
		font-size: 18px;
	}

	/* Hero: smaller padding */
	.ff-pub-hero {
		padding: 48px 20px;
		margin: 0 -16px 28px;
	}
	.ff-pub-hero h1 {
		font-size: 32px;
		line-height: 1.15;
	}

	/* Detail grid stacks */
	.ff-pub-detail-grid {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	/* Side CTA goes inline (not sticky) */
	.ff-pub-side {
		position: static;
	}

	/* Section title smaller */
	.ff-section h2 {
		font-size: 24px;
	}

	/* Criteria grid: 2 cols max */
	.ff-criteria {
		grid-template-columns: repeat(2, 1fr);
		gap: 14px;
		padding: 18px;
	}
	.ff-criterion-value {
		font-size: 18px;
	}

	/* Modals: full-screen-like on mobile */
	.ff-modal-content {
		width: 95%;
		padding: 24px 20px;
		max-height: 95vh;
	}
	.ff-modal-content h3 {
		font-size: 24px;
	}
	.ff-modal-actions {
		flex-direction: column-reverse;
		gap: 8px;
	}
	.ff-modal-actions button {
		width: 100%;
	}

	/* Pagination smaller */
	.ff-pub-pagination a {
		width: 32px;
		height: 32px;
		font-size: 12px;
	}
}

/* Small mobile ≤ 480px */
@media (max-width: 480px) {
	.ff-pub-grid {
		grid-template-columns: 1fr;  /* 1 column only */
	}
	.ff-pub-card-image {
		aspect-ratio: 16/10;  /* Wider, shorter for single column */
	}
	.ff-pub-card-content {
		padding: 16px;
	}
	.ff-pub-card-title {
		font-size: 20px;
	}

	/* Filters: collapsible toggle */
	.ff-pub-filters {
		max-height: 60px;
		overflow: hidden;
		position: relative;
		transition: max-height 0.3s ease-out;
	}
	.ff-pub-filters::after {
		content: "▾ Show filters";
		position: absolute;
		top: 16px;
		right: 0;
		color: var(--ff-pub-gold-dark);
		font-size: 12px;
		font-weight: 600;
		text-transform: uppercase;
		letter-spacing: 0.08em;
		cursor: pointer;
		padding: 4px 8px;
	}
	.ff-pub-filters.open {
		max-height: 800px;
	}
	.ff-pub-filters.open::after {
		content: "▴ Hide filters";
	}

	/* Detail: tighter padding */
	.ff-pub-hero {
		padding: 32px 16px;
		margin: 0 -16px 24px;
	}
	.ff-pub-hero h1 {
		font-size: 26px;
	}
	.ff-section h2 {
		font-size: 20px;
	}
	.ff-criteria {
		grid-template-columns: 1fr;
	}
}
