/*!
Theme Name: BTS-events
Theme URI: http://underscores.me/
Author: Underscores.me
Author URI: http://underscores.me/
Description: BTS Events — brutalist modern event management theme
Version: 2.0.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: bts-events
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
*/

/* ===================================================================
   DESIGN TOKENS
   Palette:
     White  #FFFFFF  — background
     Black  #0C0C0C  — text, borders
     Red    #FF2B00  — primary accent
     Lime   #C8FF00  — secondary accent
     Gray   #F4F4F4  — subtle bg
=================================================================== */

:root {
	--white:  #FFFFFF;
	--black:  #0C0C0C;
	--red:    #FF2B00;
	--lime:   #C8FF00;
	--gray:   #F4F4F4;

	--font-display: 'Barlow Condensed', sans-serif;
	--font-body:    'Space Grotesk', sans-serif;

	--border:     2px solid var(--black);
	--nav-height: 72px;
	--max-w:      1440px;
	--gutter:     clamp(1.5rem, 4vw, 4rem);
	--section-py: clamp(5rem, 9vw, 9rem);
}

/* ===================================================================
   NORMALIZE (v8.0.1)
=================================================================== */

html { line-height: 1.15; -webkit-text-size-adjust: 100%; }
body { margin: 0; }
main { display: block; }
h1   { font-size: 2em; margin: 0.67em 0; }
hr   { box-sizing: content-box; height: 0; overflow: visible; }
pre  { font-family: monospace, monospace; font-size: 1em; }
a    { background-color: transparent; }
abbr[title] { border-bottom: none; text-decoration: underline dotted; }
b, strong   { font-weight: bolder; }
code, kbd, samp { font-family: monospace, monospace; font-size: 1em; }
small { font-size: 80%; }
sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }
sub { bottom: -0.25em; }
sup { top: -0.5em; }
img { border-style: none; }
button, input, optgroup, select, textarea { font-family: inherit; font-size: 100%; line-height: 1.15; margin: 0; }
button, input { overflow: visible; }
button, select { text-transform: none; }
button, [type="button"], [type="reset"], [type="submit"] { -webkit-appearance: button; }
button::-moz-focus-inner, [type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner { border-style: none; padding: 0; }
button:-moz-focusring, [type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring, [type="submit"]:-moz-focusring { outline: 1px dotted ButtonText; }
fieldset { padding: 0.35em 0.75em 0.625em; }
legend { box-sizing: border-box; color: inherit; display: table; max-width: 100%; padding: 0; white-space: normal; }
progress { vertical-align: baseline; }
textarea { overflow: auto; }
[type="checkbox"], [type="radio"] { box-sizing: border-box; padding: 0; }
[type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button { height: auto; }
[type="search"] { -webkit-appearance: textfield; outline-offset: -2px; }
[type="search"]::-webkit-search-decoration { -webkit-appearance: none; }
::-webkit-file-upload-button { -webkit-appearance: button; font: inherit; }
details { display: block; }
summary { display: list-item; }
template { display: none; }
[hidden]  { display: none; }

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

/* ===================================================================
   BASE
=================================================================== */

html {
	scroll-behavior: smooth;
	box-sizing: border-box;
}

body {
	font-family: var(--font-body);
	font-size: 1rem;
	line-height: 1.65;
	color: var(--black);
	background: var(--white);
	overflow-x: hidden;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-display);
	font-weight: 800;
	line-height: 0.92;
	text-transform: uppercase;
	letter-spacing: -0.02em;
	color: var(--black);
	margin: 0 0 0.6em;
}

p { margin: 0 0 1.4em; }
p:last-child { margin-bottom: 0; }

a { color: var(--black); }
a:visited { color: var(--black); }
a:hover { color: var(--red); }
a:focus { outline: 2px solid var(--red); outline-offset: 2px; }

img { height: auto; max-width: 100%; display: block; }
figure { margin: 0; }

embed, iframe, object { max-width: 100%; }

ul, ol { margin: 0 0 1.4em 1.5em; padding: 0; }
li { margin-bottom: 0.3em; }

blockquote {
	margin: 2.5rem 0;
	padding: 2rem 2.5rem;
	border-left: 6px solid var(--red);
	background: var(--gray);
	font-family: var(--font-display);
	font-size: clamp(1.4rem, 3vw, 2rem);
	font-weight: 700;
	text-transform: uppercase;
	line-height: 1.1;
}

blockquote cite {
	display: block;
	margin-top: 1rem;
	font-family: var(--font-body);
	font-size: 0.85rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--red);
}

hr {
	border: 0;
	border-top: var(--border);
	margin: 3rem 0;
}

table { width: 100%; margin-bottom: 1.5em; border-collapse: collapse; }
th, td { padding: 0.75em 1em; border: var(--border); text-align: left; }
th { background: var(--black); color: var(--white); font-family: var(--font-display); text-transform: uppercase; letter-spacing: 0.05em; }

/* ===================================================================
   LAYOUT UTILITIES
=================================================================== */

.container {
	width: 100%;
	max-width: var(--max-w);
	margin: 0 auto;
	padding: 0 var(--gutter);
}

/* ===================================================================
   BUTTONS
=================================================================== */

.btn,
.wp-block-button__link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-family: var(--font-body);
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	text-decoration: none;
	padding: 0.9rem 2rem;
	border: var(--border);
	cursor: pointer;
	transition: background 0.18s, color 0.18s, border-color 0.18s;
	line-height: 1;
	-webkit-appearance: none;
}

.btn-primary,
.wp-block-button:not(.is-style-outline) .wp-block-button__link {
	background: var(--black);
	color: var(--white) !important;
	border-color: var(--black);
}

.btn-primary:hover,
.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
	background: var(--red);
	border-color: var(--red);
	color: var(--white) !important;
}

.btn-outline,
.wp-block-button.is-style-outline .wp-block-button__link {
	background: transparent;
	color: var(--black) !important;
	border-color: var(--black);
}

.btn-outline:hover,
.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: var(--lime);
	border-color: var(--black);
	color: var(--black) !important;
}

/* ===================================================================
   HEADER / NAVIGATION
=================================================================== */

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 900;
	height: var(--nav-height);
	background: var(--white);
	border-bottom: var(--border);
	display: flex;
	align-items: center;
}

.header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	max-width: var(--max-w);
	margin: 0 auto;
	padding: 0 var(--gutter);
}

/* Logo */
.site-branding {
	display: flex;
	align-items: center;
}

.site-logo-link {
	display: flex;
	align-items: center;
	text-decoration: none;
}

/* Constrain all logo images — catches .site-logo, .custom-logo, and WP custom logo output */
.site-branding img,
.site-branding .custom-logo-link img,
.site-logo {
	display: block;
	height: 36px !important;
	width: auto !important;
	max-width: none;
}

/* Keep old text title styles in case they're needed elsewhere */
.site-title {
	margin: 0;
	padding: 0;
	font-family: var(--font-display);
	font-size: 1.75rem;
	font-weight: 800;
	line-height: 1;
}

.site-title a {
	text-decoration: none;
	color: var(--black);
	letter-spacing: -0.04em;
	text-transform: uppercase;
}

.site-title a:visited { color: var(--black); }
.site-title a:hover { color: var(--black); }

.logo-dot { color: var(--red); }

.site-description { display: none; }

/* Nav */
.main-navigation {
	display: flex;
	align-items: center;
}

.main-navigation ul {
	display: flex;
	align-items: center;
	gap: 2.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.main-navigation ul ul {
	display: none;
	position: absolute;
	top: 100%;
	left: 0;
	background: var(--white);
	border: var(--border);
	min-width: 200px;
	z-index: 999;
	box-shadow: 4px 4px 0 var(--black);
}

.main-navigation ul li { position: relative; }
.main-navigation ul li:hover > ul { display: block; }
.main-navigation ul ul li { border-bottom: 1px solid var(--gray); }
.main-navigation ul ul li:last-child { border-bottom: 0; }
.main-navigation ul ul a { padding: 0.75rem 1.25rem; }

.main-navigation a {
	font-family: var(--font-body);
	font-size: 0.78rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	text-decoration: none;
	color: var(--black);
	transition: color 0.15s;
	display: block;
}

.main-navigation a:hover,
.main-navigation a:focus { color: var(--red); }

/* Hamburger */
.menu-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 6px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0.5rem;
	width: 40px;
	height: 40px;
}

.menu-toggle .bar {
	display: block;
	width: 28px;
	height: 2px;
	background: var(--black);
	transition: transform 0.3s, opacity 0.3s;
	transform-origin: center;
}

/* Hamburger → X */
.main-navigation.toggled .menu-toggle .bar:nth-child(1) {
	transform: translateY(8px) rotate(45deg);
}
.main-navigation.toggled .menu-toggle .bar:nth-child(2) {
	opacity: 0;
}
.main-navigation.toggled .menu-toggle .bar:nth-child(3) {
	transform: translateY(-8px) rotate(-45deg);
}

/* Screen reader */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background: var(--white);
	border: var(--border);
	clip: auto !important;
	clip-path: none;
	color: var(--black);
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 1rem;
	padding: 1rem 1.5rem;
	text-decoration: none;
	top: 1rem;
	width: auto;
	z-index: 100000;
}

#primary[tabindex="-1"]:focus { outline: 0; }

/* ===================================================================
   HERO
=================================================================== */

.hero {
	min-height: 100svh;
	display: flex;
	flex-direction: column;
	padding-top: var(--nav-height);
	border-bottom: var(--border);
}

.hero-body {
	flex: 1;
	display: grid;
	grid-template-columns: 65vw 35vw;
}

/* Hero text side */
.hero-text {
	display: flex;
	flex-direction: column;
	border-right: var(--border);
	overflow: hidden;
	height: 100%;
}

.hero-text-content {
	padding: clamp(3rem, 5vw, 5rem) var(--gutter);
	flex-shrink: 0;
}

.hero-text-image {
	flex: 1;
	min-height: 0;
	overflow: hidden;
	border-top: var(--border);
}

.hero-text-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	display: block;
}

.hero-eyebrow {
	display: inline-block;
	font-family: var(--font-body);
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--red);
	margin-bottom: 2rem;
}

.hero-title {
	font-family: var(--font-display);
	font-size: clamp(2.5rem, 5.5vw, 7.5rem);
	font-weight: 800;
	text-transform: uppercase;
	line-height: 0.9;
	letter-spacing: -0.03em;
	color: var(--black);
	margin: 0 0 2.5rem;
	overflow-wrap: break-word;
}

/* Shared body prose style — used wherever running text appears */
.hero-subtitle,
.archive-description,
.kontakt-subtitle {
	font-size: clamp(0.95rem, 1.4vw, 1.1rem);
	line-height: 1.6;
	color: var(--black);
}

.hero-subtitle {
	max-width: 42ch;
	margin: 0 0 2.5rem;
}

.hero-subtitle a {
	color: var(--red);
	text-decoration: underline;
	text-underline-offset: 3px;
	font-weight: 600;
	white-space: nowrap;
}

.hero-subtitle a:hover {
	color: var(--black);
}

.hero-actions {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}

/* Hero visual side */
.hero-visual {
	position: relative;
	background: var(--gray);
	overflow: hidden;
	min-height: 320px;
}

.hero-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	position: absolute;
	inset: 0;
}

.hero-badge {
	position: absolute;
	bottom: 2rem;
	right: 2rem;
	background: var(--lime);
	border: var(--border);
	padding: 0.75rem 1.25rem;
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	box-shadow: 4px 4px 0 var(--black);
}

/* Hero ticker */
.hero-ticker {
	background: var(--lime);
	border-bottom: var(--border);
	padding: 1rem 0;
	overflow: hidden;
}

.ticker-track {
	display: flex;
	width: max-content;
	animation: ticker 40s linear infinite;
}

.ticker-track span {
	display: block;
	flex-shrink: 0;
	font-family: var(--font-display);
	font-size: clamp(1rem, 2.2vw, 1.5rem);
	font-weight: 800;
	color: var(--black);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	white-space: nowrap;
}

@keyframes ticker {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

/* ===================================================================
   HOMEPAGE QUOTE
=================================================================== */

.homepage-quote {
	background: var(--black);
	overflow: hidden;
	position: relative;
}

/* Texture grain overlay */
.homepage-quote::before {
	content: '';
	position: absolute;
	inset: 0;
	background: url('images/texture.jpg') center / cover fixed;
	filter: grayscale(1) brightness(0.4);
	opacity: 0.35;
	mix-blend-mode: screen;
	pointer-events: none;
	z-index: 0;
}

.homepage-quote__inner {
	position: relative;
	z-index: 1;
}

.homepage-quote__inner {
	max-width: var(--max-w);
	margin: 0 auto;
	padding: clamp(4rem, 8vw, 8rem) var(--gutter);
}

.homepage-quote__text {
	font-family: var(--font-display);
	font-size: clamp(3rem, 8vw, 9rem);
	font-weight: 800;
	text-transform: uppercase;
	line-height: 0.92;
	letter-spacing: -0.03em;
	color: var(--white);
	margin: 0;
	padding: 0;
	border: 0;
	background: none;
}

/* ===================================================================
   PAGE / FRONT-PAGE CONTENT  (Gutenberg blocks)
=================================================================== */

.page-content-wrap {
	width: 100%;
}

/* Full-width sections from Gutenberg */
.page-content-wrap > .wp-block-group,
.page-content-wrap > .wp-block-cover {
	padding: var(--section-py) var(--gutter);
}

/* Constrain inner content */
.page-content-wrap .wp-block-group__inner-container,
.page-content-wrap .wp-block-cover__inner-container {
	max-width: var(--max-w);
	margin: 0 auto;
}

/* Alternating section borders */
.page-content-wrap > * {
	border-bottom: var(--border);
}

/* Headings in content */
.page-content-wrap h2 {
	font-size: clamp(3rem, 7vw, 8rem);
	margin-bottom: 1.5rem;
}

.page-content-wrap h3 {
	font-size: clamp(1.8rem, 3.5vw, 3.5rem);
	margin-bottom: 1.25rem;
}

.page-content-wrap h4 {
	font-size: clamp(1.2rem, 2vw, 2rem);
	margin-bottom: 1rem;
}

/* Columns layout */
.page-content-wrap .wp-block-columns {
	display: grid;
	gap: 0;
	margin: 0;
}

.page-content-wrap .wp-block-columns.has-2-columns { grid-template-columns: 1fr 1fr; }
.page-content-wrap .wp-block-columns.has-3-columns { grid-template-columns: 1fr 1fr 1fr; }
.page-content-wrap .wp-block-columns.has-4-columns { grid-template-columns: repeat(4, 1fr); }

.page-content-wrap .wp-block-column {
	padding: var(--gutter);
	border-right: var(--border);
}

.page-content-wrap .wp-block-column:last-child {
	border-right: 0;
}

/* Images */
.page-content-wrap .wp-block-image {
	margin: 0;
}

.page-content-wrap .wp-block-image img {
	width: 100%;
	height: auto;
	display: block;
}

/* Separators */
.page-content-wrap .wp-block-separator {
	border: 0;
	border-top: var(--border);
	margin: 0;
}

/* Cover block */
.wp-block-cover {
	position: relative;
	min-height: 60vh;
	display: flex;
	align-items: center;
	background: var(--black);
	overflow: hidden;
}

.wp-block-cover .wp-block-cover__image-background {
	object-fit: cover;
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	opacity: 0.35;
}

.wp-block-cover__inner-container {
	position: relative;
	z-index: 1;
	color: var(--white);
}

.wp-block-cover__inner-container h2,
.wp-block-cover__inner-container h3,
.wp-block-cover__inner-container p {
	color: var(--white);
}

/* Quote */
.page-content-wrap .wp-block-quote {
	margin: 2rem 0;
	padding: 2.5rem 3rem;
	border-left: 6px solid var(--red);
	border-top: var(--border);
	border-bottom: var(--border);
	border-right: 0;
	background: var(--gray);
}

.page-content-wrap .wp-block-quote p {
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 3vw, 2.5rem);
	font-weight: 700;
	text-transform: uppercase;
	line-height: 1.05;
	margin-bottom: 1rem;
}

.page-content-wrap .wp-block-quote cite {
	font-family: var(--font-body);
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--red);
}

/* Lists */
.page-content-wrap ul,
.page-content-wrap ol {
	padding-left: 1.5rem;
}

/* Buttons group */
.page-content-wrap .wp-block-buttons {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
	margin: 0;
}

/* Accent / highlight group — add class "bts-accent" in editor */
.wp-block-group.bts-accent {
	background: var(--lime);
}

.wp-block-group.bts-dark {
	background: var(--black);
	color: var(--white);
}

.wp-block-group.bts-dark h2,
.wp-block-group.bts-dark h3,
.wp-block-group.bts-dark p {
	color: var(--white);
}

/* Service card pattern */
.bts-service-number {
	font-family: var(--font-display);
	font-size: clamp(5rem, 10vw, 10rem);
	font-weight: 800;
	line-height: 1;
	color: var(--lime);
	-webkit-text-stroke: 2px var(--black);
	display: block;
	margin-bottom: 0.5rem;
}

/* ===================================================================
   STANDARD PAGE / SINGLE / ARCHIVE
=================================================================== */

.site-main {
	padding-top: var(--nav-height);
	min-height: 60vh;
}

/* On the front page the main wrapper sits between black hero/quote and black footer —
   keep it black so any sub-pixel gap between those sections doesn't flash white. */
.home .site-main {
	background: var(--black);
}

.entry-header {
	padding: clamp(4rem, 8vw, 8rem) var(--gutter) 3rem;
	border-bottom: var(--border);
	max-width: var(--max-w);
	margin: 0 auto;
}

.entry-title {
	font-size: clamp(3rem, 7vw, 8rem);
	margin: 0;
}

.entry-content {
	max-width: var(--max-w);
	margin: 0 auto;
	padding: 4rem var(--gutter);
}

.entry-content h2 { font-size: clamp(2rem, 5vw, 5rem); }
.entry-content h3 { font-size: clamp(1.5rem, 3vw, 3rem); }

.entry-footer {
	max-width: var(--max-w);
	margin: 0 auto;
	padding: 2rem var(--gutter);
	border-top: var(--border);
	font-size: 0.85rem;
	opacity: 0.55;
}

.o-nama-cta {
	max-width: var(--max-w);
	margin: 0 auto;
	padding: 0 var(--gutter) 4rem;
}

/* Archive / blog */
.archive-header {
	padding: clamp(3rem, 6vw, 6rem) var(--gutter);
	max-width: var(--max-w);
	margin: 0 auto;
}

.page-title {
	font-size: clamp(2rem, 5vw, 6rem);
	margin: 0;
}

.posts-navigation {
	max-width: var(--max-w);
	margin: 0 auto;
	padding: 3rem var(--gutter);
	border-top: var(--border);
	display: flex;
	justify-content: space-between;
}

.posts-navigation a {
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-size: 0.85rem;
	text-decoration: none;
}

.posts-navigation a:hover { color: var(--red); }

/* Post card in loop */
article.post,
article.page {
	border-bottom: var(--border);
}

article.post .entry-header,
article.page .entry-header {
	padding: 3rem var(--gutter) 2rem;
}

article.post .entry-title a {
	text-decoration: none;
	color: var(--black);
}

article.post .entry-title a:hover { color: var(--red); }

/* ===================================================================
   SIDEBAR
=================================================================== */

.widget-area { display: none; }

/* ===================================================================
   PORTFOLIO ARCHIVE
=================================================================== */

.archive-header {
	max-width: none;
	margin: 0;
	padding: 0;
	border-bottom: var(--border);
}

.archive-header__inner {
	max-width: var(--max-w);
	margin: 0 auto;
	padding: clamp(3rem, 5vw, 5rem) var(--gutter) clamp(2.5rem, 4vw, 4rem);
}

.archive-description p {
	margin: 0;
}

.archive-title {
	font-family: var(--font-display);
	font-size: clamp(4rem, 10vw, 10rem);
	font-weight: 800;
	text-transform: uppercase;
	line-height: 0.88;
	letter-spacing: -0.03em;
	margin: 0.25rem 0 1.25rem;
}

.portfolio-grid-wrap {
	padding: 0;
}

.portfolio-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
}

.portfolio-tile {
	min-width: 0;
	border-bottom: var(--border);
}

.portfolio-tile__link {
	display: grid;
	grid-template-columns: 55% 1fr;
	text-decoration: none;
	color: inherit;
	height: 42vh;
}

.portfolio-tile__image {
	overflow: hidden;
	background: var(--gray);
}

.portfolio-tile__image img,
.portfolio-tile__image-placeholder {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	display: block;
	transition: transform 0.5s ease;
}

.portfolio-tile__image-placeholder {
	background: var(--gray);
}

.portfolio-tile__link:hover .portfolio-tile__image img {
	transform: scale(1.04);
}

.portfolio-tile__meta {
	padding: clamp(2rem, 4vw, 3.5rem) clamp(2rem, 4vw, 4rem);
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	border-left: var(--border);
}

.portfolio-tile__top {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: auto;
}

.portfolio-tile__year {
	font-family: var(--font-display);
	font-size: 0.85rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--red);
}

.portfolio-tile__type {
	font-family: monospace;
	font-size: 0.7rem;
	font-weight: 400;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--black);
	opacity: 0.5;
	border: 1px solid currentColor;
	padding: 2px 6px;
	white-space: nowrap;
}

.portfolio-tile__title {
	font-family: var(--font-display);
	font-size: clamp(2rem, 4vw, 4.5rem);
	font-weight: 800;
	text-transform: uppercase;
	line-height: 0.92;
	letter-spacing: -0.03em;
	margin: 1.5rem 0 0;
	transition: color 0.2s ease;
}

.portfolio-tile__link:hover .portfolio-tile__title {
	color: var(--red);
}

/* ===================================================================
   PORTFOLIO SINGLE POST
=================================================================== */

.portfolio-single {
	border-bottom: var(--border);
}

.portfolio-single__top {
	display: grid;
	grid-template-columns: 1fr 1fr;
	border-bottom: var(--border);
}

.portfolio-single__image {
	overflow: hidden;
	border-right: var(--border);
	min-height: 50vh;
}

.portfolio-single__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
	display: block;
}

.portfolio-single__info {
	padding: clamp(2rem, 4vw, 4rem);
	display: flex;
	flex-direction: column;
}

.portfolio-single__title-row {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1.5rem;
	margin-bottom: 1.5rem;
}

.portfolio-single__title-meta {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 0.5rem;
	flex-shrink: 0;
	margin-top: 0.25rem;
}

.portfolio-single__title {
	font-family: var(--font-display);
	font-size: clamp(2.5rem, 5vw, 5rem);
	font-weight: 800;
	text-transform: uppercase;
	line-height: 0.9;
	letter-spacing: -0.03em;
	margin: 0;
}

.portfolio-single__year {
	font-family: var(--font-display);
	font-size: clamp(1rem, 2vw, 1.4rem);
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--red);
	white-space: nowrap;
	flex-shrink: 0;
	margin-top: 0.35rem;
}

.portfolio-single__role {
	font-family: var(--font-display);
	font-size: clamp(0.85rem, 1.5vw, 1rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--black);
	opacity: 0.55;
	margin: 0 0 2rem;
}

.portfolio-single__meta {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 0.5rem 1.5rem;
	margin: 0;
}

.portfolio-single__meta dt {
	font-family: var(--font-body);
	font-size: 0.8rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--black);
	opacity: 0.45;
	padding-top: 1px;
}

.portfolio-single__meta dd {
	font-family: var(--font-body);
	font-size: 0.95rem;
	margin: 0;
}

.portfolio-single__meta dd a {
	color: var(--red);
	text-decoration: underline;
	text-underline-offset: 3px;
}

/* Description — inside the info panel */
.portfolio-single__description {
	margin-top: 2.5rem;
	padding-top: 2rem;
}

.portfolio-single__description-heading {
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 2.5vw, 2.2rem);
	font-weight: 800;
	text-transform: uppercase;
	line-height: 0.9;
	letter-spacing: -0.02em;
	margin: 0 0 1.25rem;
}

/* Keep for gallery heading */
.portfolio-single__content-heading {
	font-family: var(--font-display);
	font-size: clamp(2.5rem, 6vw, 6rem);
	font-weight: 800;
	text-transform: uppercase;
	line-height: 0.9;
	letter-spacing: -0.03em;
	margin: 0 0 2rem;
}

.portfolio-single__body {
	font-size: clamp(1rem, 1.5vw, 1.15rem);
	line-height: 1.65;
	text-align: justify;
}

.portfolio-single__body p {
	margin: 0 0 1.25rem;
}

/* Gallery in content */
.portfolio-single__body .wp-block-gallery {
	margin-top: 3rem;
}

/* Gallery */
.portfolio-gallery {
	border-top: var(--border);
}

.portfolio-gallery__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

.portfolio-gallery__item {
	display: block;
	overflow: hidden;
	aspect-ratio: 4 / 3;
	border-right: var(--border);
	border-bottom: var(--border);
}

.portfolio-gallery__item:nth-child(3n) {
	border-right: 0;
}

.portfolio-gallery__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	transition: transform 0.4s ease;
}

.portfolio-gallery__item:hover .portfolio-gallery__img {
	transform: scale(1.04);
}

@media (max-width: 768px) {
	.portfolio-gallery__grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.portfolio-gallery__item:nth-child(3n) {
		border-right: var(--border);
	}

	.portfolio-gallery__item:nth-child(2n) {
		border-right: 0;
	}
}

/* Post navigation */
.portfolio-single__nav {
	padding: 2rem clamp(2rem, 5vw, 5rem);
	border-top: var(--border);
}

.portfolio-single__nav .nav-links {
	display: flex;
	justify-content: space-between;
	gap: 2rem;
}

.portfolio-single__nav a {
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--black);
	text-decoration: none;
}

.portfolio-single__nav a:hover {
	color: var(--red);
}

/* ===================================================================
   SCROLL REVEAL
=================================================================== */

.will-reveal {
	opacity: 0;
	transform: translateY( 22px );
	transition: opacity 0.55s ease, transform 0.55s ease;
}

.will-reveal.is-revealed {
	opacity: 1;
	transform: translateY( 0 );
}

/* ===================================================================
   GALLERY LIGHTBOX
=================================================================== */

#bts-lightbox {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 9999;
	align-items: center;
	justify-content: center;
}

#bts-lightbox.is-open {
	display: flex;
}

.bts-lightbox__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.92);
}

.bts-lightbox__img-wrap {
	position: relative;
	z-index: 1;
	max-width: 90vw;
	max-height: 90vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

.bts-lightbox__img {
	display: block;
	max-width: 90vw;
	max-height: 90vh;
	width: auto;
	height: auto;
	object-fit: contain;
	transition: opacity 0.15s ease;
}

.bts-lightbox__img.is-loading {
	opacity: 0;
}

.bts-lightbox__prev,
.bts-lightbox__next,
.bts-lightbox__close {
	position: absolute;
	z-index: 2;
	background: none;
	border: none;
	color: var(--white);
	cursor: pointer;
	line-height: 1;
	transition: opacity 0.15s ease;
	opacity: 0.7;
}

.bts-lightbox__prev:hover,
.bts-lightbox__next:hover,
.bts-lightbox__close:hover {
	opacity: 1;
}

.bts-lightbox__prev,
.bts-lightbox__next {
	top: 50%;
	transform: translateY( -50% );
	font-size: 2.5rem;
	padding: 1rem 1.5rem;
}

.bts-lightbox__prev { left: 1rem; }
.bts-lightbox__next { right: 1rem; }

.bts-lightbox__close {
	top: 1.25rem;
	right: 1.5rem;
	font-size: 2rem;
	padding: 0.5rem;
}

/* ===================================================================
   FOOTER
=================================================================== */

.site-footer {
	background: var(--black);
	color: var(--white);
	position: relative;
	overflow: hidden;
}

/* Texture grain overlay */
.site-footer::before {
	content: '';
	position: absolute;
	inset: 0;
	background: url('images/texture.jpg') center / cover fixed;
	filter: grayscale(1) brightness(0.4);
	opacity: 0.35;
	mix-blend-mode: screen;
	pointer-events: none;
	z-index: 0;
}

.site-footer > * {
	position: relative;
	z-index: 1;
}

.footer-top {
	display: grid;
	grid-template-columns: 1fr 1fr;
	max-width: var(--max-w);
	margin: 0 auto;
}

.footer-brand {
	padding: clamp(3rem, 5vw, 5rem) var(--gutter);
}

.footer-logo-link {
	display: inline-block;
	text-decoration: none;
}

.footer-logo-img {
	display: block;
	height: 56px;
	width: auto;
	max-width: 100%;
}

.footer-logo {
	font-family: var(--font-display);
	font-size: clamp(3rem, 6vw, 6rem);
	font-weight: 800;
	text-transform: uppercase;
	line-height: 1;
	letter-spacing: -0.04em;
	margin-bottom: 1.5rem;
	color: var(--white);
}

.footer-logo .logo-dot { color: var(--red); }

.footer-tagline {
	font-size: 1rem;
	opacity: 0.45;
	margin: 0.75rem 0 0;
	color: var(--white);
}

.footer-est {
	font-size: 0.8rem;
	opacity: 0.3;
	margin: 0.35rem 0 0;
	color: var(--white);
	letter-spacing: 0.04em;
}

.footer-nav-area {
	padding: clamp(3rem, 5vw, 5rem) var(--gutter);
}

.footer-nav-label {
	font-family: var(--font-body);
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--red);
	margin-bottom: 1.5rem;
	display: block;
}

.footer-nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.footer-nav a {
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 3vw, 2.5rem);
	font-weight: 700;
	text-transform: uppercase;
	text-decoration: none;
	color: var(--white);
	letter-spacing: -0.02em;
	transition: color 0.15s;
	line-height: 1.1;
}

.footer-nav a:hover { color: var(--lime); }

.footer-bottom {
	max-width: var(--max-w);
	margin: 0 auto;
	padding: 1.5rem var(--gutter);
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1rem;
}

.footer-copy,
.footer-credit {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	opacity: 0.35;
	color: var(--white);
}

.footer-credit a {
	color: var(--white);
	opacity: 0.7;
}

/* ===================================================================
   FORMS
=================================================================== */

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
textarea {
	width: 100%;
	background: var(--white);
	color: var(--black);
	border: var(--border);
	border-radius: 0;
	padding: 0.75rem 1rem;
	font-family: var(--font-body);
	font-size: 0.95rem;
	transition: border-color 0.15s;
	-webkit-appearance: none;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
textarea:focus {
	outline: none;
	border-color: var(--red);
}

input[type="submit"],
button[type="submit"] {
	display: inline-flex;
	font-family: var(--font-body);
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	padding: 0.9rem 2rem;
	background: var(--black);
	color: var(--white);
	border: var(--border);
	cursor: pointer;
	border-radius: 0;
	transition: background 0.18s;
	-webkit-appearance: none;
}

input[type="submit"]:hover,
button[type="submit"]:hover {
	background: var(--red);
	border-color: var(--red);
}

/* ===================================================================
   COMMENTS
=================================================================== */

.comments-area {
	max-width: var(--max-w);
	margin: 0 auto;
	padding: 4rem var(--gutter);
	border-top: var(--border);
}

.comment-content a { word-wrap: break-word; }

/* ===================================================================
   MEDIA
=================================================================== */

.alignleft  { float: left;  margin-right: 2rem; margin-bottom: 1.5rem; }
.alignright { float: right; margin-left:  2rem; margin-bottom: 1.5rem; }
.aligncenter { clear: both; display: block; margin: 0 auto 1.5rem; }
.alignfull  { width: 100vw; margin-left: calc(50% - 50vw); }
.alignwide  { width: calc(100% + var(--gutter) * 2); margin-left: calc(var(--gutter) * -1); }

.wp-caption { margin-bottom: 1.5em; max-width: 100%; }
.wp-caption img[class*="wp-image-"] { display: block; margin: 0 auto; }
.wp-caption-text { text-align: center; font-size: 0.85rem; opacity: 0.55; margin: 0.5rem 0 0; }

/* ===================================================================
   404
=================================================================== */

.error-404 .page-header {
	padding: clamp(5rem, 10vw, 10rem) var(--gutter);
	border-bottom: var(--border);
}

.error-404 .page-title {
	font-size: clamp(8rem, 20vw, 22rem);
	line-height: 0.85;
	margin-bottom: 1rem;
}

.error-404 .page-content {
	max-width: var(--max-w);
	margin: 0 auto;
	padding: 4rem var(--gutter);
}

/* ===================================================================
   RESPONSIVE — TABLET (max 1024px)
=================================================================== */

@media (max-width: 1024px) {
	.hero-body {
		grid-template-columns: 1fr;
		grid-template-rows: auto auto;
	}

	.hero-text {
		border-right: 0;
	}

	.hero-text-image {
		min-height: 50vw;
		border-top: var(--border);
	}

	.hero-visual {
		min-height: 56vw;
	}

	.page-content-wrap .wp-block-columns.has-3-columns,
	.page-content-wrap .wp-block-columns.has-4-columns {
		grid-template-columns: 1fr 1fr;
	}

	.page-content-wrap .wp-block-columns.has-4-columns .wp-block-column:nth-child(2),
	.page-content-wrap .wp-block-columns.has-3-columns .wp-block-column:nth-child(2) {
		border-right: 0;
	}

	.footer-top { grid-template-columns: 1fr; }
	.footer-brand { border-right: 0; }
}

/* ===================================================================
   RESPONSIVE — MOBILE (max 768px)
=================================================================== */

@media (max-width: 768px) {
	:root {
		--nav-height: 60px;
	}

	/* Portfolio archive — stack image above meta on mobile */
	.portfolio-tile__link {
		grid-template-columns: 1fr;
		height: auto;
	}

	.portfolio-tile__image {
		aspect-ratio: 3 / 2;
	}

	.portfolio-tile__meta {
		border-left: 0;
		border-top: var(--border);
	}

	/* Portfolio single — stack on mobile */
	.portfolio-single__top {
		grid-template-columns: 1fr;
	}

	.portfolio-single__image {
		border-right: 0;
		border-bottom: var(--border);
		max-height: 60vw;
	}

	.portfolio-single__title-row {
		flex-direction: column;
		gap: 1rem;
	}

	.portfolio-single__title-meta {
		flex-direction: row;
		align-items: center;
	}

	/* Mobile nav */
	.menu-toggle { display: flex; }

	.main-navigation {
		position: relative;
	}

	.main-navigation ul {
		display: none;
		position: fixed;
		inset: var(--nav-height) 0 0 0;
		background: var(--white);
		border-top: var(--border);
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: 1.5rem;
		z-index: 800;
	}

	.main-navigation.toggled ul {
		display: flex;
	}

	.main-navigation a {
		font-size: 1.8rem;
		font-family: var(--font-display);
		letter-spacing: -0.02em;
	}

	/* Hero mobile */
	.hero-title {
		font-size: clamp(2.5rem, 12vw, 5rem);
	}

	/* Columns — stack on mobile */
	.page-content-wrap .wp-block-columns,
	.page-content-wrap .wp-block-columns.has-2-columns,
	.page-content-wrap .wp-block-columns.has-3-columns,
	.page-content-wrap .wp-block-columns.has-4-columns {
		grid-template-columns: 1fr;
	}

	.page-content-wrap .wp-block-column {
		border-right: 0;
		border-bottom: var(--border);
	}

	.page-content-wrap .wp-block-column:last-child {
		border-bottom: 0;
	}

	/* Footer */
	.footer-bottom {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.5rem;
	}

	/* Alignments */
	.alignleft, .alignright {
		float: none;
		margin: 0 0 1.5rem;
	}
}

/* ===================================================================
   KONTAKT PAGE
=================================================================== */

.kontakt-page {
	display: flex;
	flex-direction: column;
}

/* Header */
.kontakt-header {
	border-bottom: var(--border);
}

.kontakt-header__inner {
	max-width: var(--max-w);
	margin: 0 auto;
	padding: clamp(3rem, 5vw, 5rem) var(--gutter) clamp(2.5rem, 4vw, 4rem);
}

.kontakt-title {
	font-family: var(--font-display);
	font-size: clamp(4rem, 10vw, 10rem);
	font-weight: 800;
	text-transform: uppercase;
	line-height: 0.9;
	letter-spacing: -0.03em;
	margin: 0.25rem 0 1.25rem;
}

.kontakt-subtitle {
	max-width: 60ch;
	margin-top: 1.5rem;
}

/* Email block — full-width section with texture background */
.kontakt-email-wrap {
	background: var(--black);
	color: var(--white);
	position: relative;
	overflow: hidden;
	border-bottom: var(--border);
}

/* Texture grain — same settings as footer */
.kontakt-email-wrap::before {
	content: '';
	position: absolute;
	inset: 0;
	background: url('images/texture.jpg') center / cover fixed;
	filter: grayscale(1) brightness(0.4);
	opacity: 0.35;
	mix-blend-mode: screen;
	pointer-events: none;
	z-index: 0;
}

/* Inner block — constrained width, sits above texture */
.kontakt-email-block {
	max-width: var(--max-w);
	margin: 0 auto;
	padding: clamp(2.5rem, 4vw, 3.5rem) var(--gutter);
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	position: relative;
	z-index: 1;
}

.kontakt-email-label {
	font-family: monospace;
	font-size: 0.7rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	opacity: 0.45;
}

/* Row: email address + action buttons side by side */
.kontakt-email-row {
	display: flex;
	align-items: center;
	gap: 2rem;
}

.kontakt-email-address {
	font-family: var(--font-display);
	font-size: clamp(1.4rem, 3.5vw, 3.5rem);
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: -0.02em;
	line-height: 1;
	flex: 1;
	color: var(--white);
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 6px;
}

/* Action buttons — copy + mailto */
.kontakt-email-actions {
	display: flex;
	gap: 2rem;
	flex-shrink: 0;
}

.kontakt-email-action {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.5rem;
	background: none;
	border: none;
	padding: 0;
	cursor: pointer;
	color: var(--white);
	text-decoration: none;
}

.kontakt-email-icon {
	width: clamp(1.2rem, 2vw, 1.6rem);
	height: clamp(1.2rem, 2vw, 1.6rem);
	filter: brightness(0) invert(1);
	display: block;
}

.kontakt-email-action-label {
	font-family: monospace;
	font-size: 0.7rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	opacity: 0.45;
}

/* Info strip */
.kontakt-info {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	max-width: var(--max-w);
	margin: 0 auto;
	width: 100%;
	padding: clamp(2.5rem, 4vw, 4rem) var(--gutter);
	gap: 2rem;
}

.kontakt-info__item {
	margin: 0;
}

.kontakt-info__item dt {
	font-family: monospace;
	font-size: 0.7rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	opacity: 0.45;
	margin-bottom: 0.75rem;
}

.kontakt-info__item dd {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.7;
}

.kontakt-info__item dd a {
	color: inherit;
	text-decoration: none;
}

.kontakt-info__item dd a:hover {
	color: var(--red);
}

@media ( max-width: 700px ) {
	.kontakt-info {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.kontakt-email-row {
		flex-wrap: wrap;
		gap: 1.5rem;
	}

	.kontakt-email-address {
		flex: 0 0 100%;
	}
}

/* ===================================================================
   JETPACK
=================================================================== */

.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer { display: none; }
.infinity-end.neverending .site-footer    { display: block; }
