/* ============================================================
	COMPONENTS.CSS
	Reusable UI atoms: buttons, cards, forms, badges, and the
	app tour widget. Depends on tokens in base.css.
	============================================================ */


/* ── BUTTONS ── */

/* Primary filled button */
.btn-primary {
	display:         inline-block;
	background:      var(--color-signal);
	color:       w  hite;
	font-family:     var(--font-sans);
	font-size:       15px;
	font-weight:     600;
	padding:         15px 34px;
	border:          none;
	border-radius:   3px;
	cursor:          pointer;
	text-decoration: none;
	box-shadow:      0 4px 22px rgba(1, 85, 1, 0.2);
	transition:
		background       var(--transition-fast),
		transform        var(--transition-fast),
		box-shadow       var(--transition-fast);
}

.btn-primary:hover {
	background: var(--color-signal-dark);
	transform:  translateY(-2px);
	box-shadow: 0 8px 30px rgba(1, 85, 1, 0.28);
}

/* Small variant — nav CTA */
.btn-primary-sm {
	font-size:     13px;
	padding:       9px 20px;
	border-radius: 3px;
}

/* Ghost text link button */
.btn-ghost {
	font-family:     var(--font-mono);
	font-size:       12px;
	letter-spacing:  0.1em;
	text-transform:  uppercase;
	color:           var(--color-muted-text);
	text-decoration: none;
	border-bottom:   1px solid var(--color-border-strong);
	padding-bottom:  2px;
	transition:      color var(--transition-fast);
}

.btn-ghost:hover {
	color: var(--color-ink);
}


/* ── BADGES ── */

/* Early access / status badge (nav) */
.badge-status {
	font-family:    var(--font-mono);
	font-size:      10px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	background:     var(--color-signal-subtle);
	color:          var(--color-signal-solid);
	border:         1px solid var(--color-signal-border);
	padding:        5px 12px;
	border-radius:  2px;
}


/* ── STATUS DOTS ── */

/* Base dot — size and color set per context via modifier or parent */
.status-dot {
	display:       inline-block;
	border-radius: 50%;
	flex-shrink:   0;
}

.status-dot-sm {
	width:  6px;
	height: 6px;
}

.status-dot-md {
	width:  8px;
	height: 8px;
}

/* Signal green dot with glow (nav, footer) */
.status-dot-signal {
	background: var(--color-signal);
	box-shadow: 0 0 10px rgba(1, 85, 1, 0.4);
}


/* ── PAIN POINT ITEM ── */

.pain-point-list {
	max-width: 880px;
}

.pain-point-item {
	display:               grid;
	grid-template-columns: 48px 1fr;
	gap:                   24px;
	align-items:           start;
	padding:               32px 0;
	border-bottom:         1px solid var(--color-border);
}

.pain-point-item:first-child {
	padding-top: 0;
}

.pain-point-number {
	font-family: var(--font-mono);
	font-size:   11px;
	color:       var(--color-signal-solid);
	opacity:     0.65;
	padding-top: 4px;
	text-align:  right;
}

.pain-point-title {
	font-family:   var(--font-serif);
	font-size:     22px;
	margin-bottom: 8px;
}

.pain-point-body {
	font-size:   15px;
	color:     #4a4a47;
	line-height: 1.75;
}


/* ── FEATURE CARD ── */
/* Used inside .feature-card-grid (dark background) */

.feature-card-grid {
	max-width: 880px;
}

.feature-card {
	background: var(--color-ink);
	padding:    36px 28px;
	transition: background var(--transition-fast);
}

.feature-card:hover {
	background: #181917;
}

.feature-card-label {
	font-family:    var(--font-mono);
	font-size:      10px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color:        rgba(74, 158, 74, 0.8);
	margin-bottom:  18px;
}

.feature-card-title {
	font-family:   var(--font-serif);
	font-size:     20px;
	color:         var(--color-paper);
	margin-bottom: 10px;
}

.feature-card-body {
	font-size:   14px;
	color:     rgba(245, 242, 235, 0.46);
	line-height: 1.7;
}


/* ── AUDIENCE CARD ── */

.audience-card-grid {
	max-width: 880px;
}

.audience-card {
	border:        1px solid var(--color-border-strong);
	border-radius: 4px;
	padding:       30px 26px;
	background:    var(--color-surface-warm);
	transition:
		box-shadow     var(--transition-base),
		transform      var(--transition-base);
}

.audience-card:hover {
	box-shadow: 0 8px 32px rgba(1, 85, 1, 0.07);
	transform:  translateY(-2px);
}

.audience-card-title {
	font-family:   var(--font-serif);
	font-size:     20px;
	margin-bottom: 10px;
}

.audience-card-body {
	font-size:   14px;
	color:     #5a5a57;
	line-height: 1.7;
}


/* ── CTA SECTION — LEFT COLUMN ── */

.cta-left {
	padding: 0 12px;
}

.cta-left-heading {
	font-size:     clamp(30px, 3.8vw, 48px);
	margin-bottom: 16px;
}

.cta-left-heading em {
	font-style: italic;
	color:      var(--color-muted-text);
}

.cta-left-body {
	font-size:     16px;
	color:       #4a4a47;
	line-height:   1.75;
	margin-bottom: 28px;
}

.cta-promise-list {
	display:        flex;
	flex-direction: column;
	gap:            10px;
}

.cta-promise-item {
	display:        flex;
	align-items:    center;
	gap:            10px;
	font-family:    var(--font-mono);
	font-size:      11px;
	letter-spacing: 0.06em;
	color:          var(--color-muted-text);
}

.cta-promise-item::before {
	content:   '→';
	color:     var(--color-signal-solid);
	opacity:   0.65;
	font-size: 13px;
}


/* ── EARLY ACCESS FORM BOX ── */

.form-box {
	background:    var(--color-surface-warm);
	border:        1px solid var(--color-border-strong);
	border-radius: 8px;
	padding:       36px;
	box-shadow:    0 8px 40px rgba(0, 0, 0, 0.06);
}

.form-box-title {
	font-family:   var(--font-serif);
	font-size:     22px;
	margin-bottom: 4px;
}

.form-box-subtitle {
	font-family:    var(--font-mono);
	font-size:      11px;
	letter-spacing: 0.04em;
	color:          var(--color-muted-text);
	margin-bottom:  26px;
}

.form-field-group {
	display:        flex;
	flex-direction: column;
	gap:            12px;
}

.form-field-row {
	display:               grid;
	grid-template-columns: 1fr 1fr;
	gap:                   12px;
}

.form-input {
	padding:       12px 15px;
	border:        1.5px solid var(--color-border-strong);
	border-radius: 3px;
	font-size:     14px;
	font-family:   var(--font-sans);
	background:    var(--color-paper);
	color:         var(--color-ink);
	outline:       none;
	width:         100%;
	transition:    border-color var(--transition-fast);
}

.form-input:focus {
	border-color: var(--color-signal-solid);
}

.form-input::placeholder {
	color: rgba(14, 15, 12, 0.32);
}

.form-submit-btn {
	background:    var(--color-signal);
	color:       white;
	border:        none;
	padding:       14px 28px;
	border-radius: 3px;
	font-size:     15px;
	font-family:   var(--font-sans);
	font-weight:   600;
	cursor:        pointer;
	width:         100%;
	box-shadow:    0 4px 20px rgba(1, 85, 1, 0.18);
	transition:
		background     var(--transition-fast),
		box-shadow     var(--transition-fast);
}

.form-submit-btn:hover {
	background: var(--color-signal-dark);
	box-shadow: 0 8px 28px rgba(1, 85, 1, 0.26);
}

.form-submit-btn:disabled {
	background: var(--color-signal-dim);
	box-shadow: none;
	cursor:     default;
}

.form-footnote {
	font-family:    var(--font-mono);
	font-size:      10px;
	letter-spacing: 0.05em;
	color:          var(--color-muted-text);
	text-align:     center;
	line-height:    1.6;
}

.form-status {
	font-size:  14px;
	margin-top: 10px;
	text-align: center;
	min-height: 1.4em;
}

.form-status--success {
	color: #3a6b2e;
}

.form-status--error   {
	color: #b23c3c;
}


/* ── APP TOUR WIDGET ── */
/* Self-contained mockup slideshow in the hero */

.app-tour {
	position:      relative;
	max-width:     1280px;
	margin:        0 auto;
	border-radius: 10px;
	overflow:      hidden;
	box-shadow:
		0 24px 80px rgba(0, 0, 0, 0.2),
		0 0 0 1px rgba(1, 85, 1, 0.08);
	background:  #1a1a1a;
}

/* macOS-style title bar */
.app-tour-titlebar {
	background:  #2a2a2a;
	padding:       10px 16px;
	display:       flex;
	align-items:   center;
	gap:           10px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.app-tour-traffic-lights {
	display: flex;
	gap:     6px;
}

.app-tour-traffic-dot {
	width:         10px;
	height:        10px;
	border-radius: 50%;
}

.app-tour-traffic-dot-red    { background: #ff5f57; }
.app-tour-traffic-dot-yellow { background: #febc2e; }
.app-tour-traffic-dot-green  { background: #28c840; }

.app-tour-url-bar {
	flex:           1;
	background:   rgba(255, 255, 255, 0.07);
	border-radius:  4px;
	padding:        4px 12px;
	font-family:    var(--font-mono);
	font-size:      11px;
	color:        rgba(255, 255, 255, 0.35);
	letter-spacing: 0.03em;
	text-align:     center;
	transition:     opacity var(--transition-base);
}

/* Slide viewport */
.app-tour-viewport {
	position:     relative;
	width:        100%;
	overflow:     hidden;
	background: #f8f9fa;
}

.app-tour-slide {
	position: relative;
	width: 100%;
	opacity: 0;
	transition: opacity 0.9s ease;
	display: none;
}

.app-tour-slide.is-active {
	opacity: 1;
	display: block;
}

.app-tour-slide img,
.app-tour-slide video {
	width: 100%;
	height: auto;
	display: block;
}

/* Floating caption overlay on each slide */
.app-tour-slide-caption {
	position:        absolute;
	bottom:          18px;
	left:            50%;
	transform:       translateX(-50%);
	background:    rgba(14, 15, 12, 0.8);
	backdrop-filter: blur(8px);
	border:          1px solid rgba(255, 255, 255, 0.1);
	border-radius:   6px;
	padding:         9px 18px;
	font-family:     var(--font-mono);
	font-size:       11px;
	letter-spacing:  0.07em;
	color:         white;
	white-space:     nowrap;
	display:         flex;
	align-items:     center;
	gap:             10px;
}

.app-tour-slide-caption-dot {
	width:         6px;
	height:        6px;
	border-radius: 50%;
	background:  #4ade80;
	flex-shrink:   0;
	box-shadow:    0 0 8px #4ade80;
}

/* Progress pip bar */
.app-tour-progress {
	display:         flex;
	gap:             6px;
	justify-content: center;
	padding:         11px 0 9px;
	background:    #2a2a2a;
}

.app-tour-progress-pip {
	height: 4px;
	border-radius: 4px;
	width: 40px;
	background: rgba(255, 255, 255, 0.18);
	border: none;
	cursor: pointer;
	transition: background var(--transition-base), width var(--transition-base);
}

.app-tour-progress-pip.is-active {
	background: rgba(1, 85, 1, 0.85);
	width: 56px;
}

.app-tour-progress-pip:hover {
	background: rgba(255, 255, 255, 0.35);
}

/* Bottom caption bar */
.app-tour-caption-bar {
	background:    #1e1e1e;
	padding:         13px 20px;
	display:         flex;
	align-items:     center;
	justify-content: space-between;
	border-top:      1px solid rgba(255, 255, 255, 0.05);
}

.app-tour-caption-text {
	font-family: var(--font-sans);
	font-size:   13px;
	color:     rgba(255, 255, 255, 0.65);
	transition:  opacity var(--transition-base);
}

.app-tour-caption-counter {
	font-family:    var(--font-mono);
	font-size:      10px;
	letter-spacing: 0.1em;
	color:        rgba(255, 255, 255, 0.25);
}


/* ── RESPONSIVE ── */

@media (max-width: 820px) {

	.form-field-row {
		grid-template-columns: 1fr;
	}

	.app-tour-slide-caption {
		font-size:   9px;
		padding:     7px 12px;
		white-space: normal;
		text-align:  center;
		width:       90%;
	}

}
