/*
Theme Name:        Akiya Blog
Theme URI:         https://blog.akiyatour.com
Description:       Wabi-sabi child theme of Twenty Twenty-Five for the Akiya Tour Tokyo daily listings blog. Styles the Akiya Listings plugin (filter bar, facts table, paywall teaser/fade/CTA) with the brand palette.
Author:            Akiya Tour Tokyo
Author URI:        https://akiyatour.com
Template:          twentytwentyfive
Version:           2.0.0
Requires at least: 6.7
Requires PHP:      8.1
License:           GPL-2.0-or-later
License URI:       https://www.gnu.org/licenses/gpl-2.0.html
Text Domain:       akiya-blog
*/

/* -------------------------------------------------------------------------
 * Palette & tokens
 * ---------------------------------------------------------------------- */
:root {
	--cream: #F7F4EE;
	--paper: #FDFCF9;
	--stone: #E5E0D5;
	--stone-soft: #EFEBE2;
	--moss: #6B7859;
	--moss-deep: #57644A;
	--charcoal: #2E2C28;
	--bark: #8B7355;
	--warmgray: #A39E93;
	--ink-soft: #55524B;

	--akiya-font-serif: "Noto Serif JP", "Hiragino Mincho ProN", Georgia, serif;
	--akiya-font-sans: "Noto Sans JP", "Hiragino Kaku Gothic ProN", -apple-system, sans-serif;

	--radius: 10px;
	--radius-sm: 6px;
	--shadow-card: 0 1px 2px rgba(46, 44, 40, 0.05), 0 4px 16px rgba(46, 44, 40, 0.06);
	--shadow-card-hover: 0 2px 4px rgba(46, 44, 40, 0.06), 0 12px 32px rgba(46, 44, 40, 0.12);
	--content-max: 1120px;
}

/* -------------------------------------------------------------------------
 * Base
 * ---------------------------------------------------------------------- */
body {
	background-color: var(--cream);
	color: var(--charcoal);
	font-family: var(--akiya-font-sans);
	font-size: 1.0125rem;
	line-height: 1.75;
	-webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6,
.wp-block-post-title,
.wp-block-site-title {
	font-family: var(--akiya-font-serif);
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--charcoal);
	line-height: 1.25;
}

a { color: var(--moss-deep); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--moss); }

::selection { background: var(--moss); color: var(--cream); }

/* -------------------------------------------------------------------------
 * Header
 * ---------------------------------------------------------------------- */
.akiya-header {
	max-width: var(--content-max);
	margin: 0 auto;
	padding-left: clamp(1.25rem, 4vw, 2.5rem) !important;
	padding-right: clamp(1.25rem, 4vw, 2.5rem) !important;
}

header:has(.akiya-header) {
	border-bottom: 1px solid var(--stone);
	background: var(--cream);
}

.wp-block-site-title { font-size: 1.2rem; letter-spacing: 0; }
.wp-block-site-title a { text-decoration: none; color: var(--charcoal); }
.wp-block-site-title a:hover { color: var(--moss-deep); }

.akiya-nav .wp-block-navigation-item__label {
	font-family: var(--akiya-font-sans);
	font-size: 0.8rem;
	font-weight: 500;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: var(--ink-soft);
}
.akiya-nav a { text-decoration: none; }
.akiya-nav a:hover .wp-block-navigation-item__label { color: var(--moss-deep); }
.akiya-nav { gap: 1.75rem; }

/* -------------------------------------------------------------------------
 * Page intro (homepage / archive)
 * ---------------------------------------------------------------------- */
.akiya-kicker {
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--bark);
	margin: 0 0 0.9rem;
}
/* Lives inside .akiya-intro (default layout), so no constrained-layout
   auto-centering to fight — it simply flows left. */
.akiya-lede {
	font-size: 1.1rem;
	color: var(--ink-soft);
	max-width: 34em;
	margin-top: 0.4rem;
}
h1.akiya-page-title { font-size: clamp(2rem, 4.5vw, 2.9rem); margin: 0; }

/* -------------------------------------------------------------------------
 * Filter bar
 * ---------------------------------------------------------------------- */
.akiya-filter-bar {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin: 1.75rem 0 2.25rem;
}
.akiya-filter-link {
	display: inline-block;
	padding: 0.42rem 1.05rem;
	border: 1px solid var(--stone);
	border-radius: 999px;
	background: var(--paper);
	color: var(--ink-soft);
	font-size: 0.86rem;
	font-weight: 500;
	text-decoration: none;
	transition: all 140ms ease;
}
.akiya-filter-link:hover {
	border-color: var(--moss);
	color: var(--moss-deep);
	background: #fff;
}
.akiya-filter-link.is-active {
	background: var(--moss);
	border-color: var(--moss);
	color: var(--cream);
}

/* -------------------------------------------------------------------------
 * Listing cards
 * ---------------------------------------------------------------------- */
.wp-block-post-template { gap: 1.75rem !important; }

.akiya-card {
	background: var(--paper);
	border: 1px solid var(--stone);
	border-radius: var(--radius);
	overflow: hidden;
	box-shadow: var(--shadow-card);
	transition: transform 180ms ease, box-shadow 180ms ease;
	height: 100%;
	display: flex;
	flex-direction: column;
}
.akiya-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-card-hover);
}

.akiya-card .wp-block-post-featured-image {
	margin: 0;
	overflow: hidden;
}
.akiya-card .wp-block-post-featured-image img {
	display: block;
	width: 100%;
	transition: transform 400ms ease;
}
.akiya-card:hover .wp-block-post-featured-image img { transform: scale(1.035); }

.akiya-card .wp-block-post-title {
	font-size: 1.12rem;
	line-height: 1.35;
	margin: 1rem 1.25rem 0.25rem;
}
.akiya-card .wp-block-post-title a { text-decoration: none; color: var(--charcoal); }
.akiya-card .wp-block-post-title a:hover { color: var(--moss-deep); }

.akiya-card-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.35rem 0.75rem;
	margin: 0.35rem 1.25rem 1.2rem;
	margin-top: auto;
	padding-top: 0.5rem;
}
.akiya-card-price {
	font-family: var(--akiya-font-serif);
	font-size: 1.06rem;
	font-weight: 600;
	color: var(--moss-deep);
}
.akiya-card-price .yen { font-family: var(--akiya-font-sans); font-size: 0.8rem; font-weight: 400; color: var(--warmgray); }
.akiya-card-location {
	font-size: 0.82rem;
	color: var(--warmgray);
	width: 100%;
	order: 3;
}
.akiya-locked-badge {
	font-size: 0.66rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--bark);
	background: rgba(139, 115, 85, 0.12);
	border-radius: 999px;
	padding: 0.18rem 0.6rem;
	margin-left: auto;
}

/* -------------------------------------------------------------------------
 * Single listing
 * ---------------------------------------------------------------------- */
.akiya-price {
	font-family: var(--akiya-font-serif);
	font-size: 1.45rem;
	font-weight: 600;
	color: var(--moss-deep);
	margin: 0 0 1.5rem;
}
.akiya-price .yen { font-family: var(--akiya-font-sans); font-size: 0.95rem; font-weight: 400; color: var(--warmgray); }

.akiya-single-hero img {
	border-radius: var(--radius);
	box-shadow: var(--shadow-card);
}

.akiya-facts {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(15rem, 1fr));
	column-gap: 2.5rem;
	background: var(--paper);
	border: 1px solid var(--stone);
	border-radius: var(--radius);
	padding: 0.75rem 1.5rem;
	margin: 2rem 0 2.25rem;
}
.akiya-fact {
	display: flex;
	flex-direction: column;
	padding: 0.8rem 0;
	border-bottom: 1px solid var(--stone-soft);
}
.akiya-facts .akiya-fact:last-child { border-bottom: none; }
.akiya-fact dt {
	font-size: 0.68rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--warmgray);
	margin-bottom: 0.15rem;
}
.akiya-fact dd { margin: 0; font-size: 0.98rem; color: var(--charcoal); }

.wp-block-post-content p { max-width: 42em; }

/* -------------------------------------------------------------------------
 * Paywall teaser + fade + CTA
 * ---------------------------------------------------------------------- */
.akiya-teaser { position: relative; }
.akiya-teaser p { max-width: 42em; }
.akiya-fade {
	height: 130px;
	margin-top: -130px;
	position: relative;
	background: linear-gradient(to bottom, rgba(247, 244, 238, 0), var(--cream) 88%);
	pointer-events: none;
}

.akiya-paywall-cta {
	background: var(--paper);
	border: 1px solid var(--stone);
	border-radius: var(--radius);
	box-shadow: var(--shadow-card);
	text-align: center;
	max-width: 34rem;
	margin: 0.5rem auto 2.5rem;
	padding: 2.5rem 2.25rem 2.25rem;
}
/* On archive/home pages the CTA follows the card grid, not a fade — give it
   room to breathe so it reads as its own section, not an appendix. The page's
   own bottom padding + footer spacing already handle the space below. */
.home .akiya-paywall-cta,
.archive .akiya-paywall-cta {
	margin-top: 5rem;
	margin-bottom: 0;
}
.akiya-paywall-heading {
	font-size: 1.55rem;
	margin: 0 0 0.5rem;
}
.akiya-paywall-copy {
	color: var(--ink-soft);
	font-size: 0.98rem;
	margin: 0 auto 1.5rem;
	max-width: 26em;
}
.akiya-paywall-button {
	display: inline-block;
	background: var(--moss);
	color: var(--cream);
	font-size: 0.92rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-decoration: none;
	border-radius: 999px;
	padding: 0.8rem 2.2rem;
	transition: background 140ms ease, transform 140ms ease;
}
.akiya-paywall-button:hover {
	background: var(--moss-deep);
	color: var(--cream);
	transform: translateY(-1px);
}

/* -------------------------------------------------------------------------
 * Pagination
 * ---------------------------------------------------------------------- */
.wp-block-query-pagination { margin-top: 2.5rem; font-size: 0.92rem; }
.wp-block-query-pagination a { text-decoration: none; color: var(--ink-soft); padding: 0.3rem 0.65rem; border-radius: var(--radius-sm); }
.wp-block-query-pagination a:hover { background: var(--stone-soft); color: var(--charcoal); }
.wp-block-query-pagination .page-numbers.current { color: var(--charcoal); font-weight: 600; padding: 0.3rem 0.65rem; }

/* -------------------------------------------------------------------------
 * Footer
 * ---------------------------------------------------------------------- */
.akiya-footer {
	background: var(--charcoal);
	margin-top: 2.5rem;
}
.akiya-footer-inner {
	max-width: var(--content-max);
	margin: 0 auto;
}
.akiya-footer a { color: var(--stone); text-decoration: none; }
.akiya-footer a:hover { color: #fff; }
.akiya-footer .akiya-footer-brand,
.akiya-footer .akiya-footer-brand a {
	font-family: var(--akiya-font-serif);
	font-size: 1.15rem;
	font-weight: 600;
	color: var(--cream);
}
.akiya-footer p { font-size: 0.88rem; color: var(--warmgray); }
.akiya-footer .akiya-footer-nav a { font-size: 0.84rem; letter-spacing: 0.05em; color: var(--stone); }
.akiya-footer .akiya-footer-nav a:hover { color: #fff; }

/* -------------------------------------------------------------------------
 * PMPro form polish (checkout, account, login)
 * ---------------------------------------------------------------------- */
.pmpro_card {
	background: var(--paper) !important;
	border: 1px solid var(--stone) !important;
	border-radius: var(--radius) !important;
	box-shadow: var(--shadow-card) !important;
}
.pmpro_btn, .pmpro_btn-submit-checkout, #pmpro_btn-submit {
	background: var(--moss) !important;
	border-color: var(--moss) !important;
	color: var(--cream) !important;
	border-radius: 999px !important;
	font-weight: 600 !important;
}
.pmpro_btn:hover, #pmpro_btn-submit:hover {
	background: var(--moss-deep) !important;
	border-color: var(--moss-deep) !important;
}

/* Utility toggles (e.g. "Show Password") are text links, not buttons —
   undo the big-button treatment above. */
.pmpro_btn.pmpro_btn-plain,
.pmpro_btn-password-toggle {
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	color: var(--moss-deep) !important;
	font-size: 0.8rem !important;
	font-weight: 500 !important;
	letter-spacing: 0.02em;
	padding: 0 !important;
	text-decoration: underline;
	text-underline-offset: 3px;
	white-space: nowrap;
}
.pmpro_btn.pmpro_btn-plain:hover,
.pmpro_btn-password-toggle:hover {
	background: transparent !important;
	color: var(--moss) !important;
}
/* keep label + toggle on one tidy line on small screens */
.pmpro_form_field-password-toggle { display: inline-flex; align-items: center; }
.pmpro_form input[type="text"],
.pmpro_form input[type="email"],
.pmpro_form input[type="password"] {
	border: 1px solid var(--stone) !important;
	border-radius: var(--radius-sm) !important;
	background: #fff !important;
}

/* -------------------------------------------------------------------------
 * Responsive
 * ---------------------------------------------------------------------- */
@media (max-width: 781px) {
	h1.akiya-page-title { font-size: 1.9rem; }
	.akiya-facts { grid-template-columns: 1fr; padding: 0.4rem 1.25rem; }
	.akiya-filter-bar { margin: 1.25rem 0 1.5rem; }
}

/* Locked source-link row in the facts table */
.akiya-source-locked { color: var(--warmgray); font-size: 0.82rem; white-space: nowrap; }
.akiya-source-blurred {
	filter: blur(4px);
	user-select: none;
	-webkit-user-select: none;
	color: var(--moss-deep);
	cursor: pointer;
	text-decoration: underline;
}
