/**
 * HUG'N SIP — Global base (modern retail)
 */

.hugnsip-brand {
	font-family: var(--hns-font-body);
	font-size: var(--hns-text-base);
	line-height: var(--hns-leading-normal);
	color: var(--hns-text);
	background-color: var(--hns-bg);
	-webkit-font-smoothing: antialiased;
}

.hugnsip-brand .site-content {
	background-color: var(--hns-bg);
}

/* Headings — same family, modest scale */
.hugnsip-brand h1,
.hugnsip-brand h2,
.hugnsip-brand h3,
.hugnsip-brand h4,
.hugnsip-brand .entry-title,
.hugnsip-brand .elementor-heading-title {
	font-family: var(--hns-font-heading);
	font-weight: 600;
	letter-spacing: var(--hns-tracking-tight);
	color: var(--hns-text);
	line-height: var(--hns-leading-tight);
}

.hugnsip-brand h1,
.hugnsip-brand .entry-title {
	font-size: clamp(1.5rem, 3vw, 1.875rem);
}

.hugnsip-brand h2 {
	font-size: clamp(1.25rem, 2.5vw, 1.5rem);
}

.hugnsip-brand h3 {
	font-size: var(--hns-text-lg);
}

.hugnsip-brand p,
.hugnsip-brand .elementor-widget-text-editor {
	color: var(--hns-text-secondary);
	line-height: var(--hns-leading-relaxed);
}

.hugnsip-brand a:not(.hns-btn) {
	color: var(--hns-accent);
}

.hugnsip-brand a:not(.hns-btn):hover {
	color: var(--hns-accent-hover);
}

/* Buttons — clear retail CTA */
.hns-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--hns-space-2);
	min-height: 2.75rem;
	padding: 0 var(--hns-space-6);
	border-radius: var(--hns-radius);
	font-family: var(--hns-font-body);
	font-size: var(--hns-text-sm);
	font-weight: 600;
	text-decoration: none;
	border: none;
	cursor: pointer;
	transition: background var(--hns-duration) var(--hns-ease);
}

a.hns-btn,
button.hns-btn {
	-webkit-appearance: none;
	appearance: none;
}

.hns-btn--primary,
a.hns-btn--primary,
button.hns-btn--primary {
	background: var(--hns-accent);
	color: #ffffff !important;
}

.hns-btn--primary:hover,
.hns-btn--primary:focus,
a.hns-btn--primary:hover,
a.hns-btn--primary:focus,
button.hns-btn--primary:hover {
	background: var(--hns-accent-hover);
	color: #ffffff !important;
}

.hns-btn--ghost,
a.hns-btn--ghost {
	background: var(--hns-bg-elevated);
	color: var(--hns-text) !important;
	box-shadow: inset 0 0 0 1px var(--hns-border);
}

.hns-btn--ghost:hover,
a.hns-btn--ghost:hover {
	box-shadow: inset 0 0 0 1px var(--hns-accent);
	color: var(--hns-accent) !important;
}

.hns-btn--light {
	background: var(--hns-bg-elevated);
	color: var(--hns-text);
	box-shadow: inset 0 0 0 1px var(--hns-border);
}

.hns-btn:disabled {
	opacity: 0.5;
	cursor: not-allowed;
}

.hns-link {
	color: var(--hns-accent);
	font-weight: 600;
	font-size: var(--hns-text-sm);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.hns-link:hover {
	color: var(--hns-accent-hover);
}

/* Section headers — left-aligned retail default */
.hns-section__head {
	max-width: var(--hns-content);
	margin: 0 0 var(--hns-space-8);
	text-align: left;
}

.hns-section__head--center {
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.hns-section__label {
	display: block;
	font-size: var(--hns-text-xs);
	font-weight: 600;
	letter-spacing: var(--hns-tracking-label);
	text-transform: uppercase;
	color: var(--hns-text-tertiary);
	margin: 0 0 var(--hns-space-2);
}

.hns-section__title {
	font-family: var(--hns-font-heading);
	font-size: var(--hns-text-2xl);
	font-weight: 600;
	line-height: var(--hns-leading-tight);
	margin: 0 0 var(--hns-space-3);
	color: var(--hns-text);
}

.hns-section__desc {
	margin: 0;
	max-width: 32rem;
	font-size: var(--hns-text-base);
	line-height: var(--hns-leading-relaxed);
	color: var(--hns-text-secondary);
}

.hugnsip-brand .ast-container {
	max-width: var(--hns-max);
}

.hugnsip-brand .site-header {
	border-bottom: 1px solid var(--hns-border-subtle);
}

.hugnsip-brand .elementor-widget:not(:last-child) {
	margin-bottom: var(--hns-space-5);
}

.hugnsip-brand .elementor-button {
	font-family: var(--hns-font-body) !important;
	font-weight: 600 !important;
	border-radius: var(--hns-radius) !important;
}
