/*
Theme Name: Weekend Tide
Theme URI: https://weekendtide.la
Author: Longbeach Buzz
Author URI: https://longbeachbuzz.com
Description: Weekly local newsletter + companion site for Long Beach, CA. Block theme (FSE) with a token-driven design system, an "activity / tide pick" CPT, and an add-to-calendar feature that carries the full curated context.
Version: 0.1.0
Requires at least: 6.4
Tested up to: 6.5
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: weekend-tide
Tags: full-site-editing, block-styles, newsletter, editorial, one-column
*/

/* ============================================================
   WEEKEND TIDE — theme stylesheet
   Most tokens live in theme.json. This file holds the component
   CSS that's not expressible there: category chips, tide rating,
   tide cards, calendar popover, signup flow, sticky CTA bar.
   ============================================================ */

/* ---- base typography hooks ---- */
::selection { background: var(--wp--preset--color--sun); color: var(--wp--preset--color--ink); }

body {
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

/* ---- utility text ---- */
.wt-mono-label {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 11px;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--wp--preset--color--ink-faint);
}
.wt-kicker {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 12px;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--wp--preset--color--sun-deep);
}

/* ============================================================
   MASTHEAD / SITE HEADER (sticky, paper @ 86%, blur, line bottom)
   ============================================================ */
.wt-masthead {
	position: sticky;
	top: 0;
	z-index: 50;
	height: 66px;
	display: flex;
	align-items: center;
	background: rgba(247, 241, 229, .86);
	backdrop-filter: saturate(140%) blur(10px);
	-webkit-backdrop-filter: saturate(140%) blur(10px);
	border-bottom: 1px solid var(--wp--preset--color--line);
}
.wt-masthead-inner {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 28px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}
.wt-nav {
	display: flex;
	align-items: center;
	gap: 22px;
}
.wt-nav a {
	font-size: 14px;
	font-weight: 600;
	color: var(--wp--preset--color--ink-soft);
	text-decoration: none;
}
.wt-nav a:hover { color: var(--wp--preset--color--harbor-deep); }
@media (max-width: 720px) {
	.wt-nav a:not(.wt-btn) { display: none; }
}

/* ============================================================
   BUTTONS — 3 tiers, one accent
   ============================================================ */
.wt-btn,
a.wt-btn,
button.wt-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 9px;
	padding: 12px 20px;
	border-radius: 8px;
	font-family: var(--wp--preset--font-family--sans);
	font-size: 14.5px;
	font-weight: 700;
	line-height: 1;
	border: 1px solid transparent;
	cursor: pointer;
	text-decoration: none;
	transition: transform .14s ease, box-shadow .14s ease, filter .14s ease, background .14s ease;
}
.wt-btn--primary {
	background: var(--wp--preset--color--harbor);
	color: var(--wp--preset--color--paper);
}
.wt-btn--sun {
	background: var(--wp--preset--color--sun);
	color: var(--wp--preset--color--ink); /* never white */
}
.wt-btn--ghost {
	background: transparent;
	color: var(--wp--preset--color--harbor);
	border-color: var(--wp--preset--color--line);
}
.wt-btn--sm { padding: 8px 14px; font-size: 13px; }
.wt-btn:hover {
	transform: translateY(-1px);
	filter: brightness(1.04);
	box-shadow: var(--wp--custom--shadow--md, 0 2px 6px rgba(34,31,24,.07), 0 10px 24px rgba(34,31,24,.07));
}

/* inline link */
.wt-link {
	color: var(--wp--preset--color--denim);
	text-decoration: underline;
	text-underline-offset: 3px;
	font-weight: 700;
}

/* ============================================================
   TIDE CARD
   ============================================================ */
.wt-card-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
}
@media (max-width: 900px) { .wt-card-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .wt-card-grid { grid-template-columns: 1fr; } }

.wt-tide-card {
	background: var(--wp--preset--color--shell-2);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 14px;
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	display: block;
	transition: transform .14s ease, box-shadow .15s ease, border-color .15s ease;
	box-shadow: 0 1px 2px rgba(34,31,24,.06), 0 2px 6px rgba(34,31,24,.05);
}
.wt-tide-card:hover {
	transform: translateY(-3px);
	border-color: var(--wp--preset--color--harbor);
	box-shadow: 0 2px 6px rgba(34,31,24,.07), 0 10px 24px rgba(34,31,24,.07);
}
.wt-tide-card__media {
	aspect-ratio: 16 / 9;
	background: var(--wp--preset--color--sand);
	background-size: cover;
	background-position: center;
}
.wt-tide-card__body { padding: 16px; }
.wt-tide-card__topline {
	display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
}
.wt-tide-card__title {
	font-family: var(--wp--preset--font-family--display);
	font-weight: 700;
	font-size: 17px;
	line-height: 1.15;
	color: var(--wp--preset--color--harbor-deep);
	margin: 0;
}
.wt-tide-card__meta {
	font-size: 13px;
	color: var(--wp--preset--color--ink-faint);
	margin-top: 6px;
	font-family: var(--wp--preset--font-family--mono);
	letter-spacing: .02em;
}
.wt-tide-card__cta {
	margin-top: 12px;
	display: flex; align-items: center; gap: 7px;
	color: var(--wp--preset--color--ink-faint);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 11px;
	letter-spacing: .08em;
	text-transform: uppercase;
	transition: color .15s ease;
}
.wt-tide-card:hover .wt-tide-card__cta { color: var(--wp--preset--color--sun-deep); }

/* ============================================================
   CATEGORY CHIPS (per-category bg/fg)
   ============================================================ */
.wt-chip {
	display: inline-flex;
	align-items: center;
	padding: 3px 8px;
	border-radius: 4px;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 10.5px;
	letter-spacing: .12em;
	text-transform: uppercase;
	font-weight: 500;
}
.wt-chip--food    { background: #f3e3d2; color: #9a531f; }
.wt-chip--music   { background: #e0e6e9; color: #27566b; }
.wt-chip--family  { background: #e3ece1; color: #3f6b46; }
.wt-chip--arts    { background: #efe1e0; color: #a8463a; }
.wt-chip--outdoor { background: #e7ecdf; color: #5c6e3a; }
.wt-chip--free    { background: #f0e7cf; color: #7a6526; }
.wt-chip--default { background: var(--wp--preset--color--sand); color: var(--wp--preset--color--ink-soft); }

/* ============================================================
   TIDE RATING (up to 3 wave glyphs)
   ============================================================ */
.wt-rating {
	display: inline-flex;
	gap: 2px;
	align-items: center;
}
.wt-rating svg { display: block; }
.wt-rating--off { opacity: .25; }

/* ============================================================
   HERO
   ============================================================ */
.wt-hero {
	max-width: 1200px;
	margin: 0 auto;
	padding: 54px 28px 40px;
	display: grid;
	grid-template-columns: 1.1fr .9fr;
	gap: 44px;
	align-items: center;
}
@media (max-width: 900px) {
	.wt-hero { grid-template-columns: 1fr; gap: 36px; padding: 36px 20px; }
}
.wt-hero h1 {
	font-family: var(--wp--preset--font-family--display);
	font-weight: 800;
	font-size: clamp(40px, 4.6vw, 62px);
	line-height: 1.0;
	letter-spacing: -.025em;
	color: var(--wp--preset--color--harbor-deep);
	margin: 16px 0 0;
}
.wt-hero__lede {
	font-size: 18px;
	line-height: 1.55;
	color: var(--wp--preset--color--ink-soft);
	max-width: 460px;
	margin: 0;
}
.wt-hero__proof {
	margin-top: 18px;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 12px;
	letter-spacing: .06em;
	color: var(--wp--preset--color--ink-faint);
}
.wt-hero__media {
	position: relative;
}
.wt-hero__media-img {
	aspect-ratio: 4 / 5;
	background: var(--wp--preset--color--sand) center/cover no-repeat;
	border-radius: 20px;
	overflow: hidden;
}
.wt-hero__pick-card {
	position: absolute;
	bottom: -16px;
	left: -16px;
	background: var(--wp--preset--color--harbor);
	color: var(--wp--preset--color--paper);
	padding: 14px 18px;
	border-radius: 14px;
	box-shadow: 0 2px 6px rgba(34,31,24,.07), 0 10px 24px rgba(34,31,24,.07);
	max-width: 220px;
}
.wt-hero__pick-card .wt-mono-label { color: var(--wp--preset--color--gold); }
.wt-hero__pick-card-title {
	font-family: var(--wp--preset--font-family--display);
	font-weight: 700;
	font-size: 16px;
	line-height: 1.15;
	margin-top: 5px;
}

/* ============================================================
   THIS-WEEK BAND
   ============================================================ */
.wt-week-band {
	background: var(--wp--preset--color--sand);
	border-top: 1px solid var(--wp--preset--color--line);
	padding: 34px 28px;
}
.wt-week-band__inner {
	max-width: 1200px;
	margin: 0 auto;
}
.wt-week-band__head {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: 6px;
	gap: 16px;
	flex-wrap: wrap;
}
.wt-week-band__caption {
	margin: 2px 0 18px;
	font-size: 13.5px;
	color: var(--wp--preset--color--ink-soft);
}

/* ============================================================
   SIGNUP FORM
   ============================================================ */
.wt-signup {
	background: var(--wp--preset--color--shell-2);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 20px;
	box-shadow: 0 2px 6px rgba(34,31,24,.07), 0 10px 24px rgba(34,31,24,.07);
	overflow: hidden;
}
.wt-signup__progress {
	height: 4px;
	background: var(--wp--preset--color--sand);
}
.wt-signup__progress-fill {
	height: 100%;
	width: 0%;
	background: var(--wp--preset--color--sun);
	transition: width .4s cubic-bezier(.4, 0, .2, 1);
}
.wt-signup__body {
	padding: 22px;
}
.wt-signup__step { display: none; }
.wt-signup__step.is-active { display: block; }
.wt-signup__title {
	font-family: var(--wp--preset--font-family--display);
	font-weight: 700;
	font-size: 24px;
	margin: 10px 0 6px;
	color: var(--wp--preset--color--harbor-deep);
	letter-spacing: -.01em;
}
.wt-signup__sub {
	margin: 0 0 18px;
	color: var(--wp--preset--color--ink-soft);
	font-size: 14.5px;
	line-height: 1.5;
}
.wt-signup__row {
	display: flex; gap: 10px; flex-wrap: wrap;
}
.wt-signup__email {
	flex: 1;
	min-width: 180px;
	padding: 13px 16px;
	font-size: 15px;
	font-family: var(--wp--preset--font-family--sans);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 8px;
	background: var(--wp--preset--color--paper);
	color: var(--wp--preset--color--ink);
	outline: none;
}
.wt-signup__email.is-error { border-color: var(--wp--preset--color--coral); }
.wt-signup__err {
	color: var(--wp--preset--color--coral);
	font-size: 13px;
	margin-top: 9px;
	font-weight: 600;
	display: none;
}
.wt-signup__err.is-active { display: block; }
.wt-signup__trust {
	margin-top: 14px;
	display: flex;
	gap: 16px;
	flex-wrap: wrap;
	font-family: var(--wp--preset--font-family--mono);
	font-size: 11px;
	letter-spacing: .06em;
	color: var(--wp--preset--color--ink-faint);
}
.wt-pill-group {
	display: flex; flex-wrap: wrap; gap: 8px;
	margin-bottom: 18px;
}
.wt-pill {
	padding: 8px 14px;
	border-radius: 20px;
	cursor: pointer;
	font-family: var(--wp--preset--font-family--sans);
	font-size: 13.5px;
	font-weight: 600;
	border: 1px solid var(--wp--preset--color--line);
	background: var(--wp--preset--color--shell);
	color: var(--wp--preset--color--ink-soft);
	transition: all .14s ease;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.wt-pill[aria-pressed="true"] {
	background: var(--wp--preset--color--harbor);
	color: var(--wp--preset--color--paper);
	border-color: var(--wp--preset--color--harbor);
}
.wt-signup__back {
	background: none;
	border: none;
	color: var(--wp--preset--color--ink-faint);
	cursor: pointer;
	font-family: var(--wp--preset--font-family--sans);
	font-size: 14px;
}

/* ============================================================
   ACTIVITY DETAIL PAGE
   ============================================================ */
.wt-activity {
	max-width: 720px;
	margin: 0 auto;
	padding: 32px 20px 64px;
}
.wt-activity__hero {
	position: relative;
	aspect-ratio: 16 / 9;
	border-radius: 14px;
	overflow: hidden;
	background: var(--wp--preset--color--sand) center/cover no-repeat;
	margin-bottom: 22px;
}
.wt-activity__hero-overlay {
	position: absolute;
	left: 16px; bottom: 14px;
	display: flex; gap: 8px; align-items: center;
}
.wt-activity__hero-pill {
	background: var(--wp--preset--color--paper);
	border-radius: 20px;
	padding: 4px 10px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.wt-activity__hero-pill span {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 10px;
	color: var(--wp--preset--color--ink-soft);
	letter-spacing: .06em;
}
.wt-activity__when {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 11px;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: var(--wp--preset--color--sun-deep);
}
.wt-activity__title {
	font-family: var(--wp--preset--font-family--display);
	font-weight: 800;
	font-size: 27px;
	line-height: 1.08;
	letter-spacing: -.015em;
	color: var(--wp--preset--color--harbor-deep);
	margin: 8px 0 0;
}
.wt-activity__facts {
	display: flex; flex-wrap: wrap; gap: 8px;
	margin: 14px 0 16px;
}
.wt-fact {
	background: var(--wp--preset--color--shell-2);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 8px;
	padding: 8px 12px;
}
.wt-fact__label {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 9.5px;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--wp--preset--color--ink-faint);
}
.wt-fact__value {
	font-size: 14px;
	font-weight: 700;
	color: var(--wp--preset--color--harbor-deep);
	margin-top: 2px;
}
.wt-fact__value--free { color: var(--wp--preset--color--success, #3a7d52); }
.wt-activity__blurb {
	font-size: 15.5px;
	line-height: 1.55;
	color: var(--wp--preset--color--ink);
	margin: 0 0 6px;
}
.wt-why {
	background: var(--wp--preset--color--sand);
	border-radius: 8px;
	padding: 16px;
	margin: 14px 0;
}
.wt-why__label {
	color: var(--wp--preset--color--sun-deep);
	margin-bottom: 7px;
}
.wt-why p {
	margin: 0;
	font-size: 14.5px;
	line-height: 1.55;
	color: var(--wp--preset--color--ink-soft);
}
.wt-goodtoknow__row {
	display: grid;
	grid-template-columns: 78px 1fr;
	gap: 12px;
	padding: 10px 0;
	border-bottom: 1px solid var(--wp--preset--color--line-soft, #e8ddc6);
}
.wt-goodtoknow__label {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 11px;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--wp--preset--color--harbor);
	padding-top: 1px;
}
.wt-goodtoknow__text {
	font-size: 14px;
	color: var(--wp--preset--color--ink-soft);
	line-height: 1.5;
}
.wt-cal-wrap {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-top: 22px;
	flex-wrap: wrap;
}
.wt-cal-wrap__caption {
	font-size: 12.5px;
	color: var(--wp--preset--color--ink-faint);
	font-style: italic;
	max-width: 240px;
	line-height: 1.4;
}

/* ============================================================
   ADD-TO-CALENDAR POPOVER
   ============================================================ */
.wt-cal {
	position: relative;
	display: inline-block;
}
.wt-cal__pop {
	position: absolute;
	top: calc(100% + 10px);
	left: 0;
	z-index: 40;
	width: 320px;
	background: var(--wp--preset--color--shell-2);
	border: 1px solid var(--wp--preset--color--line);
	border-radius: 14px;
	box-shadow: 0 8px 18px rgba(34,31,24,.09), 0 24px 60px rgba(34,31,24,.10);
	overflow: hidden;
	animation: wtPop .26s cubic-bezier(.2,.7,.3,1);
}
.wt-cal__pop[hidden] { display: none; }
.wt-cal__head {
	padding: 14px 16px;
	border-bottom: 1px solid var(--wp--preset--color--line-soft, #e8ddc6);
}
.wt-cal__head-sub {
	font-size: 13px;
	color: var(--wp--preset--color--ink-soft);
	margin-top: 7px;
	line-height: 1.5;
}
.wt-cal__row {
	display: flex;
	align-items: center;
	gap: 12px;
	width: 100%;
	text-align: left;
	background: transparent;
	border: none;
	padding: 13px 16px;
	cursor: pointer;
	font-family: var(--wp--preset--font-family--sans);
	font-size: 14.5px;
	color: var(--wp--preset--color--ink);
	text-decoration: none;
}
.wt-cal__row + .wt-cal__row {
	border-top: 1px solid var(--wp--preset--color--line-soft, #e8ddc6);
}
.wt-cal__row:hover {
	background: var(--wp--preset--color--shell);
}
.wt-cal__icon {
	width: 30px; height: 30px;
	border-radius: 7px;
	display: grid; place-items: center;
	font-weight: 800; font-size: 15px;
	flex: 0 0 30px;
}
.wt-cal__icon--g { background: #e8f0ea; color: #3a7d52; }
.wt-cal__icon--a { background: #e0e6e9; color: #27566b; }
.wt-cal__sub {
	display: block;
	font-size: 12px;
	color: var(--wp--preset--color--ink-faint);
	margin-top: 2px;
}
.wt-cal__scrim {
	position: fixed; inset: 0;
	z-index: 30;
}
.wt-cal__scrim[hidden] { display: none; }

@keyframes wtPop {
	from { opacity: 0; transform: translateY(14px) scale(.98); }
	to   { opacity: 1; transform: none; }
}

/* ============================================================
   STICKY FOOTER CTA BAR
   ============================================================ */
.wt-sticky-cta {
	position: fixed;
	left: 0; right: 0; bottom: 0;
	z-index: 60;
	background: var(--wp--preset--color--harbor);
	color: var(--wp--preset--color--paper);
	padding: 12px 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
	transform: translateY(100%);
	transition: transform .25s ease;
	box-shadow: 0 -8px 18px rgba(34,31,24,.10);
}
.wt-sticky-cta.is-visible { transform: translateY(0); }
.wt-sticky-cta__text {
	font-family: var(--wp--preset--font-family--sans);
	font-size: 14px;
	font-weight: 600;
}

/* ============================================================
   FOOTER
   ============================================================ */
.wt-footer {
	background: var(--wp--preset--color--harbor-deep);
	color: var(--wp--preset--color--paper);
	padding: 48px 28px 32px;
	margin-top: 64px;
}
.wt-footer__inner {
	max-width: 1200px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr;
	gap: 32px;
}
@media (max-width: 720px) { .wt-footer__inner { grid-template-columns: 1fr; } }
.wt-footer h4 {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 11px;
	letter-spacing: .16em;
	text-transform: uppercase;
	color: rgba(247,241,229,.6);
	margin: 0 0 12px;
}
.wt-footer a {
	display: block;
	color: var(--wp--preset--color--paper);
	text-decoration: none;
	font-size: 14px;
	margin-bottom: 6px;
}
.wt-footer a:hover { color: var(--wp--preset--color--sun); }
.wt-footer__bottom {
	max-width: 1200px;
	margin: 32px auto 0;
	padding-top: 20px;
	border-top: 1px solid rgba(247,241,229,.12);
	font-family: var(--wp--preset--font-family--mono);
	font-size: 11px;
	letter-spacing: .08em;
	color: rgba(247,241,229,.5);
	text-transform: uppercase;
}

/* ============================================================
   SPONSOR / PARTNER PLACEMENTS
   ============================================================ */
.wt-sponsor {
	background: var(--wp--preset--color--partner-bg);
	border: 1px dashed #c9b78c; /* partner-line */
	border-radius: 14px;
	padding: 20px;
	color: #6b5a2f; /* partner-ink */
}
.wt-sponsor__label {
	font-family: var(--wp--preset--font-family--mono);
	font-size: 10px;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: #6b5a2f;
	margin-bottom: 8px;
}

/* ============================================================
   ACCESSIBILITY HELPERS
   ============================================================ */
.screen-reader-text {
	position: absolute !important;
	clip: rect(1px, 1px, 1px, 1px);
	width: 1px; height: 1px;
	overflow: hidden;
}
