/* Arrivao Password Gate */

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

:root {
	--gate-bg: #f7f3ee;
	--gate-text: #231f20;
	--gate-muted: rgba(35,31,32,.68);
	--gate-cream: #f8f3ed;
	--gate-card-bg: rgba(255,255,255,.94);
	--gate-border: rgba(35,31,32,.12);
	--gate-accent: #8b1f4b;
	--gate-accent-dark: #6f173a;
	--gate-gold: #c9a96e;
	--gate-error-bg: rgba(139,31,75,.08);
	--gate-error-text: #8b1f4b;
	--gate-input-bg: #fff;
	--gate-input-focus: rgba(139,31,75,.16);
	--gate-radius: 18px;
	--gate-font-ui: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html {
	height: 100%;
}

body.arrivao-gate-body {
	min-height: 100%;
	background: var(--gate-bg);
	font-family: var(--gate-font-ui);
	color: var(--gate-text);
}

.arrivao-gate-header {
	width: 100%;
	min-height: 76px;
	padding: 1.05rem 1.6rem;
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	border-bottom: 1px solid rgba(35,31,32,.08);
}

.arrivao-gate-brand {
	display: flex;
	align-items: center;
	min-width: 150px;
	font-weight: 800;
	font-size: 1.25rem;
	letter-spacing: .04em;
	text-transform: uppercase;
}

.arrivao-gate-brand img {
	max-width: 145px;
	max-height: 52px;
	width: auto;
	height: auto;
	display: block;
}

.arrivao-gate-nav {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	gap: 1.7rem;
	font-size: .98rem;
	color: #171717;
	white-space: nowrap;
}

.arrivao-gate-hero {
	min-height: calc(100vh - 76px);
	padding: clamp(4rem, 10vw, 7rem) 1rem;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	overflow: hidden;
	background:
		linear-gradient(rgba(6,10,15,.58), rgba(6,10,15,.62)),
		radial-gradient(circle at 23% 35%, rgba(68,92,106,.9), transparent 28%),
		radial-gradient(circle at 75% 30%, rgba(169,93,55,.55), transparent 30%),
		linear-gradient(135deg, #14202a 0%, #11151a 45%, #2b201e 100%);
}

.arrivao-gate-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, transparent 0 18%, rgba(255,255,255,.08) 18.2% 18.5%, transparent 18.7% 100%),
		linear-gradient(0deg, rgba(255,255,255,.04), transparent 35%);
	opacity: .38;
	pointer-events: none;
}

.arrivao-gate-wrap {
	width: 100%;
	max-width: 470px;
	background: var(--gate-card-bg);
	border: 1px solid rgba(255,255,255,.38);
	border-radius: var(--gate-radius);
	padding: 2.65rem 2.5rem;
	box-shadow: 0 24px 80px rgba(0,0,0,.28);
	animation: gate-in .38s cubic-bezier(.22,.68,0,1.2) both;
	position: relative;
	z-index: 1;
	text-align: center;
}

@keyframes gate-in {
	from { opacity: 0; transform: translateY(18px) scale(.98); }
	to   { opacity: 1; transform: translateY(0) scale(1); }
}

.arrivao-gate-logo {
	text-align: center;
	margin-bottom: 1.25rem;
}

.arrivao-gate-logo img {
	max-width: 160px;
	max-height: 64px;
	width: auto;
	height: auto;
}

.arrivao-gate-eyebrow {
	font-size: .72rem;
	font-weight: 800;
	letter-spacing: .13em;
	text-transform: uppercase;
	color: var(--gate-accent);
	margin-bottom: .8rem;
}

.arrivao-gate-site-name {
	font-size: clamp(1.9rem, 4vw, 2.65rem);
	line-height: 1.05;
	font-weight: 750;
	letter-spacing: -.035em;
	text-align: center;
	color: var(--gate-text);
	margin-bottom: 1rem;
}

.arrivao-gate-message {
	font-size: 1rem;
	line-height: 1.55;
	text-align: center;
	color: var(--gate-muted);
	margin: 0 auto 1.55rem;
	max-width: 34rem;
}

.arrivao-gate-error {
	background: var(--gate-error-bg);
	color: var(--gate-error-text);
	border: 1px solid rgba(139,31,75,.18);
	border-radius: 12px;
	padding: .85rem 1rem;
	font-size: .92rem;
	margin-bottom: 1.25rem;
	text-align: left;
}

.arrivao-gate-form {
	display: grid;
	gap: .95rem;
}

.arrivao-gate-field input {
	width: 100%;
	min-height: 58px;
	border: 1px solid rgba(35,31,32,.16);
	border-radius: 12px;
	background: var(--gate-input-bg);
	color: var(--gate-text);
	font-size: 1rem;
	padding: 0 1.1rem;
	outline: none;
	transition: border-color .2s ease, box-shadow .2s ease;
}

.arrivao-gate-field input::placeholder {
	color: rgba(35,31,32,.44);
}

.arrivao-gate-field input:focus {
	border-color: var(--gate-accent);
	box-shadow: 0 0 0 4px var(--gate-input-focus);
}

.arrivao-gate-btn {
	width: 100%;
	min-height: 58px;
	border: 0;
	border-radius: 12px;
	background: var(--gate-accent);
	color: #fff;
	font-weight: 800;
	font-size: .94rem;
	letter-spacing: .04em;
	text-transform: uppercase;
	cursor: pointer;
	transition: transform .18s ease, background .18s ease, box-shadow .18s ease;
	box-shadow: 0 12px 28px rgba(139,31,75,.24);
}

.arrivao-gate-btn:hover,
.arrivao-gate-btn:focus-visible {
	background: var(--gate-accent-dark);
	transform: translateY(-1px);
}

.arrivao-gate-btn:disabled,
.arrivao-gate-field input:disabled {
	opacity: .55;
	cursor: not-allowed;
}

.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;
	width: 1px;
	word-wrap: normal !important;
}

@media (max-width: 720px) {
	.arrivao-gate-header {
		padding: .9rem 1rem;
	}

	.arrivao-gate-nav {
		display: none;
	}

	.arrivao-gate-wrap {
		padding: 2rem 1.35rem;
	}
}
