/* ============================================
           DESIGN SYSTEM — Happily Ellie After
           ============================================ */

        :root {
            /* Colours — Happily Ellie After palette */
            --cream: #FAF6EF;
            --cream-dark: #F0EBE2;
            --gold: #F2BE24;
            --gold-light: #F8D46E;
            --gold-muted: #C8981A;
            --gold-dark: #A07810;
            --lemon: #F7E48C;
            /* Lavender — primary brand purple (Ellie's favourite) */
            --purple: #B8A0D2;
            --purple-light: #E4DCF5;
            --purple-dark: #8B50C0;
            --purple-bg: #EDE8F8;
            /* Bubblegum pink */
            --pink: #FEAAC3;
            --pink-light: #FFD0E0;
            --pink-dark: #E07898;
            /* Green-teal */
            --teal: #48B8AA;
            --teal-dark: #329488;
            --blush: #FDE8EE;
            /* Neutrals */
            --lavender: #B8A0D2;
            --text-dark: #2D1E3E;
            --text-body: #4A3C5A;
            --text-light: #8A7898;
            --white: #FFFFFF;

            /* Typography */
            --font-brand: 'Abril Fatface', serif;
            --gold-brand: #F2BE24;
            --font-heading: 'Cormorant Garamond', serif;
            --font-body: 'Outfit', sans-serif;

            /* Spacing */
            --section-padding: 100px 0;
            --container-width: 1200px;
            --border-radius: 16px;
        }

        /* ============================================
           RESET & BASE
           ============================================ */

        *, *::before, *::after {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }

        html {
            scroll-behavior: smooth;
            -webkit-font-smoothing: antialiased;
        }

        body {
            font-family: var(--font-body);
            font-weight: 300;
            font-size: 17px;
            line-height: 1.7;
            color: var(--text-body);
            background-color: var(--cream);
        }

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

        a {
            text-decoration: none;
            color: inherit;
            transition: color 0.3s ease;
        }

        .container {
            max-width: var(--container-width);
            margin: 0 auto;
            padding: 0 24px;
        }

        /* ============================================
           ANNOUNCEMENT BAR
           ============================================ */

        .announcement-bar {
            background-color: var(--gold);
            width: 100%;
            padding: 10px 24px;
            text-align: center;
        }

        .announcement-bar p {
            margin: 0;
            font-family: var(--font-body);
            font-size: 12px;
            font-weight: 700;
            letter-spacing: 3px;
            text-transform: uppercase;
            color: var(--cream);
        }

        /* ============================================
           NAVIGATION
           ============================================ */

        .nav {
            padding: 20px 40px;
            display: flex;
            align-items: center;
            justify-content: center;
            position: sticky;
            top: 0;
            background-color: var(--cream);
            z-index: 200;
            transition: padding 0.3s ease, box-shadow 0.3s ease;
            will-change: padding, box-shadow;
            transform: translateZ(0);
        }

        .nav.is-scrolled {
            padding: 10px 40px;
            box-shadow: 0 2px 16px rgba(44, 26, 29, 0.08);
        }

        .nav.is-scrolled .nav-logo img {
            width: 174px;
        }

        /* ---- Hamburger button ---- */
        .nav-hamburger {
            display: none;
            flex-direction: column;
            justify-content: center;
            gap: 5px;
            width: 40px;
            height: 40px;
            background: none;
            border: none;
            cursor: pointer;
            padding: 6px;
            position: absolute;
            left: 24px;
            z-index: 200;
        }

        .nav-hamburger span {
            display: block;
            height: 1.5px;
            background-color: var(--text-dark);
            border-radius: 2px;
            transition: transform 0.3s ease, opacity 0.3s ease, width 0.3s ease;
            transform-origin: center;
        }

        /* Hamburger → X animation */
        .nav-hamburger.is-open span:nth-child(1) {
            transform: translateY(6.5px) rotate(45deg);
        }
        .nav-hamburger.is-open span:nth-child(2) {
            opacity: 0;
            transform: scaleX(0);
        }
        .nav-hamburger.is-open span:nth-child(3) {
            transform: translateY(-6.5px) rotate(-45deg);
        }

        /* ---- Desktop nav links ---- */
        .nav-links {
            display: flex;
            align-items: center;
            gap: 36px;
            flex: 1;
            list-style: none;
        }

        /* Left group right-aligns so links sit flush against the logo */
        .nav-links:first-of-type {
            justify-content: flex-end;
        }

        .nav-links a {
            color: var(--gold-brand);
            font-family: 'Young Serif', serif;
            font-size: 17px;
            font-weight: 400;
            letter-spacing: 0.3px;
            transition: color 0.3s ease;
            text-decoration: none;
        }

        .nav-links a:hover {
            color: var(--gold-muted);
        }

        .nav-logo {
            margin: 0 44px;
            text-align: center;
            flex-shrink: 0;
            text-decoration: none;
        }

        .nav-logo img {
            width: 257px;
            height: auto;
            display: block;
            margin: 0 auto;
            transition: width 0.3s ease;
        }

        /* ---- Mobile menu overlay ---- */
        .mobile-menu {
            display: none;
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background-color: var(--cream);
            z-index: 150;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 0;
            opacity: 0;
            transform: translateY(-12px);
            transition: opacity 0.3s ease, transform 0.3s ease;
            pointer-events: none;
        }

        .mobile-menu.is-open {
            opacity: 1;
            transform: translateY(0);
            pointer-events: all;
        }

        .mobile-menu-logo {
            margin-bottom: 32px;
        }

        .mobile-menu-logo img {
            width: 260px;
            height: auto;
            display: block;
        }

        .mobile-menu-links {
            list-style: none;
            text-align: center;
            display: flex;
            flex-direction: column;
            gap: 4px;
        }

        .mobile-menu-links li a {
            font-family: 'Young Serif', serif;
            font-size: 28px;
            color: var(--text-dark);
            text-decoration: none;
            letter-spacing: 0.2px;
            display: block;
            padding: 10px 24px;
            transition: color 0.2s ease;
        }

        .mobile-menu-links li a:hover {
            color: var(--gold-muted);
        }

        .mobile-menu-cta {
            margin-top: 32px;
        }

        .mobile-menu-divider {
            width: 48px;
            height: 1px;
            background: var(--gold);
            margin: 20px auto;
            opacity: 0.6;
        }

        /* ============================================
           HERO SECTION
           ============================================ */

        .hero {
            position: relative;
            width: 100%;
            height: 88vh;
            min-height: 620px;
            max-height: 950px;
            overflow: hidden;
        }

        .hero-bg {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
        }

        .hero-bg img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            object-position: center 40%;
        }

        /* Dark gradient — lower portion only */
        .hero-bg::after {
            content: '';
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            height: 60%;
            background: linear-gradient(
                to bottom,
                rgba(0,0,0,0) 0%,
                rgba(0,0,0,0.1) 40%,
                rgba(0,0,0,0.55) 70%,
                rgba(0,0,0,0.72) 100%
            );
            z-index: 1;
        }

        .hero-overlay {
            display: none;
        }

        /* Hero content — anchored to bottom of image */
        .hero-content {
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            z-index: 2;
            text-align: center;
            padding: 0 24px 48px;
        }

        .hero-label {
            font-family: var(--font-body);
            font-size: 12px;
            font-weight: 700;
            letter-spacing: 3px;
            text-transform: uppercase;
            color: var(--purple);
            margin-bottom: 12px;
        }

        .hero-display {
            font-family: var(--font-brand);
            font-size: 52px;
            font-weight: 400;
            color: #FFFFFF;
            margin-bottom: 10px;
            line-height: 1.12;
            text-shadow: 0 2px 20px rgba(0,0,0,0.25);
        }

        .hero-subtitle {
            font-family: var(--font-body);
            font-size: 17px;
            font-weight: 300;
            color: rgba(255,255,255,0.9);
            display: block;
            margin-bottom: 28px;
        }

        .hero-location {
            font-family: var(--font-body);
            font-size: 11px;
            color: rgba(255,255,255,0.6);
            letter-spacing: 2px;
            margin-top: 20px;
            text-transform: uppercase;
        }

        .hero-credit {
            position: absolute;
            bottom: 14px;
            right: 18px;
            z-index: 3;
            font-family: var(--font-body);
            font-size: 11px;
            font-style: italic;
            color: rgba(255,255,255,0.75);
            letter-spacing: 0.3px;
        }

        .hero-credit a {
            color: inherit;
            text-decoration: underline;
            text-decoration-color: rgba(255,255,255,0.45);
            text-underline-offset: 2px;
            transition: color 0.2s ease;
        }

        .hero-credit a:hover {
            color: rgba(255,255,255,1);
            text-decoration-color: rgba(255,255,255,0.9);
        }

        /* ============================================
           VIDEO EMBED (used on Spanish pages)
           ============================================ */

        .page-video {
            position: relative;
            width: 100%;
            aspect-ratio: 16 / 9;
            margin: 0 auto 48px;
            border-radius: 16px;
            overflow: hidden;
            background: var(--text-dark);
            box-shadow: 0 8px 32px rgba(45,30,62,0.12);
        }

        .page-video iframe {
            position: absolute;
            inset: 0;
            width: 100%;
            height: 100%;
            border: 0;
        }

        @media (max-width: 768px) {
            .page-video { margin-bottom: 36px; border-radius: 12px; }
        }

        /* ============================================
           BUTTONS
           ============================================ */

        .btn {
            display: inline-block;
            padding: 14px 36px;
            border-radius: 50px;
            font-family: var(--font-body);
            font-size: 15px;
            font-weight: 500;
            letter-spacing: 0.5px;
            text-transform: uppercase;
            transition: all 0.3s ease;
            cursor: pointer;
            border: none;
        }

        .btn-primary {
            background-color: var(--gold);
            color: var(--text-dark);
        }

        .btn-primary:hover {
            background-color: var(--gold-muted);
            color: var(--white);
        }

        .btn-outline {
            background-color: transparent;
            color: var(--gold);
            border: 1.5px solid var(--gold);
        }

        .btn-outline:hover {
            background-color: var(--gold);
            color: var(--white);
        }

        /* ============================================
           MEET ELLIE SECTION
           ============================================ */

        .meet-ellie {
            padding: var(--section-padding);
        }

        .meet-ellie .container {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 80px;
            align-items: center;
        }

        .meet-ellie-photo {
            position: relative;
            overflow: hidden;
            border-radius: 62% 38% 46% 54% / 60% 44% 56% 40%;
            aspect-ratio: 4/5;
            max-width: 480px;
        }

        .meet-ellie-photo img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            object-position: center top;
            display: block;
        }

        .meet-ellie-content h2 {
            font-family: var(--font-heading);
            font-size: 52px;
            font-weight: 400;
            color: var(--text-dark);
            margin-bottom: 24px;
            line-height: 1.1;
        }

        .meet-ellie-content p {
            margin-bottom: 20px;
            color: var(--text-body);
            font-size: 17px;
            line-height: 1.75;
        }

        .meet-ellie-content p em {
            font-style: italic;
            color: var(--text-dark);
        }

        .meet-ellie-content .btn {
            margin-top: 16px;
        }

        /* ============================================
           WAVE DIVIDER
           ============================================ */

        .wave-divider {
            text-align: center;
            padding: 10px 0;
            color: var(--lavender);
            font-size: 28px;
            letter-spacing: 4px;
        }

        /* ============================================
           SERVICES / CEREMONY CARDS
           ============================================ */

        .services {
            padding: 90px 0 110px;
            background-color: var(--purple-bg);
        }

        .services h2 {
            font-family: var(--font-heading);
            font-size: 72px;
            font-weight: 400;
            color: var(--text-dark);
            text-align: center;
            margin-bottom: 0;
        }

        .services-intro {
            font-family: var(--font-body);
            font-size: 16px;
            color: var(--text-light);
            text-align: center;
            margin-top: 12px;
            margin-bottom: 48px;
            letter-spacing: 0.3px;
        }

        .services-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 20px;
            max-width: 1120px;
            margin: 0 auto;
            overflow: visible;
            padding: 24px 8px 32px;
        }

        .service-card {
            border-radius: 22px;
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            aspect-ratio: 3/4;
            transition: transform 0.3s ease, box-shadow 0.3s ease;
            cursor: pointer;
            position: relative;
            overflow: hidden;
            text-decoration: none;
            padding: 30px 28px;
        }

        /* Subtle inner border — Art Deco nod */
        .service-card::after {
            content: '';
            position: absolute;
            inset: 10px;
            border-radius: 14px;
            border: 1px solid rgba(255,255,255,0.2);
            pointer-events: none;
        }

        .service-card:hover {
            transform: rotate(0deg) translateY(-10px) !important;
            box-shadow: 0 28px 60px rgba(80,30,120,0.28);
        }

        /* Teal + purple sit high at rest, so they drop downward on hover instead of lifting (would otherwise overlap neighbours) */
        .service-card--teal:hover,
        .service-card--purple:hover {
            transform: rotate(0deg) translateY(14px) !important;
        }

        .service-card--gold   { background-color: var(--gold);   transform: rotate(-1.8deg) translateY(14px); }
        .service-card--purple { background-color: var(--purple-dark); transform: rotate(1.2deg)  translateY(-16px); }
        .service-card--pink   { background-color: var(--pink);  transform: rotate(-0.8deg) translateY(10px); }
        .service-card--teal   { background-color: var(--teal);  transform: rotate(1.6deg)  translateY(-8px); }

        /* Light cards (gold + pink) need dark text for contrast */
        .service-card--gold .service-card-label,
        .service-card--pink .service-card-label  { color: rgba(45,30,62,0.45); }
        .service-card--gold .service-card-title,
        .service-card--pink .service-card-title  { color: var(--text-dark); }
        .service-card--gold .service-card-desc,
        .service-card--pink .service-card-desc   { color: rgba(45,30,62,0.7); }
        .service-card--gold .service-card-link,
        .service-card--pink .service-card-link   { color: rgba(45,30,62,0.45); }
        .service-card--gold:hover .service-card-link,
        .service-card--pink:hover .service-card-link { color: var(--text-dark); }
        .service-card--gold::after,
        .service-card--pink::after { border-color: rgba(45,30,62,0.12); }
        .service-card--gold .service-card-bottom,
        .service-card--pink .service-card-bottom { border-top-color: rgba(45,30,62,0.12); }

        /* Pink card icon — dark stroke (covers all SVG drawable elements) */
        .service-card--pink .service-card-icon path,
        .service-card--pink .service-card-icon line,
        .service-card--pink .service-card-icon circle,
        .service-card--pink .service-card-icon rect,
        .service-card--pink .service-card-icon polyline,
        .service-card--pink .service-card-icon polygon { stroke: rgba(45,30,62,0.45); }

        /* Card inner layout — top and bottom groups */
        .service-card-top {
            display: flex;
            flex-direction: column;
        }

        .service-card-bottom {
            display: flex;
            flex-direction: column;
            border-top: 1px solid rgba(255,255,255,0.18);
            padding-top: 18px;
        }

        .service-card-icon {
            display: block;
            margin-bottom: 18px;
        }

        .service-card-label {
            font-family: var(--font-body);
            font-size: 9px;
            font-weight: 700;
            letter-spacing: 3px;
            text-transform: uppercase;
            color: rgba(255,255,255,0.55);
            display: block;
        }

        .service-card-title {
            font-family: var(--font-heading);
            font-size: 32px;
            font-weight: 700;
            font-style: normal;
            color: #fff;
            line-height: 1.12;
            margin-top: 8px;
        }

        .service-card-desc {
            font-family: var(--font-body);
            font-size: 13px;
            font-weight: 300;
            color: rgba(255,255,255,0.8);
            line-height: 1.65;
            margin-bottom: 16px;
        }

        .service-card-link {
            font-family: var(--font-body);
            font-size: 10px;
            font-weight: 700;
            letter-spacing: 2.5px;
            text-transform: uppercase;
            color: rgba(255,255,255,0.6);
            display: block;
            transition: color 0.25s ease;
        }

        /* Hover state for "Explore →" — matches base text colour of the card.
           Dark-text cards (gold, pink) brighten to full dark; white-text cards
           (purple, teal) brighten to full white. This pattern should be repeated
           anywhere else card text needs to match a hover state. */
        .service-card--purple:hover .service-card-link,
        .service-card--teal:hover .service-card-link {
            color: #fff;
        }

        /* ============================================
           HOW IT WORKS
           ============================================ */

        .how-it-works {
            background-color: var(--cream);
            position: relative;
            padding: 0;
        }

        .how-it-works-wave,
        .section-wave {
            width: 100%;
            display: block;
            line-height: 0;
        }

        .how-it-works-wave svg,
        .section-wave svg {
            width: 100%;
            height: 22px;
            display: block;
        }

        .how-it-works-content {
            padding: 60px 0 80px;
        }

        .how-it-works h2 {
            font-family: var(--font-heading);
            font-size: 68px;
            font-weight: 400;
            color: var(--text-dark);
            text-align: center;
            margin-bottom: 6px;
        }

        .how-it-works .subtitle {
            text-align: center;
            font-family: var(--font-body);
            font-size: 16px;
            font-weight: 400;
            letter-spacing: 0;
            text-transform: none;
            color: var(--gold-dark);
            margin-bottom: 72px;
        }

        .steps-wrapper {
            position: relative;
            max-width: 1120px;
            margin: 0 auto;
        }

        .steps-connector {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 80px;
            pointer-events: none;
            z-index: 0;
            overflow: visible;
        }

        .steps-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 0;
            position: relative;
            align-items: start;
        }

        .step {
            text-align: center;
            padding: 0 24px;
            position: relative;
            z-index: 1;
        }

        /* Alternating vertical offset for stagger */
        .step:nth-child(1) { padding-top: 0; }
        .step:nth-child(2) { padding-top: 52px; }
        .step:nth-child(3) { padding-top: 0; }
        .step:nth-child(4) { padding-top: 52px; }

        .step-num-wrap {
            display: flex;
            align-items: center;
            justify-content: center;
            margin-bottom: 20px;
            position: relative;
        }

        /* Coloured dots per step variant */
        .step--gold  .step-dot { background-color: var(--gold);        box-shadow: 0 0 0 2px var(--gold); }
        .step--purple .step-dot { background-color: var(--purple-dark); box-shadow: 0 0 0 2px var(--purple-dark); }
        .step--pink  .step-dot { background-color: var(--pink-dark);   box-shadow: 0 0 0 2px var(--pink-dark); }
        .step--teal  .step-dot { background-color: var(--teal);        box-shadow: 0 0 0 2px var(--teal); }

        .step-dot {
            width: 18px;
            height: 18px;
            border-radius: 50%;
            border: 3px solid var(--cream);
            position: relative;
            z-index: 2;
        }

        .how-it-works-cta {
            text-align: center;
            margin-top: 56px;
        }

        /* Micro-rotation per step for a scattered, human feel */
        .step--gold   { transform: rotate(-1.5deg); }
        .step--purple { transform: rotate(1.2deg);  }
        .step--pink   { transform: rotate(-0.8deg); }
        .step--teal   { transform: rotate(1.8deg);  }

        .step-num {
            display: block;
            font-family: var(--font-brand);
            font-size: 52px;
            line-height: 1;
            color: var(--gold);
            margin-bottom: 8px;
        }

        .step--purple .step-num { color: var(--purple-dark); }
        .step--pink   .step-num { color: var(--pink-dark); }
        .step--teal   .step-num { color: var(--teal); }

        .step-title {
            font-family: var(--font-heading);
            font-size: 24px;
            font-weight: 700;
            color: var(--text-dark);
            margin-bottom: 10px;
            line-height: 1.2;
        }

        .step p {
            font-family: var(--font-body);
            font-size: 15px;
            color: var(--text-body);
            line-height: 1.65;
        }

        /* ============================================
           REGISTRY STYLE WEDDINGS
           ============================================ */

        .registry-style {
            padding: var(--section-padding);
            background-color: var(--blush);
        }

        .registry-style .container {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 80px;
            align-items: center;
        }

        .registry-style-image {
            aspect-ratio: 1/1;
            overflow: hidden;
            clip-path: url(#heart-clip);
            max-width: 546px;
            position: relative;
        }

        .registry-style-image img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            object-position: center top;
        }

        .registry-style-content h2 {
            font-family: var(--font-heading);
            font-size: 48px;
            font-weight: 400;
            color: var(--text-dark);
            margin-bottom: 8px;
            line-height: 1.1;
        }

        .registry-style-content .section-intro {
            font-family: var(--font-body);
            font-size: 16px;
            color: var(--pink-dark);
            margin-bottom: 20px;
        }

        .registry-style-content p {
            font-size: 17px;
            color: var(--text-body);
            line-height: 1.75;
            margin-bottom: 20px;
        }

        .registry-style-content .btn {
            margin-top: 8px;
        }

        /* ============================================
           TESTIMONIALS
           ============================================ */

        .testimonials {
            padding: var(--section-padding);
            background-color: var(--purple-bg);
        }

        .testimonials h2 {
            font-family: var(--font-heading);
            font-size: 52px;
            font-weight: 400;
            color: var(--text-dark);
            text-align: center;
            margin-bottom: 12px;
        }

        .testimonials .section-intro {
            font-family: var(--font-body);
            font-size: 16px;
            color: var(--text-light);
            text-align: center;
            margin-bottom: 48px;
        }

        .testimonials-google-link {
            text-align: center;
            margin-top: 48px;
        }

        .testimonials-google-link a {
            font-family: var(--font-body);
            font-size: 14px;
            font-weight: 600;
            letter-spacing: 1.5px;
            text-transform: uppercase;
            color: var(--gold-dark);
            text-decoration: underline;
            text-underline-offset: 4px;
            transition: color 0.2s ease;
        }

        .testimonials-google-link a:hover {
            color: var(--text-dark);
        }

        .testimonials-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 28px;
            max-width: 1000px;
            margin: 0 auto;
            align-items: center;
            overflow: visible;
        }

        .testimonial-card {
            border-radius: var(--border-radius);
            padding: 36px 28px;
            text-align: center;
            transition: transform 0.3s ease, box-shadow 0.3s ease;
            box-shadow: 0 8px 32px rgba(80,30,120,0.12);
        }

        .testimonial-card--gold {
            background-color: var(--gold);
            color: var(--white);
            transform: rotate(-2.5deg) translateY(16px);
        }

        .testimonial-card--cream {
            background-color: var(--cream);
            color: var(--text-dark);
            transform: rotate(0.8deg) translateY(-20px);
        }

        .testimonial-card--rose {
            background-color: var(--pink-dark);
            color: var(--white);
            transform: rotate(2deg) translateY(10px);
        }

        .testimonial-card:hover {
            transform: rotate(0deg) translateY(-6px) !important;
            box-shadow: 0 20px 48px rgba(80,30,120,0.2);
        }

        .testimonial-stars {
            font-size: 18px;
            margin-bottom: 20px;
            letter-spacing: 2px;
        }

        .testimonial-card--cream .testimonial-stars {
            color: var(--text-dark);
        }

        .testimonial-quote {
            font-family: var(--font-heading);
            font-size: 18px;
            font-weight: 600;
            font-style: italic;
            line-height: 1.5;
            margin-bottom: 24px;
        }

        .testimonial-author {
            font-family: var(--font-body);
            font-size: 14px;
            font-weight: 400;
            opacity: 0.85;
        }

        /* ============================================
           AREAS SECTION
           ============================================ */

        .areas {
            padding: var(--section-padding);
            background-color: var(--cream);
        }

        .areas-eyebrow {
            font-family: var(--font-body);
            font-size: 11px;
            font-weight: 600;
            text-align: center;
            letter-spacing: 3.5px;
            text-transform: uppercase;
            color: var(--gold-dark);
            text-align: center;
            margin-bottom: 10px;
        }

        .areas h2 {
            font-family: var(--font-heading);
            font-size: 52px;
            font-weight: 400;
            color: var(--text-dark);
            text-align: center;
            margin-bottom: 14px;
        }

        .areas .section-intro {
            font-family: var(--font-body);
            font-size: 16px;
            color: var(--text-light);
            text-align: center;
            max-width: 560px;
            margin: 0 auto 56px;
            line-height: 1.7;
        }

        .areas-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            max-width: 860px;
            margin: 0 auto;
        }

        .area-group {
            padding: 0 40px;
        }

        .area-group:first-child { padding-left: 0; }
        .area-group:last-child  { padding-right: 0; }

        .area-group-heading {
            display: flex;
            align-items: center;
            gap: 8px;
            margin-bottom: 20px;
            text-decoration: none;
        }

        .area-group-heading svg {
            flex-shrink: 0;
            width: 16px;
            height: 16px;
        }

        .area-group h3 {
            font-family: var(--font-heading);
            font-size: 24px;
            font-weight: 400;
            margin: 0;
            transition: opacity 0.2s;
        }

        .area-group-heading:hover h3 { opacity: 0.7; }

        .area-group--tweed .area-group-heading { color: var(--teal); }
        .area-group--byron .area-group-heading { color: var(--pink-dark); }
        .area-group--gc    .area-group-heading { color: var(--gold-dark); }

        .area-group ul {
            list-style: none;
        }

        .area-group li {
            margin-bottom: 7px;
        }

        .area-group a {
            font-family: var(--font-body);
            font-size: 15px;
            color: var(--text-body);
            text-decoration: none;
            display: inline-flex;
            align-items: center;
            gap: 6px;
            transition: color 0.2s ease;
        }

        .area-group a::before {
            content: '';
            width: 4px;
            height: 4px;
            border-radius: 50%;
            background: currentColor;
            opacity: 0.3;
            flex-shrink: 0;
            transition: opacity 0.2s;
        }

        .area-group-heading::before { display: none; }

        .area-group--tweed a:hover { color: var(--teal); }
        .area-group--byron a:hover { color: var(--pink-dark); }
        .area-group--gc    a:hover { color: var(--gold-dark); }

        .area-group a:hover::before { opacity: 1; }

        .areas-travel-note {
            text-align: center;
            margin-top: 52px;
            font-family: var(--font-body);
            font-size: 14px;
            color: var(--text-light);
            background: rgba(44, 26, 29, 0.04);
            display: block;
            padding: 12px 28px;
            border-radius: 40px;
            max-width: 640px;
            margin-left: auto;
            margin-right: auto;
        }

        .areas-travel-note strong {
            color: var(--gold-dark);
            font-weight: 600;
        }

        /* ============================================
           SPANISH CTA
           ============================================ */

        .spanish-cta {
            padding: 96px 0 100px;
            background-color: var(--lemon);
        }

        .spanish-cta .container {
            display: grid;
            grid-template-columns: 1.3fr 0.7fr;
            gap: 40px;
            align-items: center;
        }

        .spanish-cta-content h2 {
            font-family: var(--font-heading);
            font-size: 56px;
            font-weight: 400;
            color: var(--text-dark);
            margin-bottom: 10px;
            line-height: 1.1;
        }

        .spanish-cta-content .section-intro {
            font-family: var(--font-body);
            font-size: 16px;
            font-style: normal;
            font-weight: 400;
            color: var(--text-dark);
            opacity: 0.75;
            margin-bottom: 28px;
        }

        .spanish-cta-content p {
            margin-bottom: 24px;
            color: var(--text-dark);
            opacity: 0.8;
            font-size: 17px;
            line-height: 1.75;
        }

        .spanish-cta-content .btn-group {
            display: flex;
            gap: 14px;
            align-items: center;
            flex-wrap: wrap;
        }

        .spanish-cta-deco {
            display: flex;
            align-items: center;
            justify-content: center;
        }

        .spanish-cta-deco img {
            width: 390px;
            height: 390px;
            object-fit: cover;
            object-position: center 20%;
            clip-path: url(#heart-clip);
            transform: rotate(2deg);
            filter: drop-shadow(0 10px 28px rgba(44, 26, 29, 0.22));
            display: block;
            flex-shrink: 0;
        }

        /* Button variants for use on coloured backgrounds (gold, teal etc) */
        .btn-dark {
            background-color: var(--text-dark);
            color: var(--white);
            border: none;
        }

        .btn-dark:hover {
            background-color: #1a0e10;
            color: var(--white);
        }

        .btn-outline--dark {
            background-color: transparent;
            color: var(--text-dark);
            border: 1.5px solid var(--text-dark);
        }

        .btn-outline--dark:hover {
            background-color: var(--text-dark);
            color: var(--white);
        }

        /* ============================================
           HERO PRICING ROW
           Shared pattern for service-page hero CTAs:
           a dark "From $X" / "$X" price pill sitting next to the gold
           Check-My-Availability button. Flex wrapper forces both pills
           to the same height regardless of font/padding differences.
           ============================================ */
        .hero-pricing-row {
            display: inline-flex;
            align-items: stretch;
            gap: 12px;
            margin: 8px 0 28px;
            flex-wrap: wrap;
        }
        .hero-pricing-row .price-callout,
        .hero-pricing-row .btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            margin: 0;
        }
        .price-callout {
            background-color: var(--text-dark);
            color: var(--white);
            font-family: var(--font-heading);
            font-size: 21px;
            font-weight: 600;
            padding: 0 28px;
            border-radius: 50px;
            letter-spacing: 0.3px;
            line-height: 1;
        }

        /* ============================================
           FINAL CTA
           ============================================ */

        /* ============================================
           GALLERY
           ============================================ */

        .gallery {
            padding: 80px 0 72px;
            background-color: var(--cream-dark);
            text-align: center;
        }

        .gallery-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 16px;
            margin-bottom: 40px;
        }

        .gallery-grid img {
            width: 100%;
            aspect-ratio: 4/3;
            object-fit: cover;
            display: block;
            border-radius: 4px;
        }

        .gallery-link {
            font-family: var(--font-body);
            font-size: 16px;
            color: var(--text-dark);
            text-decoration: none;
            border-bottom: 1.5px solid var(--gold);
            padding-bottom: 2px;
            transition: color 0.2s, border-color 0.2s;
        }

        .gallery-link:hover {
            color: var(--gold-dark);
            border-color: var(--gold-dark);
        }

        /* ============================================
           FOOTER
           ============================================ */

        .footer {
            padding: 64px 0 40px;
            background-color: var(--text-dark);
            color: var(--cream-dark);
        }

        .footer-logo img {
            width: 216px;
            height: auto;
            display: block;
            margin: 0 auto 16px;
        }

        .footer-brand {
            text-align: center;
        }

        .footer-grid {
            display: grid;
            grid-template-columns: 2fr 1fr 1fr 1fr;
            gap: 40px;
            margin-bottom: 48px;
        }

        .footer-brand p {
            font-size: 14px;
            color: rgba(255,255,255,0.5);
            line-height: 1.6;
        }

        .footer h4 {
            font-family: 'Young Serif', serif;
            font-size: 18px;
            font-weight: 400;
            color: var(--gold-brand);
            margin-bottom: 20px;
        }

        .footer ul {
            list-style: none;
        }

        .footer li {
            margin-bottom: 10px;
        }

        .footer a {
            font-size: 14px;
            color: rgba(255,255,255,0.6);
            transition: color 0.3s ease;
        }

        .footer a:hover {
            color: var(--gold-light);
        }

        .footer-bottom {
            border-top: 1px solid rgba(255,255,255,0.1);
            padding-top: 24px;
            display: flex;
            justify-content: space-between;
            align-items: center;
            font-size: 13px;
            color: rgba(255,255,255,0.35);
        }

        .footer-social {
            display: flex;
            gap: 16px;
        }

        .footer-social a {
            color: rgba(255,255,255,0.5);
        }

        .footer-social a:hover {
            color: var(--gold-light);
        }

        /* ============================================
           MOBILE RESPONSIVE
           ============================================ */

        /* ---- Tablet (shrink logo, compress nav links) ---- */
        @media (max-width: 1024px) {
            .registry-style .container {
                grid-template-columns: 1fr;
                gap: 40px;
            }

            .steps-grid {
                grid-template-columns: repeat(2, 1fr);
                gap: 48px 32px;
            }

            /* Reset stagger + rotation on tablet */
            .step:nth-child(1),
            .step:nth-child(2),
            .step:nth-child(3),
            .step:nth-child(4) {
                padding-top: 0;
            }

            .step--gold, .step--purple, .step--pink, .step--teal {
                transform: none;
            }

            .steps-connector {
                display: none;
            }

            .nav-logo img {
                width: 194px;
                height: auto;
            }

            .nav-logo {
                margin: 0 22px;
            }

            .nav-links {
                gap: 24px;
                min-width: auto;
            }

            .nav-links a {
                font-size: 15px;
            }
        }

        /* ---- Mobile (hamburger + overlay menu) ---- */
        @media (max-width: 768px) {
            :root {
                --section-padding: 60px 0;
            }

            /* Show hamburger, hide desktop links */
            .nav-hamburger {
                display: flex;
            }

            .nav-links {
                display: none;
            }

            .nav {
                padding: 16px 24px;
                justify-content: center;
            }

            .nav-logo {
                margin: 0;
            }

            .nav-logo img {
                width: 180px;
                height: auto;
            }

            /* Show mobile menu when triggered */
            .mobile-menu {
                display: flex;
            }

            /* Hero */
            .hero {
                height: 85vh;
                min-height: 550px;
            }

            .hero-display {
                font-size: 38px;
            }

            .hero-content {
                padding: 0 20px 36px;
            }

            /* Meet Ellie */
            .meet-ellie .container {
                grid-template-columns: 1fr;
                gap: 40px;
            }

            .meet-ellie-photo {
                max-width: 400px;
                width: 100%;
                margin: 0 auto;
            }

            /* Services */
            .services h2 {
                font-size: 42px;
            }
            .services-grid {
                grid-template-columns: 1fr 1fr;
                gap: 14px;
            }

            .service-card {
                aspect-ratio: 3/4;
                padding: 20px 16px 24px;
            }

            .service-card-title {
                font-size: 24px;
            }

            .service-card-icon {
                margin-bottom: 12px;
            }

            .service-card-desc,
            .service-card-link {
                display: none;
            }

            /* Steps */
            .steps-grid {
                grid-template-columns: 1fr;
                max-width: 360px;
                margin: 0 auto;
                gap: 40px;
            }

            .step:nth-child(1),
            .step:nth-child(2),
            .step:nth-child(3),
            .step:nth-child(4) {
                padding-top: 0;
            }

            .step--gold, .step--purple, .step--pink, .step--teal {
                transform: none;
            }

            .steps-connector {
                display: none;
            }

            /* Registry Style */
            .registry-style-image {
                max-width: 416px;
                margin: 0 auto;
            }

            /* [placeholder — packages removed] */
            .packages-grid {
                grid-template-columns: 1fr;
                max-width: 400px;
                margin: 0 auto;
            }

            /* Testimonials */
            .testimonials-grid {
                grid-template-columns: 1fr;
                max-width: 400px;
                margin: 0 auto;
                gap: 16px;
            }

            .testimonial-card--gold,
            .testimonial-card--cream,
            .testimonial-card--rose {
                transform: none;
            }

            /* Registry Style */
            .registry-style .container {
                grid-template-columns: 1fr;
                gap: 40px;
            }

            /* Areas */
            .areas-grid {
                grid-template-columns: 1fr;
                gap: 0;
            }

            .area-group {
                padding: 24px 0;
                border-bottom: 1px solid rgba(44, 26, 29, 0.1);
            }

            .area-group:last-child {
                border-bottom: none;
                padding-bottom: 0;
            }

            /* Spanish CTA */
            .spanish-cta {
                padding: 72px 0 56px;
            }

            .spanish-cta .container {
                grid-template-columns: 1fr;
                gap: 32px;
            }

            .spanish-cta-deco {
                margin: 0 auto;
                width: 100%;
                max-width: 360px;
            }

            .spanish-cta-deco img {
                width: 100%;
                height: auto;
                aspect-ratio: 1 / 1;
                transform: rotate(1.5deg);
            }

            .spanish-cta-content .btn-group {
                flex-direction: column;
                align-items: stretch;
            }

            .spanish-cta-content .btn-group .btn {
                text-align: center;
            }

            /* Footer */
            .footer-logo img {
                width: 150px;
                height: auto;
            }

            .footer-grid {
                grid-template-columns: 1fr 1fr;
                gap: 32px;
            }

            .footer-bottom {
                flex-direction: column;
                gap: 12px;
                text-align: center;
            }
        }

        @media (max-width: 480px) {
            .hero-display {
                font-size: 32px;
            }

            .meet-ellie-content h2,
            .services h2,
            .how-it-works h2,
            .testimonials h2,
            .areas h2 {
                font-size: 32px;
            }

            .gallery-grid {
                grid-template-columns: 1fr;
                gap: 12px;
            }

            .footer-grid {
                grid-template-columns: 1fr;
            }
        }

/* ============================================
   Easter Egg Modal — footer husband secret
   ============================================ */

.footer .easter-egg-trigger {
    cursor: pointer;
    transition: color 0.4s ease;
}

.footer .easter-egg-trigger:hover {
    color: rgba(254, 170, 195, 0.55) !important;
}

.easter-egg-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 24px;
}

.easter-egg-modal.is-open {
    display: flex;
    animation: easterEggFade 0.35s ease forwards;
}

.easter-egg-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(45, 30, 62, 0.55);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    cursor: pointer;
}

.easter-egg-card {
    position: relative;
    background: var(--cream);
    border-radius: 24px;
    padding: 48px 44px 40px;
    max-width: 460px;
    width: 100%;
    box-shadow: 0 24px 64px rgba(45, 30, 62, 0.25);
    max-height: 90vh;
    overflow-y: auto;
    animation: easterEggSlide 0.5s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

.easter-egg-close {
    position: absolute;
    top: 14px;
    right: 14px;
    background: none;
    border: none;
    font-size: 26px;
    color: var(--text-light);
    cursor: pointer;
    width: 36px;
    height: 36px;
    border-radius: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s ease, color 0.2s ease;
    padding: 0;
    line-height: 1;
}

.easter-egg-close:hover {
    background: var(--cream-dark);
    color: var(--text-dark);
}

.easter-egg-eyebrow {
    font-family: var(--font-body);
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--purple-dark);
    margin: 0 0 14px;
    text-align: center;
}

.easter-egg-heading {
    font-family: var(--font-heading);
    font-style: italic;
    font-size: 36px;
    font-weight: 400;
    color: var(--text-dark);
    text-align: center;
    margin: 0 0 28px;
    line-height: 1.1;
}

.easter-egg-stats {
    margin: 0 0 28px;
}

.easter-egg-stat {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 16px;
    padding: 10px 0;
    border-bottom: 1px dotted rgba(45, 30, 62, 0.18);
    font-family: var(--font-body);
    font-size: 14px;
    line-height: 1.4;
    color: var(--text-body);
}

.easter-egg-stat:last-child {
    border-bottom: none;
}

.easter-egg-stat-label {
    flex: 1;
}

.easter-egg-stat-value {
    font-weight: 600;
    color: var(--text-dark);
    text-align: right;
    white-space: nowrap;
}

.easter-egg-strike {
    color: var(--text-light);
    font-weight: 400;
    opacity: 0.55;
    margin-right: 4px;
}

.easter-egg-message {
    font-family: var(--font-heading);
    font-style: italic;
    font-size: 18px;
    line-height: 1.55;
    color: var(--text-body);
    margin: 0 0 14px;
    text-align: center;
}

.easter-egg-message--punchline {
    margin-bottom: 24px;
    color: var(--text-dark);
}

.easter-egg-heart {
    display: inline-block;
    color: var(--pink-dark);
    animation: easterEggHeart 1.6s ease-in-out infinite;
    transform-origin: center;
}

.easter-egg-signature {
    font-family: var(--font-heading);
    font-style: italic;
    font-size: 16px;
    color: var(--text-light);
    text-align: right;
    margin: 0;
    padding-top: 8px;
    border-top: 1px solid var(--cream-dark);
    letter-spacing: 0.5px;
}

@keyframes easterEggFade {
    from { opacity: 0; }
    to   { opacity: 1; }
}

@keyframes easterEggSlide {
    from {
        opacity: 0;
        transform: translateY(20px) scale(0.96);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes easterEggHeart {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.25); }
}

@media (max-width: 480px) {
    .easter-egg-card {
        padding: 40px 24px 32px;
        border-radius: 20px;
    }
    .easter-egg-heading {
        font-size: 28px;
    }
    .easter-egg-stat {
        font-size: 13px;
    }
    .easter-egg-message {
        font-size: 16px;
    }
}
