/* ==========================================================================
   CyprusBites — Public components. Requires public-tokens.css.
   Mobile-first. The one loud element per view is the match ring.
   ========================================================================== */

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

body {
	margin: 0;
	background: var(--bg-page);
	color: var(--ink);
	font-family: var(--font-body);
	font-size: var(--fs-base);
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
}

h1, h2, h3, p { margin: 0; }
a { color: var(--act); text-decoration: none; }
a:hover { color: var(--act-hover); }
img { max-width: 100%; display: block; }

:focus-visible { outline: none; box-shadow: var(--ring); border-radius: var(--r-sm); }

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

.wrap { max-width: var(--page-max); margin: 0 auto; padding: 0 var(--sp-4); }

/* ---- Header ---- */
.site-head {
	background: var(--bg-card);
	border-bottom: 1px solid var(--line);
	position: sticky; top: 0; z-index: 40;
}
.site-head .wrap { display: flex; align-items: center; gap: var(--sp-4); height: 60px; }
.brand {
	font-family: var(--font-display);
	font-weight: 800;
	font-size: 1.35rem;
	letter-spacing: -0.02em;
	color: var(--ink);
}
.brand em { font-style: normal; color: var(--act); }
.site-nav { margin-left: auto; display: flex; gap: var(--sp-5); align-items: center; }
.site-nav a { color: var(--ink-soft); font-weight: 500; font-size: var(--fs-sm); }
.site-nav a.is-here, .site-nav a:hover { color: var(--ink); }
@media (max-width: 640px) { .site-nav a.hide-sm { display: none; } }

/* ---- Hero (ink band) ---- */
.hero {
	background: var(--bg-ink);
	color: var(--ink-on-dark);
	padding: var(--sp-14) 0 var(--sp-10);
}
.hero h1 {
	font-family: var(--font-display);
	font-weight: 800;
	font-size: var(--fs-hero);
	line-height: 1.04;
	letter-spacing: -0.025em;
	max-width: 15ch;
}
.hero .lead { color: var(--ink-on-dark-soft); font-size: var(--fs-md); margin-top: var(--sp-4); max-width: 46ch; }

/* ---- Mood deck (chips) ---- */
.mood-deck { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-top: var(--sp-6); }
.mood-chip {
	display: inline-flex; align-items: center; gap: var(--sp-2);
	background: rgba(255, 255, 255, 0.07);
	border: 1px solid rgba(255, 255, 255, 0.16);
	color: var(--ink-on-dark);
	border-radius: var(--r-pill);
	padding: 9px 16px;
	font-family: var(--font-body);
	font-size: var(--fs-sm);
	font-weight: 600;
	cursor: pointer;
	transition: background-color 140ms ease, transform 140ms ease;
}
.mood-chip:hover { background: rgba(255, 255, 255, 0.14); transform: translateY(-1px); color: var(--ink-on-dark); }
.mood-chip.on-light { background: var(--bg-card); border-color: var(--line-strong); color: var(--ink); }
.mood-chip.on-light:hover { border-color: var(--act); color: var(--act-hover); }
.mood-chip.is-active { background: var(--act); border-color: var(--act); color: #fff; }

/* ---- Sections ---- */
.section { padding: var(--sp-10) 0; }
.section-head { display: flex; align-items: baseline; gap: var(--sp-4); margin-bottom: var(--sp-5); }
.section-head h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-xl); letter-spacing: -0.015em; }
.section-head .more { margin-left: auto; font-size: var(--fs-sm); font-weight: 600; white-space: nowrap; }
.section-sub { color: var(--ink-faint); font-size: var(--fs-sm); margin-top: -var(--sp-4); }

/* ---- Result cards ---- */
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: var(--sp-4); }
.r-card {
	background: var(--bg-card);
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	overflow: hidden;
	box-shadow: var(--shadow-card);
	display: flex; flex-direction: column;
	transition: transform 140ms ease, box-shadow 140ms ease;
}
.r-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-pop); }
.r-card .photo { height: 168px; background: var(--bg-dip); position: relative; }
.r-card .photo img { width: 100%; height: 100%; object-fit: cover; }
.r-card .photo .flag {
	position: absolute; top: var(--sp-3); left: var(--sp-3);
	background: var(--sun); color: var(--petrol-950);
	font-size: var(--fs-xs); font-weight: 700;
	border-radius: var(--r-pill); padding: 3px 10px;
}
.r-card .body { padding: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-2); flex: 1; }
.r-card .name { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-lg); letter-spacing: -0.01em; color: var(--ink); }
.r-card .meta { color: var(--ink-faint); font-size: var(--fs-sm); }
.r-card .meta .open { color: var(--good-600); font-weight: 600; }
.r-card .meta .closed { color: var(--ink-faint); }

/* DNA stamps */
.dna { display: flex; flex-wrap: wrap; gap: var(--sp-1); }
.stamp {
	background: var(--bg-dip);
	color: var(--ink-soft);
	border-radius: var(--r-sm);
	padding: 2px 8px;
	font-size: var(--fs-xs);
	font-weight: 600;
}
.stamp.hit { background: var(--act-wash); color: var(--act-hover); }
.stamp.gem { background: var(--sun-wash); color: var(--warn-600); }

/* ---- Match ring (the signature) ---- */
.match-row { display: flex; gap: var(--sp-3); align-items: flex-start; }
.ring { width: 56px; height: 56px; flex: none; position: relative; }
.ring svg { transform: rotate(-90deg); }
.ring .track { stroke: var(--wash-200); }
.ring .arc { stroke: var(--match); stroke-linecap: round; transition: stroke-dashoffset 500ms ease; }
.ring .pct {
	position: absolute; inset: 0;
	display: grid; place-items: center;
	font-family: var(--font-display); font-weight: 800; font-size: 0.95rem; color: var(--match);
}
.reasons { display: flex; flex-direction: column; gap: 3px; font-size: var(--fs-sm); color: var(--ink-soft); }
.reasons li { list-style: none; }
.reasons { margin: 0; padding: 0; }
.reasons li::before { content: "— "; color: var(--match); }

/* ---- Buttons ---- */
.btn {
	display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
	font-family: var(--font-body); font-weight: 600; font-size: var(--fs-sm);
	border-radius: var(--r-pill); border: 1px solid transparent;
	padding: 10px 20px; cursor: pointer; line-height: 1;
	transition: background-color 140ms ease, border-color 140ms ease;
}
.btn-act { background: var(--act); color: #fff; }
.btn-act:hover { background: var(--act-hover); color: #fff; }
.btn-line { background: var(--bg-card); border-color: var(--line-strong); color: var(--ink); }
.btn-line:hover { border-color: var(--act); color: var(--act-hover); }
.btn-ghost { background: transparent; color: var(--ink-soft); }
.btn-ghost:hover { background: var(--bg-dip); color: var(--ink); }
.btn-lg { padding: 13px 26px; font-size: var(--fs-base); }

/* ---- Filters bar (directory) ---- */
.filter-rail {
	display: flex; gap: var(--sp-2); flex-wrap: wrap; align-items: center;
	padding: var(--sp-4) 0;
}
.filter-rail select, .filter-rail input[type="search"] {
	font: inherit; font-size: var(--fs-sm);
	border: 1px solid var(--line-strong); border-radius: var(--r-pill);
	background: var(--bg-card); color: var(--ink);
	padding: 8px 14px;
}
.filter-rail select:focus, .filter-rail input:focus { outline: none; border-color: var(--act); box-shadow: var(--ring); }

/* ---- Profile page ---- */
.profile-hero { background: var(--bg-card); border-bottom: 1px solid var(--line); padding: var(--sp-8) 0; }
.profile-hero h1 { font-family: var(--font-display); font-weight: 800; font-size: clamp(1.7rem, 5vw, 2.6rem); letter-spacing: -0.02em; }
.profile-hero .sub { color: var(--ink-faint); margin-top: var(--sp-2); }
.photo-strip { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: var(--sp-2); margin-top: var(--sp-5); }
.photo-strip img { border-radius: var(--r-md); height: 130px; width: 100%; object-fit: cover; }
.profile-cols { display: grid; grid-template-columns: 2fr 1fr; gap: var(--sp-6); align-items: start; }
@media (max-width: 800px) { .profile-cols { grid-template-columns: 1fr; } }
.panel { background: var(--bg-card); border: 1px solid var(--line); border-radius: var(--r-lg); padding: var(--sp-5); }
.panel + .panel { margin-top: var(--sp-4); }
.panel h2 { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-lg); margin-bottom: var(--sp-3); }
.sig { display: flex; gap: var(--sp-2); align-items: baseline; padding: var(--sp-1) 0; font-size: var(--fs-sm); }
.sig .yes { color: var(--good-600); font-weight: 700; }
.sig .no { color: var(--bad-600); font-weight: 700; }
.hours-line { display: flex; justify-content: space-between; font-size: var(--fs-sm); padding: 3px 0; color: var(--ink-soft); }
.hours-line.today { color: var(--ink); font-weight: 600; }
.badge-open { color: var(--good-600); font-weight: 700; }
.badge-closed { color: var(--ink-faint); font-weight: 600; }
.offer-note {
	background: var(--sun-wash); border-radius: var(--r-md);
	padding: var(--sp-3) var(--sp-4); font-size: var(--fs-sm); margin-bottom: var(--sp-2);
}
.offer-note b { color: var(--warn-600); }

/* ---- Concierge steps ---- */
.steps { max-width: 620px; margin: 0 auto; }
.step-card { background: var(--bg-card); border: 1px solid var(--line); border-radius: var(--r-lg); padding: var(--sp-6); box-shadow: var(--shadow-card); }
.step-q { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-xl); letter-spacing: -0.015em; margin-bottom: var(--sp-4); }
.step-dots { display: flex; gap: var(--sp-1); justify-content: center; margin: var(--sp-4) 0; }
.step-dots span { width: 7px; height: 7px; border-radius: 50%; background: var(--wash-300); }
.step-dots span.done { background: var(--act); }
.chip-set { display: flex; flex-wrap: wrap; gap: var(--sp-2); }

/* ---- Compare ---- */
.vs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.vs-row { display: grid; grid-template-columns: 120px 1fr 1fr; gap: var(--sp-3); padding: var(--sp-2) 0; border-bottom: 1px solid var(--line); font-size: var(--fs-sm); align-items: baseline; }
.vs-row dt { color: var(--ink-faint); }
@media (max-width: 640px) { .vs-row { grid-template-columns: 90px 1fr 1fr; } }

/* ---- Footer ---- */
.site-foot { background: var(--bg-ink); color: var(--ink-on-dark-soft); margin-top: var(--sp-14); padding: var(--sp-10) 0; font-size: var(--fs-sm); }
.site-foot a { color: var(--ink-on-dark-soft); }
.site-foot a:hover { color: var(--ink-on-dark); }
.foot-cols { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: var(--sp-8); }
@media (max-width: 700px) { .foot-cols { grid-template-columns: 1fr; } }
.foot-cols h3 { color: var(--ink-on-dark); font-size: var(--fs-sm); font-weight: 700; margin-bottom: var(--sp-3); }
.foot-cols li { list-style: none; padding: 2px 0; }
.foot-cols ul { margin: 0; padding: 0; }
.news-form { display: flex; gap: var(--sp-2); margin-top: var(--sp-3); max-width: 340px; }
.news-form input {
	flex: 1; font: inherit; font-size: var(--fs-sm);
	background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.18);
	border-radius: var(--r-pill); padding: 9px 14px; color: var(--ink-on-dark);
}
.news-form input::placeholder { color: var(--ink-on-dark-soft); }

/* ---- Utility ---- */
.empty-note { text-align: center; color: var(--ink-faint); padding: var(--sp-10) var(--sp-4); }
.pager { display: flex; gap: var(--sp-2); justify-content: center; padding: var(--sp-6) 0; }
.pager a, .pager span {
	min-width: 34px; height: 34px; display: inline-flex; align-items: center; justify-content: center;
	border-radius: var(--r-sm); font-size: var(--fs-sm); font-weight: 600; color: var(--ink-soft);
}
.pager .now { background: var(--bg-card); border: 1px solid var(--line-strong); color: var(--ink); }
.star { color: var(--sun); }
.gem-dot { color: var(--warn-600); }

/* [hidden] must always win over explicit display values */
[hidden] { display: none !important; }

/* ---- Forms (account, planner, groups) ---- */
.form-stack { display: flex; flex-direction: column; gap: var(--sp-4); max-width: 460px; }
.form-stack label { font-size: var(--fs-sm); font-weight: 600; color: var(--ink-soft); display: block; margin-bottom: var(--sp-1); }
.form-stack input, .form-stack select, .form-stack textarea {
	width: 100%; font: inherit; font-size: var(--fs-base);
	border: 1px solid var(--line-strong); border-radius: var(--r-md);
	background: var(--bg-card); color: var(--ink); padding: 11px 14px;
}
.form-stack input:focus, .form-stack select:focus, .form-stack textarea:focus { outline: none; border-color: var(--act); box-shadow: var(--ring); }
.form-error { background: #FBE9E7; color: var(--bad-600); border-radius: var(--r-md); padding: var(--sp-3) var(--sp-4); font-size: var(--fs-sm); }

/* ---- Passport ---- */
.badge-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--sp-4); }
.badge-card { text-align: center; }
.badge-card .emoji { font-size: 2rem; filter: grayscale(1); opacity: 0.45; }
.badge-card.earned .emoji { filter: none; opacity: 1; }
.badge-bar { height: 6px; background: var(--bg-dip); border-radius: var(--r-pill); overflow: hidden; margin-top: var(--sp-2); }
.badge-bar span { display: block; height: 100%; background: var(--sun); border-radius: inherit; }
.badge-card.earned .badge-bar span { background: var(--act); }

/* ---- Planner timeline ---- */
.day-block { margin-bottom: var(--sp-6); }
.day-title { font-family: var(--font-display); font-weight: 800; font-size: var(--fs-lg); margin-bottom: var(--sp-3); }
.slot-row { display: grid; grid-template-columns: 110px 1fr; gap: var(--sp-3); padding: var(--sp-3) 0; border-bottom: 1px solid var(--line); }
.slot-row:last-child { border-bottom: none; }
.slot-label { font-size: var(--fs-sm); font-weight: 700; color: var(--act-hover); text-transform: uppercase; letter-spacing: 0.04em; padding-top: 3px; }

/* ---- Profile action bar & reviews ---- */
.act-bar { display: flex; gap: var(--sp-2); flex-wrap: wrap; margin-top: var(--sp-4); }
.act-bar .btn.is-on { background: var(--match-wash); border-color: var(--match); color: var(--match); }
.memory-note { background: var(--act-wash); border-radius: var(--r-md); padding: var(--sp-3) var(--sp-4); font-size: var(--fs-sm); margin-top: var(--sp-4); }
.review-item { padding: var(--sp-3) 0; border-bottom: 1px solid var(--line); font-size: var(--fs-sm); }
.review-item:last-child { border-bottom: none; }
.review-item .who { font-weight: 700; }
.stars { color: var(--sun); letter-spacing: 1px; }

/* ---- Toasts & dialogs (replace browser defaults) ---- */
.cb-toast-region { position: fixed; bottom: var(--sp-6); left: 50%; transform: translateX(-50%); z-index: 90; display: flex; flex-direction: column; gap: var(--sp-2); align-items: center; }
.cb-toast {
	background: var(--bg-ink); color: var(--ink-on-dark);
	border-radius: var(--r-pill); padding: 10px 20px;
	font-size: var(--fs-sm); font-weight: 600;
	box-shadow: var(--shadow-pop); max-width: min(92vw, 480px); text-align: center;
}
.cb-overlay {
	position: fixed; inset: 0; background: rgba(16, 40, 44, 0.45);
	z-index: 95; display: grid; place-items: center; padding: var(--sp-4);
}
.cb-dialog {
	background: var(--bg-card); border-radius: var(--r-lg);
	box-shadow: var(--shadow-pop); width: 100%; max-width: 400px;
	padding: var(--sp-6); text-align: center;
}
.cb-dialog h3 { font-family: var(--font-display); font-weight: 800; font-size: var(--fs-lg); margin-bottom: var(--sp-2); }
.cb-dialog .big { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-xl); letter-spacing: 0.02em; margin: var(--sp-3) 0; color: var(--ink); user-select: all; }
.cb-dialog p { font-size: var(--fs-sm); color: var(--ink-soft); }
.cb-dialog .row { display: flex; gap: var(--sp-2); justify-content: center; flex-wrap: wrap; margin-top: var(--sp-5); }

/* --------------------------------------------------------------------------
   Editorial: blog & guide articles (v1.8)
   -------------------------------------------------------------------------- */
.article-body { line-height: 1.75; color: var(--ink); }
.article-body h2 { font-family: var(--font-display); font-weight: 800; font-size: var(--fs-lg); margin: var(--sp-7) 0 var(--sp-3); }
.article-body h3 { font-family: var(--font-display); font-weight: 700; font-size: var(--fs-md); margin: var(--sp-5) 0 var(--sp-2); }
.article-body p { margin-bottom: var(--sp-4); }
.article-body ul, .article-body ol { margin: 0 0 var(--sp-4) var(--sp-5); }
.article-body li { margin-bottom: var(--sp-2); }
.article-body a { color: var(--act); text-decoration-color: color-mix(in srgb, var(--act) 40%, transparent); }
.article-body strong { color: var(--ink); }
.article-body blockquote { border-left: 3px solid var(--sun); padding-left: var(--sp-4); color: var(--ink-soft); margin: var(--sp-5) 0; }

/* FAQ blocks on landing pages */
.faq-block details { border-bottom: 1px solid var(--line); padding: var(--sp-3) 0; }
.faq-block summary { font-weight: 700; cursor: pointer; }
.faq-block p { margin-top: var(--sp-2); color: var(--ink-soft); line-height: 1.65; }
