/* ============================================================
   FREIZEITMATRIX LUXURY_PREMIUM STYLE.CSS
   Modern, luxurious, premium visual language
   ============================================================ */

/* ===== RESET & BASELINE NORMALIZATION ===== */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
    box-sizing: border-box;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
}
body {
    min-height: 100vh;
    background: #F7F8FA;
    color: #1A2233;
    font-family: 'Open Sans', Arial, sans-serif;
    line-height: 1.6;
    font-size: 1rem;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

img, picture, video {
    max-width: 100%;
    height: auto;
    display: block;
}

*, *:before, *:after {
    box-sizing: inherit;
}
a {
    text-decoration: none;
    color: inherit;
    transition: color 0.2s cubic-bezier(.4,0,.2,1);
}
ul, ol {
    list-style: none;
}

/* ===== BRAND COLORS & FONTS ===== */
:root {
    --primary: #234892;
    --secondary: #E0E4FF;
    --accent: #FFD447;
    --luxury-gold: #D1B06B;
    --luxury-blue-dark: #192134;
    --luxury-blue-medium: #2a3450;
    --luxury-bg: #F7F8FA;
    --luxury-grey: #828899;
    --luxury-card-bg: #fff;
    --luxury-border: #ECECF1;
    --footer-bg: #21273a;
    --footer-text: #ffffff;
    --luxury-shadow: 0 10px 32px 0 rgba(32, 47, 97, 0.08);
}

body, input, textarea, button {
    font-family: 'Open Sans', Arial, sans-serif;
}
h1, h2, h3, h4, h5, h6, .cta, .primary {
    font-family: 'Montserrat', Arial, Helvetica, sans-serif;
    font-weight: 700;
    letter-spacing: 0.01em;
}
h1 { font-size: 2.375rem; line-height: 1.15; color: var(--luxury-blue-dark); margin-bottom: 18px; }
h2 { font-size: 1.75rem; line-height: 1.18; color: var(--luxury-blue-dark); margin-bottom: 14px; }
h3 { font-size: 1.25rem; line-height: 1.24; color: var(--luxury-blue-medium); margin-bottom: 10px; }
h4 { font-size: 1.1rem; color: var(--luxury-blue-medium); }

p, span, li, th, td {
    color: var(--luxury-blue-medium);
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: 0.01em;
}

em {
    font-style: italic;
    color: var(--primary);
}
strong {
    font-weight: 700;
    color: var(--luxury-blue-dark);
}

/* ====== LAYOUT CONTAINERS & SPACING ====== */
.container {
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 20px;
}

.section {
    margin-bottom: 60px;
    padding: 40px 20px;
    background: var(--luxury-card-bg);
    border-radius: 22px;
    box-shadow: var(--luxury-shadow);
}
@media (max-width: 900px) {
    .section { padding: 28px 8px; }
}

.content-wrapper {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.card-container {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
}
.card {
    margin-bottom: 20px;
    position: relative;
    background: var(--luxury-card-bg);
    border-radius: 18px;
    box-shadow: var(--luxury-shadow);
    padding: 28px 24px;
    border: 1px solid var(--luxury-border);
}

.content-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: space-between;
    align-items: stretch;
}

.text-image-section {
    display: flex;
    align-items: center;
    gap: 30px;
    flex-wrap: wrap;
}

.testimonial-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
    padding: 20px;
    background: #FDFDFE;
    border-radius: 18px;
    margin-bottom: 20px;
    border-left: 5px solid var(--luxury-gold);
    box-shadow: 0 2px 22px 0 rgba(32, 47, 97, 0.06);
    min-width: 250px;
    max-width: 420px;
    font-size: 1.05rem;
}
.testimonial-card p {
    color: var(--luxury-blue-medium);
}
.testimonial-card span, .testimonial-card strong {
    color: var(--luxury-blue-dark);
    font-family: 'Montserrat', Arial, Helvetica, sans-serif;
    font-size: 1rem;
    font-weight: 600;
}

.feature-item {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 15px;
}

.text-section {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 32px 24px;
    background: var(--luxury-card-bg);
    border-radius: 22px;
    box-shadow: var(--luxury-shadow);
}

/* ===== NAVBAR & HEADER ===== */
header {
    width: 100%;
    background: #fff;
    border-bottom: 1.5px solid var(--luxury-border);
    position: sticky;
    top: 0;
    z-index: 42;
    box-shadow: 0 1px 8px 0 rgba(32,47,97,0.03);
}
nav {
    display: flex;
    align-items: center;
    gap: 18px;
    padding: 14px 0;
}
nav > a {
    padding: 7px 18px;
    border-radius: 8px;
    transition: background .18s, color .18s;
    color: var(--luxury-blue-dark);
    font-family: 'Montserrat', Arial, sans-serif;
    font-size: 1rem;
    font-weight: 500;
    position: relative;
}
nav > a:hover, nav > a:focus {
    background: var(--secondary);
    color: var(--primary);
}
nav > a.cta.primary {
    background: var(--luxury-gold);
    color: #23221E;
    font-weight: 700;
    border-radius: 10px;
    box-shadow: 0 2px 16px 0 rgba(209, 176, 107, 0.18);
    letter-spacing: 0.02em;
    transition: background .17s, color .17s, box-shadow .17s;
    margin-left: 10px;
}
nav > a.cta.primary:hover, nav > a.cta.primary:focus {
    background: #f5e3a0;
    color: var(--primary);
    box-shadow: 0 4px 28px 0 rgba(209, 176, 107, 0.27);
}
nav img {
    height: 42px; width: auto; margin-right: 14px;
}

/* ===== MOBILE MENU & RESPONSIVE NAVIGATION ===== */
.mobile-menu-toggle {
    display: none;
    position: relative;
    background: none;
    border: none;
    font-size: 2.1rem;
    color: var(--primary);
    cursor: pointer;
    z-index: 502;
    margin-left: auto;
    padding: 8px 16px;
    transition: color .2s cubic-bezier(.48,0,.14,1);
}

.mobile-menu {
    display: none;
    position: fixed;
    top: 0; left: 0; width: 100vw; height: 100vh;
    background: rgba(25, 33, 52, 0.94);
    z-index: 500;
    padding-top: 36px;
    flex-direction: column;
    align-items: flex-start;
    transition: transform .36s cubic-bezier(.37,1.01,.78,1), opacity .22s;
    opacity: 0;
    transform: translateX(100%);
}
.mobile-menu.open {
    display: flex;
    opacity: 1;
    transform: translateX(0);
}
.mobile-menu-close {
    background: none;
    border: none;
    color: var(--accent);
    font-size: 2.2rem;
    cursor: pointer;
    position: absolute;
    top: 22px;
    right: 24px;
    transition: color .2s;
    z-index: 1127;
}
.mobile-menu-close:hover, .mobile-menu-close:focus {
    color: var(--luxury-gold);
}
.mobile-nav {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 18px;
    margin-left: 32px;
    margin-top: 36px;
}
.mobile-nav a {
    color: var(--footer-text);
    font-size: 1.21rem;
    font-family: 'Montserrat', Arial, sans-serif;
    font-weight: 600;
    padding: 8px 0;
    border-radius: 6px;
    transition: color .12s, background .16s, padding .16s;
    width: fit-content;
}
.mobile-nav a:hover, .mobile-nav a:focus {
    color: var(--luxury-gold);
    background: rgba(255, 212, 71, 0.09);
    padding-left: 6px;
}

@media (max-width: 1050px) {
    nav {
        gap: 10px;
    }
    nav > a {
        font-size: .98rem;
        padding: 7px 11px;
    }
}
@media (max-width: 900px) {
    nav {
        flex-wrap: wrap;
    }
}
@media (max-width: 768px) {
    header nav {
        display: none;
    }
    .mobile-menu-toggle {
        display: block;
    }
    .mobile-menu {
        display: flex;
    }
}

/* ===== MAIN CONTENT STYLES ===== */
main {
    padding-top: 12px;
    padding-bottom: 36px;
}

section {
    margin-bottom: 60px;
    padding: 40px 20px;
    border-radius: 18px;
    background: var(--luxury-card-bg);
    box-shadow: var(--luxury-shadow);
    transition: box-shadow .2s;
}
section:hover, section:focus-within {
    box-shadow: 0 14px 46px 0 rgba(25, 34, 52, 0.11);
}
@media (max-width: 900px) {
    section {
        padding: 26px 8px;
        margin-bottom: 32px;
    }
}

ul, ol {
    padding-left: 0;
    margin-left: 0;
}
ul li, ol li {
    margin-bottom: 11px;
    padding-left: 0;
    color: var(--luxury-blue-medium);
    font-size: 1rem;
}
ul li strong, ol li strong {
    color: var(--primary);
    font-weight: 700;
}
ul li img, ol li img {
    width: 34px;
    height: 34px;
    margin-bottom: 3px;
    margin-right: 11px;
    vertical-align: middle;
}
table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 16px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 1px 6px rgba(25,34,52,0.07);
}
table th, table td {
    padding: 12px 10px;
    border-bottom: 1px solid var(--luxury-border);
    color: var(--luxury-blue-dark);
    text-align: left;
}
table tr:last-child td {
    border-bottom: none;
}
table th {
    background: var(--luxury-gold);
    font-family: 'Montserrat', Arial, sans-serif;
    font-weight: 600;
    color: #23221E;
}

@media (max-width: 768px) {
    table th, table td {
        padding: 8px 4px;
        font-size: .98rem;
    }
}

/* ===== CTA BUTTONS ===== */
.cta,
.cta.primary {
    display: inline-block;
    background: var(--luxury-gold);
    color: #23221E;
    border: none;
    border-radius: 10px;
    font-family: 'Montserrat', Arial, sans-serif;
    font-size: 1.14rem;
    font-weight: 700;
    padding: 12px 35px;
    line-height: 1.3;
    cursor: pointer;
    transition: background 0.18s, color 0.18s, box-shadow .22s cubic-bezier(.16,1.03,.71,1);
    box-shadow: 0 2px 16px 0 rgba(209, 176, 107, 0.13);
    letter-spacing: .02em;
    margin-top: 8px;
}
.cta.primary:hover,
.cta.primary:focus {
    background: #f5e3a0;
    color: var(--primary);
    box-shadow: 0 4px 28px 0 rgba(209, 176, 107, 0.25);
    outline: none;
}
.cta {
    background: var(--primary);
    color: #fff;
    border-radius: 10px;
}
.cta:not(.primary):hover,
.cta:not(.primary):focus {
    background: #4366b7;
    color: var(--accent);
    box-shadow: 0 3px 16px 0 rgba(35, 72, 146, 0.18);
    outline: none;
}

/* ===== FOOTER ===== */
footer {
    width: 100%;
    background: var(--footer-bg);
    color: var(--footer-text);
    padding: 56px 0 28px 0;
    margin-top: 50px;
}
footer .container {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    align-items: flex-start;
    justify-content: space-between;
}
.footer-links {
    display: flex;
    flex-direction: column;
    gap: 10px;
    min-width: 160px;
}
.footer-links a {
    color: var(--luxury-gold);
    font-size: 1.02rem;
    padding: 3px 0;
    transition: color .15s;
}
.footer-links a:hover, .footer-links a:focus {
    color: #fff;
}
.contact-info {
    color: var(--footer-text);
    font-size: 1.02rem;
    font-family: 'Open Sans', Arial, sans-serif;
    max-width: 270px;
    margin: 0 20px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.contact-info a {
    color: var(--accent);
    text-decoration: underline;
    word-break: break-all;
}
.social-links {
    display: flex;
    gap: 15px;
    align-items: center;
}
.social-links img {
    width: 33px;
    height: 33px;
    background: #ececf1;
    border-radius: 7px;
    padding: 3px;
    transition: box-shadow .16s, background .16s;
    box-shadow: 0 2px 8px 0 rgba(33, 39, 58, 0.08);
}
.social-links img:hover, .social-links img:focus {
    background: #FFD447;
    box-shadow: 0 4px 20px 0 rgba(209,176,107,.09);
}

@media (max-width: 900px) {
    footer .container {
        flex-direction: column;
        gap: 30px;
        align-items: flex-start;
    }
    .contact-info, .social-links, .footer-links {
        margin: 0;
    }
}
footer {
    margin-top: 42px;
}

/* ===== RESPONSIVE LAYOUTS ===== */
@media (max-width: 768px) {
    .section,
    section {
        padding: 18px 8px;
        margin-bottom: 24px;
        border-radius: 15px;
    }
    .text-section { padding: 18px 6px; }
    .card, .testimonial-card { padding: 15px 11px; border-radius: 13px; }
    .testimonial-card { min-width: unset; max-width: unset; }
    .card-container, .content-grid { gap: 12px; }
    .content-wrapper { gap: 10px; }
    h1 { font-size: 1.58rem; margin-bottom: 10px; }
    h2 { font-size: 1.2rem; margin-bottom: 7px; }
    h3 { font-size: 1rem; margin-bottom: 4px; }
    .text-image-section { flex-direction: column; gap: 16px; }
}

@media (max-width: 500px) {
    .container { padding: 0 4px; }
}

/* ===== FORMS & INTERACTIVE ELEMENTS ===== */
input, textarea, select {
    font-family: 'Open Sans', Arial, sans-serif;
    font-size: 1rem;
    padding: 9px 14px;
    border-radius: 7px;
    border: 1.5px solid var(--luxury-border);
    background: #fff;
    color: var(--luxury-blue-medium);
    margin-bottom: 16px;
    box-shadow: none;
    transition: border .13s, box-shadow .13s;
}
input:focus, textarea:focus, select:focus {
    border-color: var(--primary);
    outline: none;
    box-shadow: 0 2px 8px 0 rgba(35,72,146,0.06);
}
label {
    font-weight: 600;
    color: var(--primary);
    font-size: 1.02rem;
    margin-bottom: 2px;
    display: inline-block;
}
button {
    cursor: pointer;
    font-family: 'Montserrat', Arial, sans-serif;
}

/* ===== LUXURY MICRO-DETAILS ===== */
h1, h2, h3, h4 {
    letter-spacing: .01em;
    position: relative;
}
h2:after {
    content: '';
    display: block;
    width: 44px; height: 2.5px;
    background: var(--luxury-gold);
    border-radius: 2px;
    margin: 10px 0 2px 0;
}
@media (max-width: 768px) {
    h2:after { width: 30px; height: 2px; }
}

section ul li img,
section ol li img {
    margin-bottom: -6px;
    margin-right: 12px;
}

/* ===== MICRO-INTERACTIONS & TRANSITIONS ===== */
.card, .testimonial-card, .cta, .cta.primary, .mobile-menu, nav > a, .mobile-nav a {
    transition: box-shadow .18s, background .18s, color .18s, border-color .18s, transform .16s;
}
.card:hover, .testimonial-card:hover {
    box-shadow: 0 14px 44px 0 rgba(209,176,107,0.16), var(--luxury-shadow);
    border-color: var(--luxury-gold);
    transform: translateY(-2px) scale(1.012);
}

/* ====== FLEXBOX ALIGNMENT FOR LISTS AND WRAPPERS ====== */
section ul, section ol {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    align-items: flex-start;
}
@media (max-width: 768px) {
    section ul, section ol { flex-direction: column; gap: 8px; }
}
section ul li, section ol li {
    background: #F8F7FB;
    border-radius: 10px;
    padding: 13px 15px;
    box-shadow: 0 1px 7px 0 rgba(209,176,107,0.055);
    min-width: 180px;
    flex: 1 0 220px;
    margin-bottom: 0;
    display: flex;
    align-items: flex-start;
    gap: 10px;
}
@media (max-width: 768px) {
    section ul li, section ol li { flex: 1 0 100%; min-width: unset; padding: 10px 8px; }
}

/* ===== COOKIE CONSENT BANNER & MODAL ===== */
.cookie-banner {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9999;
    background: #fffbe7;
    box-shadow: 0 -8px 40px 0 rgba(32,47,97,0.06);
    border-top: 2px solid var(--luxury-gold);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding: 18px 28px;
    gap: 18px;
    font-size: 1.04rem;
    color: var(--luxury-blue-medium);
    transition: transform .33s cubic-bezier(.77,0,.18,1), opacity .2s;
    opacity: 1;
    transform: translateY(0);
}
.cookie-banner.closed {
    opacity: 0;
    transform: translateY(100%);
    pointer-events: none;
}
.cookie-banner-buttons {
    display: flex;
    gap: 12px;
}
.cookie-btn {
    background: var(--luxury-gold);
    color: #23221E;
    border: none;
    font-family: 'Montserrat', Arial, sans-serif;
    font-weight: 700;
    padding: 8px 22px;
    border-radius: 7px;
    cursor: pointer;
    transition: background .18s, color .18s; 
    font-size: .98rem;
    box-shadow: 0 2px 8px rgba(209,176,107,0.05);
    margin-right: 2px;
}
.cookie-btn:hover, .cookie-btn:focus {
    background: #F0E3BC;
    color: var(--primary);
}
.cookie-btn.reject {
    background: #ECECF1;
    color: var(--luxury-blue-dark);
}
.cookie-btn.reject:hover, .cookie-btn.reject:focus {
    background: #FFD447;
    color: #23221E;
}
.cookie-btn.settings {
    background: #fff;
    color: var(--luxury-blue-dark);
    border: 1px solid var(--luxury-gold);
}
.cookie-btn.settings:hover, .cookie-btn.settings:focus {
    background: #fff7db;
    color: var(--primary);
}

/* Cookie Settings Modal */
.cookie-modal-backdrop {
    display: none;
    position: fixed; top:0; left: 0; width: 100vw; height: 100vh;
    background: rgba(25,33,52,0.6);
    backdrop-filter: blur(2.5px);
    z-index: 10001;
    justify-content: center;
    align-items: center;
}
.cookie-modal-backdrop.open {
    display: flex;
    animation: fadeIn .26s cubic-bezier(.4,0,.2,1);
}
.cookie-modal {
    background: #fff;
    max-width: 480px; width: 96%;
    border-radius: 16px;
    box-shadow: 0 14px 38px 0 rgba(25,33,52,0.18);
    padding: 28px 30px 26px 30px;
    animation: popIn .22s cubic-bezier(.4,0,.2,1);
    color: var(--luxury-blue-medium);
    display: flex; flex-direction: column;
    gap: 20px;
    position: relative;
}
.cookie-modal h2 {
    font-size: 1.20rem; color: var(--luxury-blue-dark); margin-bottom: 4px;
}
.cookie-modal label {
    font-size: 1.01rem;
    display: flex; align-items: center;
    gap: 6px;
    margin-bottom: 10px;
}
.cookie-modal .cookie-switch {
    appearance: none;
    width: 36px; height: 20px;
    background: #ECECF1;
    border-radius: 11px;
    position: relative;
    outline: none;
    cursor: pointer;
    transition: background .15s;
}
.cookie-modal .cookie-switch:checked {
    background: var(--accent);
}
.cookie-modal .cookie-switch::after {
    content: "";
    display: block;
    width: 18px; height: 18px;
    background: #fff;
    border-radius: 50%;
    position: absolute;
    top: 1px; left: 2px;
    transition: transform .15s;
    box-shadow: 0 1px 5px 0 rgba(25,33,52,0.11);
}
.cookie-modal .cookie-switch:checked::after {
    transform: translateX(15px);
}
.cookie-modal .modal-actions {
    display: flex;
    gap: 11px;
    justify-content: flex-end;
}
.cookie-modal-close {
    border: none;
    background: none;
    color: var(--primary);
    font-size: 1.6rem;
    position: absolute;
    top: 12px; right: 14px;
    cursor: pointer;
    transition: color .18s;
}
.cookie-modal-close:hover, .cookie-modal-close:focus {
    color: var(--luxury-gold);
}

@keyframes fadeIn {
    0% { opacity: 0; }
    100% { opacity: 1; }
}
@keyframes popIn {
    0% { transform: scale(0.92); opacity: 0; }
    100% { transform: scale(1); opacity: 1; }
}

/* ====== ACCESSIBILITY ====== */
:focus { outline: 2px solid var(--luxury-gold); outline-offset: 2px; }
button:focus, a:focus, input:focus, textarea:focus {
    outline: 2px solid var(--primary); outline-offset: 2px;
}

/* ====== EXTRA: THANK YOU PAGE ====== */
.text-section ul {
    gap: 8px;
}
.text-section ul li {
    background: transparent;
    box-shadow: none;
    padding: 5px 0;
    min-width: unset;
    flex: unset;
    color: var(--luxury-blue-medium);
}

/* ===== LUXURY GOLDFRAME ACCENTS FOR VISUAL HIERARCHY ===== */
section, .card, .testimonial-card, .text-section {
    border: 1.5px solid var(--luxury-gold);
    background-clip: padding-box;
}

/* ===== END OF STYLE.CSS ===== */
