/* ========================================================================== MannySpeaking.com — Editorial, Refined, Authoritative ========================================================================== */ /* ---------- CSS Variables ---------- */ :root { --color-bg: #f7f4ef; --color-bg-alt: #ede8df; --color-ink: #1a1a1a; --color-ink-soft: #3d3d3d; --color-ink-muted: #6b6b6b; --color-accent: #b8732a; --color-accent-soft: #d89856; --color-accent-dark: #8a4d12; --color-line: rgba(26, 26, 26, 0.12); --color-line-strong: rgba(26, 26, 26, 0.4); --font-display: 'Fraunces', Georgia, serif; --font-body: 'Manrope', -apple-system, BlinkMacSystemFont, sans-serif; --space-xs: 0.5rem; --space-sm: 1rem; --space-md: 2rem; --space-lg: 4rem; --space-xl: 8rem; --space-2xl: 12rem; --container-max: 1280px; --container-narrow: 920px; --container-text: 720px; --transition-smooth: cubic-bezier(0.22, 1, 0.36, 1); --transition-quick: cubic-bezier(0.4, 0, 0.2, 1); } /* ---------- Reset ---------- */ *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; } html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; } body { font-family: var(--font-body); font-weight: 400; font-size: 17px; line-height: 1.6; color: var(--color-ink); background-color: var(--color-bg); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; overflow-x: hidden; } img { max-width: 100%; height: auto; display: block; } a { color: inherit; text-decoration: none; transition: color 0.25s var(--transition-quick); } ul, ol { list-style: none; } button { font-family: inherit; cursor: pointer; border: none; background: none; } /* ---------- Typography ---------- */ h1, h2, h3, h4, h5, h6 { font-family: var(--font-display); font-weight: 500; line-height: 1.1; letter-spacing: -0.02em; color: var(--color-ink); } .h-display { font-family: var(--font-display); font-size: clamp(3rem, 8vw, 6.5rem); font-weight: 400; line-height: 0.95; letter-spacing: -0.035em; } .h-display em { font-style: italic; font-weight: 300; color: var(--color-accent); } .h-section { font-size: clamp(2.25rem, 5vw, 3.75rem); font-weight: 400; letter-spacing: -0.03em; line-height: 1.05; } .h-section em { font-style: italic; font-weight: 300; color: var(--color-accent); } .eyebrow { font-family: var(--font-body); font-size: 0.75rem; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-accent); display: inline-block; position: relative; padding-left: 2.5rem; } .eyebrow::before { content: ""; position: absolute; left: 0; top: 50%; width: 2rem; height: 1px; background-color: var(--color-accent); } .lead { font-size: 1.25rem; line-height: 1.55; color: var(--color-ink-soft); font-weight: 400; } /* ---------- Layout ---------- */ .container { width: 100%; max-width: var(--container-max); margin: 0 auto; padding: 0 2rem; } .container-narrow { max-width: var(--container-narrow); margin: 0 auto; padding: 0 2rem; } .container-text { max-width: var(--container-text); margin: 0 auto; padding: 0 2rem; } section { padding: var(--space-xl) 0; } /* ---------- Navigation ---------- */ .nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; padding: 1.5rem 0; background: rgba(247, 244, 239, 0.85); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid transparent; transition: border-color 0.3s ease, padding 0.3s ease; } .nav.scrolled { border-bottom-color: var(--color-line); padding: 1rem 0; } .nav__inner { display: flex; align-items: center; justify-content: space-between; max-width: var(--container-max); margin: 0 auto; padding: 0 2rem; } .nav__brand { font-family: var(--font-display); font-size: 1.4rem; font-weight: 500; letter-spacing: -0.02em; color: var(--color-ink); } .nav__brand em { font-style: italic; font-weight: 300; color: var(--color-accent); } .nav__links { display: flex; gap: 2.5rem; align-items: center; } .nav__link { font-size: 0.9rem; font-weight: 500; letter-spacing: 0.02em; color: var(--color-ink-soft); position: relative; padding: 0.25rem 0; } .nav__link::after { content: ""; position: absolute; left: 0; bottom: 0; width: 0; height: 1px; background-color: var(--color-accent); transition: width 0.3s var(--transition-quick); } .nav__link:hover { color: var(--color-ink); } .nav__link:hover::after, .nav__link.active::after { width: 100%; } .nav__cta { font-size: 0.85rem; font-weight: 600; letter-spacing: 0.02em; padding: 0.7rem 1.5rem; background-color: var(--color-ink); color: var(--color-bg); border-radius: 999px; transition: background-color 0.25s var(--transition-quick), transform 0.25s var(--transition-quick); } .nav__cta:hover { background-color: var(--color-accent); transform: translateY(-1px); } .nav__toggle { display: none; width: 28px; height: 28px; flex-direction: column; justify-content: center; gap: 5px; } .nav__toggle span { display: block; width: 100%; height: 1.5px; background-color: var(--color-ink); transition: transform 0.3s var(--transition-quick); } /* ---------- Buttons ---------- */ .btn { display: inline-flex; align-items: center; gap: 0.65rem; padding: 1rem 2rem; font-family: var(--font-body); font-size: 0.95rem; font-weight: 600; letter-spacing: 0.02em; border-radius: 999px; cursor: pointer; transition: all 0.3s var(--transition-quick); border: 1px solid transparent; } .btn--primary { background-color: var(--color-ink); color: var(--color-bg); } .btn--primary:hover { background-color: var(--color-accent); transform: translateY(-2px); box-shadow: 0 10px 30px rgba(184, 115, 42, 0.25); } .btn--secondary { background: transparent; color: var(--color-ink); border-color: var(--color-ink); } .btn--secondary:hover { background-color: var(--color-ink); color: var(--color-bg); } .btn--accent { background-color: var(--color-accent); color: white; } .btn--accent:hover { background-color: var(--color-accent-dark); transform: translateY(-2px); } .btn__arrow { display: inline-block; transition: transform 0.3s var(--transition-quick); } .btn:hover .btn__arrow { transform: translateX(4px); } /* ---------- Hero ---------- */ .hero { min-height: 100vh; display: flex; align-items: center; position: relative; padding: 9rem 0 4rem; overflow: hidden; } .hero__bg { position: absolute; inset: 0; z-index: 0; opacity: 0.4; pointer-events: none; } .hero__bg::before { content: ""; position: absolute; top: -20%; right: -10%; width: 60vw; height: 60vw; border-radius: 50%; background: radial-gradient(circle at center, rgba(184, 115, 42, 0.15) 0%, rgba(184, 115, 42, 0.05) 40%, transparent 70%); filter: blur(40px); } .hero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.2fr 1fr; gap: 4rem; align-items: center; max-width: var(--container-max); margin: 0 auto; padding: 0 2rem; } .hero__content { animation: fadeUp 1s var(--transition-smooth); } .hero__eyebrow { margin-bottom: 1.5rem; } .hero__title { margin-bottom: 2rem; } .hero__lead { margin-bottom: 2.5rem; max-width: 32rem; } .hero__cta-group { display: flex; gap: 1rem; flex-wrap: wrap; } .hero__visual { position: relative; aspect-ratio: 4/5; border-radius: 4px; overflow: hidden; background: linear-gradient(135deg, var(--color-ink) 0%, var(--color-ink-soft) 100%); animation: fadeUp 1s var(--transition-smooth) 0.2s both; } .hero__visual::before { content: ""; position: absolute; inset: 0; background: linear-gradient(45deg, rgba(184, 115, 42, 0.3) 0%, transparent 60%); z-index: 1; } .hero__visual::after { content: "MP"; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); font-family: var(--font-display); font-size: clamp(6rem, 14vw, 11rem); font-weight: 300; color: rgba(247, 244, 239, 0.92); letter-spacing: -0.05em; z-index: 2; font-style: italic; } .hero__visual-label { position: absolute; bottom: 2rem; left: 2rem; z-index: 3; color: var(--color-bg); font-size: 0.75rem; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 500; } .hero__scroll { position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--color-ink-muted); display: flex; flex-direction: column; align-items: center; gap: 0.5rem; z-index: 5; } .hero__scroll::after { content: ""; width: 1px; height: 30px; background-color: var(--color-ink-muted); animation: scrollPulse 2s ease-in-out infinite; } /* ---------- Section: Intro ---------- */ .intro { background-color: var(--color-bg-alt); position: relative; } .intro__grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 4rem; align-items: start; } .intro__heading { position: sticky; top: 8rem; } .intro__text p { font-size: 1.25rem; line-height: 1.65; color: var(--color-ink-soft); margin-bottom: 1.5rem; } .intro__text p:first-child::first-letter { font-family: var(--font-display); font-size: 4.5rem; font-weight: 400; float: left; line-height: 0.9; margin: 0.3rem 0.7rem 0 0; color: var(--color-accent); } /* ---------- Stats Bar ---------- */ .stats { background-color: var(--color-ink); color: var(--color-bg); padding: 5rem 0; } .stats__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 3rem; } .stat { text-align: center; } .stat__number { font-family: var(--font-display); font-size: clamp(2.5rem, 5vw, 4rem); font-weight: 400; line-height: 1; margin-bottom: 0.5rem; color: var(--color-accent-soft); } .stat__label { font-size: 0.85rem; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(247, 244, 239, 0.7); font-weight: 500; } /* ---------- Topics ---------- */ .topics__header { margin-bottom: 5rem; max-width: 50rem; } .topics__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background-color: var(--color-line); border-top: 1px solid var(--color-line); border-bottom: 1px solid var(--color-line); } .topic { background-color: var(--color-bg); padding: 3rem 2.5rem; position: relative; transition: background-color 0.3s var(--transition-quick); cursor: pointer; } .topic:hover { background-color: var(--color-bg-alt); } .topic__number { font-family: var(--font-display); font-size: 0.95rem; font-style: italic; color: var(--color-accent); margin-bottom: 1.5rem; } .topic__title { font-size: 1.65rem; font-weight: 500; margin-bottom: 1rem; line-height: 1.15; } .topic__description { color: var(--color-ink-soft); font-size: 1rem; line-height: 1.6; margin-bottom: 1.5rem; } .topic__arrow { font-size: 1rem; color: var(--color-accent); transition: transform 0.3s var(--transition-quick); display: inline-block; } .topic:hover .topic__arrow { transform: translateX(6px); } /* ---------- Testimonials ---------- */ .testimonials { background-color: var(--color-bg-alt); } .testimonials__header { text-align: center; margin-bottom: 5rem; } .testimonials__header .eyebrow { padding-left: 0; } .testimonials__header .eyebrow::before { display: none; } .testimonial { max-width: var(--container-narrow); margin: 0 auto; text-align: center; } .testimonial__quote { font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2.25rem); font-weight: 400; line-height: 1.4; color: var(--color-ink); margin-bottom: 2.5rem; letter-spacing: -0.015em; } .testimonial__quote::before { content: """; font-size: 4rem; line-height: 0.5; color: var(--color-accent); vertical-align: -0.5em; margin-right: 0.5rem; font-style: italic; } .testimonial__attribution { display: inline-block; } .testimonial__name { font-weight: 600; font-size: 1rem; color: var(--color-ink); margin-bottom: 0.25rem; } .testimonial__role { font-size: 0.85rem; color: var(--color-ink-muted); letter-spacing: 0.05em; } /* ---------- Press Logos ---------- */ .press { padding: 4rem 0; border-top: 1px solid var(--color-line); border-bottom: 1px solid var(--color-line); } .press__label { font-size: 0.75rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--color-ink-muted); text-align: center; margin-bottom: 2.5rem; font-weight: 600; } .press__logos { display: flex; justify-content: space-around; align-items: center; flex-wrap: wrap; gap: 2.5rem; } .press__logo { font-family: var(--font-display); font-size: 1.5rem; font-style: italic; color: var(--color-ink-muted); font-weight: 400; letter-spacing: -0.02em; opacity: 0.6; transition: opacity 0.3s ease; } .press__logo:hover { opacity: 1; } /* ---------- CTA Block ---------- */ .cta-block { background-color: var(--color-ink); color: var(--color-bg); padding: var(--space-xl) 0; position: relative; overflow: hidden; } .cta-block::before { content: ""; position: absolute; top: -50%; right: -20%; width: 70vw; height: 70vw; border-radius: 50%; background: radial-gradient(circle at center, rgba(184, 115, 42, 0.25) 0%, transparent 60%); filter: blur(40px); pointer-events: none; } .cta-block__inner { position: relative; z-index: 1; text-align: center; max-width: 50rem; margin: 0 auto; padding: 0 2rem; } .cta-block .h-section { color: var(--color-bg); margin-bottom: 1.5rem; } .cta-block .h-section em { color: var(--color-accent-soft); } .cta-block__text { font-size: 1.2rem; color: rgba(247, 244, 239, 0.85); margin-bottom: 2.5rem; line-height: 1.6; } /* ---------- Forms ---------- */ .form { display: grid; gap: 1.75rem; } .form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.75rem; } .form__field { display: flex; flex-direction: column; } .form__label { font-size: 0.8rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-ink-soft); margin-bottom: 0.6rem; } .form__input, .form__textarea, .form__select { font-family: var(--font-body); font-size: 1rem; padding: 1rem 1.25rem; border: 1px solid var(--color-line); background-color: var(--color-bg); color: var(--color-ink); border-radius: 4px; transition: border-color 0.25s var(--transition-quick); } .form__input:focus, .form__textarea:focus, .form__select:focus { outline: none; border-color: var(--color-accent); } .form__textarea { min-height: 140px; resize: vertical; font-family: var(--font-body); } .form__note { background-color: var(--color-bg-alt); border-left: 3px solid var(--color-accent); padding: 1.25rem 1.5rem; font-size: 0.95rem; color: var(--color-ink-soft); line-height: 1.55; border-radius: 0 4px 4px 0; } .form__note strong { color: var(--color-ink); } .form__submit { justify-self: start; } /* ---------- Booking Page Specific ---------- */ .booking-process { padding: var(--space-xl) 0; background-color: var(--color-bg-alt); } .process__steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 3rem; margin-top: 4rem; } .process__step { position: relative; } .process__step-num { font-family: var(--font-display); font-size: 4rem; font-weight: 300; font-style: italic; color: var(--color-accent); line-height: 1; margin-bottom: 1.5rem; } .process__step-title { font-size: 1.35rem; font-weight: 500; margin-bottom: 0.75rem; } .process__step-text { color: var(--color-ink-soft); font-size: 1rem; line-height: 1.55; } /* ---------- Contact Page ---------- */ .contact-info { display: grid; grid-template-columns: repeat(3, 1fr); gap: 3rem; margin-top: 4rem; } .contact-card { text-align: center; padding: 2.5rem 2rem; background-color: var(--color-bg-alt); border-radius: 4px; } .contact-card__icon { width: 56px; height: 56px; margin: 0 auto 1.5rem; display: flex; align-items: center; justify-content: center; background-color: var(--color-ink); color: var(--color-bg); border-radius: 50%; font-size: 1.5rem; } .contact-card__label { font-size: 0.8rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--color-ink-muted); margin-bottom: 0.5rem; font-weight: 600; } .contact-card__value { font-family: var(--font-display); font-size: 1.4rem; font-weight: 400; color: var(--color-ink); margin-bottom: 0.5rem; } .contact-card__value a { color: inherit; border-bottom: 1px solid transparent; transition: border-color 0.25s var(--transition-quick); } .contact-card__value a:hover { border-color: var(--color-accent); } /* ---------- Footer ---------- */ .footer { background-color: var(--color-ink); color: var(--color-bg); padding: 5rem 0 2rem; } .footer__top { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; padding-bottom: 3rem; border-bottom: 1px solid rgba(247, 244, 239, 0.12); margin-bottom: 2rem; } .footer__brand { font-family: var(--font-display); font-size: 1.6rem; font-weight: 400; margin-bottom: 1.25rem; } .footer__brand em { font-style: italic; color: var(--color-accent-soft); } .footer__tagline { color: rgba(247, 244, 239, 0.65); font-size: 0.95rem; max-width: 22rem; line-height: 1.6; } .footer__heading { font-family: var(--font-body); font-size: 0.8rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--color-accent-soft); margin-bottom: 1.5rem; font-weight: 600; } .footer__links { display: flex; flex-direction: column; gap: 0.65rem; } .footer__link { color: rgba(247, 244, 239, 0.7); font-size: 0.95rem; transition: color 0.25s var(--transition-quick); } .footer__link:hover { color: var(--color-accent-soft); } .footer__bottom { display: flex; justify-content: space-between; align-items: center; color: rgba(247, 244, 239, 0.5); font-size: 0.85rem; } .footer__bottom a { color: rgba(247, 244, 239, 0.7); transition: color 0.25s var(--transition-quick); } .footer__bottom a:hover { color: var(--color-accent-soft); } /* ---------- Page Header (Inner Pages) ---------- */ .page-header { padding: 10rem 0 5rem; background-color: var(--color-bg-alt); position: relative; } .page-header__inner { max-width: var(--container-max); margin: 0 auto; padding: 0 2rem; } .page-header__title { font-size: clamp(2.5rem, 6vw, 5rem); margin-bottom: 1.5rem; font-weight: 400; letter-spacing: -0.03em; line-height: 1; } .page-header__title em { font-style: italic; color: var(--color-accent); font-weight: 300; } .page-header__lead { font-size: 1.25rem; color: var(--color-ink-soft); max-width: 40rem; line-height: 1.55; } /* ---------- About Page ---------- */ .bio { padding: var(--space-xl) 0; } .bio__grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 5rem; align-items: start; } .bio__image { position: sticky; top: 8rem; aspect-ratio: 3/4; background: linear-gradient(135deg, var(--color-ink) 0%, var(--color-ink-soft) 100%); border-radius: 4px; position: relative; overflow: hidden; } .bio__image::after { content: "MP"; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 8rem; font-style: italic; color: rgba(247, 244, 239, 0.85); font-weight: 300; } .bio__text p { font-size: 1.15rem; line-height: 1.7; color: var(--color-ink-soft); margin-bottom: 1.5rem; } .bio__text h3 { font-size: 1.5rem; margin: 3rem 0 1.25rem; font-weight: 500; } .bio__text h3:first-child { margin-top: 0; } /* ---------- Animations ---------- */ @keyframes fadeUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } } @keyframes scrollPulse { 0%, 100% { transform: scaleY(0.3); transform-origin: top; opacity: 0.4; } 50% { transform: scaleY(1); transform-origin: top; opacity: 1; } } .reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.8s var(--transition-smooth), transform 0.8s var(--transition-smooth); } .reveal.in-view { opacity: 1; transform: translateY(0); } /* ---------- Responsive ---------- */ @media (max-width: 968px) { section { padding: 5rem 0; } .hero__inner, .intro__grid, .bio__grid { grid-template-columns: 1fr; gap: 3rem; } .hero { padding: 7rem 0 4rem; min-height: auto; } .hero__visual { max-width: 24rem; margin: 0 auto; } .intro__heading, .bio__image { position: static; } .topics__grid { grid-template-columns: 1fr; } .stats__grid { grid-template-columns: repeat(2, 1fr); gap: 2.5rem; } .process__steps, .contact-info { grid-template-columns: 1fr; gap: 2rem; } .form__row { grid-template-columns: 1fr; gap: 1.75rem; } .footer__top { grid-template-columns: 1fr 1fr; gap: 2.5rem; } .footer__bottom { flex-direction: column; gap: 1rem; text-align: center; } .nav__links { display: none; position: absolute; top: 100%; left: 0; right: 0; background: var(--color-bg); flex-direction: column; padding: 2rem; gap: 1.5rem; border-bottom: 1px solid var(--color-line); } .nav__links.active { display: flex; } .nav__toggle { display: flex; } .nav__cta { align-self: stretch; text-align: center; } } @media (max-width: 600px) { .container, .container-narrow, .container-text, .nav__inner, .hero__inner, .cta-block__inner, .page-header__inner { padding-left: 1.25rem; padding-right: 1.25rem; } .topic { padding: 2rem 1.5rem; } .stats__grid { grid-template-columns: 1fr; gap: 2rem; } .footer__top { grid-template-columns: 1fr; } .hero__cta-group { flex-direction: column; align-items: stretch; } .btn { justify-content: center; } }