.elementor-42669 .elementor-element.elementor-element-2da28086{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;}.elementor-42669 .elementor-element.elementor-element-2da28086 > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}/* Start custom CSS for html, class: .elementor-element-5623fc03 *//* --- GLOBALA INSTÄLLNINGAR --- */
html { scroll-behavior: smooth; }
.sp-wrapper-single { font-family: 'Poppins', sans-serif; color: #1f2937; background-color: white; width: 100vw; max-width: 100vw; position: relative; left: 50%; transform: translateX(-50%); overflow-x: hidden; margin: 0 !important; padding: 0 !important; -webkit-font-smoothing: antialiased; }
.sp-wrapper-single * { box-sizing: border-box; }
.sp-single-main { width: 100%; position: relative; }

/* Inlagans behållare */
.sp-single-content-container { max-width: 64rem; margin: 0 auto; padding: 4rem 1.5rem 5rem 1.5rem; }
@media(min-width: 768px) { .sp-single-content-container { padding: 6rem 2rem 5rem 2rem; } }

/* Gemensamma rubriker/element */
.sp-single-tag { color: #078586; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.75rem; margin-bottom: 1rem; display: block; }
@media(min-width: 768px) { .sp-single-tag { font-size: 0.875rem; } }

.sp-single-section-title { font-size: 1.4rem; font-weight: 800; color: #282F3B; margin-bottom: 1.5rem; letter-spacing: -0.025em; line-height: 1.1; margin-top: 0; }
@media(min-width: 768px) { .sp-single-section-title { font-size: 1.875rem; } }
@media(min-width: 1024px) { .sp-single-section-title { font-size: 2.25rem; } }

.sp-single-divider { width: 4rem; height: 0.375rem; background-color: #078586; border-radius: 9999px; margin-bottom: 1.5rem; }
.sp-single-divider-small { width: 4rem; height: 0.375rem; background-color: #078586; border-radius: 9999px; margin-bottom: 0; }
.sp-single-divider-large { width: 4rem; height: 0.375rem; background-color: #078586; border-radius: 9999px; margin-bottom: 2.5rem; }

.sp-single-desc { font-size: 1.125rem; color: #4b5563; line-height: 1.625; max-width: 48rem; margin: 0; }
.sp-single-mb-large { margin-bottom: 2rem; }

.sp-single-section { margin-bottom: 3.5rem; }
@media(min-width: 768px) { .sp-single-section { margin-bottom: 4rem; } }

.sp-single-line-divider { width: 100%; height: 1px; background-color: #e5e7eb; margin: 4rem 0; }
@media(min-width: 768px) { .sp-single-line-divider { margin: 5rem 0; } }
.sp-single-line-divider-large { width: 100%; height: 1px; background-color: #e5e7eb; margin-bottom: 4rem; }
@media(min-width: 768px) { .sp-single-line-divider-large { margin-bottom: 5rem; } }

/* --- 1. HEADER --- */
.sp-single-header { display: flex; flex-direction: column; gap: 2.5rem; align-items: center; margin-bottom: 4rem; }
@media(min-width: 768px) { .sp-single-header { flex-direction: row; gap: 4rem; align-items: flex-start; margin-bottom: 5rem; } }

.sp-single-header-img-box { width: 100%; position: relative; flex-shrink: 0; }
@media(min-width: 768px) { .sp-single-header-img-box { width: 50%; } }
.sp-single-header-img-bg { position: absolute; top: -1rem; right: -1rem; width: 100%; height: 100%; background-color: rgba(7,133,134,0.1); border-radius: 1rem; transform: rotate(2deg); z-index: 0; }
.sp-single-header-img { z-index: 10; width: 100%; aspect-ratio: 16/9; object-fit: cover; border-radius: 0.75rem; box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1); display: block; position: relative; }

.sp-single-header-text { width: 100%; display: flex; flex-direction: column; justify-content: center; }
@media(min-width: 768px) { .sp-single-header-text { width: 50%; } }

.sp-single-title { font-size: 1.75rem; font-weight: 800; color: #282F3B; margin-top: 0; margin-bottom: 1.5rem; letter-spacing: -0.025em; line-height: 1.1; }
@media(min-width: 768px) { .sp-single-title { font-size: 2rem; } }
@media(min-width: 1024px) { .sp-single-title { font-size: 2.5rem; } }

.sp-single-title-sub { display: block; color: #078586; }

/* --- 2. PRESENTATION (Prose) --- */
.sp-single-prose { color: #4b5563; font-size: 1.125rem; line-height: 1.75; display: flex; flex-direction: column; gap: 1.5rem; }
.sp-single-prose p { margin: 0; }

/* --- 3. UPPLÄGG & INNEHÅLL --- */
.sp-single-structure { margin-bottom: 3.5rem; }
@media(min-width: 768px) { .sp-single-structure { margin-bottom: 4rem; } }

.sp-single-themes-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
@media(min-width: 768px) { .sp-single-themes-grid { grid-template-columns: repeat(2, 1fr); gap: 2rem; } }

.sp-single-theme-box { background-color: #f9fafb; border-radius: 1rem; padding: 2rem; border: 1px solid #f3f4f6; box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05); transition: border-color 0.3s ease; }
.sp-single-theme-box:hover { border-color: rgba(7,133,134,0.3); }
.sp-single-theme-span-2 { grid-column: span 1; }
@media(min-width: 768px) { .sp-single-theme-span-2 { grid-column: span 2; } }

.sp-single-theme-number { width: 3rem; height: 3rem; background-color: rgba(7,133,134,0.1); color: #078586; border-radius: 0.75rem; display: flex; align-items: center; justify-content: center; font-size: 1.25rem; font-weight: 900; margin-bottom: 1.5rem; }
.sp-single-theme-title { font-size: 1.15rem; font-weight: 700; color: #282F3B; margin-top: 0; margin-bottom: 0.75rem; }
@media(min-width: 768px) { .sp-single-theme-title { font-size: 1.25rem; } }
.sp-single-theme-desc { font-size: 0.875rem; color: #4b5563; line-height: 1.625; margin: 0; }

/* --- 4. FÖRELÄSARE --- */
.sp-single-expert-section { display: flex; flex-direction: column; gap: 2.5rem; align-items: center; margin-bottom: 5rem; }
@media(min-width: 768px) { .sp-single-expert-section { flex-direction: row; gap: 4rem; align-items: flex-start; margin-bottom: 6rem; } }

.sp-single-expert-img-box { width: 14rem; flex-shrink: 0; position: relative; }
@media(min-width: 768px) { .sp-single-expert-img-box { width: 16rem; } }
.sp-single-expert-img-bg { position: absolute; inset: -0.75rem; background-color: rgba(7,133,134,0.1); border-radius: 2rem; transform: rotate(-3deg); z-index: 0; }
.sp-single-expert-img { position: relative; z-index: 10; width: 100%; aspect-ratio: 4/5; object-fit: cover; border-radius: 1rem; box-shadow: 0 10px 15px -3px rgba(0,0,0,0.1); display: block; }

.sp-single-expert-text { flex-grow: 1; padding-top: 0.5rem; }
.sp-single-expert-badge { display: inline-flex; align-items: center; gap: 1rem; background-color: #f9fafb; border: 1px solid #f3f4f6; border-radius: 0.75rem; padding: 0.75rem 1.25rem; }
.sp-single-expert-badge-icon { width: 2.5rem; height: 2.5rem; background-color: rgba(7,133,134,0.1); color: #078586; border-radius: 9999px; display: flex; align-items: center; justify-content: center; font-size: 1.125rem; flex-shrink: 0; }
.sp-single-expert-badge-text { font-weight: 700; color: #282F3B; font-size: 0.9375rem; }

/* --- 5. PRAKTISK INFO & KONTAKT --- */
.sp-single-practical-section { display: grid; grid-template-columns: 1fr; gap: 3rem; align-items: start; margin-bottom: 5rem; }
@media(min-width: 1024px) { .sp-single-practical-section { grid-template-columns: 7fr 5fr; gap: 4rem; margin-bottom: 6rem; } }

.sp-single-practical-box { background-color: #f9fafb; border: 1px solid #e5e7eb; border-radius: 1.5rem; padding: 2.5rem; box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05); position: relative; overflow: hidden; width: 100%; }
.sp-single-practical-watermark { position: absolute; right: -3rem; bottom: -3rem; width: 300px; height: 300px; opacity: 0.04; transform: rotate(6deg); pointer-events: none; object-fit: contain; z-index: 0; }
.sp-single-practical-content { position: relative; z-index: 10; }

.sp-single-practical-title { font-size: 1.3rem; font-weight: 800; color: #282F3B; margin-top: 0; margin-bottom: 1.5rem; letter-spacing: -0.025em; line-height: 1.2; }
@media(min-width: 768px) { .sp-single-practical-title { font-size: 1.6rem; } }
@media(min-width: 1024px) { .sp-single-practical-title { font-size: 1.875rem; } }

.sp-single-info-list { display: flex; flex-direction: column; gap: 1.5rem; }
.sp-single-info-row { display: flex; flex-direction: column; border-bottom: 1px solid #e5e7eb; padding-bottom: 0.75rem; }
@media(min-width: 640px) { .sp-single-info-row { flex-direction: row; justify-content: space-between; align-items: flex-end; } }
.sp-single-info-label { color: #282F3B; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.75rem; margin-bottom: 0.25rem; }
@media(min-width: 640px) { .sp-single-info-label { margin-bottom: 0; } }
.sp-single-info-value { color: #374151; font-weight: 500; font-size: 1rem; }

.sp-single-pdf-btn { display: flex; align-items: center; justify-content: center; width: 100%; background-color: white; border: 1px solid #078586; color: #078586 !important; font-weight: 700; padding: 0.875rem 1.5rem; border-radius: 0.75rem; transition: all 0.3s ease; box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05); text-decoration: none !important; margin-top: 2rem; cursor: pointer; }
.sp-single-pdf-btn:hover { background-color: #078586; color: white !important; }
.sp-single-pdf-btn i { margin-right: 0.625rem; font-size: 1.125rem; transition: transform 0.3s ease; }
.sp-single-pdf-btn:hover i { animation: spBounceSingle 1s infinite; }
@keyframes spBounceSingle { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-25%); } }

.sp-single-contact-section { display: flex; flex-direction: column; padding-top: 1rem; }
.sp-single-contact-img-box { width: 100%; max-width: 320px; position: relative; margin-bottom: 2.5rem; }
.sp-single-contact-img-bg { position: absolute; bottom: -0.75rem; right: -0.75rem; width: 100%; height: 100%; background-color: rgba(7,133,134,0.1); border-radius: 1rem; transform: rotate(2deg); z-index: 0; }
.sp-single-contact-img { z-index: 10; width: 100%; aspect-ratio: 16/9; object-fit: cover; border-radius: 0.75rem; box-shadow: 0 10px 15px -3px rgba(0,0,0,0.1); display: block; position: relative; }

.sp-single-contact-title { font-size: 1.3rem; font-weight: 800; color: #282F3B; margin-top: 0; margin-bottom: 1.5rem; letter-spacing: -0.025em; line-height: 1.2; }
@media(min-width: 768px) { .sp-single-contact-title { font-size: 1.6rem; } }
@media(min-width: 1024px) { .sp-single-contact-title { font-size: 1.875rem; } }

.sp-single-contact-desc { color: #4b5563; font-size: 1rem; margin-top: 0; margin-bottom: 2.5rem; line-height: 1.625; max-width: 24rem; }

.sp-single-contact-card { background-color: white; border: 1px solid #e5e7eb; border-radius: 1rem; padding: 1.5rem; box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05); transition: box-shadow 0.3s ease; display: flex; align-items: center; gap: 1.25rem; max-width: 24rem; width: 100%; }
.sp-single-contact-card:hover { box-shadow: 0 4px 6px -1px rgba(0,0,0,0.1); }
.sp-single-contact-icon { width: 3.5rem; height: 3.5rem; border-radius: 9999px; background-color: rgba(7,133,134,0.1); color: #078586; display: flex; align-items: center; justify-content: center; font-size: 1.25rem; flex-shrink: 0; }
.sp-single-contact-name { color: #1f2937; font-size: 1rem; font-weight: 700; margin: 0 0 0.125rem 0; }
.sp-single-contact-phone { color: #4b5563; font-size: 0.9375rem; font-weight: 500; margin: 0 0 0.125rem 0; }
.sp-single-contact-email { color: #6b7280; font-size: 0.875rem; margin: 0; }

/* --- 6. FAQ --- */
.sp-single-faq-header { text-align: center; margin-bottom: 3.5rem; }
@media(min-width: 768px) { .sp-single-faq-header { margin-bottom: 4rem; } }

.sp-single-faq-title { font-size: 1.5rem; font-weight: 800; color: #282F3B; margin-top: 0; margin-bottom: 1.5rem; letter-spacing: -0.025em; }
@media(min-width: 768px) { .sp-single-faq-title { font-size: 2.25rem; } }
@media(min-width: 1024px) { .sp-single-faq-title { font-size: 2.5rem; } }

.sp-single-faq-divider { width: 4rem; height: 0.375rem; background-color: #078586; border-radius: 9999px; margin: 0 auto; }

.sp-single-faq-list { max-width: 56rem; margin: 0 auto; display: flex; flex-direction: column; gap: 1rem; }
.sp-single-faq-item { background-color: #f9fafb; border: 1px solid #e5e7eb; border-radius: 0.75rem; box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05); transition: box-shadow 0.3s ease; }
.sp-single-faq-item[open] { box-shadow: 0 4px 6px -1px rgba(0,0,0,0.1); }
.sp-single-faq-summary { display: flex; align-items: center; justify-content: space-between; cursor: pointer; padding: 1.5rem; font-weight: 700; font-size: 1.125rem; color: #282F3B; outline: none; list-style: none; transition: color 0.3s ease; }
.sp-single-faq-summary::-webkit-details-marker { display: none; }
.sp-single-faq-item[open] .sp-single-faq-summary { color: #078586; }
.sp-single-faq-icon { color: #078586; transition: transform 0.3s ease; }
.sp-single-faq-item[open] .sp-single-faq-icon { transform: rotate(180deg); }
.sp-single-faq-content { padding: 0 1.5rem 1.5rem 1.5rem; color: #4b5563; line-height: 1.625; border-top: 1px solid #e5e7eb; padding-top: 1rem; }
details.sp-single-faq-item[open] .sp-single-faq-summary ~ * { animation: spSlideDownSingle 0.3s ease-in-out; }
@keyframes spSlideDownSingle { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }

/* --- 7. BOKNING / FORMULÄR --- */
.sp-single-book-section { padding: 6rem 0; background-color: rgba(7,133,134,0.03); border-top: 1px solid #e5e7eb; position: relative; overflow: hidden; width: 100%; }
@media(min-width: 1024px) { .sp-single-book-section { padding: 8rem 0; } }
.sp-single-book-bg-icon { position: absolute; top: -2.5rem; right: -5rem; font-size: 300px; color: rgba(7,133,134,0.05); transform: rotate(12deg); pointer-events: none; z-index: 0; }

.sp-single-book-container { max-width: 72rem; margin: 0 auto; padding: 0 1.5rem; position: relative; z-index: 10; }
@media(min-width: 1024px) { .sp-single-book-container { padding: 0 2rem; } }

.sp-single-book-header { text-align: center; margin-bottom: 4rem; }

.sp-single-book-title { font-size: 2rem; font-weight: 800; color: #282F3B; margin-top: 0; margin-bottom: 1.5rem; letter-spacing: -0.025em; }
@media(min-width: 768px) { .sp-single-book-title { font-size: 2.25rem; } }
@media(min-width: 1024px) { .sp-single-book-title { font-size: 3rem; } }

.sp-single-book-desc { font-size: 1.125rem; color: #4b5563; max-width: 42rem; margin: 0 auto; font-weight: 300; line-height: 1.625; }
@media(min-width: 768px) { .sp-single-book-desc { font-size: 1.25rem; } }

.sp-single-book-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media(min-width: 1024px) { .sp-single-book-grid { grid-template-columns: repeat(12, 1fr); } }

/* Vänster: Info panel */
.sp-single-book-info { background-color: #282F3B; color: white; border-radius: 1rem; padding: 2rem; box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1); display: flex; flex-direction: column; width: 100%; }
@media(min-width: 1024px) { .sp-single-book-info { grid-column: span 4 / span 4; padding: 2.5rem; } }

.sp-single-book-info-title { font-size: 1.5rem; font-weight: 700; color: white; margin-top: 0; margin-bottom: 1.5rem; letter-spacing: 0.025em; }
@media(min-width: 768px) { .sp-single-book-info-title { font-size: 1.625rem; } }

.sp-single-book-info-divider { width: 100%; height: 1px; background-color: rgba(255,255,255,0.2); margin-bottom: 2rem; }

.sp-single-book-price-box { margin-bottom: 2.5rem; }
.sp-single-book-price-label { color: #9ca3af; text-transform: uppercase; font-weight: 600; letter-spacing: 0.1em; font-size: 0.75rem; margin-bottom: 0.75rem; }
.sp-single-book-price-row { display: flex; align-items: center; gap: 1rem; }

.sp-single-book-price-amount { font-size: 1.875rem; font-weight: 700; color: white; letter-spacing: -0.025em; line-height: 1; }
@media(min-width: 1280px) { .sp-single-book-price-amount { font-size: 2.5rem; } }

.sp-single-book-price-tax { display: flex; flex-direction: column; justify-content: center; color: #9ca3af; font-weight: 500; font-size: 0.875rem; line-height: 1.25; }

.sp-single-book-list { list-style: none; padding: 0; margin: 0 0 3rem 0; display: flex; flex-direction: column; gap: 1.5rem; color: #d1d5db; font-size: 1rem; flex-grow: 1; }
.sp-single-book-list li { display: flex; align-items: flex-start; }
.sp-single-book-icon { color: #078586; margin-top: 0.25rem; margin-right: 1rem; font-size: 1.25rem; flex-shrink: 0; }
.sp-single-book-list strong { color: white; font-weight: 700; }

.sp-single-book-guarantee { background-color: transparent; border: 1px solid #ffffff; border-radius: 0.75rem; padding: 1rem 1.5rem; display: flex; align-items: center; justify-content: center; width: 100%; margin-top: auto; }
.sp-single-guarantee-inner { display: flex; align-items: center; gap: 1rem; }
.sp-single-guarantee-icon { color: #078586; font-size: 2.25rem; flex-shrink: 0; }
.sp-single-guarantee-text { display: flex; flex-direction: column; text-align: left; }
.sp-single-guarantee-title { font-weight: 700; color: white; font-size: 1rem; line-height: 1.25; margin-bottom: 0.25rem; margin-top: 0; }
.sp-single-guarantee-sub { font-size: 0.875rem; color: #9ca3af; line-height: 1.25; margin: 0; }

/* Höger: Formulär */
.sp-single-book-form-panel { background-color: white; border-radius: 1rem; box-shadow: 0 20px 25px -5px rgba(0,0,0,0.1); display: flex; flex-direction: column; overflow: hidden; width: 100%; border: none; }
@media(min-width: 1024px) { .sp-single-book-form-panel { grid-column: span 8 / span 8; } }

.sp-single-form-accent { height: 0.75rem; width: 100%; background-color: #078586; }

.sp-single-form-body { padding: 2rem; width: 100%; flex-grow: 1; }
@media(min-width: 1024px) { .sp-single-form-body { padding: 2.5rem; } }

.sp-single-form { display: flex; flex-direction: column; gap: 1.5rem; width: 100%; }

.sp-single-form-group { width: 100%; display: flex; flex-direction: column; }
.sp-single-form-row { display: grid; grid-template-columns: 1fr; gap: 1.5rem; width: 100%; }
@media(min-width: 768px) { .sp-single-form-row { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; } }

.sp-single-label { font-size: 0.9375rem; font-weight: 700; color: #1f2937; margin-bottom: 0.5rem; }

/* Input field med ikon (Readonly) */
.sp-single-input-with-icon { position: relative; width: 100%; }
.sp-single-input-icon { position: absolute; inset-y: 0; left: 0; padding-left: 0.875rem; display: flex; align-items: center; pointer-events: none; color: #078586; }
.sp-single-input-readonly { background-color: #f9fafb !important; padding-left: 2.5rem !important; cursor: not-allowed; font-weight: 500; color: #4b5563 !important; }

.sp-single-input, .sp-single-textarea { background-color: white; border: 1px solid #d1d5db; color: #111827; font-size: 0.9375rem; border-radius: 0.5rem; width: 100%; padding: 0.75rem; box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05); outline: none; font-family: inherit; transition: border-color 0.3s ease, box-shadow 0.3s ease; }
.sp-single-textarea { resize: none; }
.sp-single-input:hover:not(.sp-single-input-readonly), .sp-single-textarea:hover { border-color: #9ca3af; }
.sp-single-input:focus:not(.sp-single-input-readonly), .sp-single-textarea:focus { border-color: #078586; box-shadow: 0 0 0 3px rgba(7, 133, 134, 0.2); }

.sp-single-form-footer { padding-top: 1rem; display: flex; flex-direction: column; align-items: center; gap: 1.5rem; width: 100%; }
@media(min-width: 768px) { .sp-single-form-footer { flex-direction: row; justify-content: space-between; } }

/* Button & Icon Styling */
.sp-single-submit-btn { display: inline-flex; align-items: center; justify-content: center; width: 100%; background-color: #328284; color: white !important; padding: 0.75rem 2rem; border-radius: 0.5rem; font-weight: 700; font-size: 1rem; transition: all 0.3s ease; box-shadow: 0 1px 2px 0 rgba(0,0,0,0.05); border: none; cursor: pointer; outline: none; font-family: inherit; }
@media(min-width: 768px) { .sp-single-submit-btn { width: auto; } }
.sp-single-submit-btn:hover { background-color: #056364; box-shadow: 0 4px 6px -1px rgba(0,0,0,0.1); transform: translateY(-1px); }
.sp-single-submit-btn:focus { box-shadow: 0 0 0 4px rgba(7, 133, 134, 0.3); }

.sp-single-submit-btn i { margin-right: 1.25rem; position: relative; top: 1px; }

.sp-single-form-info { font-size: 0.875rem; color: #6b7280; font-weight: 500; display: flex; align-items: center; text-align: center; margin: 0; }
@media(min-width: 768px) { .sp-single-form-info { text-align: left; } }
.sp-single-form-info i { color: #078586; margin-right: 0.5rem; }/* End custom CSS */