/* ========================================================================
   Lanns Associates - Styles
   ======================================================================== */

/* Reset & Base
   ======================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { line-height: 1.15; -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { margin: 0; background-color: #ffffff; color: #1a1a1a; font-weight: 400; font-size: 16px; font-family: 'Roboto', sans-serif; line-height: 1.6; }
article, aside, footer, header, nav, section { display: block; }
figure { margin: 0; }
img { max-width: 100%; height: auto; border: 0; vertical-align: middle; }
a { color: #2a5a8f; text-decoration: none; transition: all 0.2s ease; }
a:hover { color: #1e3a5f; text-decoration: none; }
a:focus, button:focus { transition: none; outline: 2px solid #2a5a8f; color: inherit; }
button { border: 0; margin: 0; padding: 0; text-align: inherit; text-transform: inherit; font: inherit; letter-spacing: inherit; background: none; cursor: pointer; overflow: visible; transition: all 0.2s ease; }
strong { font-weight: bold; }
p { margin: 25px 0; font-size: 16px; }
p:last-child { margin-bottom: 0; }
h1, h2, h3, h4, h5, h6 { display: block; margin: 50px 0 30px 0; color: #1e3a5f; font-weight: 400; text-transform: uppercase; font-family: 'Lora', serif; line-height: 1.25; }
h1, .h1 { font-size: 1.8em; line-height: 1.1em; font-weight: 400; }
@media (min-width: 576px) { h1, .h1 { font-size: 2em; } }
@media (min-width: 768px) { h1, .h1 { font-size: 3em; line-height: 1.4em; } }
h2, .h2 { font-size: 1.75em; color: #1e3a5f; }
@media (min-width: 768px) { h2, .h2 { font-size: 48px; } }
h3, .h3 { font-size: 1.5em; }
@media (min-width: 768px) { h3, .h3 { font-size: 2.25em; } }
h4, .h4 { font-size: 1.25em; color: #1e3a5f; }
@media (min-width: 768px) { h4, .h4 { font-size: 28px; } }
h5, .h5 { font-size: 1.125em; color: #1e3a5f; text-transform: uppercase; }
@media (min-width: 768px) { h5, .h5 { font-size: 1.25em; } }
h6, .h6 { font-size: 1em; }
h1:last-child, h2:last-child, h3:last-child, h4:last-child, h5:last-child, h6:last-child { margin-bottom: 0; }
ul { list-style: none; padding: 0; margin: 0; }

/* Utility Classes
   ======================================================================== */
.hide { display: none !important; }
.skip-link { position: absolute; top: -40px; left: 0; background: #000; color: #fff; padding: 8px; z-index: 1000; }
.skip-link:focus { top: 0; }
.overflow-hidden { overflow: hidden; }
.type-center { text-align: center; }
.text-link { position: relative; display: inline-block; color: #2a5a8f; font-size: 1em; text-decoration: underline; }
.text-link:hover { text-decoration: underline; opacity: 0.5; color: inherit; }
.text-link--white { color: #fff !important; }
.text-link--white:hover { color: #ccc !important; }

@media (min-width: 992px) {
	.mobile-only { display: none !important; }
}
@media (max-width: 991px) {
	.desktop-only { display: none !important; }
}

/* Container & Grid System
   ======================================================================== */
.container { max-width: 1224px; margin: 0 auto; padding: 0 15px; }
@media (min-width: 576px) { .container { max-width: 540px; } }
@media (min-width: 768px) { .container { max-width: 720px; } }
@media (min-width: 992px) { .container { max-width: 1140px; } }
.container--small { max-width: 1024px; margin: 0 auto; padding: 0 15px; }

.grid { display: flex; flex-wrap: wrap; margin: 0 -15px; }
.grid--no-padding { margin: 0; }
.grid--no-padding > .grid__column { padding: 0; }
.grid__column { padding: 0 15px; width: 100%; }

.grid__column--1 { width: 8.333%; }
.grid__column--2 { width: 16.667%; }
.grid__column--3 { width: 25%; }
.grid__column--4 { width: 33.333%; }
.grid__column--5 { width: 41.667%; }
.grid__column--6 { width: 50%; }
.grid__column--7 { width: 58.333%; }
.grid__column--8 { width: 66.667%; }
.grid__column--9 { width: 75%; }
.grid__column--10 { width: 83.333%; }
.grid__column--11 { width: 91.667%; }
.grid__column--12 { width: 100%; }

@media (min-width: 576px) {
	.grid__column--1--sm { width: 8.333%; }
	.grid__column--2--sm { width: 16.667%; }
	.grid__column--3--sm { width: 25%; }
	.grid__column--4--sm { width: 33.333%; }
	.grid__column--5--sm { width: 41.667%; }
	.grid__column--6--sm { width: 50%; }
	.grid__column--7--sm { width: 58.333%; }
	.grid__column--8--sm { width: 66.667%; }
	.grid__column--9--sm { width: 75%; }
	.grid__column--10--sm { width: 83.333%; }
	.grid__column--11--sm { width: 91.667%; }
	.grid__column--12--sm { width: 100%; }
}
@media (min-width: 768px) {
	.grid__column--1--md { width: 8.333%; }
	.grid__column--2--md { width: 16.667%; }
	.grid__column--3--md { width: 25%; }
	.grid__column--4--md { width: 33.333%; }
	.grid__column--5--md { width: 41.667%; }
	.grid__column--6--md { width: 50%; }
	.grid__column--7--md { width: 58.333%; }
	.grid__column--8--md { width: 66.667%; }
	.grid__column--9--md { width: 75%; }
	.grid__column--10--md { width: 83.333%; }
	.grid__column--11--md { width: 91.667%; }
	.grid__column--12--md { width: 100%; }
}
@media (min-width: 992px) {
	.grid__column--1--lg { width: 8.333%; }
	.grid__column--2--lg { width: 16.667%; }
	.grid__column--3--lg { width: 25%; }
	.grid__column--4--lg { width: 33.333%; }
	.grid__column--5--lg { width: 41.667%; }
	.grid__column--6--lg { width: 50%; }
	.grid__column--7--lg { width: 58.333%; }
	.grid__column--8--lg { width: 66.667%; }
	.grid__column--9--lg { width: 75%; }
	.grid__column--10--lg { width: 83.333%; }
	.grid__column--11--lg { width: 91.667%; }
	.grid__column--12--lg { width: 100%; }
}

/* Typography
   ======================================================================== */
p.lead { font-size: 1.125em; }
@media (min-width: 768px) { p.lead { font-size: 1.5em; } }
.lead { font-weight: 500; font-size: 1.25em; }
@media (min-width: 768px) { .lead { font-size: 20px; } }
.preheadline { margin-top: 0; margin-bottom: 10px; font-size: 1.25rem; opacity: 0.75; color: #1a1a1a; text-transform: uppercase; font-weight: 400; }
.subheadline { margin-top: -20px; font-size: 20px; margin-bottom: 20px !important; color: #1a1a1a; }
@media (min-width: 768px) { .subheadline { font-size: 28px; } }

/* Lists
   ======================================================================== */
.list__item { line-height: 1.25em; font-size: 1.15rem !important; margin-bottom: 15px !important; position: relative; }
@media (min-width: 576px) { .list__item { padding-right: 10px; } }
.list--inline { padding-left: 0; }
.list--inline .list__item { display: inline-block; }
.list--inline .list__item:not(:last-child) { padding-right: 0; }
@media (min-width: 576px) { .list--inline .list__item:not(:last-child) { padding-right: 25px; } }

/* Buttons
   ======================================================================== */
.btn { position: relative; padding: 15px 25px; border-radius: 0px; border: 0; display: inline-block; color: #ffffff; font-size: 0.85em; font-family: 'Lora', serif; font-weight: 400; line-height: 21px; text-align: center; text-transform: uppercase; white-space: normal; transition: all 0.2s ease; cursor: pointer; }
@media (min-width: 576px) { .btn { font-size: 1em; } }
.btn:hover, .btn:focus, .btn:active { box-shadow: 0px 5px 20px 2px rgba(0,0,0,0.1); transform: translateY(-2px); transition: all 0.2s ease; color: #fff; }
.btn--navy { background-color: #2a5a8f; color: #ffffff; }
.btn--navy:hover { background-color: #1e3a5f; color: #ffffff; }
.btn--dark { background-color: #1e3a5f; color: #ffffff; }
.btn--dark:hover { background-color: #2a5a8f; color: #ffffff; }
.btn--white { background-color: #ffffff; color: #1a1a1a; }
.btn--white:hover { background-color: #ffffff; color: #1a1a1a; }

/* CTA Arrow Link
   ======================================================================== */
.cta-link { display: inline-block; color: #ffffff; font-family: 'Lora', serif; font-size: 1.1em; font-weight: 400; text-transform: uppercase; letter-spacing: 1px; transition: all 0.3s ease; }
.cta-link:hover { color: #ffffff; opacity: 0.8; }
.cta-link__arrow { display: inline-block; margin-left: 8px; transition: transform 0.3s ease; }
.cta-link:hover .cta-link__arrow { transform: translateX(5px); }

/* Header & Navigation
   ======================================================================== */
.header { background-color: #fff; box-shadow: 0 0 10px rgba(30,58,95,0.3); position: fixed; top: 0; width: 100%; z-index: 99; overflow: visible; padding: 15px 0; }
@media (min-width: 992px) { .header { padding: 0; } }

.nav { margin-bottom: 0; }
@media (min-width: 992px) { .nav { display: flex; align-items: center; } }
.nav__item { display: block; margin-bottom: 0; text-align: center; }
@media (min-width: 992px) { .nav__item { text-align: left; } }
.nav__link { position: relative; display: inline-block; padding: 10px; margin: 0; text-transform: uppercase; font-weight: 700; font-size: 1.125em; color: #fff; white-space: nowrap; }
.nav__link:hover { color: #fff; text-decoration: underline; }
@media (min-width: 992px) {
	.nav__link { font-size: 0.875em; color: #1e3a5f; padding: 11px 10px; }
	.nav__link:hover { color: #2a5a8f; text-decoration: none; }
}
@media (min-width: 1200px) { .nav__link { padding: 11px 20px; } }
.nav__link--phone { display: none; }
@media (min-width: 992px) { .nav__link--phone { display: block; } }

.navbar { display: flex; padding: 0; align-items: center; justify-content: space-between; }
.navbar__logo { padding: 0; display: block; text-decoration: none; }
.navbar__logo:hover { text-decoration: none; }
.navbar__logo-text { display: inline-block; background-color: #1e3a5f; color: #fff; font-family: 'Lora', serif; font-size: 1.1em; font-weight: 400; letter-spacing: 0.25em; text-transform: uppercase; padding: 10px 18px; white-space: nowrap; }
@media (min-width: 992px) { .navbar__logo-text { font-size: 1.3em; padding: 12px 22px; } }
.navbar__logo-divider { color: rgba(255,255,255,0.4); margin: 0 2px; font-weight: 300; }

.navbar__nav { position: fixed; top: 0; left: 0; right: 0; bottom: 0; z-index: 998; overflow-y: scroll; background-color: #1e3a5f; display: block; padding: 50px 15px 0; opacity: 0; visibility: hidden; transition: all 0.3s ease; }
.navbar__nav--is-open { opacity: 1; visibility: visible; overflow: hidden; }
@media (min-width: 992px) {
	.navbar__nav { position: relative; top: auto; left: auto; right: auto; bottom: auto; z-index: 998; opacity: 1; overflow: visible; visibility: visible; background-color: transparent; display: inline-block; padding: 0; }
}
@media (min-width: 992px) { .navbar__mobile-buttons { display: none; } }
.navbar__phone-icon { display: inline-block; font-size: 21px; line-height: 18px; padding: 10px 13px; }
.navbar__phone-icon a { color: #1e3a5f; }

.navicon { position: relative; z-index: 999; border: none; background-color: transparent; padding: 10px 8px; outline: none; display: inline-block; }
.navicon__holder { display: block; cursor: pointer; }
.navicon__line { position: relative; width: 26px; height: 3px; margin-bottom: 5px; display: block; border-radius: 5px; background-color: #1e3a5f; transition: all 0.25s cubic-bezier(0.57, 0.28, 0.25, 0.69); }
.navicon__line:last-of-type { margin-bottom: -1px; }
.navicon--toggle .navicon__line { background-color: #fff; }
.navicon--toggle .navicon__line:first-of-type { transform: rotate(45deg) translateY(6px) translateX(6px); }
.navicon--toggle .navicon__line:nth-of-type(2) { opacity: 0; transform: scale(0); }
.navicon--toggle .navicon__line:last-of-type { transform: rotate(-45deg) translateY(-5px) translateX(5px); }

/* Active Nav Link
   ======================================================================== */
@media (min-width: 992px) {
	.nav__link--active { color: #2a5a8f !important; }
	.nav__link--active::after { content: ''; position: absolute; bottom: 30px; left: 50%; transform: translateX(-50%); width: 30px; height: 2px; background-color: #2a5a8f; }
}

/* Banner / Hero
   ======================================================================== */
.banner { position: relative; z-index: 10; background-color: #1e3a5f; padding: 50px 0; margin-top: 80px; display: flex; align-items: center; justify-content: center; min-height: 400px; }
@media (min-width: 768px) { .banner { height: 60vh; min-height: 500px; } }
@media (min-width: 992px) { .banner { height: 70vh; margin-top: 100px; } }
@media (min-width: 1200px) { .banner { height: 90vh; } }

.banner__content { position: relative; padding: 0 15px; text-align: center; animation: moveDown 1s forwards; z-index: 2; }
.banner__heading { margin-top: 0; margin-bottom: 25px !important; color: #fff; font-family: 'Lora', serif; }
.banner__subheading { color: rgba(255,255,255,0.9); font-size: 1.1em; margin-top: -15px; margin-bottom: 30px; max-width: 600px; margin-left: auto; margin-right: auto; }
@media (min-width: 768px) { .banner__subheading { font-size: 1.35em; } }

.banner__background { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-position: center center; background-repeat: no-repeat; background-size: cover; opacity: 0.3; }

@keyframes moveDown { 0% { transform: translateY(-10px); opacity: 0; } 100% { transform: translateY(0px); opacity: 1; } }

/* Sections
   ======================================================================== */
.section { position: relative; padding-top: 40px; padding-bottom: 40px; color: #1a1a1a; }
.section h2 { color: #1e3a5f; }
.section p { color: #1a1a1a; }
@media (min-width: 768px) { .section { padding-top: 60px; padding-bottom: 60px; } }
@media (min-width: 992px) { .section { padding-top: 80px; padding-bottom: 80px; } }
.section--light-gray { background-color: #f5f5f5; }
.section--light-gray h2, .section--light-gray h3 { color: #1e3a5f; }
.section--light-gray p, .section--light-gray li { color: #1a1a1a; }
.section--navy { background-color: #1e3a5f; }
.section--navy h1, .section--navy h2, .section--navy h3, .section--navy h4, .section--navy h5, .section--navy h6, .section--navy p, .section--navy ul li, .section--navy a { color: #fff; }

.anchor { position: relative; top: -80px; display: block; }
@media (min-width: 992px) { .anchor { top: -100px; } }

/* About Section
   ======================================================================== */
.about-intro { text-align: center; max-width: 760px; margin: 0 auto; }

/* Service Cards
   ======================================================================== */
.service-cards { display: grid; grid-template-columns: 1fr; gap: 25px; margin-top: 30px; }
@media (min-width: 576px) { .service-cards { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) { .service-cards { grid-template-columns: repeat(4, 1fr); } }

.service-card { text-align: center; padding: 30px 20px; }
.service-card__icon { font-size: 2.5em; color: rgba(255,255,255,0.8); margin-bottom: 15px; display: block; }
.service-card__title { font-family: 'Lora', serif; font-size: 1.1em; font-weight: 600; color: #fff; margin: 0 0 10px 0; text-transform: none; }
.service-card__text { font-size: 0.9em; color: rgba(255,255,255,0.8); margin: 0; line-height: 1.5; }

/* Portfolio Cards
   ======================================================================== */
.portfolio-cards { display: grid; grid-template-columns: 1fr; gap: 30px; margin-top: 30px; }
@media (min-width: 768px) { .portfolio-cards { grid-template-columns: repeat(2, 1fr); } }

.portfolio-card { background-color: #fff; overflow: hidden; box-shadow: 0 2px 15px rgba(0,0,0,0.08); transition: box-shadow 0.3s ease; }
.portfolio-card:hover { box-shadow: 0 5px 25px rgba(0,0,0,0.15); }
.portfolio-card__image { height: 250px; background-color: #e0e0e0; overflow: hidden; }
.portfolio-card__image img { width: 100%; height: 100%; object-fit: cover; }
@media (min-width: 768px) { .portfolio-card__image { height: 300px; } }
.portfolio-card__content { padding: 25px 30px; }
.portfolio-card__title { font-family: 'Lora', serif; font-size: 1.4em; color: #1e3a5f; margin: 0 0 5px 0; text-transform: none; }
.portfolio-card__location { font-size: 0.9em; color: #666; margin: 0 0 12px 0; text-transform: uppercase; letter-spacing: 0.5px; }
.portfolio-card__desc { font-size: 0.95em; color: #1a1a1a; margin: 0 0 15px 0; line-height: 1.6; }
.portfolio-card__link { display: inline-block; color: #2a5a8f; font-weight: 600; font-size: 0.95em; text-transform: uppercase; }
.portfolio-card__link:hover { color: #1e3a5f; }
.portfolio-card__link-arrow { margin-left: 5px; transition: transform 0.3s ease; display: inline-block; }
.portfolio-card__link:hover .portfolio-card__link-arrow { transform: translateX(4px); }

/* Service Area
   ======================================================================== */
.service-area { display: flex; flex-direction: column; gap: 30px; }
@media (min-width: 768px) { .service-area { flex-direction: row; align-items: center; } }
.service-area__text { flex: 1; }
.service-area__text h3 { margin-top: 0; color: #1e3a5f; text-transform: none; font-size: 1.3em; }
@media (min-width: 768px) { .service-area__text h3 { font-size: 1.6em; } }
.service-area__counties { list-style: none; padding: 0; margin: 20px 0; }
.service-area__counties li { padding: 8px 0; font-size: 1.05em; color: #1a1a1a; border-bottom: 1px solid #e0e0e0; }
.service-area__counties li:last-child { border-bottom: none; }
.service-area__counties li i { color: #2a5a8f; margin-right: 10px; width: 20px; text-align: center; }
.service-area__map { flex: 1; display: flex; align-items: center; justify-content: center; }
.service-area__map-placeholder { width: 100%; max-width: 400px; aspect-ratio: 3/4; background-color: #e8edf3; border-radius: 8px; display: flex; align-items: center; justify-content: center; color: #2a5a8f; font-family: 'Lora', serif; font-size: 1.2em; text-align: center; padding: 30px; }

/* Why Choose Us
   ======================================================================== */
.differentiators { display: grid; grid-template-columns: 1fr; gap: 30px; margin-top: 30px; }
@media (min-width: 768px) { .differentiators { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 992px) { .differentiators { grid-template-columns: repeat(3, 1fr); } }

.differentiator { text-align: center; padding: 20px; }
.differentiator__icon { font-size: 2em; color: rgba(255,255,255,0.8); margin-bottom: 12px; display: block; }
.differentiator__title { font-family: 'Lora', serif; font-size: 1.15em; font-weight: 600; color: #fff; margin: 0 0 8px 0; text-transform: none; }
.differentiator__text { font-size: 0.9em; color: rgba(255,255,255,0.8); margin: 0; line-height: 1.5; }

/* Contact Form
   ======================================================================== */
.control { margin-bottom: 20px; }
.control:last-of-type { margin-bottom: 0; }
.control__label { color: #1a1a1a; display: block; margin-bottom: 5px; font-weight: 500; font-size: 0.9em; }
.control__label--is-required::after { content: " *"; color: #c00; }
.control__input { display: block; width: 100%; padding: 0.5rem 1rem; border: 1px solid #E0E0E0; border-radius: 0; font-family: inherit; font-size: 1rem; transition: border-color 0.2s ease; background-color: #fff; color: #1a1a1a; appearance: none; }
.control__input:focus { border-color: #2a5a8f; outline: none; box-shadow: 0 0 0 2px rgba(42,90,143,0.2); }
.control__textarea { resize: vertical; min-height: 120px; }
.form .control__label { font-weight: normal; font-size: 18px; padding-bottom: 0; margin-bottom: 2px; }
.form .control__input { border: 2px solid rgba(42,90,143,.5); font-family: 'Roboto', sans-serif; font-size: 18px; padding: 15px; height: 55px; transition: all ease 0.25s; }
.form .control__input:focus { border: 2px solid rgba(30,58,95,1); outline: none; box-shadow: none; }
.form .control__textarea { height: 125px; }
.form-status { margin-top: 15px; display: none; }
.form-status--success { display: block; }
.form-status--error { display: block; padding: 10px; background-color: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; border-radius: 2px; }
.form-status__banner { background-color: #1e3a5f; color: #fff; font-family: 'Lora', serif; font-size: 24px; padding: 15px 20px; }
.form-status__thanks { font-size: 16px; color: #333; margin-top: 12px; }

/* Honeypot - hidden from real users */
.form__honeypot { position: absolute; left: -9999px; }

/* Footer
   ======================================================================== */
.footer { padding: 0 !important; text-align: center; }
.footer__top { padding: 50px 0; background-color: #1e3a5f; }
.footer__contacts li { font-size: 1em !important; text-transform: uppercase; font-weight: 300; font-family: 'Lora', serif; color: #fff; }
.footer__contacts li a { color: #fff; }
.footer__contacts li a:hover { text-decoration: underline; }
.footer__bottom { padding: 15px 0; background-color: #0f1f33; }
.footer__bottom p { margin: 10px 0; font-size: 13px; color: #fff; }
.footer__copyright { text-align: center; }
@media (min-width: 992px) { .footer__copyright { text-align: left; } }
.footer__copyright .list { margin-top: 10px; margin-bottom: 10px; }
.footer__copyright .list__item { display: inline-block; margin-bottom: 0 !important; font-size: 13px !important; opacity: 0.85 !important; font-weight: 300; color: #fff; }
.footer__copyright .list__item a { color: #ffffff; font-size: 0.95em; opacity: 0.85; font-weight: 300; text-transform: uppercase; font-family: 'Lora', serif; }
.footer__copyright .list__item a::before { content: ""; padding-right: 10px; padding-left: 10px; }
@media (min-width: 576px) { .footer__copyright .list__item a::before { content: "|"; } }
.footer__copyright .list__item a:hover { text-decoration: underline; }
.footer__developer { text-align: center; }
@media (min-width: 992px) { .footer__developer { text-align: right; } }
.footer__developer p { color: rgba(255,255,255,0.7); }

/* Scroll to Top
   ======================================================================== */
#to-top { position: fixed; bottom: 65px; right: 10px; cursor: pointer; display: none; padding: 0; z-index: 999; opacity: 0.6; }
@media (min-width: 576px) { #to-top { bottom: 20px; } }
@media (min-width: 768px) { #to-top { bottom: 15px; right: 15px; } }
#to-top:hover { opacity: 1; }
#to-top .fa { color: #fff; background: #2a5a8f; font-size: 2.5em; padding: 5px 12px; line-height: 36px; width: 50px; height: 50px; border-radius: 50%; transition: all 0.25s ease; }
#to-top .fa:hover { background: #1e3a5f; }

/* Cookie Warning
   ======================================================================== */
.cookie-warning { position: fixed; z-index: 9999; bottom: 15px; left: 15px; right: 15px; padding: 30px; background-color: #1e3a5f; color: #ffffff; transition: opacity 0.3s ease; }
.cookie-warning--is-hidden { display: none !important; }
.cookie-warning__container { display: flex; flex-direction: column; }
@media (min-width: 768px) { .cookie-warning__container { flex-direction: row; } }
.cookie-warning__content { flex: 1; }
.cookie-warning__notice { color: #fff; font-size: 13px; margin: 0; max-width: 880px; line-height: 1.5; }
.cookie-warning__link { color: #fff; text-decoration: underline; }
.cookie-warning__link:hover { color: #ccc; text-decoration: underline; }
.cookie-warning__action { margin-top: 20px; }
@media (min-width: 768px) { .cookie-warning__action { margin-top: 0; padding-left: 30px; flex: 0 0 300px; max-width: 300px; text-align: right; } }
.btn.cookie-warning__button { background-color: #fff; color: #1a1a1a !important; min-width: 150px; padding: 8px 25px; white-space: nowrap; font-size: 0.85em; }
.btn.cookie-warning__button:hover { background-color: #2a5a8f; color: #fff !important; }

/* FAQ Section
   ======================================================================== */
.faq-list { max-width: 800px; margin: 30px auto 0; }
.faq-item { border-bottom: 1px solid #e0e0e0; }
.faq-item:last-child { border-bottom: none; }
.faq-item__question { padding: 18px 0; font-family: 'Lora', serif; font-size: 1.1em; font-weight: 600; color: #1e3a5f; cursor: pointer; list-style: none; position: relative; padding-right: 30px; }
.faq-item__question::-webkit-details-marker { display: none; }
.faq-item__question::after { content: '+'; position: absolute; right: 0; top: 18px; font-size: 1.4em; font-weight: 300; color: #2a5a8f; transition: transform 0.2s ease; }
.faq-item[open] .faq-item__question::after { content: '\2212'; }
.faq-item__answer { padding: 0 0 18px 0; }
.faq-item__answer p { margin: 0; font-size: 0.95em; line-height: 1.7; color: #1a1a1a; }

/* Service Area Cities
   ======================================================================== */
.service-area__cities { font-size: 0.85em; color: #666; font-weight: 300; }

/* Scroll Animations
   ======================================================================== */
.fade-in { opacity: 0; transform: translateY(20px); transition: opacity 0.6s ease, transform 0.6s ease; }
.fade-in--visible { opacity: 1; transform: translateY(0); }
