/*!
Theme Name: telotraduzco
Theme URI: http://underscores.me/
Author: Underscores.me
Author URI: http://underscores.me/
Description: Description
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: telotraduzco
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

telotraduzco is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Generic
	- Normalize
	- Box sizing
# Base
	- Typography
	- Elements
	- Links
	- Forms
## Layouts
# Components
	- Navigation
	- Posts and pages
	- Comments
	- Widgets
	- Media
	- Captions
	- Galleries
# plugins
	- Jetpack infinite scroll
# Utilities
	- Accessibility
	- Alignments

--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Generic
--------------------------------------------------------------*/

/* Normalize
--------------------------------------------- */

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
	 ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
}

/* Sections
	 ========================================================================== */

/**
 * Remove the margin in all browsers.
 */
body {
	margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
	display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

/* Grouping content
	 ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
	box-sizing: content-box;
	height: 0;
	overflow: visible;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
	font-family: monospace, monospace;
	font-size: 1em;
}

/* Text-level semantics
	 ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */
a {
	background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
	border-bottom: none;
	text-decoration: underline;
	text-decoration: underline dotted;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
	font-family: monospace, monospace;
	font-size: 1em;
}

/**
 * Add the correct font size in all browsers.
 */
small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
	 ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */
img {
	border-style: none;
}

/* Forms
	 ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-size: 100%;
	line-height: 1.15;
	margin: 0;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
	overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
	text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
	-webkit-appearance: button;
	appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
	padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *		`fieldset` elements in all browsers.
 */
legend {
	box-sizing: border-box;
	color: inherit;
	display: table;
	max-width: 100%;
	padding: 0;
	white-space: normal;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
	overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
	-webkit-appearance: textfield;
	appearance: textfield;
	outline-offset: -2px;
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

/* Interactive
	 ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
	display: list-item;
}

/* Misc
	 ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */
template {
	display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
	display: none;
}

/* Box sizing
--------------------------------------------- */

/* Inherit box-sizing to more easily change it's value on a component level.
@link http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
*,
*::before,
*::after {
	box-sizing: inherit;
}

html {
	box-sizing: border-box;
}

/*--------------------------------------------------------------
# Base
--------------------------------------------------------------*/

/* Typography
--------------------------------------------- */
body,
button,
input,
select,
optgroup,
textarea {
	color: #404040;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	font-size: 1rem;
	line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	clear: both;
}

p {
	margin-bottom: 1.5em;
}

dfn,
cite,
em,
i {
	font-style: italic;
}

blockquote {
	margin: 0 1.5em;
}

address {
	margin: 0 0 1.5em;
}

pre {
	background: #eee;
	font-family: "Courier 10 Pitch", courier, monospace;
	line-height: 1.6;
	margin-bottom: 1.6em;
	max-width: 100%;
	overflow: auto;
	padding: 1.6em;
}

code,
kbd,
tt,
var {
	font-family: monaco, consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}

abbr,
acronym {
	border-bottom: 1px dotted #666;
	cursor: help;
}

mark,
ins {
	background: #fff9c0;
	text-decoration: none;
}

big {
	font-size: 125%;
}

/* Elements
--------------------------------------------- */
body {
	background: #fff;
}

hr {
	background-color: #ccc;
	border: 0;
	height: 1px;
	margin-bottom: 1.5em;
}

ul,
ol {
	margin: 0 0 1.5em 3em;
}

ul {
	list-style: disc;
}

ol {
	list-style: decimal;
}

li > ul,
li > ol {
	margin-bottom: 0;
	margin-left: 1.5em;
}

dt {
	font-weight: 700;
}

dd {
	margin: 0 1.5em 1.5em;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
	max-width: 100%;
}

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

figure {
	margin: 1em 0;
}

table {
	margin: 0 0 1.5em;
	width: 100%;
}

/* Links
--------------------------------------------- */
a {
	color: #4169e1;
}

a:visited {
	color: #800080;
}

a:hover,
a:focus,
a:active {
	color: #191970;
}

a:focus {
	outline: thin dotted;
}

a:hover,
a:active {
	outline: 0;
}

/* Forms
--------------------------------------------- */
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	border: 1px solid;
	border-color: #ccc #ccc #bbb;
	border-radius: 3px;
	background: #e6e6e6;
	color: rgba(0, 0, 0, 0.8);
	line-height: 1;
	padding: 0.6em 1em 0.4em;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	border-color: #ccc #bbb #aaa;
}

button:active,
button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
	border-color: #aaa #bbb #bbb;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	color: #666;
	border: 1px solid #ccc;
	border-radius: 3px;
	padding: 3px;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
	color: #111;
}

select {
	border: 1px solid #ccc;
}

textarea {
	width: 100%;
}

/*--------------------------------------------------------------
# Layouts
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Components
--------------------------------------------------------------*/

/* Header
--------------------------------------------- */
.site-header {
	background: #ffffff;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06);
	padding: 0;
	position: relative;
	z-index: 999;
}

.header-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 1.25rem 1.5rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	flex-wrap: wrap;
}

.header-container > * {
	flex-shrink: 0;
}

.site-branding {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}

.site-title {
	margin: 0;
	font-size: 1.5rem;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: -0.02em;
}

.site-title a {
	color: #1a1a1a;
	text-decoration: none;
	transition: color 0.2s ease;
}

.site-title a:hover,
.site-title a:focus {
	color: #333333;
}

.custom-logo-link {
	display: inline-block;
	line-height: 0;
}

.custom-logo-link img {
	max-height: 50px;
	width: auto;
	height: auto;
}

/* Navigation
--------------------------------------------- */
.main-navigation {
	display: flex;
	align-items: center;
	position: relative;
	flex: 1;
	justify-content: flex-end;
	min-width: 0;
}

.main-navigation ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.main-navigation .nav-menu {
	display: none;
	align-items: center;
	gap: 0.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.main-navigation li {
	position: relative;
	margin: 0;
}

.main-navigation a {
	display: block;
	padding: 0.5rem 1rem;
	color: #4a4a4a;
	text-decoration: none;
	font-size: 0.95rem;
	font-weight: 400;
	line-height: 1.5;
	transition: color 0.2s ease;
	border-radius: 4px;
}

.main-navigation a:hover,
.main-navigation a:focus {
	color: #1a1a1a;
	background: rgba(0, 0, 0, 0.02);
}

/* Dropdown menus */
.main-navigation ul ul {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
	background: #ffffff;
	border-radius: 8px;
	float: left;
	position: absolute;
	top: 100%;
	left: -999em;
	z-index: 99999;
	padding: 0.5rem 0;
	min-width: 200px;
	margin-top: 0.5rem;
	border: 1px solid rgba(0, 0, 0, 0.06);
}

.main-navigation ul ul ul {
	left: -999em;
	top: 0;
	margin-top: 0;
	margin-left: 0.5rem;
}

.main-navigation ul ul li:hover > ul,
.main-navigation ul ul li.focus > ul {
	display: block;
	left: 100%;
}

.main-navigation ul ul a {
	width: auto;
	padding: 0.75rem 1.25rem;
	font-size: 0.9rem;
	border-radius: 0;
}

.main-navigation ul ul a:hover {
	background: rgba(0, 0, 0, 0.04);
}

.main-navigation ul li:hover > ul,
.main-navigation ul li.focus > ul {
	left: 0;
	display: block;
}

/* Mobile menu toggle */
.menu-toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	background: transparent;
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 6px;
	cursor: pointer;
	transition: all 0.2s ease;
	color: #1a1a1a;
}

.menu-toggle:hover,
.menu-toggle:focus {
	background: rgba(0, 0, 0, 0.02);
	border-color: rgba(0, 0, 0, 0.15);
	outline: none;
}

.menu-toggle-icon {
	display: block;
	width: 20px;
	height: 2px;
	background: currentColor;
	position: relative;
	transition: background 0.2s ease;
}

.menu-toggle-icon::before,
.menu-toggle-icon::after {
	content: "";
	display: block;
	width: 20px;
	height: 2px;
	background: currentColor;
	position: absolute;
	left: 0;
	transition: transform 0.2s ease, top 0.2s ease;
}

.menu-toggle-icon::before {
	top: -6px;
}

.menu-toggle-icon::after {
	top: 6px;
}

.menu-toggle[aria-expanded="true"] .menu-toggle-icon {
	background: transparent;
}

.menu-toggle[aria-expanded="true"] .menu-toggle-icon::before {
	top: 0;
	transform: rotate(45deg);
}

.menu-toggle[aria-expanded="true"] .menu-toggle-icon::after {
	top: 0;
	transform: rotate(-45deg);
}

.menu-toggle-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

@media screen and (max-width: 37.4375em) {
	.main-navigation.toggled .nav-menu {
		display: block;
		position: absolute;
		top: calc(100% + 0.75rem);
		right: 0;
		left: 0;
		background: #ffffff;
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
		border-radius: 8px;
		padding: 0.5rem 0;
		border: 1px solid rgba(0, 0, 0, 0.06);
		z-index: 999;
	}
}

.main-navigation.toggled .nav-menu {
	flex-direction: column;
	align-items: stretch;
	gap: 0;
}

.main-navigation.toggled li {
	width: 100%;
}

.main-navigation.toggled a {
	padding: 0.875rem 1.25rem;
	border-radius: 0;
}

@media screen and (min-width: 37.5em) {
	.menu-toggle {
		display: none;
	}

	.main-navigation .nav-menu {
		display: flex !important;
	}

	.header-container {
		padding: 1.5rem 2rem;
	}
}

@media screen and (min-width: 768px) {
	.header-container {
		padding: 1.75rem 2.5rem;
	}

	.site-title {
		font-size: 1.625rem;
	}
}

@media screen and (max-width: 374px) {
	.header-container {
		padding: 1rem 1.25rem;
	}

	.site-title {
		font-size: 1.25rem;
	}
}

.site-main .comment-navigation,
.site-main .posts-navigation,
.site-main .post-navigation {
	margin: 0 0 1.5em;
}

.comment-navigation .nav-links,
.posts-navigation .nav-links,
.post-navigation .nav-links {
	display: flex;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
	flex: 1 0 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
	text-align: end;
	flex: 1 0 50%;
}

/* Posts and pages
--------------------------------------------- */
.sticky {
	display: block;
}

.post,
.page {
	margin: 0 0 1.5em;
}

.updated:not(.published) {
	display: none;
}

.page-content,
.entry-content,
.entry-summary {
	margin: 1.5em 0 0;
}

.page-links {
	clear: both;
	margin: 0 0 1.5em;
}

/* Hero
--------------------------------------------- */
.hero {
	max-width: 1200px;
	margin: 0 auto;
	padding: 5rem 2rem;
	text-align: center;
}

.hero h1 {
	margin: 0 0 1.5rem;
	font-size: 2.5rem;
	font-weight: 700;
	color: #1a1a1a;
	letter-spacing: -0.03em;
	line-height: 1.2;
}

.hero p {
	margin: 0 0 2.5rem;
	font-size: 1.25rem;
	color: #666;
	line-height: 1.6;
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
}

.hero .button {
	display: inline-block;
	padding: 1rem 2.5rem;
	background: #1a1a1a;
	color: #ffffff;
	text-decoration: none;
	border-radius: 6px;
	font-size: 1rem;
	font-weight: 500;
	transition: all 0.2s ease;
	border: 1px solid #1a1a1a;
}

.hero .button:hover,
.hero .button:focus {
	background: #333333;
	border-color: #333333;
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.hero .button:active {
	transform: translateY(0);
}

@media screen and (min-width: 768px) {
	.hero {
		padding: 7rem 2.5rem;
	}

	.hero h1 {
		font-size: 3.5rem;
		margin-bottom: 2rem;
	}

	.hero p {
		font-size: 1.375rem;
		margin-bottom: 3rem;
	}

	.hero .button {
		padding: 1.125rem 3rem;
		font-size: 1.05rem;
	}
}

@media screen and (max-width: 767px) {
	.hero {
		padding: 4rem 1.5rem;
	}

	.hero h1 {
		font-size: 2rem;
	}

	.hero p {
		font-size: 1.125rem;
	}
}

@media screen and (max-width: 374px) {
	.hero {
		padding: 3rem 1.25rem;
	}

	.hero h1 {
		font-size: 1.75rem;
	}

	.hero p {
		font-size: 1rem;
	}
}

/* Services
--------------------------------------------- */

/* Quote Section (Language Selection Form)
--------------------------------------------- */
.quote {
	max-width: 1200px;
	margin: 0 auto 3rem;
	padding: 2rem;
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 12px;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.quote p {
	margin: 0 0 1.5rem;
	color: #666;
	font-size: 1rem;
	line-height: 1.6;
	text-align: center;
}

.quote form {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.quote label {
	display: block;
	margin-bottom: 0.5rem;
	font-size: 0.95rem;
	font-weight: 500;
	color: #1a1a1a;
}

.quote select {
	width: 100%;
	padding: 0.875rem 1.25rem;
	font-size: 1rem;
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 6px;
	background: #ffffff;
	color: #1a1a1a;
	transition: all 0.2s ease;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	cursor: pointer;
}

.quote select:hover {
	border-color: rgba(0, 0, 0, 0.2);
}

.quote select:focus {
	outline: none;
	border-color: #1a1a1a;
	box-shadow: 0 0 0 3px rgba(26, 26, 26, 0.1);
}

.quote .button {
	display: inline-block;
	padding: 0.875rem 2rem;
	background: #1a1a1a;
	color: #ffffff;
	text-decoration: none;
	border-radius: 6px;
	font-size: 1rem;
	font-weight: 500;
	transition: all 0.2s ease;
	border: 1px solid #1a1a1a;
	cursor: pointer;
	width: 100%;
	text-align: center;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
}

.quote .button:hover,
.quote .button:focus {
	background: #333333;
	border-color: #333333;
	color: #ffffff;
	transform: translateY(-1px);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.quote .button:active {
	transform: translateY(0);
}

@media screen and (min-width: 768px) {
	.quote {
		padding: 1rem;
	}

	.quote form {
		flex-direction: row;
		align-items: flex-end;
		gap: 1rem;
	}

	.quote form > * {
		flex: 1;
	}

	.quote .button {
		width: auto;
		flex: 0 0 auto;
		padding: 0.875rem 2.5rem;
	}
}

@media screen and (max-width: 767px) {
	.quote {
		padding: 1.5rem;
		margin-bottom: 2rem;
	}
}

/* Services Container and Service Cards
--------------------------------------------- */
.services {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 2rem 4rem;
}

.services-container {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
}

.service {
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 12px;
	padding: 2.5rem 2rem;
	text-align: center;
	transition: all 0.3s ease;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.service:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
	transform: translateY(-2px);
	border-color: rgba(0, 0, 0, 0.1);
}

.service h3 {
	margin: 0 0 1rem;
	font-size: 1.75rem;
	font-weight: 600;
	color: #1a1a1a;
	letter-spacing: -0.02em;
	line-height: 1.3;
}

.service h2 {
	margin: 0 0 1rem;
	font-size: 1.75rem;
	font-weight: 600;
	color: #1a1a1a;
	letter-spacing: -0.02em;
	line-height: 1.3;
}

.service p {
	margin: 0 0 1.5rem;
	color: #666;
	font-size: 1rem;
	line-height: 1.6;
}

.service .button {
	display: inline-block;
	padding: 0.75rem 2rem;
	background: #1a1a1a;
	color: #ffffff;
	text-decoration: none;
	border-radius: 6px;
	font-size: 0.95rem;
	font-weight: 500;
	transition: all 0.2s ease;
	border: 1px solid #1a1a1a;
}

.service .button:hover,
.service .button:focus {
	background: #333333;
	border-color: #333333;
	color: #ffffff;
	transform: translateY(-1px);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.service .button:active {
	transform: translateY(0);
}

@media screen and (min-width: 768px) {
	.services-container {
		grid-template-columns: repeat(3, 1fr);
		gap: 2.5rem;
	}

	.services {
		padding: 0 1rem 4rem;
	}

	.service {
		padding: 3rem 2.5rem;
	}

	.service h3 {
		font-size: 2rem;
	}

	.service h2 {
		font-size: 2rem;
	}

	.service p {
		font-size: 1.05rem;
	}
}

@media screen and (max-width: 767px) {
	.services {
		padding: 0 1.5rem 3rem;
	}

	.service {
		padding: 2rem 1.5rem;
	}

	.service h3 {
		font-size: 1.5rem;
	}

	.service h2 {
		font-size: 1.5rem;
	}
}

/* How to Use Section
--------------------------------------------- */
.how-to-use-section {
	max-width: 1200px;
	margin: 0 auto;
	padding: 4rem 2rem;
	background: #ffffff;
}

.how-to-use-container {
	max-width: 900px;
	margin: 0 auto;
	text-align: center;
}

.how-to-use-container h2 {
	margin: 0 0 1rem;
	font-size: 2.5rem;
	font-weight: 600;
	color: #1a1a1a;
	letter-spacing: -0.02em;
}

.how-to-use-description {
	margin: 0 0 3rem;
	color: #666;
	font-size: 1.125rem;
	line-height: 1.7;
}

.how-to-use-steps {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
	text-align: left;
}

.how-to-use-step {
	display: flex;
	gap: 1.5rem;
	align-items: flex-start;
}

.step-number {
	flex-shrink: 0;
	width: 3rem;
	height: 3rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #635bff;
	color: #ffffff;
	border-radius: 50%;
	font-size: 1.5rem;
	font-weight: 600;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
}

.step-content {
	flex: 1;
}

.step-content h3 {
	margin: 0 0 0.75rem;
	font-size: 1.5rem;
	font-weight: 600;
	color: #1a1a1a;
	letter-spacing: -0.01em;
}

.step-content p {
	margin: 0;
	color: #666;
	font-size: 1rem;
	line-height: 1.7;
}

@media screen and (min-width: 768px) {
	.how-to-use-section {
		padding: 5rem 2.5rem;
	}

	.how-to-use-container h2 {
		font-size: 3rem;
		margin-bottom: 1.5rem;
	}

	.how-to-use-description {
		font-size: 1.25rem;
		margin-bottom: 4rem;
	}

	.how-to-use-steps {
		gap: 3rem;
	}

	.how-to-use-step {
		gap: 2rem;
	}

	.step-number {
		width: 3.5rem;
		height: 3.5rem;
		font-size: 1.75rem;
	}

	.step-content h3 {
		font-size: 1.75rem;
		margin-bottom: 1rem;
	}

	.step-content p {
		font-size: 1.05rem;
	}
}

@media screen and (max-width: 767px) {
	.how-to-use-section {
		padding: 3rem 1.5rem;
	}

	.how-to-use-container h2 {
		font-size: 2rem;
	}

	.how-to-use-description {
		font-size: 1rem;
		margin-bottom: 2.5rem;
	}

	.how-to-use-steps {
		gap: 2rem;
	}

	.how-to-use-step {
		flex-direction: column;
		align-items: center;
		text-align: center;
		gap: 1rem;
	}

	.step-number {
		width: 2.5rem;
		height: 2.5rem;
		font-size: 1.25rem;
	}

	.step-content h3 {
		font-size: 1.25rem;
	}

	.step-content p {
		font-size: 0.95rem;
	}
}

/* Quote Generator
--------------------------------------------- */
.quote-generator {
	max-width: 1200px;
	margin: 0 auto;
	padding: 1.5rem;
	background: #fafafa;
}

.quote-generator h2 {
	margin: 0 0 2.5rem;
	font-size: 1.5rem;
	font-weight: 600;
	color: #1a1a1a;
	text-align: center;
	letter-spacing: -0.02em;
}

.quote-generator form {
	max-width: 600px;
	margin: 0 auto;
	display: none;
	flex-direction: column;
	gap: 1.25rem;
}

.quote-generator form.show {
	display: flex;
}

.quote-generator select,
.quote-generator input[type="number"] {
	width: 100%;
	padding: 0.875rem 1.25rem;
	font-size: 1rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	color: #1a1a1a;
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 6px;
	transition: all 0.2s ease;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
}

.quote-generator select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a1a1a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	background-size: 12px;
	padding-right: 2.5rem;
	cursor: pointer;
}

.quote-generator input[type="number"] {
	-webkit-appearance: textfield;
	-moz-appearance: textfield;
	appearance: textfield;
	display: none;
}

.quote-generator input[type="number"].visible {
	display: block;
}

/* Language selectors are always visible */
.quote-generator select#language-from,
.quote-generator select#language-to {
	display: block;
}

.quote-generator input[type="number"]::-webkit-inner-spin-button,
.quote-generator input[type="number"]::-webkit-outer-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

.quote-generator select::placeholder,
.quote-generator input[type="number"]::placeholder {
	color: #999;
}

.quote-generator select:hover,
.quote-generator input[type="number"]:hover {
	border-color: rgba(0, 0, 0, 0.2);
}

.quote-generator select:focus,
.quote-generator input[type="number"]:focus {
	outline: none;
	border-color: #1a1a1a;
	box-shadow: 0 0 0 3px rgba(26, 26, 26, 0.1);
}

.quote-generator output {
	display: flex;
	width: 100%;
	padding: 1rem 1.5rem;
	font-size: 1.5rem;
	font-weight: 600;
	color: #1a1a1a;
	text-align: center;
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 6px;
	margin-top: 0.5rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	min-height: 3.5rem;
	align-items: center;
	justify-content: center;
	transition: all 0.3s ease;
}

.quote-generator output:empty {
	display: none;
}

.quote-generator output.calculated {
	background: #f0f9ff;
	border-color: #1a1a1a;
	color: #1a1a1a;
	font-size: 1.75rem;
	font-weight: 700;
}

.quote-generator output.error {
	background: #fef2f2;
	border-color: #dc2626;
	color: #dc2626;
	font-size: 1rem;
	font-weight: 400;
}

.quote-generator .buttons {
	display: flex;
	gap: 1rem;
	justify-content: center;
}

.quote-generator button.button,
.quote-generator button[type="submit"],
.quote-generator button[type="button"] {
	display: inline-block;
	padding: 1rem 2.5rem;
	background: #1a1a1a;
	color: #ffffff;
	text-decoration: none;
	border-radius: 6px;
	font-size: 1rem;
	font-weight: 500;
	transition: all 0.2s ease;
	border: 1px solid #1a1a1a;
	cursor: pointer;
	width: 100%;
	margin-top: 0.5rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
}

.quote-generator .start {
	display: flex;
	justify-content: center;
	margin-top: 1rem;
}

.quote-generator .start.hidden {
	display: none;
}

.quote-generator button.button:hover,
.quote-generator button.button:focus,
.quote-generator button[type="submit"]:hover,
.quote-generator button[type="submit"]:focus,
.quote-generator button[type="button"]:hover,
.quote-generator button[type="button"]:focus {
	background: #333333;
	border-color: #333333;
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.quote-generator button.button:active,
.quote-generator button[type="submit"]:active,
.quote-generator button[type="button"]:active {
	transform: translateY(0);
}

@media screen and (min-width: 768px) {
	.quote-generator {
		padding: 2.5rem;
	}

	.quote-generator h2 {
		font-size: 2rem;
		margin-bottom: 3rem;
	}

	.quote-generator form {
		gap: 1.5rem;
	}

	.quote-generator select,
	.quote-generator input[type="number"] {
		padding: 1rem 1.5rem;
		font-size: 1.05rem;
	}

	.quote-generator button.button,
	.quote-generator button[type="submit"],
	.quote-generator button[type="button"] {
		padding: 1.125rem 3rem;
		font-size: 1.05rem;
		width: auto;
		align-self: center;
	}

	.quote-generator output {
		min-height: 4rem;
	}

	.quote-generator output.calculated {
		font-size: 2rem;
		padding: 1.25rem 1.5rem;
	}

	.quote-generator output.error {
		font-size: 1.125rem;
	}
}

@media screen and (max-width: 767px) {
	.quote-generator {
		padding: 3rem 1.5rem;
	}

	.quote-generator h2 {
		font-size: 1.75rem;
	}
}

/* Registration
--------------------------------------------- */
.registration-section {
	max-width: 1200px;
	margin: 0 auto;
	padding: 4rem 2rem;
}

.registration-container {
	max-width: 500px;
	margin: 0 auto;
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 12px;
	padding: 3rem 2.5rem;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.registration-container h2 {
	margin: 0 0 0.5rem;
	font-size: 2rem;
	font-weight: 600;
	color: #1a1a1a;
	text-align: center;
	letter-spacing: -0.02em;
}

.registration-description {
	margin: 0 0 2.5rem;
	color: #666;
	text-align: center;
	font-size: 1rem;
	line-height: 1.6;
}

.registration-form {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.form-group {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.form-group label {
	font-size: 0.95rem;
	font-weight: 500;
	color: #1a1a1a;
	margin-bottom: 0.25rem;
}

.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="password"],
.form-group input[type="tel"] {
	width: 100%;
	padding: 0.875rem 1.25rem;
	font-size: 1rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	color: #1a1a1a;
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 6px;
	transition: all 0.2s ease;
}

.form-group select {
	width: 100%;
	padding: 0.875rem 1.25rem;
	padding-right: 3rem;
	font-size: 1rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	color: #1a1a1a;
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 6px;
	transition: all 0.2s ease;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a1a1a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	background-size: 12px;
	cursor: pointer;
}

.form-group input[type="text"]:hover,
.form-group input[type="email"]:hover,
.form-group input[type="password"]:hover,
.form-group input[type="tel"]:hover,
.form-group select:hover {
	border-color: rgba(0, 0, 0, 0.2);
}

.form-group input[type="text"]:focus,
.form-group input[type="email"]:focus,
.form-group input[type="password"]:focus,
.form-group input[type="tel"]:focus,
.form-group select:focus {
	outline: none;
	border-color: #1a1a1a;
	box-shadow: 0 0 0 3px rgba(26, 26, 26, 0.1);
}

.form-help {
	display: block;
	font-size: 0.875rem;
	color: #999;
	margin-top: 0.25rem;
}

.password-input-wrapper {
	position: relative;
	width: 100%;
}

.password-input-wrapper input[type="password"],
.password-input-wrapper input[type="text"] {
	padding-right: 3rem;
}

.password-toggle {
	position: absolute;
	right: 0.75rem;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	cursor: pointer;
	padding: 0.5rem;
	font-size: 1.25rem;
	line-height: 1;
	color: #666;
	transition: color 0.2s ease;
	display: flex;
	align-items: center;
	justify-content: center;
}

.password-toggle:hover {
	color: #1a1a1a;
}

.password-toggle:focus {
	outline: 2px solid #1a1a1a;
	outline-offset: 2px;
	border-radius: 4px;
}

.password-toggle-icon {
	display: inline-block;
	user-select: none;
	width: 20px;
	height: 20px;
	vertical-align: middle;
	flex-shrink: 0;
}

.registration-form .button {
	width: 100%;
	padding: 1rem 2.5rem;
	margin-top: 0.5rem;
	font-size: 1rem;
	background-color: #1a1a1a;
	color: #ffffff;
	border: none;
	cursor: pointer;
}

.registration-error {
	background: #fef2f2;
	border: 1px solid #dc2626;
	border-radius: 6px;
	padding: 1rem 1.25rem;
	margin-bottom: 1.5rem;
	color: #dc2626;
	font-size: 0.95rem;
	line-height: 1.6;
}

.registration-error a {
	color: #dc2626;
	text-decoration: underline;
}

.registration-success {
	background: #f0fdf4;
	border: 1px solid #22c55e;
	border-radius: 6px;
	padding: 1rem 1.25rem;
	margin-bottom: 1.5rem;
	color: #166534;
	font-size: 0.95rem;
	line-height: 1.6;
}

.registration-footer {
	margin-top: 2rem;
	text-align: center;
	font-size: 0.95rem;
	color: #666;
}

.registration-footer a {
	color: #1a1a1a;
	text-decoration: none;
	font-weight: 500;
	transition: color 0.2s ease;
}

.registration-footer a:hover {
	color: #333333;
	text-decoration: underline;
}

@media screen and (min-width: 768px) {
	.registration-section {
		padding: 5rem 2.5rem;
	}

	.registration-container {
		padding: 4rem 3rem;
	}

	.registration-container h2 {
		font-size: 2.5rem;
	}
}

@media screen and (max-width: 767px) {
	.registration-section {
		padding: 3rem 1.5rem;
	}

	.registration-container {
		padding: 2.5rem 1.5rem;
	}

	.registration-container h2 {
		font-size: 1.75rem;
	}
}

/* Contact
--------------------------------------------- */
.contact-section {
	max-width: 1200px;
	margin: 0 auto;
	padding: 4rem 2rem;
}

.contact-container {
	max-width: 700px;
	margin: 0 auto;
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 12px;
	padding: 3rem 2.5rem;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.contact-container h2 {
	margin: 0 0 0.5rem;
	font-size: 2rem;
	font-weight: 600;
	color: #1a1a1a;
	text-align: center;
	letter-spacing: -0.02em;
}

.contact-description {
	margin: 0 0 2.5rem;
	color: #666;
	text-align: center;
	font-size: 1rem;
	line-height: 1.6;
}

.contact-form {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.contact-form .form-group label {
	font-size: 0.95rem;
	font-weight: 500;
	color: #1a1a1a;
	margin-bottom: 0.25rem;
}

.contact-form .form-group label .required {
	color: #dc2626;
}

.contact-form .form-group input[type="text"],
.contact-form .form-group input[type="email"],
.contact-form .form-group input[type="tel"],
.contact-form .form-group select,
.contact-form .form-group textarea {
	width: 100%;
	padding: 0.875rem 1.25rem;
	font-size: 1rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	color: #1a1a1a;
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 6px;
	transition: all 0.2s ease;
}

.contact-form .form-group textarea {
	resize: vertical;
	min-height: 120px;
	line-height: 1.6;
}

.contact-form .form-group select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a1a1a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	background-size: 12px;
	padding-right: 2.5rem;
	cursor: pointer;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
}

.contact-form .form-group input[type="text"]:hover,
.contact-form .form-group input[type="email"]:hover,
.contact-form .form-group input[type="tel"]:hover,
.contact-form .form-group select:hover,
.contact-form .form-group textarea:hover {
	border-color: rgba(0, 0, 0, 0.2);
}

.contact-form .form-group input[type="text"]:focus,
.contact-form .form-group input[type="email"]:focus,
.contact-form .form-group input[type="tel"]:focus,
.contact-form .form-group select:focus,
.contact-form .form-group textarea:focus {
	outline: none;
	border-color: #1a1a1a;
	box-shadow: 0 0 0 3px rgba(26, 26, 26, 0.1);
}

.contact-form .button {
	width: 100%;
	padding: 1rem 2.5rem;
	margin-top: 0.5rem;
	font-size: 1rem;
}

.contact-error {
	background: #fef2f2;
	border: 1px solid #dc2626;
	border-radius: 6px;
	padding: 1rem 1.25rem;
	margin-bottom: 1.5rem;
	color: #dc2626;
	font-size: 0.95rem;
	line-height: 1.6;
}

.contact-success {
	background: #f0fdf4;
	border: 1px solid #22c55e;
	border-radius: 6px;
	padding: 1rem 1.25rem;
	margin-bottom: 1.5rem;
	color: #166534;
	font-size: 0.95rem;
	line-height: 1.6;
}

.contact-info {
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 1px solid rgba(0, 0, 0, 0.06);
	text-align: center;
}

.contact-info h3 {
	margin: 0 0 1rem;
	font-size: 1.5rem;
	font-weight: 600;
	color: #1a1a1a;
}

.contact-info p {
	margin: 0.5rem 0;
	color: #666;
	font-size: 0.95rem;
	line-height: 1.6;
}

.contact-info a {
	color: #1a1a1a;
	text-decoration: none;
	font-weight: 500;
	transition: color 0.2s ease;
}

.contact-info a:hover {
	color: #333333;
	text-decoration: underline;
}

@media screen and (min-width: 768px) {
	.contact-section {
		padding: 5rem 2.5rem;
	}

	.contact-container {
		padding: 4rem 3rem;
	}

	.contact-container h2 {
		font-size: 2.5rem;
	}
}

@media screen and (max-width: 767px) {
	.contact-section {
		padding: 3rem 1.5rem;
	}

	.contact-container {
		padding: 2.5rem 1.5rem;
	}

	.contact-container h2 {
		font-size: 1.75rem;
	}
}

/* About
--------------------------------------------- */
.about-section {
	max-width: 1200px;
	margin: 0 auto;
	padding: 4rem 2rem;
}

.about-container {
	max-width: 900px;
	margin: 0 auto;
}

.about-container h2 {
	margin: 0 0 1rem;
	font-size: 2.5rem;
	font-weight: 600;
	color: #1a1a1a;
	text-align: center;
	letter-spacing: -0.02em;
}

.about-intro {
	margin: 0 0 3rem;
	color: #666;
	text-align: center;
	font-size: 1.125rem;
	line-height: 1.8;
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
}

.about-services {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
	margin-bottom: 3rem;
}

.about-service {
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 12px;
	padding: 2.5rem 2rem;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.about-service h3 {
	margin: 0 0 1rem;
	font-size: 1.75rem;
	font-weight: 600;
	color: #1a1a1a;
	letter-spacing: -0.02em;
}

.about-service > p {
	margin: 0 0 1.5rem;
	color: #666;
	line-height: 1.7;
	font-size: 1rem;
}

.service-features {
	margin: 1.5rem 0;
	padding-left: 1.5rem;
	list-style: none;
}

.service-features li {
	position: relative;
	padding-left: 1.5rem;
	margin-bottom: 0.75rem;
	color: #4a4a4a;
	line-height: 1.6;
}

.service-features li::before {
	content: "✓";
	position: absolute;
	left: 0;
	color: #1a1a1a;
	font-weight: 600;
}

.service-price {
	margin: 1.5rem 0 0;
	padding-top: 1.5rem;
	border-top: 1px solid rgba(0, 0, 0, 0.06);
	font-size: 1.125rem;
	color: #1a1a1a;
}

.service-price strong {
	font-weight: 600;
}

.about-cta {
	background: #fafafa;
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 12px;
	padding: 3rem 2.5rem;
	text-align: center;
}

.about-cta h3 {
	margin: 0 0 0.75rem;
	font-size: 2rem;
	font-weight: 600;
	color: #1a1a1a;
	letter-spacing: -0.02em;
}

.about-cta > p {
	margin: 0 0 2rem;
	color: #666;
	font-size: 1.05rem;
	line-height: 1.7;
}

.about-buttons {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}

.about-buttons .button {
	padding: 1rem 2.5rem;
	font-size: 1rem;
	min-width: 180px;
}

.about-buttons .button-secondary {
	background: transparent;
	color: #1a1a1a;
	border: 1px solid rgba(0, 0, 0, 0.2);
}

.about-buttons .button-secondary:hover,
.about-buttons .button-secondary:focus {
	background: rgba(0, 0, 0, 0.02);
	border-color: #1a1a1a;
	color: #1a1a1a;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

@media screen and (min-width: 768px) {
	.about-section {
		padding: 5rem 2.5rem;
	}

	.about-container h2 {
		font-size: 3rem;
	}

	.about-services {
		grid-template-columns: 1fr;
		gap: 3rem;
	}

	.about-service {
		padding: 3rem 2.5rem;
	}

	.about-service h3 {
		font-size: 2rem;
	}

	.about-cta {
		padding: 4rem 3rem;
	}

	.about-cta h3 {
		font-size: 2.5rem;
	}
}

@media screen and (max-width: 767px) {
	.about-section {
		padding: 3rem 1.5rem;
	}

	.about-container h2 {
		font-size: 2rem;
	}

	.about-intro {
		font-size: 1rem;
	}

	.about-service {
		padding: 2rem 1.5rem;
	}

	.about-service h3 {
		font-size: 1.5rem;
	}

	.about-cta {
		padding: 2.5rem 1.5rem;
	}

	.about-cta h3 {
		font-size: 1.75rem;
	}

	.about-buttons {
		flex-direction: column;
	}

	.about-buttons .button {
		width: 100%;
	}
}

/* CTA Section
--------------------------------------------- */
.cta-section {
	max-width: 1200px;
	margin: 0 auto;
	padding: 4rem 2rem;
	background: #fafafa;
}

.cta-container {
	max-width: 700px;
	margin: 0 auto;
	text-align: center;
}

.cta-container h2 {
	margin: 0 0 1rem;
	font-size: 2.5rem;
	font-weight: 600;
	color: #1a1a1a;
	letter-spacing: -0.02em;
}

.cta-description {
	margin: 0 0 2.5rem;
	color: #666;
	font-size: 1.125rem;
	line-height: 1.7;
}

.cta-container .button {
	padding: 1.125rem 3rem;
	font-size: 1.05rem;
	text-decoration: none;
	display: inline-block;
	background: #1a1a1a;
	color: #ffffff;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.1s ease;
}
.cta-container .button:hover {
	background: #333333;
	transform: translateY(-1px);
}
.cta-container .button:active {
	transform: translateY(0);
}

@media screen and (min-width: 768px) {
	.cta-section {
		padding: 5rem 2.5rem;
	}

	.cta-container h2 {
		font-size: 3rem;
	}

	.cta-description {
		font-size: 1.25rem;
	}
}

@media screen and (max-width: 767px) {
	.cta-section {
		padding: 3rem 1.5rem;
	}

	.cta-container h2 {
		font-size: 2rem;
	}

	.cta-description {
		font-size: 1rem;
	}
}

/* Account Page (Subscriber Only)
--------------------------------------------- */
.account-section {
	max-width: 1200px;
	margin: 0 auto;
	padding: 4rem 2rem;
}

.account-container {
	max-width: 1024px;
	margin: 0 auto;
}

.account-container h2 {
	margin: 0 0 0.5rem;
	font-size: 1.5rem;
	font-weight: 600;
	color: #1a1a1a;
	text-align: center;
	letter-spacing: -0.02em;
}

.account-welcome {
	margin: 0 0 3rem;
	color: #666;
	text-align: center;
	font-size: 1.125rem;
	line-height: 1.7;
}

.account-info {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	margin-bottom: 3rem;
}

.account-details,
.account-actions {
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 12px;
	padding: 2.5rem 2rem;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.account-details h3,
.account-actions h3 {
	margin: 0 0 1.5rem;
	font-size: 1.5rem;
	font-weight: 600;
	color: #1a1a1a;
	letter-spacing: -0.02em;
}

.account-logout {
	margin-bottom: 2rem;
	text-align: center;
}

.account-buttons {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.account-buttons .button {
	width: 100%;
	text-align: center;
}

.account-services {
	margin-top: 2rem;
}

.account-services h3 {
	margin: 0 0 2rem;
	font-size: 1.75rem;
	font-weight: 600;
	color: #1a1a1a;
	text-align: center;
	letter-spacing: -0.02em;
}

.services-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}

.service-card {
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 12px;
	padding: 2rem 1.5rem;
	text-align: center;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.service-card h4 {
	margin: 0 0 0.75rem;
	font-size: 1.5rem;
	font-weight: 600;
	color: #1a1a1a;
}

.service-card p {
	margin: 0 0 1.5rem;
	color: #666;
	font-size: 0.95rem;
}

.button-small {
	padding: 0.75rem 1.5rem;
	font-size: 0.95rem;
}

@media screen and (min-width: 768px) {
	.account-section {
		padding: 5rem 2.5rem;
	}

	.account-container h2 {
		font-size: 2rem;
	}

	.account-info {
		grid-template-columns: 1fr 1fr;
		gap: 2.5rem;
	}

	.account-buttons {
		flex-direction: row;
	}

	.services-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 2rem;
	}

	.service-card {
		padding: 2.5rem 2rem;
	}
}

@media screen and (max-width: 767px) {
	.account-section {
		padding: 3rem 1.5rem;
	}

	.account-container h2 {
		font-size: 2rem;
	}

	.account-details,
	.account-actions {
		padding: 2rem 1.5rem;
	}
}

/* Document Upload Form
--------------------------------------------- */
.document-upload-section {
	margin-top: 3rem;
	padding-top: 3rem;
	border-top: 1px solid rgba(0, 0, 0, 0.06);
}

.document-upload-section h3 {
	margin: 0 0 0.75rem;
	font-size: 1.75rem;
	font-weight: 600;
	color: #1a1a1a;
	letter-spacing: -0.02em;
}

.upload-description {
	margin: 0 0 2rem;
	color: #666;
	font-size: 1rem;
	line-height: 1.6;
}

.document-upload-form {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.document-upload-form .form-group {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.document-upload-form .form-group label {
	font-size: 0.95rem;
	font-weight: 500;
	color: #1a1a1a;
	margin-bottom: 0.25rem;
}

.document-upload-form .form-group label .required {
	color: #dc2626;
}

.document-upload-form .form-group input[type="file"] {
	width: 100%;
	padding: 0.875rem 1.25rem;
	font-size: 1rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	color: #1a1a1a;
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 6px;
	transition: all 0.2s ease;
	cursor: pointer;
}

.document-upload-form .form-group input[type="file"]:hover {
	border-color: rgba(0, 0, 0, 0.2);
}

.document-upload-form .form-group input[type="file"]:focus {
	outline: none;
	border-color: #1a1a1a;
	box-shadow: 0 0 0 3px rgba(26, 26, 26, 0.1);
}

.document-upload-form .form-group input[type="datetime-local"] {
	width: 100%;
	padding: 0.875rem 1.25rem;
	font-size: 1rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	color: #1a1a1a;
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 6px;
	transition: all 0.2s ease;
}

.document-upload-form .form-group input[type="datetime-local"]:hover {
	border-color: rgba(0, 0, 0, 0.2);
}

.document-upload-form .form-group input[type="datetime-local"]:focus {
	outline: none;
	border-color: #1a1a1a;
	box-shadow: 0 0 0 3px rgba(26, 26, 26, 0.1);
}

.document-upload-form .form-group select {
	width: 100%;
	padding: 0.875rem 1.25rem;
	font-size: 1rem;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
		Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	color: #1a1a1a;
	background: #ffffff;
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 6px;
	transition: all 0.2s ease;
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a1a1a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	background-size: 12px;
	padding-right: 2.5rem;
	cursor: pointer;
}

.document-upload-form .form-group select:hover {
	border-color: rgba(0, 0, 0, 0.2);
}

.document-upload-form .form-group select:focus {
	outline: none;
	border-color: #1a1a1a;
	box-shadow: 0 0 0 3px rgba(26, 26, 26, 0.1);
}

.checkbox-label {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	cursor: pointer;
	font-size: 0.95rem;
	font-weight: 500;
	color: #1a1a1a;
}

.checkbox-label input[type="checkbox"] {
	width: 20px;
	height: 20px;
	cursor: pointer;
	accent-color: #1a1a1a;
}

.checkbox-label span {
	user-select: none;
}

.upload-error {
	background: #fef2f2;
	border: 2px solid #dc2626;
	border-radius: 8px;
	padding: 1.25rem 1.5rem;
	margin-bottom: 1.5rem;
	color: #991b1b;
	font-size: 0.95rem;
	line-height: 1.6;
	box-shadow: 0 2px 4px rgba(220, 38, 38, 0.1);
	position: relative;
}

.upload-error::before {
	content: "⚠️";
	display: inline-block;
	margin-right: 0.5rem;
	font-size: 1.2rem;
}

.upload-success {
	background: #f0fdf4;
	border: 2px solid #22c55e;
	border-radius: 8px;
	padding: 1.25rem 1.5rem;
	margin-bottom: 1.5rem;
	color: #166534;
	font-size: 0.95rem;
	line-height: 1.6;
	box-shadow: 0 2px 4px rgba(34, 197, 94, 0.1);
	position: relative;
}

.upload-success::before {
	content: "✓";
	display: inline-block;
	margin-right: 0.5rem;
	font-size: 1.2rem;
	font-weight: bold;
	color: #22c55e;
}

@keyframes slideIn {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Admin Page Styles
--------------------------------------------- */
.admin-text-muted {
	color: #999;
}

.admin-button-spei {
	background: #0ea5e9;
	color: #ffffff;
}

.admin-button-spei:hover,
.admin-button-spei:focus {
	background: #0d8cc7;
	color: #ffffff;
}

.admin-button-completed {
	background: #22c55e;
	color: #ffffff;
}

.admin-button-completed:hover,
.admin-button-completed:focus {
	background: #16a34a;
	color: #ffffff;
}

.admin-button-approve {
	background: #22c55e;
	color: #ffffff;
	width: 100%;
}

.admin-button-approve:hover,
.admin-button-approve:focus {
	background: #16a34a;
	color: #ffffff;
}

.admin-button-reject {
	background: #dc2626;
	color: #ffffff;
	width: 100%;
}

.admin-button-reject:hover,
.admin-button-reject:focus {
	background: #b91c1c;
	color: #ffffff;
}

.admin-actions-container {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.admin-form-inline {
	margin: 0;
}

.admin-input-small {
	width: 100%;
	font-size: 11px;
	margin-bottom: 0.25rem;
	padding: 0.25rem;
}

.admin-select-small {
	width: 150px;
}

.admin-file-input-small {
	font-size: 11px;
	margin-bottom: 0.25rem;
}

.admin-urgent-text {
	color: #dc2626;
	font-weight: bold;
}

.document-upload-form .button {
	width: 100%;
	padding: 1rem 2.5rem;
	margin-top: 0.5rem;
	font-size: 1rem;
	background: #635bff;
	color: #ffffff;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.1s ease;
	font-weight: 500;
}
.document-upload-form .button:hover {
	background: #5851ea;
	transform: translateY(-1px);
}
.document-upload-form .button:active {
	transform: translateY(0);
}
.document-upload-form .button:disabled {
	background: #9ca3af;
	cursor: not-allowed;
	opacity: 0.7;
}

/* Payment Section
--------------------------------------------- */
.payment-option {
	margin-bottom: 1rem;
	padding: 1rem;
}

.stripe-payment-button {
	background: #635bff;
	color: #ffffff;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	padding: 0.75rem 1.5rem;
	font-size: 1rem;
	font-weight: 500;
	transition: background-color 0.2s ease, transform 0.1s ease;
}
.stripe-payment-button:hover {
	background: #5851ea;
	transform: translateY(-1px);
}
.stripe-payment-button:active {
	transform: translateY(0);
}

.spei-payment-button {
	background: #0ea5e9;
	color: #ffffff;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	padding: 0.75rem 1.5rem;
	font-size: 1rem;
	font-weight: 500;
	transition: background-color 0.2s ease, transform 0.1s ease;
}
.spei-payment-button:hover {
	background: #0875b0;
	transform: translateY(-1px);
}
.spei-payment-button:active {
	transform: translateY(0);
}

.payment-section {
	background: #ffffff;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	padding: 2rem;
	margin-bottom: 2rem;
}

.payment-section h3 {
	font-size: 1.5rem;
	font-weight: 600;
	color: #1a1a1a;
	margin-bottom: 1.5rem;
}

.payment-status {
	background: #f0fdf4;
	border: 1px solid #22c55e;
	border-radius: 6px;
	padding: 1.5rem;
}

.payment-status.paid p {
	margin: 0.5rem 0;
	color: #166534;
	font-size: 0.95rem;
}

.payment-status.paid p strong {
	font-weight: 600;
}

.payment-info {
	margin-bottom: 1.5rem;
}

.payment-info p {
	color: #4b5563;
	font-size: 0.95rem;
	line-height: 1.6;
	margin-bottom: 0.75rem;
}

.payment-amount {
	font-size: 1.125rem;
	color: #1a1a1a;
	margin-top: 1rem;
}

.payment-amount strong {
	font-weight: 600;
}

#stripe-checkout-button {
	width: 100%;
	padding: 1rem 2.5rem;
	font-size: 1rem;
	background: #635bff;
	color: #ffffff;
	border: none;
	border-radius: 6px;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.1s ease;
	font-weight: 500;
}

#stripe-checkout-button:hover:not(:disabled) {
	background: #5851ea;
	transform: translateY(-1px);
}

#stripe-checkout-button:active:not(:disabled) {
	transform: translateY(0);
}

#stripe-checkout-button:disabled {
	background: #9ca3af;
	cursor: not-allowed;
	opacity: 0.7;
}

#payment-error {
	margin-top: 1rem;
}

@media screen and (min-width: 768px) {
	.payment-section {
		padding: 2.5rem;
	}

	#stripe-checkout-button {
		width: auto;
		min-width: 200px;
	}

	.document-upload-section {
		margin-top: 2rem;
	}

	.document-upload-section h3 {
		font-size: 2rem;
	}
}

@media screen and (max-width: 767px) {
	.document-upload-section h3 {
		font-size: 1.5rem;
	}
}

/* Footer
--------------------------------------------- */
.site-footer {
	background: #1a1a1a;
	color: #ffffff;
	padding: 2rem 0;
	text-align: center;
}

.footer-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 2rem;
}

.footer-navigation {
	display: flex;
	justify-content: center;
	margin-bottom: 1.5rem;
}

.footer-navigation .nav-menu {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-navigation .nav-menu li {
	margin: 0;
}

.footer-navigation .nav-menu a {
	color: #ffffff;
	text-decoration: none;
	font-size: 0.95rem;
	padding: 0.5rem 0;
	transition: color 0.2s ease;
	opacity: 0.9;
}

.footer-navigation .nav-menu a:hover,
.footer-navigation .nav-menu a:focus {
	color: #ffffff;
	opacity: 1;
	text-decoration: underline;
}

.site-info {
	margin-top: 1rem;
	padding-top: 1.5rem;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	font-size: 0.875rem;
	opacity: 0.8;
}

.site-info p {
	margin: 0;
}

@media screen and (max-width: 767px) {
	.site-footer {
		padding: 1.5rem 0;
	}

	.footer-container {
		padding: 0 1.5rem;
	}

	.footer-navigation .nav-menu {
		flex-direction: column;
		gap: 1rem;
		align-items: center;
	}
}

/* Comments
--------------------------------------------- */
.comment-content a {
	word-wrap: break-word;
}

.bypostauthor {
	display: block;
}

/* Widgets
--------------------------------------------- */
.widget {
	margin: 0 0 1.5em;
}

.widget select {
	max-width: 100%;
}

/* Media
--------------------------------------------- */
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
	border: none;
	margin-bottom: 0;
	margin-top: 0;
	padding: 0;
}

/* Make sure logo link wraps around logo image. */
.custom-logo-link {
	display: inline-block;
}

/* Captions
--------------------------------------------- */
.wp-caption {
	margin-bottom: 1.5em;
	max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.wp-caption .wp-caption-text {
	margin: 0.8075em 0;
}

.wp-caption-text {
	text-align: center;
}

/* Galleries
--------------------------------------------- */
.gallery {
	margin-bottom: 1.5em;
	display: grid;
	grid-gap: 1.5em;
}

.gallery-item {
	display: inline-block;
	text-align: center;
	width: 100%;
}

.gallery-columns-2 {
	grid-template-columns: repeat(2, 1fr);
}

.gallery-columns-3 {
	grid-template-columns: repeat(3, 1fr);
}

.gallery-columns-4 {
	grid-template-columns: repeat(4, 1fr);
}

.gallery-columns-5 {
	grid-template-columns: repeat(5, 1fr);
}

.gallery-columns-6 {
	grid-template-columns: repeat(6, 1fr);
}

.gallery-columns-7 {
	grid-template-columns: repeat(7, 1fr);
}

.gallery-columns-8 {
	grid-template-columns: repeat(8, 1fr);
}

.gallery-columns-9 {
	grid-template-columns: repeat(9, 1fr);
}

.gallery-caption {
	display: block;
}

/*--------------------------------------------------------------
# Plugins
--------------------------------------------------------------*/

/* Jetpack infinite scroll
--------------------------------------------- */

/* Hide the Posts Navigation and the Footer when Infinite Scroll is in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
	display: none;
}

/* Re-display the Theme Footer when Infinite Scroll has reached its end. */
.infinity-end.neverending .site-footer {
	display: block;
}

/*--------------------------------------------------------------
# Utilities
--------------------------------------------------------------*/

/* Accessibility
--------------------------------------------- */

/* Text meant only for screen readers. */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	color: #21759b;
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* Do not show the outline on the skip link target. */
#primary[tabindex="-1"]:focus {
	outline: 0;
}

/* Services Price Section
--------------------------------------------- */
.services-price-section {
	text-align: center;
	margin-bottom: 2rem;
}

/* History Section
--------------------------------------------- */
.history-section {
	margin-top: 0;
	padding-top: 1rem;
}

.history-subsection {
	margin-bottom: 2rem;
}

.history-subsection h4 {
	font-size: 1.25rem;
	margin-bottom: 1rem;
	color: #1a1a1a;
}

.history-grid {
	display: grid;
	gap: 1rem;
}

.history-card {
	background: #ffffff;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	padding: 1.5rem;
}

.history-card-header {
	display: flex;
	justify-content: space-between;
	align-items: start;
	margin-bottom: 1rem;
	flex-wrap: wrap;
	gap: 1rem;
}

.history-card-header-simple {
	display: flex;
	justify-content: space-between;
	align-items: start;
	flex-wrap: wrap;
	gap: 1rem;
}

.history-card-content {
	flex: 1;
}

.history-card-title {
	margin: 0 0 0.5rem 0;
	font-size: 1.1rem;
	color: #1a1a1a;
}

.history-card-text {
	margin: 0.25rem 0;
	color: #6b7280;
	font-size: 0.9rem;
}

.history-card-text-small {
	margin: 0.25rem 0;
	color: #6b7280;
	font-size: 0.85rem;
}

.history-card-text-tiny {
	margin: 0.25rem 0;
	color: #9ca3af;
	font-size: 0.8rem;
}

.history-card-actions {
	text-align: right;
}

.history-status-badge {
	display: inline-block;
	padding: 0.375rem 0.75rem;
	border-radius: 4px;
	font-size: 0.875rem;
	font-weight: 500;
}

.history-status-badge.requested {
	background: #fef3c7;
	color: #92400e;
	border: 1px solid #fbbf24;
}

.history-status-badge.in-progress {
	background: #dbeafe;
	color: #1e40af;
	border: 1px solid #3b82f6;
}

.history-status-badge.completed {
	background: #d1fae5;
	color: #065f46;
	border: 1px solid #22c55e;
}

.history-status-badge.paid {
	background: #dbeafe;
	color: #1e40af;
	border: 1px solid #3b82f6;
}

.history-status-badge.status-completed {
	background: #22c55e;
	color: #ffffff;
}

.history-status-badge.status-paid {
	background: #3b82f6;
	color: #ffffff;
}

.history-details-box {
	background: #f9fafb;
	border-radius: 6px;
	padding: 1rem;
	margin-top: 1rem;
}

.history-details-title {
	margin: 0 0 0.5rem 0;
	font-weight: 500;
	color: #1a1a1a;
}

.history-download-link {
	margin-left: 0.5rem;
	padding: 0.25rem 0.5rem;
	font-size: 0.8rem;
}

.history-urgent-text {
	margin: 0.25rem 0;
	color: #dc2626;
	font-size: 0.9rem;
	font-weight: 500;
}

.history-completed-section {
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid #e5e7eb;
}

.history-completed-title {
	margin: 0 0 0.5rem 0;
	font-weight: 600;
	color: #22c55e;
}

.history-download-button {
	margin-left: 0.5rem;
	padding: 0.5rem 1rem;
	background: #22c55e;
	color: #ffffff;
	text-decoration: none;
	border-radius: 4px;
	display: inline-block;
}

.history-download-button:hover,
.history-download-button:focus {
	background: #16a34a;
	color: #ffffff;
}

/* Account Page Styles
--------------------------------------------- */
.account-tabs {
	margin: 2rem 0;
	border-bottom: 2px solid #e5e7eb;
}

.account-tab-button {
	padding: 0.75rem 1.5rem;
	background: none;
	border: none;
	border-bottom: 3px solid transparent;
	cursor: pointer;
	font-size: 1rem;
	font-weight: 500;
	color: #6b7280;
	margin-right: 1rem;
	transition: all 0.3s ease;
}

.account-tab-button:last-child {
	margin-right: 0;
}

.account-tab-button.active {
	border-bottom-color: #3b82f6;
	color: #1a1a1a;
}

.account-tab-button:hover:not(.active) {
	color: #3b82f6;
}

.account-tab-content {
	display: none;
}

.account-tab-content.active {
	display: block;
}

.services-unavailable-message {
	padding: 2rem;
	background: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: 8px;
	margin: 2rem 0;
	text-align: center;
}

.services-unavailable-message h3 {
	margin: 0 0 1rem 0;
	color: #991b1b;
}

.services-unavailable-message p {
	margin: 0;
	font-size: 1.1rem;
	color: #7f1d1d;
}

#quote-payment-section {
	display: none;
	margin-top: 1.5rem;
	padding-top: 1.5rem;
	border-top: 1px solid #e5e7eb;
}

#quote-payment-section p {
	margin-bottom: 1rem;
	font-weight: 500;
}

.payment-method-selection {
	margin-bottom: 1.5rem;
}

.payment-method-selection label {
	display: block;
	margin-bottom: 0.5rem;
	font-weight: 500;
}

#payment-method {
	width: 100%;
	padding: 0.875rem 1.25rem;
	font-size: 1rem;
	border: 1px solid rgba(0, 0, 0, 0.1);
	border-radius: 6px;
}

.stripe-payment-button {
	background: #635bff;
	color: #ffffff;
}

.stripe-payment-button:hover,
.stripe-payment-button:focus {
	background: #5851e6;
	color: #ffffff;
}

.payment-option {
	display: none;
}

.payment-option.active {
	display: block;
}

.spei-payment-info {
	background: #f0f9ff;
	border: 1px solid #0ea5e9;
	border-radius: 8px;
	padding: 1.5rem;
	margin-bottom: 1rem;
}

.spei-payment-info h4 {
	margin: 0 0 0.75rem 0;
	color: #0c4a6e;
	font-size: 1.1rem;
}

.spei-payment-info p {
	margin: 0.5rem 0;
	color: #075985;
	font-size: 0.95rem;
}

.spei-payment-info p.spei-payment-amount {
	font-weight: 600;
}

.spei-payment-button {
	background: #0ea5e9;
	color: #ffffff;
}

.spei-payment-button:hover,
.spei-payment-button:focus {
	background: #0d8cc7;
	color: #ffffff;
}

#quote-payment-error {
	display: none;
	margin-top: 1rem;
}

.upload-success,
.upload-error {
	animation: slideIn 0.3s ease-out;
}

.upload-success {
	margin: 2rem 0;
}

.upload-error {
	margin: 2rem 0;
}

.upload-success p,
.upload-error p {
	margin: 0;
	font-weight: 500;
}

.upload-success p + p,
.upload-error p + p {
	margin: 0.5rem 0 0 0;
}

.upload-error p.upload-error-detail {
	font-size: 0.9rem;
	color: #6b7280;
}

.spei-verification-section {
	margin: 2rem 0;
	padding: 1.5rem;
	background: #fef3c7;
	border: 1px solid #fbbf24;
	border-radius: 8px;
}

.spei-verification-section h3 {
	margin: 0 0 1rem 0;
	color: #92400e;
}

.spei-verification-section > p {
	margin: 0 0 1rem 0;
	color: #78350f;
	font-weight: 500;
}

.spei-verification-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.spei-verification-item {
	padding: 0.75rem;
	margin: 0.5rem 0;
	background: #ffffff;
	border: 1px solid #fbbf24;
	border-radius: 6px;
}

.payment-requests-list {
	list-style: none;
	padding: 0;
	margin: 1rem 0;
}

.payment-request-item {
	padding: 0.75rem;
	margin: 0.5rem 0;
	background: #f0fdf4;
	border: 1px solid #22c55e;
	border-radius: 6px;
}

#deadline-group {
	display: none;
}

#deadline-group.show {
	display: block;
}

@keyframes slideIn {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Admin Page Styles
--------------------------------------------- */
.admin-text-muted {
	color: #999;
}

.admin-button-spei {
	background: #0ea5e9;
	color: #ffffff;
}

.admin-button-spei:hover,
.admin-button-spei:focus {
	background: #0d8cc7;
	color: #ffffff;
}

.admin-button-completed {
	background: #22c55e;
	color: #ffffff;
}

.admin-button-completed:hover,
.admin-button-completed:focus {
	background: #16a34a;
	color: #ffffff;
}

.admin-button-approve {
	background: #22c55e;
	color: #ffffff;
	width: 100%;
}

.admin-button-approve:hover,
.admin-button-approve:focus {
	background: #16a34a;
	color: #ffffff;
}

.admin-button-reject {
	background: #dc2626;
	color: #ffffff;
	width: 100%;
}

.admin-button-reject:hover,
.admin-button-reject:focus {
	background: #b91c1c;
	color: #ffffff;
}

.admin-actions-container {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.admin-form-inline {
	margin: 0;
}

.admin-input-small {
	width: 100%;
	font-size: 11px;
	margin-bottom: 0.25rem;
	padding: 0.25rem;
}

.admin-select-small {
	width: 150px;
}

.admin-file-input-small {
	font-size: 11px;
	margin-bottom: 0.25rem;
}

.admin-urgent-text {
	color: #dc2626;
	font-weight: bold;
}

/* New Quote Flow Styles
--------------------------------------------- */
#quote-flow-container {
	margin: 2rem 0;
}

.quote-step {
	display: none;
	padding: 2rem;
	background: #ffffff;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	margin-bottom: 1.5rem;
	opacity: 0.6;
	transition: opacity 0.3s ease, border-color 0.3s ease;
}

.quote-step.active {
	display: block !important;
	opacity: 1;
	border-color: #0ea5e9;
	border-width: 2px;
	box-shadow: 0 2px 8px rgba(14, 165, 233, 0.1);
}

/* Show steps that have been displayed (not hidden by JavaScript) */
.quote-step[style*="display: block"] {
	display: block !important;
}

.quote-step h3 {
	margin: 0 0 1rem 0;
	color: #1a1a1a;
	font-size: 1.5rem;
}

.quote-step > p {
	margin: 0 0 1.5rem 0;
	color: #6b7280;
}

#word-count-display {
	padding: 1.5rem;
	background: #f0f9ff;
	border: 1px solid #0ea5e9;
	border-radius: 8px;
	margin-bottom: 1rem;
}

#word-count-display p {
	margin: 0.5rem 0;
	font-size: 1.1rem;
}

#word-count-display #word-count-value {
	font-size: 1.5rem;
	font-weight: 700;
	color: #0ea5e9;
}

#detected-language-inline {
	color: #6b7280;
	font-weight: normal;
}

#detected-language-inline strong {
	color: #374151;
	font-weight: 600;
}

#detected-language-value {
	color: #22c55e;
	font-weight: 600;
}

.file-name-display {
	font-size: 0.9rem;
	color: #6b7280;
	margin-top: 0.5rem;
}

#quote-display {
	margin: 1.5rem 0;
}

.quote-summary {
	padding: 1.5rem;
	background: #f9fafb;
	border: 1px solid #e5e7eb;
	border-radius: 8px;
}

.quote-summary p {
	margin: 0.75rem 0;
	color: #374151;
}

.quote-summary .quote-total {
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 2px solid #e5e7eb;
	font-size: 1.25rem;
}

.quote-summary .quote-total strong {
	color: #1a1a1a;
}

#quote-total-amount {
	font-size: 1.5rem;
	font-weight: 700;
	color: #0ea5e9;
}

.upload-progress {
	padding: 1rem;
	background: #fef3c7;
	border: 1px solid #fbbf24;
	border-radius: 6px;
	margin: 1rem 0;
	text-align: center;
}

.upload-progress p {
	margin: 0;
	color: #92400e;
}

.button-secondary {
	background: #6b7280;
	color: #ffffff;
}

.button-secondary:hover,
.button-secondary:focus {
	background: #4b5563;
	color: #ffffff;
}

@media (max-width: 37.5em) {
	.quote-step {
		padding: 1.5rem;
	}

	.quote-step h3 {
		font-size: 1.25rem;
	}
}

.quote-step-actions {
	display: flex;
	gap: 1rem;
	margin-top: 1.5rem;
	align-items: center;
}

@media (max-width: 37.5em) {
	.quote-step-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.quote-step-actions .button {
		width: 100%;
	}
}

.word-count-mismatch {
	margin: 1.5rem 0;
	padding: 1rem;
	background: #fef2f2;
	border: 1px solid #f87171;
	border-radius: 8px;
}

.word-count-mismatch p {
	margin: 0 0 1rem 0;
	color: #991b1b;
	font-weight: 500;
}

#expected-word-count-display {
	margin-top: 0.75rem;
	padding: 0.5rem;
	background: #f9fafb;
	border-left: 3px solid #6b7280;
	padding-left: 0.75rem;
}

#expected-word-count-display strong {
	color: #374151;
}

#expected-word-count-value {
	color: #6b7280;
	font-weight: 600;
}
