/*
Theme Name:  DadFails Child
Theme URI:   https://dadfails.com
Description: A family-friendly humor and entertainment child theme for DadFails.com, built on Divi 5. Covers dad fails, parenting moments, submission forms, and community features.
Author:      Glen Collins
Author URI:  https://dadfails.com
Template:    Divi
Version:     1.0.0
Tags:        humor, family, parenting, entertainment, divi-child
Text Domain: dadfails-child
License:     GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
*/

/* =============================================================================
   GOOGLE FONTS IMPORT
   ============================================================================= */
@import url('https://fonts.googleapis.com/css2?family=Nunito:ital,wght@0,400;0,600;0,700;0,800;0,900;1,400;1,700&family=Inter:wght@300;400;500;600;700&display=swap');

/* =============================================================================
   CSS CUSTOM PROPERTIES — BRAND TOKENS
   ============================================================================= */
:root {
	/* Brand Colors */
	--df-primary:       #FF6B2B;
	--df-primary-dark:  #e05520;
	--df-primary-light: #ff8c5a;
	--df-secondary:     #1A2B4A;
	--df-secondary-dark:#111e34;
	--df-accent:        #FFD700;
	--df-accent-dark:   #e6c200;

	/* Neutrals */
	--df-bg:            #FFFFFF;
	--df-text-dark:     #2C2C2C;
	--df-text-light:    #6B7280;
	--df-light-bg:      #F8F9FA;
	--df-border:        #E5E7EB;

	/* Status / Rating */
	--df-legendary:     #FF6B2B;
	--df-medium:        #FFD700;
	--df-mild:          #4CAF50;

	/* Typography */
	--df-font-heading:  'Nunito', sans-serif;
	--df-font-body:     'Inter', sans-serif;

	/* Spacing scale */
	--df-space-xs:   0.25rem;
	--df-space-sm:   0.5rem;
	--df-space-md:   1rem;
	--df-space-lg:   1.5rem;
	--df-space-xl:   2rem;
	--df-space-2xl:  3rem;
	--df-space-3xl:  4rem;

	/* Border radius */
	--df-radius-sm:  4px;
	--df-radius-md:  8px;
	--df-radius-lg:  16px;
	--df-radius-pill: 9999px;

	/* Shadows */
	--df-shadow-sm:  0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.05);
	--df-shadow-md:  0 4px 12px rgba(0,0,0,0.10), 0 2px 6px rgba(0,0,0,0.06);
	--df-shadow-lg:  0 10px 30px rgba(0,0,0,0.14), 0 4px 12px rgba(0,0,0,0.08);
	--df-shadow-hover: 0 16px 40px rgba(255,107,43,0.18), 0 6px 16px rgba(0,0,0,0.10);

	/* Transitions */
	--df-transition: 0.2s ease;
	--df-transition-slow: 0.35s ease;

	/* Container */
	--df-container-max: 1200px;
	--df-container-pad: clamp(1rem, 4vw, 2rem);
}

/* =============================================================================
   BASE RESET & GLOBAL STYLES
   ============================================================================= */
*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	font-size: 16px;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	font-family: var(--df-font-body);
	font-size: 1rem;
	line-height: 1.65;
	color: var(--df-text-dark);
	background-color: var(--df-bg);
	margin: 0;
	padding: 0;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: var(--df-primary);
	text-decoration: none;
	transition: color var(--df-transition);
}

a:hover,
a:focus {
	color: var(--df-primary-dark);
	text-decoration: underline;
}

a:focus-visible {
	outline: 3px solid var(--df-accent);
	outline-offset: 2px;
	border-radius: var(--df-radius-sm);
}

/* =============================================================================
   TYPOGRAPHY
   ============================================================================= */
h1, h2, h3, h4, h5, h6,
.df-heading {
	font-family: var(--df-font-heading);
	font-weight: 800;
	line-height: 1.2;
	color: var(--df-secondary);
	margin-top: 0;
	margin-bottom: var(--df-space-md);
}

h1 { font-size: clamp(2rem, 5vw, 3.25rem); }
h2 { font-size: clamp(1.6rem, 4vw, 2.5rem); }
h3 { font-size: clamp(1.3rem, 3vw, 1.875rem); }
h4 { font-size: clamp(1.1rem, 2.5vw, 1.5rem); }
h5 { font-size: 1.125rem; }
h6 { font-size: 1rem; }

p {
	margin-top: 0;
	margin-bottom: var(--df-space-md);
}

strong, b { font-weight: 700; }
em, i     { font-style: italic; }

blockquote {
	border-left: 4px solid var(--df-primary);
	margin: var(--df-space-xl) 0;
	padding: var(--df-space-md) var(--df-space-xl);
	background: var(--df-light-bg);
	border-radius: 0 var(--df-radius-md) var(--df-radius-md) 0;
	font-family: var(--df-font-heading);
	font-size: 1.125rem;
	font-style: italic;
	color: var(--df-secondary);
}

blockquote cite {
	display: block;
	margin-top: var(--df-space-sm);
	font-size: 0.875rem;
	font-style: normal;
	color: var(--df-text-light);
}

code, kbd, samp, pre {
	font-family: 'Courier New', Courier, monospace;
	font-size: 0.9em;
}

code {
	background: var(--df-light-bg);
	border: 1px solid var(--df-border);
	border-radius: var(--df-radius-sm);
	padding: 0.15em 0.4em;
}

pre {
	background: var(--df-secondary);
	color: #f8f8f2;
	padding: var(--df-space-lg);
	border-radius: var(--df-radius-md);
	overflow-x: auto;
	line-height: 1.5;
}

pre code {
	background: none;
	border: none;
	padding: 0;
	color: inherit;
}

/* =============================================================================
   BUTTONS
   ============================================================================= */

/* Base button */
.df-btn,
.et_pb_button,
button[type="submit"] {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--df-space-sm);
	font-family: var(--df-font-heading);
	font-size: 1rem;
	font-weight: 700;
	line-height: 1;
	padding: 0.75rem 1.5rem;
	border-radius: var(--df-radius-pill);
	border: 2px solid transparent;
	cursor: pointer;
	text-decoration: none;
	transition: background-color var(--df-transition),
	            color var(--df-transition),
	            border-color var(--df-transition),
	            box-shadow var(--df-transition),
	            transform var(--df-transition);
	white-space: nowrap;
	user-select: none;
}

.df-btn:hover,
.df-btn:focus {
	text-decoration: none;
	transform: translateY(-2px);
}

/* Primary */
.df-btn-primary,
.et_pb_button {
	background-color: var(--df-primary);
	color: #ffffff;
	border-color: var(--df-primary);
}

.df-btn-primary:hover,
.df-btn-primary:focus,
.et_pb_button:hover {
	background-color: var(--df-primary-dark);
	border-color: var(--df-primary-dark);
	color: #ffffff;
	box-shadow: 0 6px 20px rgba(255,107,43,0.35);
}

/* Secondary */
.df-btn-secondary {
	background-color: var(--df-secondary);
	color: #ffffff;
	border-color: var(--df-secondary);
}

.df-btn-secondary:hover,
.df-btn-secondary:focus {
	background-color: var(--df-secondary-dark);
	border-color: var(--df-secondary-dark);
	color: #ffffff;
	box-shadow: 0 6px 20px rgba(26,43,74,0.3);
}

/* Outline Primary */
.df-btn-outline {
	background-color: transparent;
	color: var(--df-primary);
	border-color: var(--df-primary);
}

.df-btn-outline:hover,
.df-btn-outline:focus {
	background-color: var(--df-primary);
	color: #ffffff;
}

/* Ghost */
.df-btn-ghost {
	background-color: transparent;
	color: var(--df-text-dark);
	border-color: var(--df-border);
}

.df-btn-ghost:hover,
.df-btn-ghost:focus {
	border-color: var(--df-primary);
	color: var(--df-primary);
}

/* Accent */
.df-btn-accent {
	background-color: var(--df-accent);
	color: var(--df-secondary);
	border-color: var(--df-accent);
}

.df-btn-accent:hover,
.df-btn-accent:focus {
	background-color: var(--df-accent-dark);
	border-color: var(--df-accent-dark);
	color: var(--df-secondary);
	box-shadow: 0 6px 20px rgba(255,215,0,0.4);
}

/* Sizes */
.df-btn-sm { padding: 0.5rem 1rem; font-size: 0.875rem; }
.df-btn-lg { padding: 1rem 2rem; font-size: 1.125rem; }
.df-btn-xl { padding: 1.125rem 2.5rem; font-size: 1.25rem; }

/* Disabled */
.df-btn:disabled,
.df-btn[aria-disabled="true"] {
	opacity: 0.5;
	cursor: not-allowed;
	transform: none;
	pointer-events: none;
}

/* =============================================================================
   LINKS (standalone, not in headings)
   ============================================================================= */
.entry-content a:not([class]),
.df-prose a {
	color: var(--df-primary);
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 3px;
}

.entry-content a:not([class]):hover,
.df-prose a:hover {
	color: var(--df-primary-dark);
}

/* =============================================================================
   CARDS
   ============================================================================= */
.df-card {
	background: var(--df-bg);
	border: 1px solid var(--df-border);
	border-radius: var(--df-radius-lg);
	overflow: hidden;
	box-shadow: var(--df-shadow-sm);
	transition: box-shadow var(--df-transition-slow),
	            transform var(--df-transition-slow);
	display: flex;
	flex-direction: column;
}

.df-card:hover {
	box-shadow: var(--df-shadow-hover);
	transform: translateY(-4px);
}

.df-card__image {
	position: relative;
	aspect-ratio: 4/3;
	overflow: hidden;
}

.df-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--df-transition-slow);
}

.df-card:hover .df-card__image img {
	transform: scale(1.04);
}

.df-card__body {
	padding: var(--df-space-lg);
	flex: 1;
	display: flex;
	flex-direction: column;
}

.df-card__meta {
	display: flex;
	align-items: center;
	gap: var(--df-space-sm);
	flex-wrap: wrap;
	margin-bottom: var(--df-space-sm);
}

.df-card__title {
	font-family: var(--df-font-heading);
	font-size: 1.2rem;
	font-weight: 800;
	color: var(--df-secondary);
	margin: 0 0 var(--df-space-sm);
	line-height: 1.3;
}

.df-card__title a {
	color: inherit;
	text-decoration: none;
}

.df-card__title a:hover {
	color: var(--df-primary);
}

.df-card__excerpt {
	font-size: 0.9rem;
	color: var(--df-text-light);
	margin: 0;
	flex: 1;
}

.df-card__footer {
	padding: var(--df-space-md) var(--df-space-lg);
	border-top: 1px solid var(--df-border);
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: 0.8rem;
	color: var(--df-text-light);
}

/* =============================================================================
   BADGES
   ============================================================================= */
.df-badge {
	display: inline-flex;
	align-items: center;
	padding: 0.25em 0.75em;
	border-radius: var(--df-radius-pill);
	font-family: var(--df-font-heading);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	text-transform: uppercase;
	white-space: nowrap;
	line-height: 1.4;
}

.df-badge-primary   { background: var(--df-primary);   color: #fff; }
.df-badge-secondary { background: var(--df-secondary); color: #fff; }
.df-badge-accent    { background: var(--df-accent);    color: var(--df-secondary); }
.df-badge-light     { background: var(--df-light-bg);  color: var(--df-text-dark); border: 1px solid var(--df-border); }
.df-badge-legendary { background: var(--df-legendary); color: #fff; }
.df-badge-medium    { background: var(--df-medium);    color: var(--df-secondary); }
.df-badge-mild      { background: var(--df-mild);      color: #fff; }

/* =============================================================================
   RESPONSIVE HELPERS
   ============================================================================= */

/* Container */
.df-container {
	width: 100%;
	max-width: var(--df-container-max);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--df-container-pad);
	padding-right: var(--df-container-pad);
}

/* Display utilities */
.df-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	white-space: nowrap;
	border: 0;
}

.df-text-center  { text-align: center; }
.df-text-left    { text-align: left; }
.df-text-right   { text-align: right; }

.df-mt-0  { margin-top: 0 !important; }
.df-mb-0  { margin-bottom: 0 !important; }
.df-mt-lg { margin-top: var(--df-space-lg) !important; }
.df-mb-lg { margin-bottom: var(--df-space-lg) !important; }
.df-mt-xl { margin-top: var(--df-space-xl) !important; }
.df-mb-xl { margin-bottom: var(--df-space-xl) !important; }

/* Responsive show/hide */
@media (max-width: 767px) {
	.df-hide-mobile { display: none !important; }
}
@media (min-width: 768px) {
	.df-hide-desktop { display: none !important; }
}

/* =============================================================================
   DIVI 5 OVERRIDES
   ============================================================================= */

/* Ensure Divi picks up our font variables where possible */
.et_pb_section,
.et_pb_row,
.et_pb_module {
	font-family: var(--df-font-body);
}

.et_pb_text h1, .et_pb_text h2, .et_pb_text h3,
.et_pb_text h4, .et_pb_text h5, .et_pb_text h6 {
	font-family: var(--df-font-heading);
}

/* Primary CTA button colour from Divi builder */
.et_pb_button_0 {
	background-color: var(--df-primary) !important;
	border-color: var(--df-primary) !important;
}

/* =============================================================================
   FORMS — BASE
   ============================================================================= */
input[type="text"],
input[type="email"],
input[type="url"],
input[type="tel"],
input[type="search"],
input[type="password"],
textarea,
select {
	font-family: var(--df-font-body);
	font-size: 1rem;
	color: var(--df-text-dark);
	background: var(--df-bg);
	border: 2px solid var(--df-border);
	border-radius: var(--df-radius-md);
	padding: 0.625rem 0.875rem;
	width: 100%;
	transition: border-color var(--df-transition), box-shadow var(--df-transition);
	outline: none;
	appearance: none;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="tel"]:focus,
textarea:focus,
select:focus {
	border-color: var(--df-primary);
	box-shadow: 0 0 0 3px rgba(255,107,43,0.15);
}

label {
	display: block;
	font-family: var(--df-font-heading);
	font-weight: 700;
	font-size: 0.9rem;
	color: var(--df-secondary);
	margin-bottom: var(--df-space-xs);
}

.df-form-group {
	margin-bottom: var(--df-space-lg);
}

.df-form-help {
	display: block;
	font-size: 0.8rem;
	color: var(--df-text-light);
	margin-top: var(--df-space-xs);
}

.df-form-error {
	display: block;
	font-size: 0.8rem;
	color: #dc2626;
	margin-top: var(--df-space-xs);
}

/* =============================================================================
   ALERTS / NOTICES
   ============================================================================= */
.df-alert {
	padding: var(--df-space-md) var(--df-space-lg);
	border-radius: var(--df-radius-md);
	border-left: 4px solid transparent;
	font-size: 0.95rem;
	margin-bottom: var(--df-space-lg);
}

.df-alert-success {
	background: #ecfdf5;
	border-left-color: #10b981;
	color: #065f46;
}

.df-alert-error {
	background: #fef2f2;
	border-left-color: #dc2626;
	color: #7f1d1d;
}

.df-alert-warning {
	background: #fffbeb;
	border-left-color: var(--df-accent);
	color: #78350f;
}

.df-alert-info {
	background: #eff6ff;
	border-left-color: #3b82f6;
	color: #1e3a8a;
}

/* =============================================================================
   DIVIDER
   ============================================================================= */
.df-divider {
	border: none;
	border-top: 2px solid var(--df-border);
	margin: var(--df-space-xl) 0;
}

.df-divider-accent {
	border-top-color: var(--df-primary);
}

/* =============================================================================
   SOCIAL SHARE BUTTONS
   ============================================================================= */
.df-social-share {
	display: flex;
	gap: var(--df-space-sm);
	flex-wrap: wrap;
	align-items: center;
	margin: var(--df-space-lg) 0;
}

.df-social-share__label {
	font-family: var(--df-font-heading);
	font-weight: 700;
	font-size: 0.875rem;
	color: var(--df-text-light);
}

.df-share-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--df-space-xs);
	padding: 0.4rem 0.875rem;
	border-radius: var(--df-radius-pill);
	font-size: 0.8rem;
	font-weight: 700;
	font-family: var(--df-font-heading);
	cursor: pointer;
	border: none;
	transition: opacity var(--df-transition), transform var(--df-transition);
	color: #fff;
	text-decoration: none;
}

.df-share-btn:hover {
	opacity: 0.85;
	transform: translateY(-1px);
	color: #fff;
	text-decoration: none;
}

.df-share-btn--facebook { background: #1877F2; }
.df-share-btn--twitter  { background: #1DA1F2; }
.df-share-btn--reddit   { background: #FF4500; }
.df-share-btn--whatsapp { background: #25D366; }

/* =============================================================================
   LIKE / RATING BUTTON
   ============================================================================= */
.df-like-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--df-space-xs);
	background: var(--df-light-bg);
	border: 2px solid var(--df-border);
	border-radius: var(--df-radius-pill);
	padding: 0.4rem 1rem;
	font-family: var(--df-font-heading);
	font-size: 0.875rem;
	font-weight: 700;
	cursor: pointer;
	transition: all var(--df-transition);
	color: var(--df-text-dark);
}

.df-like-btn:hover,
.df-like-btn.is-liked {
	background: var(--df-primary);
	border-color: var(--df-primary);
	color: #fff;
}

.df-like-btn .df-like-icon {
	font-size: 1rem;
}

/* =============================================================================
   PRINT STYLES
   ============================================================================= */
@media print {
	.df-btn,
	.df-social-share,
	.df-like-btn,
	nav {
		display: none !important;
	}

	body {
		font-size: 12pt;
		color: #000;
	}

	a::after {
		content: " (" attr(href) ")";
		font-size: 0.8em;
	}
}
