/* Skyemotion Core – global frontend styles (floater, utility) */

:root {
    --sky-blue: #1e88e5;
    --sky-orange: #ff6b35;
    --sky-slate: #1f2933;
    --sky-cloud: #fafafa;
}

.sky-floater {
    position: fixed;
    right: 1rem;
    bottom: 1rem;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

.sky-floater__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    color: #fff;
    text-decoration: none;
    box-shadow: 0 6px 16px rgba(0, 0, 0, .2);
    transition: transform .15s ease;
}

.sky-floater__btn:hover {
    transform: translateY(-2px);
}

.sky-floater__wa { background: #25d366; }
.sky-floater__tel { background: var(--sky-blue); }

@media (max-width: 600px) {
    .sky-floater { right: .5rem; bottom: .5rem; }
}

/* === Brand tokens (mirror theme) === */
:root {
    --sky-radius: 14px;
    --sky-radius-sm: 8px;
    --sky-shadow-sm: 0 1px 3px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
    --sky-shadow-md: 0 6px 20px rgba(15,23,42,.08), 0 2px 6px rgba(15,23,42,.04);
    --sky-shadow-lg: 0 18px 40px rgba(15,23,42,.14), 0 4px 12px rgba(15,23,42,.06);
    --sky-blue-grad: linear-gradient(135deg, #1e88e5 0%, #1565c0 100%);
    --sky-section-y: clamp(2.5rem, 6vw, 5rem);
}

/* === Icons === */
.sky-icon { display: inline-block; vertical-align: -.18em; }
.sky-icon--lg { width: 32px; height: 32px; }

/* === Images === */
.sky-image { margin: 0; }
.sky-image__img { display: block; width: 100%; height: auto; object-fit: cover; }
.sky-image.is-rounded .sky-image__img { border-radius: var(--sky-radius); box-shadow: var(--sky-shadow-md); }
.sky-image__cap { color: var(--sky-muted, #6b7280); font-size: .85rem; margin-top: .5rem; text-align: center; }
.sky-image--missing { aspect-ratio: 16/9; background: linear-gradient(135deg,#dbeafe,#bfdbfe); border-radius: var(--sky-radius); }

/* === Hero (with image background) === */
.sky-hero { position: relative; }
.sky-hero .wp-block-cover__background {
    background: linear-gradient(180deg, rgba(15,23,42,.15) 0%, rgba(15,23,42,.55) 65%, rgba(15,23,42,.75) 100%) !important;
    opacity: 1 !important;
}
.sky-hero .wp-block-cover__inner-container {
    padding: clamp(3rem,8vw,6rem) 1.25rem;
    max-width: 980px;
    margin: 0 auto;
}
.sky-hero h1 { text-shadow: 0 2px 16px rgba(0,0,0,.35); }
.sky-hero .wp-block-button__link {
    padding: .95rem 1.6rem;
    box-shadow: var(--sky-shadow-md);
    transition: transform .15s ease, box-shadow .15s ease;
}
.sky-hero .wp-block-button__link:hover { transform: translateY(-2px); box-shadow: var(--sky-shadow-lg); }

/* === Trust bar with icons === */
.sky-trustbar { padding: clamp(1.25rem, 3vw, 2rem) 1rem; }
.sky-trustbar .sky-icon { color: var(--sky-blue, #1e88e5); margin-bottom: .4rem; }
.sky-trustbar .sky-trustbar__item { text-align: center; }
.sky-trustbar .sky-trustbar__num { display: block; font-weight: 700; color: var(--sky-blue, #1e88e5); font-size: 1.1rem; line-height: 1.1; }
.sky-trustbar .sky-trustbar__label { display: block; color: var(--sky-muted, #6b7280); font-size: .92rem; }

/* === Cards (course / offer cards) === */
.sky-card {
    background: #fff;
    border: 1px solid var(--sky-line, #e4e7ec);
    border-radius: var(--sky-radius);
    padding: 1.5rem;
    box-shadow: var(--sky-shadow-sm);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
    height: 100%;
}
.sky-card:hover { transform: translateY(-3px); box-shadow: var(--sky-shadow-md); border-color: #cbd5e1; }
.sky-card .sky-card__badge {
    display: inline-block;
    background: #dbeafe;
    color: #1565c0;
    font-size: .78rem;
    font-weight: 700;
    padding: .25rem .6rem;
    border-radius: 999px;
    margin-bottom: .75rem;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.sky-card .sky-card__badge--hot { background: #fef3c7; color: #b45309; }
.sky-card h3 { margin: 0 0 .5rem; font-size: 1.35rem; }
.sky-card .sky-card__price { font-weight: 700; color: var(--sky-blue, #1e88e5); font-size: 1.15rem; }
.sky-card .wp-block-button { margin-top: .5rem; }

/* === How-it-works (3 steps) === */
.sky-steps { padding: var(--sky-section-y) 1rem; }
.sky-steps__step { position: relative; text-align: center; padding: 1rem; }
.sky-steps__num {
    display: inline-flex; align-items: center; justify-content: center;
    width: 48px; height: 48px; border-radius: 50%;
    background: var(--sky-blue-grad); color: #fff;
    font-weight: 700; font-size: 1.2rem;
    margin: 0 auto 1rem; box-shadow: var(--sky-shadow-md);
}
.sky-steps__step h3 { font-size: 1.25rem; margin: 0 0 .5rem; }
.sky-steps__step p { color: #4b5563; margin: 0; }

/* === Gallery === */
.sky-gallery { padding: var(--sky-section-y) 0; }
.sky-gallery .wp-block-gallery { gap: .75rem; }
.sky-gallery figure img { border-radius: var(--sky-radius-sm); transition: transform .25s ease; }
.sky-gallery figure:hover img { transform: scale(1.02); }

/* === Media-text Pia === */
.sky-media-pia { padding: var(--sky-section-y) 1rem; }
.sky-media-pia blockquote {
    font-family: var(--sky-font-head, 'Outfit', sans-serif);
    font-size: 1.4rem;
    line-height: 1.4;
    color: var(--sky-ink, #111827);
    border-left: 4px solid var(--sky-blue, #1e88e5);
    padding-left: 1.25rem;
    margin: 0 0 1rem;
    font-style: italic;
}
.sky-media-pia cite { color: var(--sky-muted, #6b7280); font-style: normal; font-weight: 600; }

/* === Lead bar (conversion stripe) === */
.sky-leadbar {
    padding: 1.75rem 1.25rem;
    background: var(--sky-blue-grad);
    color: #fff;
    text-align: center;
}
.sky-leadbar h2, .sky-leadbar p { color: #fff !important; }
.sky-leadbar h2 { margin: 0 0 .5rem; font-size: clamp(1.4rem, 3vw, 1.9rem); }
.sky-leadbar p { margin: 0 0 1rem; opacity: .95; }
.sky-leadbar .wp-block-button__link {
    background: #fff; color: var(--sky-blue-dark, #1565c0);
    font-weight: 700; padding: .85rem 1.5rem;
    box-shadow: 0 6px 18px rgba(0,0,0,.18);
}
.sky-leadbar .wp-block-button__link:hover { background: #fafafa; }

/* === FAQ polish (extends theme) === */
details.sky-faq__item { transition: box-shadow .15s ease; }
details.sky-faq__item:hover { box-shadow: var(--sky-shadow-sm); }
details.sky-faq__item[open] { box-shadow: var(--sky-shadow-md); border-color: #93c5fd; }

/* === Section spacing helpers === */
.sky-section { padding: var(--sky-section-y) 1rem; }
.sky-section--tint { background: #f8fafc; }
.sky-section h2 { font-size: clamp(1.7rem, 3.5vw, 2.3rem); }

/* === Layout: constrain inner content of full-bleed sky-* sections =========
   Without this, alignfull groups let their non-aligned children (headings,
   paragraphs, lists, columns, course-grids) overflow the viewport on both
   sides because Kadence's content container only constrains .alignwide /
   .aligndefault children, not raw block content.

   Selector covers ALL `sky-*` alignfull wrappers (sky-section, sky-hero,
   sky-cta, sky-trustbar, sky-testimonials, sky-leadbar, sky-gallery,
   sky-media-pia, sky-steps, …) – we don't need to enumerate them. */
/* Override Kadence's alignfull `width:100vw + margin:calc(50% - 50vw)` rule.
   That formula breaks the moment any other element forces the body wider than
   the viewport: 50% becomes half of the wider body, 50vw stays the viewport
   half, and the section drifts sideways. We use plain `width:100%` instead,
   relying on the layout-safety guard (html/body { overflow-x: clip }) to keep
   the viewport tight, and on the inner constraint below to center content. */
[class*="sky-"].alignfull,
[class*="sky-"].wp-block-cover.alignfull {
    width: 100% !important;
    max-width: 100vw !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: clamp(1rem, 4vw, 2rem);
    padding-right: clamp(1rem, 4vw, 2rem);
    box-sizing: border-box;
}
/* Skyemotion wrappers must never grow past the viewport. */
[class*="sky-"] { max-width: 100vw; }
[class*="sky-"].alignfull > *:not(.wp-block-cover__background):not(.wp-block-cover__image-background):not(.wp-block-cover__video-background) {
    max-width: var(--global-content-width, 1290px);
    margin-left: auto !important;
    margin-right: auto !important;
}
/* Cover inner-container (for sky-hero / sky-cta) – constrain its content too. */
[class*="sky-"].alignfull .wp-block-cover__inner-container {
    max-width: var(--global-content-width, 1290px);
    margin-left: auto;
    margin-right: auto;
    padding-left: clamp(1rem, 4vw, 2rem);
    padding-right: clamp(1rem, 4vw, 2rem);
    box-sizing: border-box;
}
/* alignwide children inside alignfull get max-width too. */
[class*="sky-"].alignfull > .alignwide,
[class*="sky-"].alignfull .wp-block-media-text.alignwide {
    max-width: min(100%, var(--global-content-width, 1290px));
}

/* Columns themselves must respect their parent. Without this they sometimes
   inherit Kadence's intrinsic sizing and push past the wrapper. */
.wp-block-columns { max-width: 100%; }
.wp-block-columns > .wp-block-column { min-width: 0; }

/* Skyemotion-specific flex children that must shrink instead of pushing. */
.sky-card,
.sky-trustbar__item,
.sky-testimonials .wp-block-quote,
.sky-step { min-width: 0; }

/* Below 900px column blocks must wrap to a single column. Kadence's default
   breakpoint (782px) is too low for 3-column card sections with padding. */
@media (max-width: 900px) {
    [class*="sky-"] .wp-block-columns:not(.is-not-stacked-on-mobile) {
        flex-wrap: wrap;
    }
    [class*="sky-"] .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column {
        flex-basis: 100% !important;
    }
    /* Trust-bar items: 2 columns at tablet, 1 at mobile. */
    .sky-trustbar .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column {
        flex-basis: 50% !important;
    }
}
@media (max-width: 540px) {
    .sky-trustbar .wp-block-columns:not(.is-not-stacked-on-mobile) > .wp-block-column {
        flex-basis: 100% !important;
    }
}

/* Media-Text Pia: stack at < 900px instead of Kadence's 600px. */
@media (max-width: 900px) {
    .sky-media-pia .wp-block-media-text.is-stacked-on-mobile {
        grid-template-columns: 1fr !important;
    }
    .sky-media-pia .wp-block-media-text__media,
    .sky-media-pia .wp-block-media-text__content {
        grid-column: 1 !important;
    }
}

/* === Hero / Image safety – defuse mix-blend or sticky-header overlap === */
.sky-image,
.sky-image__img {
    mix-blend-mode: normal;
    isolation: isolate;
    background: transparent;
}
.sky-image { position: relative; z-index: 0; }

/* === Cards: flex layout so footer button sits at bottom === */
.sky-card { display: flex; flex-direction: column; }
.sky-card > p:last-child,
.sky-card__footer { margin-top: auto; }
.sky-card__footer { padding-top: .25rem; }
.sky-card__footer .wp-block-button__link,
.sky-card__footer .button {
    display: inline-block;
    background: var(--sky-blue-grad);
    color: #fff !important;
    text-decoration: none;
    padding: .55rem 1.1rem;
    border-radius: var(--sky-radius-sm);
    font-weight: 600;
}
.sky-card__footer .wp-block-button__link:hover,
.sky-card__footer .button:hover { filter: brightness(1.07); }

/* === Course list (shortcode [sky_courses]) =================================
   The shortcode renders .sky-courses-grid > .sky-course-card – previously
   unstyled. */
.sky-courses-grid {
    display: grid;
    gap: 1.25rem;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    margin: 1.5rem 0;
}
.sky-course-card {
    background: #fff;
    border: 1px solid var(--sky-line, #e4e7ec);
    border-radius: var(--sky-radius);
    padding: 1.25rem;
    box-shadow: var(--sky-shadow-sm);
    display: flex;
    flex-direction: column;
    transition: transform .15s ease, box-shadow .15s ease;
}
.sky-course-card:hover { transform: translateY(-2px); box-shadow: var(--sky-shadow-md); }
.sky-course-card h3 { margin: 0 0 .4rem; font-size: 1.15rem; line-height: 1.3; }
.sky-course-card h3 a { color: inherit; text-decoration: none; }
.sky-course-card h3 a:hover { color: var(--sky-blue, #1e88e5); }
.sky-course-card__meta {
    display: flex; flex-wrap: wrap; gap: .35rem .85rem;
    color: var(--sky-muted, #6b7280);
    font-size: .92rem;
    margin: .25rem 0 .75rem;
}
.sky-course-card__excerpt { color: #374151; font-size: .95rem; margin-bottom: 1rem; flex: 1; }
.sky-course-card__cta { margin: 0; }
.sky-course-card__cta .button {
    display: inline-block;
    background: var(--sky-blue-grad);
    color: #fff !important;
    text-decoration: none;
    padding: .55rem 1rem;
    border-radius: var(--sky-radius-sm);
    font-weight: 600;
}
.sky-course-card.is-full .sky-course-card__cta .button {
    background: #9ca3af;
    pointer-events: none;
}
.sky-courses-empty {
    padding: 1.5rem;
    background: #f8fafc;
    border-radius: var(--sky-radius);
    text-align: center;
    color: var(--sky-muted, #6b7280);
}

/* === CTA / Lead-Bar buttons – guarantee contrast === */
.sky-cta .wp-block-buttons .wp-block-button:not(.is-style-outline) .wp-block-button__link,
.sky-leadbar .wp-block-buttons .wp-block-button:not(.is-style-outline) .wp-block-button__link {
    background: #ffffff !important;
    color: #1565c0 !important;
    font-weight: 700;
    border-radius: var(--sky-radius-sm);
    padding: .85rem 1.6rem;
}
.sky-cta .wp-block-button.is-style-outline .wp-block-button__link,
.sky-leadbar .wp-block-button.is-style-outline .wp-block-button__link {
    background: transparent !important;
    color: #fff !important;
    border-color: #fff !important;
}
.sky-leadbar { background: var(--sky-blue-grad); color: #fff; padding-block: clamp(2rem, 5vw, 3.5rem); }
.sky-leadbar h2,
.sky-leadbar p { color: #fff !important; }

/* === Media-Text Pia – ensure rounded image and no edge bleed === */
.sky-media-pia .wp-block-media-text { padding: 0; }
.sky-media-pia .wp-block-media-text__media img { border-radius: var(--sky-radius); }

/* === Flight-area pages – facts box + insider-tip === */
.sky-area-facts {
    background: #f8fafc;
    border-left: 4px solid var(--sky-blue, #1e88e5);
    border-radius: var(--sky-radius-sm);
    padding: 1.25rem 1.5rem;
    margin: 1.25rem 0 2rem;
}
.sky-area-facts dl {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: .25rem 1.5rem;
    margin: 0;
}
.sky-area-facts dl > div {
    display: flex;
    justify-content: space-between;
    gap: .5rem;
    padding: .35rem 0;
    border-bottom: 1px solid #e4e7ec;
}
.sky-area-facts dl > div:last-child { border-bottom: 0; }
.sky-area-facts dt {
    color: var(--sky-muted, #6b7280);
    font-size: .92rem;
    margin: 0;
}
.sky-area-facts dd {
    margin: 0;
    font-weight: 600;
    color: #1e293b;
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.sky-area-tip {
    background: linear-gradient(135deg, #fff7ed 0%, #fef3c7 100%);
    border-radius: var(--sky-radius);
    padding: 1.25rem 1.5rem;
    margin: 1.5rem 0;
    border-left: 4px solid #f59e0b;
}
.sky-area-tip h3 {
    margin: 0 0 .4rem;
    color: #92400e;
    font-size: 1.05rem;
}
.sky-area-tip p { margin: 0; color: #78350f; }

/* === Flight-area archive listing (single fluggebiet cards) === */
.post-type-archive-sky_flight_area article {
    background: #fff;
    border: 1px solid var(--sky-line, #e4e7ec);
    border-radius: var(--sky-radius);
    box-shadow: var(--sky-shadow-sm);
    padding: 1.25rem;
    margin-bottom: 1.5rem;
    transition: transform .15s, box-shadow .15s;
}
.post-type-archive-sky_flight_area article:hover {
    transform: translateY(-2px);
    box-shadow: var(--sky-shadow-md);
}

/* === Pricing table (auto-generated) === */
.sky-pricing-table { margin: 1.5rem 0; }
.sky-pricing-table h3 { margin-top: 2rem; margin-bottom: .5rem; }
.sky-pricing-table__table { width: 100%; border-collapse: collapse; }
.sky-pricing-table__table td { padding: .65rem .75rem; border-bottom: 1px solid var(--sky-line, #e4e7ec); vertical-align: top; }
.sky-pricing-table__table tr:hover { background: #f8fafc; }
.sky-pricing-table__table td:nth-child(2) { white-space: nowrap; text-align: right; font-variant-numeric: tabular-nums; color: var(--sky-blue, #1e88e5); }
.sky-pricing-table__hint { color: var(--sky-muted, #6b7280); font-size: .9rem; }
