@import url('typography-responsive.css');

/* Lang toggle (moved from lang.js inline injection) */
.lang-toggle {
    font-family: var(--font-display, 'Archivo Black', sans-serif) !important;
    font-size: 0.75rem !important;
    letter-spacing: 0.12em !important;
    color: var(--yellow, #ffbd59) !important;
    border: 2px solid var(--yellow, #ffbd59) !important;
    padding: 0.25rem 0.625rem !important;
    border-radius: 2px !important;
    text-decoration: none !important;
    transition: background 0.2s, color 0.2s !important;
    min-height: 2.75rem;
    min-width: 2.75rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.lang-toggle:hover {
    background: var(--yellow, #ffbd59) !important;
    color: var(--black, #080517) !important;
}
.lang-toggle::after { display: none !important; }

/* Extracted from index.html / home.html — preserves exact layout (no visual change) */
.service-header {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 1000;
    background-color: var(--black);
    border-bottom: 2px solid var(--yellow);
    transition: all 0.3s ease;
}
.service-header.scrolled { box-shadow: 0 4px 20px rgba(0,0,0,0.3); }
.header-container {
    max-width: 1400px;
    margin: 0 auto;
    padding: 1.5rem 2rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.logo { display: flex; align-items: center; text-decoration: none; transition: transform 0.3s ease; }
.logo:hover { transform: scale(1.04); }
.logo-image { height: 40px; width: 40px; filter: brightness(0) invert(1); transition: filter 0.3s ease; }
.logo:hover .logo-image { filter: brightness(0) saturate(100%) invert(77%) sepia(55%) saturate(500%) hue-rotate(340deg) brightness(103%) contrast(97%); }
.main-nav { display: flex; gap: 2.5rem; align-items: center; list-style: none; margin: 0; padding: 0; }
.main-nav a { font-family: var(--font-display); font-size: 0.875rem; letter-spacing: 0.1em; color: var(--white); text-decoration: none; position: relative; transition: color 0.3s ease; }
.main-nav a::after { content: ''; position: absolute; bottom: -5px; left: 0; width: 0; height: 2px; background-color: var(--yellow); transition: width 0.3s ease; }
.main-nav a:hover { color: var(--yellow); }
.main-nav a:hover::after { width: 100%; }
.nav-cta { background-color: var(--red) !important; color: var(--white) !important; padding: 0.75rem 1.5rem; border: 2px solid var(--red); transition: all 0.3s ease !important; }
.nav-cta::after { display: none !important; }
.nav-cta:hover { background-color: var(--yellow) !important; border-color: var(--yellow) !important; color: var(--black) !important; }
.mobile-menu-toggle { display: none; flex-direction: column; gap: 5px; background: transparent; border: none; cursor: pointer; padding: 5px; }
.mobile-menu-toggle span { width: 25px; height: 3px; background-color: var(--yellow); display: block; transition: all 0.3s ease; }
.mobile-menu-toggle.active span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
.mobile-menu-toggle.active span:nth-child(2) { opacity: 0; }
.mobile-menu-toggle.active span:nth-child(3) { transform: rotate(-45deg) translate(7px,-7px); }
@media (max-width: 768px) {
    .main-nav { display: none; position: absolute; top: 100%; left: 0; right: 0; background-color: var(--black); flex-direction: column; padding: 2rem 1.5rem; gap: 1.5rem; border-top: 2px solid var(--yellow); border-bottom: 2px solid var(--yellow); }
    .main-nav.active { display: flex; }
    .mobile-menu-toggle { display: flex; }
}

.faq-section { background-color: var(--black); padding: 6rem 0; border-top: 4px solid var(--yellow); }
.faq-container { max-width: 900px; margin: 0 auto; padding: 0 2rem; }
.faq-title { font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3rem); color: var(--yellow); text-align: center; margin-bottom: 3rem; letter-spacing: 0.05em; }
.faq-item { border: 2px solid var(--yellow); margin-bottom: 1rem; overflow: hidden; }
.faq-question { width: 100%; padding: 1.5rem; background-color: transparent; border: none; color: var(--yellow); font-family: var(--font-display); font-size: 1rem; letter-spacing: 0.03em; cursor: pointer; display: flex; justify-content: space-between; align-items: center; transition: background-color 0.3s ease, color 0.3s ease; text-align: left; }
.faq-question:hover, .faq-question.active { background-color: var(--yellow); color: var(--black); }
.faq-icon { font-size: 1.2rem; transition: transform 0.3s ease; flex-shrink: 0; margin-left: 1rem; }
.faq-question.active .faq-icon { transform: rotate(180deg); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.35s ease; }
.faq-answer.active { max-height: 500px; border-top: 2px solid var(--yellow); }
.faq-answer-content { padding: 1.5rem; color: var(--white); line-height: 1.8; font-weight: 300; }
.faq-answer-content p { margin-bottom: 1rem; }
.faq-answer-content ul { margin: 1rem 0 1rem 2rem; }
.faq-answer-content li { margin-bottom: 0.5rem; }
.faq-answer-content strong { color: var(--yellow); font-weight: 600; }
.faq-answer-content a { color: var(--yellow); }
@media (max-width: 768px) { .faq-title { font-size: 1.75rem; } .faq-question { font-size: 0.95rem; } .faq-container { padding: 0 1rem; } }

.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.phone-input-group { display: flex; align-items: stretch; border: 2px solid var(--white); transition: border-color 0.3s ease; }
.phone-input-group:focus-within { border-color: var(--yellow); }
.phone-prefix { padding: 0 1rem; background-color: var(--yellow); color: var(--black); font-family: var(--font-display); font-size: 0.9rem; display: flex; align-items: center; white-space: nowrap; flex-shrink: 0; user-select: none; }
.phone-input-group input { border: none !important; flex: 1; min-width: 0; }
.phone-input-group input:focus { outline: none; background-color: var(--black); }
.form-status { display: none; padding: 1.25rem 1.5rem; border: 2px solid; font-family: var(--font-display); font-size: 0.9rem; letter-spacing: 0.05em; margin-top: 1rem; text-align: center; }
.form-status.success { display: block; border-color: #28c840; color: #28c840; }
.form-status.error { display: block; border-color: var(--red); color: var(--red); }

/* Honeypot: never rely on inline display:none (may be CSP-stripped); keep focusable bots only */
.honeypot-field {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    clip-path: inset(50%) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

/* Cal.com: mask transient iframe error flash until iframe load */
.cal-embed-shell {
    position: relative;
    width: 100%;
}
.cal-embed-loading-panel {
    position: absolute;
    inset: 0;
    z-index: 5;
    background: var(--black);
    pointer-events: none;
    transition: opacity 0.4s ease, visibility 0.4s ease;
}
.cal-embed-loading-panel.cal-embed-loading-panel--done {
    opacity: 0;
    visibility: hidden;
}
.cal-embed-error-hidden {
    display: none !important;
    visibility: hidden !important;
}
.btn[disabled] { opacity: 0.5; cursor: not-allowed; pointer-events: none; }
.btn-loading { display: inline-flex !important; align-items: center; justify-content: center; gap: 0.6rem; opacity: 0.85 !important; }
.btn-spinner { width: 16px; height: 16px; border: 2px solid rgba(255,255,255,0.3); border-top-color: #fff; border-radius: 50%; animation: spin 0.7s linear infinite; flex-shrink: 0; }
@keyframes spin { to { transform: rotate(360deg); } }

.booking-section { background-color: var(--black); border-top: 4px solid var(--red); border-bottom: 4px solid var(--yellow); padding: 6rem 0 0; }
.booking-header { max-width: 900px; margin: 0 auto; text-align: center; padding: 0 2rem 4rem; }
.booking-header .section-label { border-left: none; padding-left: 0; color: var(--red); }
.booking-title { font-family: var(--font-display); font-size: clamp(2rem, 8vw, 5rem); line-height: 0.95; color: var(--white); margin: 1rem 0 1.5rem; letter-spacing: -0.02em; }
.booking-accent { color: var(--yellow); }
.booking-subtitle { font-size: 1.1rem; color: var(--white); font-weight: 300; max-width: 600px; margin: 0 auto; line-height: 1.6; }
.booking-widget-wrapper { max-width: 1100px; margin: 0 auto; border-top: 2px solid var(--yellow); position: relative; }
.booking-widget-wrapper iframe { display: block; width: 100%; border: none; height: 700px; }
#my-cal-inline-30min { width: 100%; height: 700px; position: relative; z-index: 1; }
@media (max-width: 768px) { .booking-section { padding: 3rem 0 0; } .booking-header { padding: 0 1rem 2.5rem; } #my-cal-inline-30min { height: 900px !important; } }
@media (max-width: 480px) { #my-cal-inline-30min { height: 1000px !important; } }

.footer-legal a { color: var(--white); font-family: var(--font-display); font-size: 0.8rem; letter-spacing: 0.05em; text-decoration: none; transition: color 0.3s ease; }
.footer-legal a:hover { color: var(--yellow); }
