/*
Theme Name: Star Management
Theme URI: https://starmanagement.com.au
Author: Star Management
Author URI: https://starmanagement.com.au
Description: Custom WordPress theme for Star Management.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 8.2
Text Domain: starmanagement
Tags: custom-theme
*/

/* =====================
   Base Reset
   ===================== */
*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

/* =====================
   Typography & Colors
   ===================== */
:root {
	--color-primary: #1a1a2e;
	--color-accent: #e94560;
	--color-text: #333333;
	--color-bg: #ffffff;
	--font-base: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

body {
	font-family: var(--font-base);
	color: var(--color-text);
	background-color: var(--color-bg);
	line-height: 1.6;
}

a {
	color: var(--color-accent);
	text-decoration: none;
}

a:hover {
	text-decoration: underline;
}

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

/* =====================
   Layout
   ===================== */
.container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 1.5rem;
}

/* =====================
   Header
   ===================== */
.site-header {
	background-color: #ffffff;
	color: var(--color-primary);
	padding: 1.25rem 0;
	border-bottom: 1px solid #e5e5e5;
	position: relative;
}

.site-header .container {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.site-title a {
	color: var(--color-primary);
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}

.site-title a:hover {
	text-decoration: none;
	color: var(--color-accent);
}

.site-logo {
	display: block;
	width: 200px;
	height: auto;
}

/* =====================
   Navigation
   ===================== */
.nav-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0.25rem;
	z-index: 100;
}

.nav-toggle__bar {
	display: block;
	width: 24px;
	height: 2px;
	background-color: var(--color-primary);
	border-radius: 2px;
	transition: transform 0.25s, opacity 0.25s;
}

.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) {
	opacity: 0;
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

.main-navigation ul {
	list-style: none;
	display: flex;
	gap: 1.5rem;
}

.main-navigation a {
	color: var(--color-primary);
	font-size: 0.95rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	transition: color 0.2s;
}

.main-navigation a:hover {
	color: var(--color-accent);
	text-decoration: none;
}

@media (max-width: 768px) {
	.nav-toggle {
		display: flex;
	}

	.main-navigation .primary-menu {
		display: none;
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		background-color: #ffffff;
		border-top: 1px solid #e5e5e5;
		border-bottom: 1px solid #e5e5e5;
		padding: 1rem 1.5rem;
		flex-direction: column;
		gap: 0;
	}

	.main-navigation.is-open .primary-menu {
		display: flex;
	}

	.main-navigation .primary-menu li {
		border-bottom: 1px solid #f0f0f0;
	}

	.main-navigation .primary-menu li:last-child {
		border-bottom: none;
	}

	.main-navigation .primary-menu a {
		display: block;
		padding: 0.75rem 0;
	}
}

/* =====================
   Main Content
   ===================== */
.site-main {
	padding: 3rem 0;
}

/* =====================
   Footer
   ===================== */
.site-footer {
	background-color: var(--color-primary);
	color: #ccc;
	text-align: center;
	padding: 1.5rem 0;
	font-size: 0.875rem;
}

/* =====================
   Buttons
   ===================== */
.btn {
	display: inline-block;
	padding: 0.65rem 1.4rem;
	background-color: var(--color-accent);
	color: #fff;
	border-radius: 4px;
	font-weight: 600;
	transition: background-color 0.2s;
}

.btn:hover {
	background-color: #c73650;
	text-decoration: none;
}

/* =====================
   Coming Soon
   ===================== */
body.coming-soon-page {
	background-color: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 100vh;
}

.coming-soon {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2rem;
	padding: 2rem;
	text-align: center;
}

.coming-soon__logo {
	width: min(360px, 80vw);
	height: auto;
}

.coming-soon__text {
	font-size: clamp(1.5rem, 4vw, 2.5rem);
	font-weight: 300;
	color: var(--color-primary);
	letter-spacing: 0.1em;
}

/* =====================
   404
   ===================== */
body.error-404-page {
	background-color: #ffffff;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 100vh;
	color: var(--color-primary);
}

.error-404 {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: 2rem;
	max-width: 480px;
}

.error-404__logo {
	width: min(220px, 60vw);
	height: auto;
	margin-bottom: 3rem;
	opacity: 0.85;
}

.error-404__code {
	font-size: clamp(5rem, 20vw, 9rem);
	font-weight: 700;
	line-height: 1;
	color: #00aaff;
	letter-spacing: -0.04em;
}

.error-404__title {
	font-size: clamp(1.1rem, 3vw, 1.4rem);
	font-weight: 600;
	margin-top: 1rem;
	letter-spacing: 0.02em;
}

.error-404__message {
	font-size: 0.95rem;
	color: #666;
	margin-top: 0.75rem;
	line-height: 1.6;
}

.error-404__btn {
	display: inline-block;
	margin-top: 2rem;
	padding: 0.75rem 2rem;
	background-color: var(--color-primary);
	color: #fff;
	text-decoration: none;
	border-radius: 4px;
	font-size: 0.9rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	transition: background-color 0.2s;
}

.error-404__btn:hover {
	background-color: #00aaff;
}
