/*
Theme Name: Twenty Twenty-Five Child
Template: twentytwentyfive
Description: Child theme for Twenty Twenty-Five
Version: 1.0.0
*/

/* ─── Google Fonts ──────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Kaisei+Tokumin:wght@400;500;700;800&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap');

/* ─── CSS Variables ─────────────────────────────────────────────────────────── */
:root {
    --color-accent:      #F08C6E;   /* coral peach */
    --color-accent-dark: #D87051;
    --color-accent-pale: rgba(240,140,110,0.10);
    --color-accent-mid:  rgba(240,140,110,0.18);

    --color-mint:        #7DC4B9;   /* mint/teal */
    --color-pink:        #F7C8C6;   /* soft pink (frame bg) */

    --color-text:        #2B4D52;
    --color-muted:       #6B7B7D;
    --color-white:       #FFFFFF;

    --color-bg:          #FFFFFF;   /* white inner */
    --color-surface:     #FCF2EE;   /* very soft cream */
    --color-border:      #EAD8D4;

    --color-deep:        #2B4D52;   /* deep teal */

    --shadow-sm:   0 1px 4px rgba(43,77,82,0.06);
    --shadow-md:   0 4px 18px rgba(43,77,82,0.08);
    --shadow-lg:   0 8px 36px rgba(43,77,82,0.10);
    --shadow-md-h: 0 8px 28px rgba(43,77,82,0.12);

    --font-heading: 'Kaisei Tokumin', serif;
    --font-body:    'DM Sans', sans-serif;

    --space-1:  8px;
    --space-2:  16px;
    --space-3:  24px;
    --space-4:  32px;
    --space-5:  40px;
    --space-6:  48px;
    --space-7:  56px;
    --space-8:  64px;
    --space-9:  72px;
    --space-10: 80px;

    --radius-card:   14px;
    --radius-button: 999px;

    --container-max:     1200px;
    --container-padding: 0px;
    --section-padding-y: var(--space-10);
    --transition: 0.22s ease;
}

/* ─── Reset & base ──────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    font-family: var(--font-body);
    font-size: 1.125rem;
    font-weight: 400;
    line-height: 1.6;
    color: var(--color-text);
    background-color: var(--color-pink);
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
}

/* ─── Page frame ──────────────────────────────────────────────────────────────── */
.mas-page-frame {
    background-color: var(--color-bg);
    overflow: clip;
}

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

/* ─── Typography ─────────────────────────────────────────────────────────────── */
h1, h2, h3, h4 {
    font-family: var(--font-heading);
    font-weight: 700;
    line-height: 1.15;
    color: var(--color-text);
    margin-top: 0;
}

h1 { font-size: clamp(2.75rem, 6.5vw, 4.5rem); font-weight: 800; }
h2 { font-size: clamp(2rem, 4.5vw, 3rem);       font-weight: 700; }
h3 { font-size: clamp(1.25rem, 2.5vw, 1.75rem); font-weight: 700; }
h4 { font-size: 1.25rem; font-weight: 600; }
h5, h6 { font-family: var(--font-body); font-weight: 600; }

p { margin-top: 0; margin-bottom: var(--space-3); }
p:last-child { margin-bottom: 0; }

a {
    color: var(--color-accent);
    text-decoration: none;
    transition: opacity var(--transition);
}
a:hover { opacity: 0.75; }

ul, ol { padding-left: var(--space-3); }

/* ─── Layout ─────────────────────────────────────────────────────────────────── */
.mas-container {
    max-width: var(--container-max);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--container-padding);
    padding-right: var(--container-padding);
}

.mas-section {
    padding-top: var(--section-padding-y);
    padding-bottom: var(--section-padding-y);
}

.mas-section--surface { background-color: var(--color-surface); }
.mas-section--white   { background-color: var(--color-bg); }

.mas-section__header {
    text-align: center;
    max-width: 680px;
    margin: 0 auto var(--space-8);
}
.mas-section__heading  { margin-bottom: var(--space-2); }

/* ─── Accent line ────────────────────────────────────────────────────────────── */
.mas-accent-line {
    display: block;
    width: 48px;
    height: 3px;
    background-color: var(--color-accent);
    border-radius: 999px;
    margin: var(--space-2) auto 0;
}

/* ─── Buttons ────────────────────────────────────────────────────────────────── */
.mas-btn {
    display: inline-block;
    padding: 13px 30px;
    font-family: var(--font-body);
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1;
    border-radius: var(--radius-button);
    border: 1.5px solid transparent;
    cursor: pointer;
    transition: background-color var(--transition), color var(--transition), border-color var(--transition), box-shadow var(--transition), transform var(--transition);
    text-decoration: none;
    letter-spacing: 0.02em;
}
.mas-btn:hover { transform: translateY(-1px); text-decoration: none; }

.mas-btn--primary {
    background-color: var(--color-accent);
    color: var(--color-white);
    border-color: var(--color-accent);
    box-shadow: 0 4px 18px rgba(192,86,36,0.28);
}
.mas-btn--primary:hover {
    background-color: var(--color-accent-dark);
    border-color: var(--color-accent-dark);
    color: var(--color-white);
    box-shadow: 0 6px 24px rgba(192,86,36,0.36);
}

.mas-btn--outline {
    background-color: transparent;
    color: var(--color-accent);
    border-color: var(--color-accent);
}
.mas-btn--outline:hover {
    background-color: var(--color-accent);
    color: var(--color-white);
}

.mas-btn--white {
    background-color: var(--color-white);
    color: var(--color-text);
    border-color: rgba(255,255,255,0.6);
    box-shadow: 0 2px 12px rgba(0,0,0,0.12);
}
.mas-btn--white:hover {
    background-color: var(--color-surface);
    color: var(--color-text);
}

.mas-btn-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    align-items: center;
}

/* ─── Cards ──────────────────────────────────────────────────────────────────── */
.mas-card {
    background-color: var(--color-white);
    border-radius: var(--radius-card);
    border: 1px solid var(--color-border);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition), transform var(--transition);
    text-decoration: none;
    color: inherit;
}
.mas-card:hover {
    box-shadow: var(--shadow-md-h);
    transform: translateY(-3px);
    text-decoration: none;
}

.mas-card__image {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.mas-card__body { padding: var(--space-4); }

.mas-card__title {
    font-family: var(--font-heading);
    font-size: 1.125rem;
    font-weight: 700;
    margin-bottom: var(--space-2);
    color: var(--color-text);
}

.mas-card__text {
    font-size: 1.125rem;
    color: var(--color-muted);
    margin-bottom: var(--space-3);
}

/* ─── Grid utilities ─────────────────────────────────────────────────────────── */
.mas-grid { display: grid; gap: var(--space-4); }
.mas-grid--1 { grid-template-columns: 1fr; }
.mas-grid--2 { grid-template-columns: repeat(2, 1fr); }
.mas-grid--3 { grid-template-columns: repeat(3, 1fr); }
.mas-grid--4 { grid-template-columns: repeat(4, 1fr); }
.mas-grid--5 { grid-template-columns: repeat(5, 1fr); }

/* ─── Hero ───────────────────────────────────────────────────────────────────── */
.mas-hero {
    position: relative;
    height: 340px;
    display: flex;
    align-items: center;
    overflow: hidden;
    background-color: var(--color-surface);
}

.mas-hero__bg {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.mas-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(110deg, rgba(30,14,6,0.88) 0%, rgba(30,14,6,0.62) 55%, rgba(30,14,6,0.28) 100%);
}

.mas-hero__content {
    position: relative;
    z-index: 2;
    width: 100%;
    padding: var(--space-10) var(--container-padding);
    margin-left: max(calc((100% - var(--container-max)) / 2), var(--container-padding));
}

.mas-hero__heading {
    color: var(--color-white);
    font-size: clamp(1.875rem, 4vw, 3rem);
    font-weight: 800;
    margin-bottom: var(--space-4);
    line-height: 1.05;
    max-width: 65%;
}

.mas-hero__subtext {
    color: rgba(255,255,255,0.88);
    font-size: 1.125rem;
    line-height: 1.75;
    margin-bottom: var(--space-5);
    max-width: 65%;
}

/* ─── Feature items ──────────────────────────────────────────────────────────── */
.mas-feature {
    text-align: center;
    padding: var(--space-5) var(--space-4);
    border-radius: var(--radius-card);
    border: none;
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition), transform var(--transition);
}
.mas-feature:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

/* Rotating pastel card backgrounds for tasteful multi-color contrast */
.mas-feature:nth-child(4n+1) { background-color: var(--color-pink); }
.mas-feature:nth-child(4n+2) { background-color: #C8E4DE; }
.mas-feature:nth-child(4n+3) { background-color: #F5DEB0; }
.mas-feature:nth-child(4n+4) { background-color: #FDD3C5; }

.mas-feature__icon {
    font-size: 1.75rem;
    width: 68px;
    height: 68px;
    border-radius: 50%;
    background-color: rgba(255,255,255,0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto var(--space-3);
}

.mas-feature__title { font-family: var(--font-heading); font-size: 1.0625rem; font-weight: 700; margin-bottom: var(--space-1); color: var(--color-text); }
.mas-feature__text  { font-size: 1.125rem; color: var(--color-text); line-height: 1.65; }

/* ─── Testimonials ───────────────────────────────────────────────────────────── */
.mas-founder {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: var(--space-8);
    align-items: start;
    max-width: 960px;
    margin: 0 auto;
}

.mas-giftcard-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
    align-items: center;
}

.mas-testimonials {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--space-4);
    align-items: start;
}

.mas-testimonial {
    background-color: var(--color-white);
    border-radius: var(--radius-card);
    border: 1px solid var(--color-border);
    padding: var(--space-3);
    box-shadow: var(--shadow-sm);
    margin: 0;
}
.mas-testimonial__text   { font-style: italic; font-size: 1.0625rem; line-height: 1.75; margin-bottom: var(--space-3); color: var(--color-text); }
.mas-testimonial__author { font-weight: 700; color: var(--color-accent); font-family: var(--font-heading); font-size: 1.125rem; }
.mas-testimonial__avatar {
    width: 120px;
    height: 120px;
    object-fit: cover;
    margin-bottom: var(--space-2);
    background-color: var(--color-accent-pale);
    -webkit-mask-image: url("assets/shapes/sunny.svg");
            mask-image: url("assets/shapes/sunny.svg");
    -webkit-mask-size: contain;
            mask-size: contain;
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    -webkit-mask-position: center;
            mask-position: center;
}

/* ─── Gallery ────────────────────────────────────────────────────────────────── */
.mas-gallery-filters {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    justify-content: center;
    margin-bottom: var(--space-6);
}
.mas-gallery-filter {
    padding: 12px 22px;
    border: 1.5px solid var(--color-border);
    border-radius: 999px;
    font-size: 1.0625rem;
    font-weight: 600;
    background-color: rgba(255,255,255,0.05);
    color: var(--color-muted);
    cursor: pointer;
    transition: color var(--transition), background-color var(--transition), border-color var(--transition);
    backdrop-filter: blur(6px);
}
.mas-gallery-filter:hover { color: var(--color-text); border-color: var(--color-accent-mid); }
.mas-gallery-filter.is-active {
    background-color: var(--color-accent);
    border-color: var(--color-accent);
    color: var(--color-white);
}

.mas-gallery-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-2);
}
.mas-gallery-item {
    overflow: hidden;
    border-radius: var(--radius-card);
    cursor: pointer;
    aspect-ratio: 1;
    transition: transform var(--transition), box-shadow var(--transition);
}
.mas-gallery-item:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.mas-gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.35s ease; }
.mas-gallery-item:hover img { transform: scale(1.05); }

/* ─── Lightbox ───────────────────────────────────────────────────────────────── */
.mas-lightbox {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(30,14,6,0.92);
    align-items: center;
    justify-content: center;
}
.mas-lightbox.is-open { display: flex; }
.mas-lightbox__img { max-width: 90vw; max-height: 90vh; border-radius: var(--radius-card); object-fit: contain; }
.mas-lightbox__close {
    position: absolute;
    top: var(--space-4);
    right: var(--space-4);
    background: var(--color-accent);
    border: none;
    color: var(--color-white);
    font-size: 1.5rem;
    cursor: pointer;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    box-shadow: var(--shadow-md);
}

/* ─── Services tabs ──────────────────────────────────────────────────────────── */
.mas-tabs__nav {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-bottom: var(--space-6);
    justify-content: center;
}
.mas-tabs__tab {
    padding: 12px 22px;
    font-family: var(--font-body);
    font-size: 1.0625rem;
    font-weight: 600;
    background-color: rgba(255,255,255,0.05);
    border: 1.5px solid var(--color-border);
    border-radius: 999px;
    cursor: pointer;
    color: var(--color-muted);
    transition: color var(--transition), background-color var(--transition), border-color var(--transition);
    backdrop-filter: blur(6px);
}
.mas-tabs__tab:hover { color: var(--color-text); border-color: var(--color-accent-mid); }
.mas-tabs__tab.is-active { color: var(--color-white); background-color: var(--color-accent); border-color: var(--color-accent); }

.mas-tabs__panel { display: none; }
.mas-tabs__panel.is-active { display: block; }

.mas-service-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-2) var(--space-6);
}
.mas-service-list li {
    padding: var(--space-1) 0;
    border-bottom: 1px solid var(--color-border);
    font-size: 1.125rem;
}
.mas-service-list li::before { content: '—'; color: var(--color-accent); margin-right: var(--space-2); font-weight: 600; }


/* ─── Contact ────────────────────────────────────────────────────────────────── */
.mas-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); align-items: start; }
.mas-contact-details { list-style: none; padding: 0; margin: 0 0 var(--space-5); }
.mas-contact-details li { display: flex; gap: var(--space-2); padding: var(--space-2) 0; border-bottom: 1px solid var(--color-border); font-size: 1.125rem; }
.mas-contact-details li:last-child { border-bottom: none; }
.mas-contact-map { width: 100%; aspect-ratio: 4/3; border: 0; border-radius: var(--radius-card); display: block; box-shadow: var(--shadow-md); }

/* ─── Contact form ───────────────────────────────────────────────────────────── */
.mas-form { display: flex; flex-direction: column; gap: var(--space-3); }
.mas-form__label { display: block; font-size: 0.875rem; font-weight: 600; margin-bottom: var(--space-1); color: var(--color-text); }
.mas-form__input,
.mas-form__textarea {
    width: 100%;
    padding: 12px 18px;
    border: 1.5px solid var(--color-border);
    border-radius: 10px;
    font-family: var(--font-body);
    font-size: 1.125rem;
    color: var(--color-text);
    background-color: var(--color-white);
    transition: border-color var(--transition), box-shadow var(--transition);
}
.mas-form__input:focus,
.mas-form__textarea:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px var(--color-accent-pale);
}
.mas-form__textarea { resize: vertical; min-height: 140px; }
.mas-form__notice { padding: var(--space-3) var(--space-4); border-radius: 10px; font-size: 1.125rem; margin-bottom: var(--space-3); }
.mas-form__notice--success { background-color: #f0faf2; color: #1d6b2e; border: 1px solid #b4dfc0; }
.mas-form__notice--error   { background-color: #fdf0f0; color: #a03030; border: 1px solid #e8c0c0; }

/* ─── Header ─────────────────────────────────────────────────────────────────── */
.mas-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background-color: var(--color-bg);
    border-bottom: 1px solid var(--color-border);
    transition: box-shadow var(--transition);
    overflow: visible;
}
.mas-header.is-scrolled {
    box-shadow: 0 2px 20px rgba(30,14,6,0.08);
    border-bottom-color: transparent;
}

.mas-header__inner {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-padding);
    min-height: 70px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    transition: min-height 0.3s ease;
}
.mas-header.is-scrolled .mas-header__inner { min-height: 56px; }

.mas-header__logo { display: flex; align-items: flex-end; gap: 10px; text-decoration: none; flex-shrink: 0; align-self: flex-end; }
.mas-header__logo-img { height: 110px; width: auto; display: block; transition: height 0.3s ease, margin-bottom 0.3s ease; margin-bottom: -18px; }
.mas-header.is-scrolled .mas-header__logo { align-self: center; }
.mas-header.is-scrolled .mas-header__logo-img { height: 44px; margin-bottom: 0; }
.mas-header__logo-name {
    display: none;
    font-family: var(--font-heading);
    font-size: 1.25rem;
    font-weight: 800;
    color: var(--color-accent);
    white-space: nowrap;
}
.mas-header__logo--text .mas-header__logo-name { display: block; }
.mas-header__logo--text:hover { text-decoration: none; opacity: 0.85; }

.mas-nav__list { display: flex; list-style: none; margin: 0; padding: 0; gap: 2px; }
.mas-nav__link {
    display: block;
    padding: 8px 16px;
    font-size: 1.125rem;
    font-weight: 500;
    color: var(--color-text);
    border-radius: 999px;
    transition: color var(--transition), background-color var(--transition);
    text-decoration: none;
}
.mas-nav__link:hover { color: var(--color-accent); background-color: var(--color-accent-pale); }
.mas-nav__link.is-current { color: var(--color-accent); background-color: var(--color-accent-mid); }

.mas-hamburger {
    display: none;
    background: none;
    border: 1.5px solid var(--color-border);
    border-radius: 8px;
    cursor: pointer;
    padding: 8px;
    flex-direction: column;
    gap: 5px;
}
.mas-hamburger span { display: block; width: 20px; height: 2px; background-color: var(--color-text); border-radius: 999px; transition: transform 0.25s ease, opacity 0.2s ease; transform-origin: center; }
.mas-hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.mas-hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.mas-hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ─── Footer ─────────────────────────────────────────────────────────────────── */
.mas-footer {
    background-color: var(--color-deep);
    color: rgba(250,243,238,0.80);
    padding: var(--space-10) 0 var(--space-6);
}
.mas-footer__inner { max-width: var(--container-max); margin: 0 auto; padding: 0 var(--container-padding); }
.mas-footer__top {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--space-8);
    padding-bottom: var(--space-8);
    border-bottom: 1px solid rgba(250,243,238,0.12);
    margin-bottom: var(--space-5);
}
.mas-footer__logo-text { font-family: var(--font-heading); font-size: 1.35rem; font-weight: 800; color: var(--color-white); text-decoration: none; }
.mas-footer__tagline   { font-size: 0.875rem; margin-top: var(--space-1); opacity: 0.55; color: rgba(250,243,238,0.80); }
.mas-footer__heading {
    font-family: var(--font-body);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-accent);
    margin-bottom: var(--space-3);
}
.mas-footer__nav { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-1); }
.mas-footer__nav a { color: rgba(250,243,238,0.70); font-size: 1.125rem; text-decoration: none; transition: color var(--transition); }
.mas-footer__nav a:hover { color: var(--color-white); opacity: 1; }
.mas-footer__contact { list-style: none; padding: 0; margin: 0 0 var(--space-4); display: flex; flex-direction: column; gap: var(--space-2); font-size: 1.125rem; }
.mas-footer__contact a { color: rgba(250,243,238,0.70); text-decoration: none; transition: color var(--transition); }
.mas-footer__contact a:hover { color: var(--color-white); }
.mas-social { display: flex; gap: var(--space-2); align-items: center; }
.mas-social__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border: 1px solid rgba(250,243,238,0.18);
    border-radius: 50%;
    color: rgba(250,243,238,0.70);
    transition: all var(--transition);
    text-decoration: none;
}
.mas-social__link:hover { background-color: var(--color-accent); border-color: var(--color-accent); color: var(--color-white); opacity: 1; }
.mas-social__link svg { width: 16px; height: 16px; fill: currentColor; }
.mas-footer__bottom { text-align: center; font-size: 0.875rem; opacity: 0.40; color: rgba(250,243,238,0.80); }

/* ─── Fienta events ──────────────────────────────────────────────────────────── */
.fienta-events { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
.fienta-events__card {
    background-color: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-card);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--transition), transform var(--transition);
}
.fienta-events__card:hover { box-shadow: var(--shadow-md-h); transform: translateY(-3px); }
.fienta-events__image { width: 100%; aspect-ratio: 16/9; object-fit: cover; }
.fienta-events__body  { padding: var(--space-4); }
.fienta-events__badge {
    display: inline-block;
    padding: 3px 10px;
    background-color: rgba(192,86,36,0.10);
    color: var(--color-accent);
    font-size: 0.75rem;
    font-weight: 600;
    border-radius: 999px;
    margin-bottom: var(--space-2);
}
.fienta-events__badge--sold-out { background-color: rgba(160,48,48,0.10); color: #a03030; }
.fienta-events__title { font-family: var(--font-heading); font-size: 1.125rem; font-weight: 700; margin-bottom: var(--space-2); }
.fienta-events__title a { color: var(--color-text); text-decoration: none; }
.fienta-events__title a:hover { color: var(--color-accent); opacity: 1; }
.fienta-events__meta    { display: flex; flex-direction: column; gap: 3px; font-size: 0.875rem; color: var(--color-muted); margin-bottom: var(--space-3); }
.fienta-events__excerpt { font-size: 1.125rem; color: var(--color-muted); margin-bottom: var(--space-3); line-height: 1.65; }
.fienta-events__button {
    display: inline-block;
    padding: 10px 22px;
    background-color: var(--color-accent);
    color: var(--color-white);
    border-radius: 999px;
    font-size: 1.125rem;
    font-weight: 600;
    text-decoration: none;
    transition: background-color var(--transition), transform var(--transition);
}
.fienta-events__button:hover { background-color: var(--color-accent-dark); color: var(--color-white); transform: translateY(-1px); opacity: 1; }
.fienta-events__empty,
.fienta-events__error { grid-column: 1/-1; text-align: center; padding: var(--space-8); color: var(--color-muted); }

/* ─── Page hero (interior pages) ────────────────────────────────────────────── */
.mas-page-hero {
    position: relative;
    height: 340px;
    display: flex;
    align-items: center;
    background-color: var(--color-surface);
    overflow: hidden;
}
.mas-page-hero__bg      { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.mas-page-hero__overlay { position: absolute; inset: 0; background: rgba(30,14,6,0.68); }
.mas-page-hero__content { position: relative; z-index: 2; padding: 0 var(--container-padding); max-width: var(--container-max); margin: 0 auto; width: 100%; }
.mas-page-hero__heading { color: var(--color-white); margin: 0; font-size: clamp(1.75rem, 3.5vw, 2.75rem); max-width: 65%; }

/* ─── Hero logo badge ────────────────────────────────────────────────────────── */
.mas-hero-logo {
    display: inline-block;
    margin-bottom: var(--space-4);
    padding: 10px 18px 10px 14px;
    background: rgba(255,255,255,0.82);
    backdrop-filter: blur(14px) saturate(1.4);
    -webkit-backdrop-filter: blur(14px) saturate(1.4);
    border-radius: 6px 28px 10px 22px / 22px 10px 28px 6px;
    box-shadow: 0 4px 24px rgba(0,0,0,0.18), inset 0 1px 0 rgba(255,255,255,0.6);
    text-decoration: none;
    transition: background 0.2s;
}
.mas-hero-logo:hover { background: rgba(255,255,255,0.92); }
.mas-hero-logo img {
    display: block;
    height: 56px;
    width: auto;
}

/* ─── Colored sections (with wavy dividers) ──────────────────────────────────── */
.mas-section--dark,
.mas-section--accent,
.mas-section--mint {
    background-image: none;
    color: var(--color-white);
    position: relative;
    padding-top: calc(var(--section-padding-y) + 30px);
    padding-bottom: calc(var(--section-padding-y) + 30px);
    overflow: hidden;
}
.mas-section--dark   { background-color: var(--color-deep);   }
.mas-section--accent { background-color: var(--color-accent); }
.mas-section--mint   { background-color: var(--color-mint);   }

/* Top wave (white curve dipping into colored section) */
.mas-section--accent::before,
.mas-section--mint::before {
    content: '';
    position: absolute;
    top: -1px;
    left: 0;
    right: 0;
    height: 50px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 50' preserveAspectRatio='none'%3E%3Cpath d='M0,0 L1200,0 L1200,25 C800,0 400,55 0,25 Z' fill='%23FFFFFF'/%3E%3C/svg%3E");
    background-size: 100% 100%;
    background-repeat: no-repeat;
    pointer-events: none;
    z-index: 2;
}

/* Bottom wave (white curve rising into colored section from below) */
.mas-section--accent:not(.mas-section--to-footer)::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    height: 50px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 50' preserveAspectRatio='none'%3E%3Cpath d='M0,25 C400,55 800,0 1200,25 L1200,50 L0,50 Z' fill='%23FFFFFF'/%3E%3C/svg%3E");
    background-size: 100% 100%;
    background-repeat: no-repeat;
    pointer-events: none;
    z-index: 2;
}

/* Accent or mint bottom wave transitions directly into deep teal footer (no white gap) */
.mas-section--to-footer.mas-section--accent::after,
.mas-section--mint::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    height: 50px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 50' preserveAspectRatio='none'%3E%3Cpath d='M0,25 C400,55 800,0 1200,25 L1200,50 L0,50 Z' fill='%232B4D52'/%3E%3C/svg%3E");
    background-size: 100% 100%;
    background-repeat: no-repeat;
    pointer-events: none;
    z-index: 2;
}

/* Container positioning above the waves */
.mas-section--accent .mas-container,
.mas-section--mint .mas-container,
.mas-section--dark .mas-container { position: relative; z-index: 3; }

.mas-section--dark h1, .mas-section--dark h2, .mas-section--dark h3, .mas-section--dark h4,
.mas-section--accent h1, .mas-section--accent h2, .mas-section--accent h3, .mas-section--accent h4,
.mas-section--mint h1, .mas-section--mint h2, .mas-section--mint h3, .mas-section--mint h4 { color: var(--color-white); }

.mas-section--dark .mas-accent-line,
.mas-section--accent .mas-accent-line,
.mas-section--mint .mas-accent-line { background-color: rgba(255,255,255,0.6); }

.mas-section--dark .mas-card,
.mas-section--mint .mas-card {
    background-color: rgba(255,255,255,0.12);
    border-color: rgba(255,255,255,0.18);
    color: var(--color-white);
    box-shadow: none;
}
.mas-section--accent .mas-card {
    background-color: rgba(255,255,255,0.92);
    border-color: rgba(255,255,255,0.6);
    color: var(--color-text);
    box-shadow: none;
}
.mas-section--dark .mas-card:hover,
.mas-section--mint .mas-card:hover { background-color: rgba(255,255,255,0.18); transform: translateY(-3px); box-shadow: 0 8px 30px rgba(0,0,0,0.15); }
.mas-section--accent .mas-card:hover { background-color: rgba(255,255,255,1); transform: translateY(-3px); box-shadow: 0 8px 30px rgba(0,0,0,0.12); }
.mas-section--dark .mas-card__title,
.mas-section--mint .mas-card__title { color: var(--color-white); }
.mas-section--accent .mas-card__title { color: var(--color-text); }
.mas-section--dark .mas-card__text,
.mas-section--mint .mas-card__text { color: rgba(255,255,255,0.72); }
.mas-section--accent .mas-card__text { color: var(--color-muted); }

.mas-section--dark .mas-testimonial {
    background-color: rgba(255,255,255,0.12);
    border-color: rgba(255,255,255,0.18);
}
.mas-section--dark .mas-testimonial__text   { color: rgba(255,255,255,0.92); }
.mas-section--dark .mas-testimonial__author { color: var(--color-white); opacity: 0.9; }

.mas-section--accent .mas-testimonial,
.mas-section--mint .mas-testimonial {
    background-color: rgba(255,255,255,0.92);
    border-color: rgba(255,255,255,0.6);
}
.mas-section--accent .mas-testimonial__text,
.mas-section--mint .mas-testimonial__text { color: var(--color-text); }
.mas-section--accent .mas-testimonial__author { color: var(--color-accent-dark); opacity: 1; }
.mas-section--mint .mas-testimonial__author   { color: var(--color-accent); opacity: 1; }

.mas-section--dark .mas-feature,
.mas-section--accent .mas-feature,
.mas-section--mint .mas-feature {
    background-color: rgba(255,255,255,0.12);
    border-color: rgba(255,255,255,0.18);
}
.mas-section--dark .mas-feature__title,
.mas-section--accent .mas-feature__title,
.mas-section--mint .mas-feature__title { color: var(--color-white); }
.mas-section--dark .mas-feature__text,
.mas-section--accent .mas-feature__text,
.mas-section--mint .mas-feature__text { color: rgba(255,255,255,0.72); }
.mas-section--dark .mas-feature__icon,
.mas-section--accent .mas-feature__icon,
.mas-section--mint .mas-feature__icon { background-color: rgba(255,255,255,0.18); }

.mas-section--dark .mas-tabs__tab,
.mas-section--accent .mas-tabs__tab,
.mas-section--mint .mas-tabs__tab { color: rgba(255,255,255,0.75); border-color: rgba(255,255,255,0.22); background-color: rgba(255,255,255,0.05); }
.mas-section--dark .mas-tabs__tab:hover,
.mas-section--accent .mas-tabs__tab:hover,
.mas-section--mint .mas-tabs__tab:hover { color: var(--color-white); border-color: rgba(255,255,255,0.5); }
.mas-section--dark .mas-tabs__tab.is-active,
.mas-section--accent .mas-tabs__tab.is-active,
.mas-section--mint .mas-tabs__tab.is-active { background-color: var(--color-white); color: var(--color-accent); border-color: var(--color-white); }
.mas-section--dark .mas-service-list li,
.mas-section--accent .mas-service-list li,
.mas-section--mint .mas-service-list li { border-bottom-color: rgba(255,255,255,0.18); color: rgba(255,255,255,0.9); }
.mas-section--dark .mas-service-list li::before,
.mas-section--accent .mas-service-list li::before,
.mas-section--mint .mas-service-list li::before { color: rgba(255,255,255,0.65); }

/* ─── Surface section overrides ─────────────────────────────────────────────── */
.mas-section--surface .mas-feature,
.mas-section--surface .mas-testimonial { background-color: var(--color-white); }


/* ─── Consent checkbox ───────────────────────────────────────────────────────── */
.mas-form__checkbox-label { display: flex; align-items: flex-start; gap: var(--space-2); font-size: 1.125rem; cursor: pointer; line-height: 1.5; }
.mas-form__checkbox-label input[type="checkbox"] { width: 18px; height: 18px; flex-shrink: 0; margin-top: 2px; accent-color: var(--color-accent); }

/* ─── Privacy policy ─────────────────────────────────────────────────────────── */
.mas-privacy-content h2 { font-size: 1.375rem; margin-top: var(--space-6); margin-bottom: var(--space-2); }
.mas-privacy-content h2:first-child { margin-top: 0; }
.mas-privacy-content ul { margin-bottom: var(--space-4); }

/* ─── WordPress block overrides ─────────────────────────────────────────────── */
.wp-block-button__link { border-radius: var(--radius-button) !important; font-family: var(--font-body) !important; }
.is-style-outline .wp-block-button__link { border-color: var(--color-accent) !important; color: var(--color-accent) !important; }
.is-style-outline .wp-block-button__link:hover { background-color: var(--color-accent) !important; color: var(--color-white) !important; }

/* ─── Responsive ─────────────────────────────────────────────────────────────── */
@media (max-width: 1024px) {
    .mas-grid--4 { grid-template-columns: repeat(2, 1fr); }
    .mas-grid--5 { grid-template-columns: repeat(2, 1fr); }
    .fienta-events { grid-template-columns: repeat(2, 1fr); }
    .mas-gallery-grid { grid-template-columns: repeat(3, 1fr); }
    .mas-footer__top { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
    :root {
        --section-padding-y: var(--space-6);
        --container-padding: var(--space-3);
    }

    .mas-hamburger { display: flex; }
    .mas-header__inner { min-height: 60px; }
    .mas-header.is-scrolled .mas-header__inner { min-height: 60px; }
    .mas-header__logo { align-self: center; }
    .mas-header__logo-img,
    .mas-header.is-scrolled .mas-header__logo-img { height: 44px; margin-bottom: 0; }

    .mas-nav {
        display: none;
        position: fixed;
        inset: 0;
        background-color: var(--color-bg);
        z-index: 99;
        padding: var(--space-6) var(--container-padding);
        align-items: center;
        justify-content: center;
    }
    .mas-nav.is-open { display: flex; }
    .mas-nav__list {
        flex-direction: column;
        gap: var(--space-2);
        align-items: center;
        justify-content: center;
        width: 100%;
    }
    .mas-nav__link {
        padding: var(--space-2) var(--space-4);
        border-radius: 999px;
        border-bottom: none;
        font-size: 1.5rem;
        font-weight: 600;
        text-align: center;
    }
    .mas-nav__link:hover { background-color: transparent; }
    .mas-hamburger { position: relative; z-index: 100; }
    body:has(.mas-nav.is-open) { overflow: hidden; }

    .mas-hero { height: auto; min-height: 340px; }
    .mas-hero__content { margin-left: 0; padding: var(--space-6) var(--container-padding); }
    .mas-hero__heading,
    .mas-hero__subtext { max-width: 100%; }

    .mas-page-hero { height: auto; min-height: 200px; }
    .mas-page-hero__heading { max-width: 100%; }

    .mas-grid--2, .mas-grid--3, .mas-grid--4, .mas-grid--5 { grid-template-columns: 1fr; }
    .mas-founder { grid-template-columns: 1fr; gap: var(--space-4); max-width: 420px; }
    .mas-contact-grid { grid-template-columns: 1fr; }
    .mas-service-list { grid-template-columns: 1fr; }
    .fienta-events { grid-template-columns: 1fr; }
    .mas-gallery-grid { grid-template-columns: repeat(2, 1fr); }
    .mas-giftcard-grid { grid-template-columns: 1fr; }
    .mas-footer__top { grid-template-columns: 1fr; gap: var(--space-5); }
    .mas-tabs__nav,
    .mas-gallery-filters { gap: var(--space-1); margin-bottom: var(--space-5); }
    .mas-tabs__tab,
    .mas-gallery-filter { padding: 8px 14px; font-size: 0.875rem; }
}

@media (max-width: 480px) {
    .mas-gallery-grid { grid-template-columns: repeat(2, 1fr); }
    .mas-btn-group { flex-direction: column; align-items: stretch; }
    .mas-btn-group .mas-btn { text-align: center; }
}
