.services {
background:
linear-gradient(135deg, rgba(242, 161, 163, 0.15), transparent 32rem),
var(--paper-warm);
}
.services-grid {
display: grid;
gap: 1rem;
grid-template-columns: repeat(3, minmax(0, 1fr));
}
.service-card {
background: rgba(255, 255, 255, 0.78);
border: 1px solid rgba(34, 24, 51, 0.08);
border-radius: var(--radius-md);
box-shadow: var(--shadow-sm);
min-height: 20rem;
overflow: hidden;
padding: 1rem;
position: relative;
transition: transform var(--ease), box-shadow var(--ease), background-color var(--ease);
}
.service-card:hover,
.service-card:focus-within,
.service-card.is-open {
background: var(--white);
box-shadow: var(--shadow-lg);
transform: translateY(-0.55rem);
}
.service-card-top {
display: flex;
justify-content: space-between;
}
.service-visual {
align-items: center;
border-radius: 1.1rem;
display: flex;
height: 7.4rem;
justify-content: center;
overflow: hidden;
position: relative;
width: 7.4rem;
}
.service-visual::before,
.service-visual::after {
border: 1px solid rgba(255, 255, 255, 0.55);
border-radius: 50%;
content: "";
height: 7rem;
position: absolute;
width: 7rem;
}
.service-visual::after {
height: 4.4rem;
width: 4.4rem;
}
.service-visual svg {
fill: none;
height: 3.5rem;
position: relative;
stroke: var(--white);
stroke-linecap: round;
stroke-linejoin: round;
stroke-width: 2.3;
width: 3.5rem;
z-index: 1;
}
.visual-coral { background: linear-gradient(135deg, #ff9877, var(--coral-dark)); }
.visual-violet { background: linear-gradient(135deg, #a793e0, var(--violet)); }
.visual-sun { background: linear-gradient(135deg, #f8d87f, #e49c2e); }
.visual-mint { background: linear-gradient(135deg, #9bdac6, #43a68d); }
.visual-blue { background: linear-gradient(135deg, #a2c8f1, #4e83c4); }
.visual-rose { background: linear-gradient(135deg, #f6b0b8, #d96177); }
.service-number {
color: rgba(34, 24, 51, 0.25);
font-family: var(--font-display);
font-size: 1.5rem;
}
.service-card h3 {
font-family: var(--font-body);
font-size: 1.3rem;
font-weight: 800;
letter-spacing: -0.05em;
line-height: 1.18;
margin-top: 1.25rem;
max-width: 16rem;
}
.service-card p {
color: var(--ink-soft);
font-size: 0.87rem;
line-height: 1.6;
margin-top: 0.65rem;
min-height: 4.2rem;
}
.service-toggle {
align-items: center;
background: transparent;
color: var(--coral-dark);
cursor: pointer;
display: flex;
font-size: 0.68rem;
font-weight: 800;
gap: 0.6rem;
letter-spacing: 0.12em;
bottom: 1.35rem;
left: 1.5rem;
position: absolute;
text-transform: uppercase;
z-index: 4;
}
.service-toggle span {
font-size: 1.2rem;
transition: transform var(--ease);
}
.service-card.is-open .service-toggle span {
transform: rotate(45deg);
}
.service-card:hover .service-toggle,
.service-card:focus-within .service-toggle,
.service-card.is-open .service-toggle {
color: var(--sun);
}
.service-details {
background: var(--violet-deep);
border-radius: 1rem;
bottom: 0.8rem;
color: rgba(255, 255, 255, 0.82);
display: flex;
flex-direction: column;
justify-content: center;
left: 0.8rem;
opacity: 0;
padding: 1rem 1rem 3.6rem;
pointer-events: none;
position: absolute;
right: 0.8rem;
top: 0.8rem;
transform: translateY(0.8rem);
transition: opacity var(--ease), transform var(--ease);
z-index: 3;
}
.service-card:hover .service-details,
.service-card:focus-within .service-details,
.service-card.is-open .service-details {
opacity: 1;
transform: translateY(0);
}
.service-details li {
border-bottom: 1px solid var(--line-light);
font-size: 0.77rem;
padding: 0.75rem 0.2rem;
}
.service-details li:last-child {
border-bottom: 0;
}
.service-fit {
color: var(--ink-soft);
font-size: 0.84rem;
margin-top: 1.6rem;
text-align: center;
}
.service-fit strong {
color: var(--ink);
}
.trust {
background: var(--violet-deep);
color: var(--white);
overflow: hidden;
}
.trust-glow {
background: var(--violet);
border-radius: 50%;
filter: blur(100px);
height: 32rem;
opacity: 0.25;
pointer-events: none;
position: absolute;
right: -10rem;
top: -10rem;
width: 32rem;
}
.trust-grid {
align-items: center;
display: grid;
gap: clamp(2rem, 6vw, 6.5rem);
grid-template-columns: 0.85fr 1.15fr;
}
.trust-copy p:not(.eyebrow) {
color: rgba(255, 255, 255, 0.68);
margin-top: 1.5rem;
max-width: 33rem;
}
.trust-copy .text-link {
color: var(--white);
margin-top: 2rem;
}
.trust-cards {
display: grid;
gap: 1rem;
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.trust-card {
background: rgba(255, 255, 255, 0.07);
border: 1px solid var(--line-light);
border-radius: var(--radius-md);
min-height: 14rem;
padding: 1.5rem;
transition: background-color var(--ease), border-color var(--ease), transform var(--ease);
}
.trust-card:hover {
background: rgba(255, 255, 255, 0.12);
border-color: rgba(243, 189, 87, 0.5);
transform: translateY(-0.4rem);
}
.trust-card span {
color: var(--sun);
font-size: 0.74rem;
font-weight: 800;
letter-spacing: 0.14em;
}
.trust-card h3 {
font-size: 2rem;
margin-top: 2rem;
}
.trust-card p {
color: rgba(255, 255, 255, 0.62);
font-size: 0.82rem;
line-height: 1.65;
margin-top: 0.75rem;
}
.audience {
background:
radial-gradient(circle at 5% 15%, rgba(105, 191, 166, 0.2), transparent 18rem),
radial-gradient(circle at 95% 88%, rgba(242, 161, 163, 0.2), transparent 20rem),
var(--paper);
}
.audience-grid {
display: grid;
gap: 1rem;
grid-template-columns: repeat(3, minmax(0, 1fr));
margin-top: 3.8rem;
}
.audience-card {
background: rgba(255, 255, 255, 0.72);
border: 1px solid rgba(34, 24, 51, 0.09);
border-radius: var(--radius-md);
min-height: 13rem;
overflow: hidden;
padding: 1.4rem;
position: relative;
transition: background-color var(--ease), box-shadow var(--ease), transform var(--ease);
}
.audience-card::after {
background: var(--sun);
border-radius: 50%;
bottom: -3rem;
content: "";
height: 6rem;
opacity: 0.34;
position: absolute;
right: -3rem;
transition: transform var(--ease);
width: 6rem;
}
.audience-card:nth-child(2n)::after {
background: var(--mint);
}
.audience-card:nth-child(3n)::after {
background: var(--rose);
}
.audience-card:hover {
background: var(--white);
box-shadow: var(--shadow-sm);
transform: translateY(-0.4rem);
}
.audience-card:hover::after {
transform: scale(1.35);
}
.audience-icon {
color: var(--coral-dark);
font-family: var(--font-display);
font-size: 1.7rem;
}
.audience-card h3 {
font-size: 1.8rem;
margin-top: 2.2rem;
max-width: 17rem;
}
.audience-card p {
color: var(--ink-soft);
font-size: 0.82rem;
line-height: 1.6;
margin-top: 0.75rem;
max-width: 18rem;
}
.process {
background: var(--paper-warm);
}
.process-list {
border-top: 1px solid var(--line);
}
.process-item {
align-items: start;
border-bottom: 1px solid var(--line);
display: grid;
gap: 2rem;
grid-template-columns: 5rem 1fr;
padding-block: 1.5rem;
transition: background-color var(--ease), padding-inline var(--ease);
}
.process-item:hover {
background: rgba(255, 255, 255, 0.52);
padding-inline: 1rem;
}
.process-item > span {
color: var(--coral-dark);
font-family: var(--font-display);
font-size: 2.4rem;
}
.process-item h3 {
font-size: 2.15rem;
}
.process-item p {
color: var(--ink-soft);
font-size: 0.9rem;
margin-top: 0.55rem;
max-width: 42rem;
}
.proof {
background: var(--violet-dark);
color: var(--white);
overflow: hidden;
}
.proof-orb {
background: var(--coral);
border-radius: 50%;
filter: blur(120px);
height: 40rem;
opacity: 0.14;
pointer-events: none;
position: absolute;
right: -17rem;
top: 4rem;
width: 40rem;
}
.proof-intro p:not(.eyebrow) {
color: rgba(255, 255, 255, 0.64);
}
.proof-counts {
border-block: 1px solid var(--line-light);
display: grid;
grid-template-columns: repeat(3, 1fr);
margin-top: 3.5rem;
}
.proof-counts div {
padding: 1.4rem;
text-align: center;
}
.proof-counts div + div {
border-left: 1px solid var(--line-light);
}
.proof-counts strong,
.proof-counts span {
display: block;
}
.proof-counts strong {
color: var(--sun);
font-family: var(--font-display);
font-size: 3.4rem;
font-weight: 400;
line-height: 1;
}
.proof-counts span {
color: rgba(255, 255, 255, 0.56);
font-size: 0.67rem;
font-weight: 800;
letter-spacing: 0.14em;
margin-top: 0.5rem;
text-transform: uppercase;
}
.collaboration-groups {
display: grid;
gap: 2.5rem;
margin-top: 4.5rem;
}
.group-heading {
align-items: baseline;
display: flex;
justify-content: space-between;
margin-bottom: 1rem;
}
.group-heading p {
color: var(--sun);
font-family: var(--font-display);
font-size: 2.3rem;
}
.group-heading span {
color: rgba(255, 255, 255, 0.5);
font-size: 0.65rem;
font-weight: 800;
letter-spacing: 0.14em;
text-transform: uppercase;
}
.collaboration-grid {
display: grid;
gap: 0.7rem;
grid-template-columns: repeat(4, minmax(0, 1fr));
}
.collaboration-grid a {
background: rgba(255, 255, 255, 0.07);
border: 1px solid var(--line-light);
border-radius: 1rem;
color: var(--white);
font-size: 0.82rem;
font-weight: 800;
min-height: 5.5rem;
padding: 1rem;
transition: background-color var(--ease), border-color var(--ease), transform var(--ease);
}
.collaboration-grid a:hover {
background: rgba(255, 255, 255, 0.13);
border-color: rgba(243, 189, 87, 0.58);
transform: translateY(-0.25rem);
}
.collaboration-grid small {
color: rgba(255, 255, 255, 0.5);
display: block;
font-size: 0.66rem;
font-weight: 600;
margin-top: 0.35rem;
}
.story-grid {
display: grid;
gap: 1rem;
grid-template-columns: 1.5fr 1fr 1fr;
margin-top: 5.5rem;
}
.story-card {
background: rgba(255, 255, 255, 0.08);
border: 1px solid var(--line-light);
border-radius: var(--radius-md);
overflow: hidden;
transition: transform var(--ease), background-color var(--ease);
}
.story-card:hover {
background: rgba(255, 255, 255, 0.12);
transform: translateY(-0.45rem);
}
.story-card img {
aspect-ratio: 1.16;
object-fit: cover;
width: 100%;
}
.story-card div {
padding: 1.2rem;
}
.story-card p {
color: var(--sun);
font-size: 0.65rem;
font-weight: 800;
letter-spacing: 0.12em;
text-transform: uppercase;
}
.story-card h3 {
font-family: var(--font-body);
font-size: 1.05rem;
font-weight: 700;
letter-spacing: -0.04em;
line-height: 1.4;
margin-top: 0.65rem;
}
.story-card a {
color: rgba(255, 255, 255, 0.65);
display: inline-flex;
font-size: 0.68rem;
font-weight: 800;
gap: 0.7rem;
letter-spacing: 0.1em;
margin-top: 1rem;
text-transform: uppercase;
}
.story-card a span {
color: var(--sun);
font-size: 1.1rem;
}
.carousel-block {
background: rgba(255, 255, 255, 0.055);
border: 1px solid var(--line-light);
border-radius: var(--radius-lg);
margin-top: 5.5rem;
overflow: hidden;
padding: clamp(1.2rem, 4vw, 2.8rem);
}
.carousel-heading {
align-items: end;
display: flex;
justify-content: space-between;
}
.carousel-heading h3 {
font-size: clamp(2.9rem, 5vw, 4.8rem);
}
.carousel-controls {
display: flex;
gap: 0.6rem;
}
.carousel-button {
align-items: center;
background: transparent;
border: 1px solid var(--line-light);
border-radius: 50%;
color: var(--white);
cursor: pointer;
display: flex;
font-size: 1.1rem;
height: 3.2rem;
justify-content: center;
transition: background-color var(--ease), border-color var(--ease), transform var(--ease);
width: 3.2rem;
}
.carousel-button:hover {
background: var(--coral);
border-color: var(--coral);
transform: translateY(-0.2rem);
}
.carousel-window {
margin-top: 8.5rem;
overflow: visible;
touch-action: pan-y;
}
.carousel-track {
display: flex;
gap: 1rem;
transition: transform 650ms cubic-bezier(0.22, 1, 0.36, 1);
will-change: transform;
}
.perspective-card {
background: var(--paper);
border-radius: 1.3rem;
color: var(--ink);
display: grid;
flex: 0 0 min(78vw, 49rem);
grid-template-columns: 14rem 1fr;
min-height: 26rem;
opacity: 0.5;
overflow: visible;
position: relative;
transform: scale(0.94);
transition: opacity var(--ease-slow), transform var(--ease-slow);
}
.perspective-card.is-active {
opacity: 1;
transform: scale(1);
z-index: 5;
}
.perspective-video {
background: var(--ink);
min-height: 100%;
position: relative;
border-radius: 1.3rem 0 0 1.3rem;
overflow: hidden;
}
.perspective-video video {
height: 100%;
object-fit: cover;
width: 100%;
}
.mute-button {
align-items: center;
background: rgba(34, 24, 51, 0.85);
backdrop-filter: blur(8px);
-webkit-backdrop-filter: blur(8px);
border: 1px solid rgba(255, 255, 255, 0.2);
border-radius: 999px;
bottom: 1rem;
color: var(--white);
cursor: pointer;
display: flex;
font-size: 0.75rem;
font-weight: 700;
height: 2.4rem;
justify-content: center;
padding: 0 1.2rem;
position: absolute;
right: 1rem;
z-index: 20;
width: auto;
}
.perspective-content {
display: flex;
flex-direction: column;
justify-content: space-between;
padding: clamp(1.3rem, 4vw, 2.3rem);
}
.perspective-label {
color: var(--coral-dark);
font-size: 0.64rem;
font-weight: 800;
letter-spacing: 0.14em;
text-transform: uppercase;
}
.perspective-content blockquote {
font-family: var(--font-display);
font-size: clamp(1.4rem, 2.4vw, 2rem);
line-height: 1.18;
margin: 1rem 0;
}
.perspective-profile {
align-items: center;
border-top: 1px solid var(--line);
display: flex;
justify-content: space-between;
padding-top: 1rem;
}
.perspective-profile-info {
display: flex;
flex-direction: column;
}
.perspective-profile strong {
display: block;
font-size: 0.88rem;
}
.perspective-profile span {
color: var(--ink-soft);
display: block;
font-size: 0.7rem;
margin-top: 0.2rem;
}
.carousel-meta {
align-items: center;
display: flex;
justify-content: space-between;
margin-top: 1.4rem;
}
.carousel-dots {
display: flex;
gap: 0.45rem;
}
.carousel-dot {
background: rgba(255, 255, 255, 0.22);
border-radius: 999px;
cursor: pointer;
height: 0.45rem;
padding: 0;
transition: background-color var(--ease), width var(--ease);
width: 0.45rem;
}
.carousel-dot.is-active {
background: var(--sun);
width: 1.8rem;
}
.carousel-meta p {
color: rgba(255, 255, 255, 0.54);
font-size: 0.7rem;
font-weight: 800;
letter-spacing: 0.14em;
}
.carousel-current {
color: var(--sun);
}
.instagram-followers-card {
align-items: center;
background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
border-radius: 0.5rem;
color: var(--white);
display: flex;
gap: 0.65rem;
padding: 0.55rem 0.85rem;
text-decoration: none;
transition: transform var(--ease), box-shadow var(--ease);
}
.instagram-followers-card:hover {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(204, 35, 102, 0.25);
}
.instagram-followers-text {
display: flex;
flex-direction: column;
}
.instagram-followers-card span {
color: var(--white);
display: block;
font-size: 0.78rem;
line-height: 1.1;
margin: 0;
}
.instagram-followers-card .instagram-followers-count {
font-size: 0.68rem;
font-weight: 800;
opacity: 0.95;
margin-top: 0.2rem;
text-transform: uppercase;
}
.contact {
background:
radial-gradient(circle at 15% 20%, rgba(243, 189, 87, 0.27), transparent 22rem),
radial-gradient(circle at 85% 90%, rgba(128, 100, 201, 0.15), transparent 24rem),
var(--paper);
}
.contact-grid {
align-items: center;
display: grid;
gap: clamp(2rem, 7vw, 7rem);
grid-template-columns: 0.95fr 1.05fr;
}
.contact-copy h2 {
font-size: clamp(3rem, 5.5vw, 4.8rem);
}
.contact-copy > p:not(.eyebrow) {
color: var(--ink-soft);
margin-top: 1.5rem;
max-width: 34rem;
}
.contact-profile {
align-items: center;
display: flex;
gap: 0.8rem;
margin-top: 2rem;
}
.contact-profile img {
border: 3px solid var(--white);
border-radius: 50%;
box-shadow: var(--shadow-sm);
height: 4.5rem;
object-fit: cover;
width: 4.5rem;
}
.contact-profile strong,
.contact-profile span {
display: block;
}
.contact-profile strong {
font-size: 1.15rem;
}
.contact-profile span {
color: var(--ink-soft);
font-size: 0.85rem;
margin-top: 0.2rem;
}
.direct-contact {
display: flex;
flex-direction: column;
gap: 0.35rem;
margin-top: 1.5rem;
}
.direct-contact a {
color: var(--coral-dark);
font-size: 0.78rem;
font-weight: 800;
width: fit-content;
}
.direct-contact a:hover {
color: var(--violet);
}
.contact-form {
background: rgba(255, 255, 255, 0.82);
border: 1px solid rgba(34, 24, 51, 0.09);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-lg);
display: grid;
gap: 0.85rem;
grid-template-columns: repeat(2, minmax(0, 1fr));
padding: clamp(1.2rem, 4vw, 2.2rem);
}
.form-heading,
.form-message,
.form-submit,
.form-status {
grid-column: 1 / -1;
}
.form-heading {
margin-bottom: 0.4rem;
}
.form-heading span {
font-family: var(--font-display);
font-size: 2rem;
}
.form-heading p {
color: var(--ink-soft);
font-size: 0.74rem;
margin-top: 0.2rem;
}
.contact-form label span {
display: block;
font-size: 0.7rem;
font-weight: 800;
letter-spacing: 0.08em;
margin-bottom: 0.35rem;
text-transform: uppercase;
}
.contact-form input,
.contact-form textarea,
.contact-form select {
background: var(--paper);
border: 1px solid rgba(34, 24, 51, 0.12);
border-radius: 0.75rem;
color: var(--ink);
min-height: 3.1rem;
padding: 0.7rem 0.8rem;
transition: border-color var(--ease), box-shadow var(--ease);
width: 100%;
}
.contact-form textarea {
resize: vertical;
}
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus {
border-color: var(--coral);
box-shadow: 0 0 0 4px rgba(239, 106, 91, 0.14);
outline: 0;
}
.contact-form small {
color: var(--coral-dark);
display: none;
font-size: 0.68rem;
margin-top: 0.25rem;
}
.contact-form label.has-error small {
display: block;
}
.contact-form label.has-error input,
.contact-form label.has-error textarea {
border-color: var(--coral-dark);
}
.form-status {
color: var(--ink-soft);
font-size: 0.74rem;
min-height: 1.1rem;
text-align: center;
}
.floating-cta {
align-items: center;
background: var(--coral);
border: 4px solid var(--paper);
border-radius: 50%;
bottom: 1.2rem;
box-shadow: 0 12px 28px rgba(52, 34, 69, 0.22);
color: var(--white);
display: flex;
font-size: 0.66rem;
font-weight: 800;
height: 4.4rem;
justify-content: center;
letter-spacing: 0.1em;
line-height: 1.1;
position: fixed;
right: 1.2rem;
text-align: center;
text-transform: uppercase;
transition: background-color var(--ease), transform var(--ease);
width: 4.4rem;
z-index: 30;
}
.floating-cta:hover {
background: var(--violet);
transform: translateY(-0.35rem) rotate(-7deg);
}
.site-footer {
background: var(--violet-deep);
color: var(--white);
padding-block: 3rem 1.2rem;
}
.footer-grid,
.footer-base,
.footer-links {
align-items: center;
display: flex;
}
.footer-grid {
gap: 2rem;
justify-content: space-between;
}
.footer-brand {
color: var(--white);
}
.footer-grid p {
color: rgba(255, 255, 255, 0.55);
font-family: var(--font-display);
font-size: 1.25rem;
}
.footer-links {
gap: 1.15rem;
}
.footer-links a,
.footer-base p {
color: rgba(255, 255, 255, 0.58);
font-size: 0.65rem;
font-weight: 800;
letter-spacing: 0.09em;
text-transform: uppercase;
}
.footer-links a:hover,
.footer-base a:hover {
color: var(--sun);
}
.footer-base {
border-top: 1px solid var(--line-light);
justify-content: space-between;
margin-top: 2rem;
padding-top: 1rem;
}
@media (max-width: 1080px) {
.services-grid,
.audience-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.collaboration-grid {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
.story-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.story-large {
grid-column: 1 / -1;
}
}
@media (max-width: 820px) {
.container {
width: min(calc(100% - 2rem), var(--container));
}
.site-nav {
align-items: stretch;
background: rgba(255, 250, 245, 0.78);
-webkit-backdrop-filter: blur(18px);
backdrop-filter: blur(18px);
flex-direction: column;
inset: 0;
justify-content: center;
opacity: 0;
padding: 5rem 2rem 2rem;
pointer-events: none;
position: fixed;
transform: translateY(-1rem);
transition: opacity var(--ease), transform var(--ease);
z-index: 51;
}
.site-nav.is-open {
opacity: 1;
pointer-events: auto;
transform: translateY(0);
}
.site-nav a {
border-bottom: 1px solid var(--line);
font-family: var(--font-display);
font-size: 1.6rem;
font-weight: 400;
letter-spacing: -0.03em;
padding-block: 0.55rem;
text-transform: none;
}
.site-nav .nav-cta {
border-radius: 1rem;
font-family: var(--font-body);
font-size: 0.78rem;
font-weight: 800;
letter-spacing: 0.1em;
margin-top: 1rem;
padding: 1rem;
text-align: center;
text-transform: uppercase;
}
.menu-toggle {
display: block;
}
.menu-toggle.is-open span:nth-child(1) {
transform: translateY(7px) rotate(45deg);
}
.menu-toggle.is-open span:nth-child(2) {
opacity: 0;
}
.menu-toggle.is-open span:nth-child(3) {
transform: translateY(-7px) rotate(-45deg);
}
body.menu-open {
overflow: hidden;
}
body.menu-open .site-header {
background: transparent !important;
backdrop-filter: none !important;
-webkit-backdrop-filter: none !important;
box-shadow: none !important;
}
.hero {
min-height: auto;
padding-top: 8.5rem;
}
.hero-grid,
.trust-grid,
.contact-grid {
grid-template-columns: 1fr;
}
.hero-visual {
max-width: 18rem;
order: -1;
position: relative;
top: auto;
}
.hero-note-top {
left: -1rem;
}
.hero-note-bottom {
right: -0.6rem;
}
.hero-metrics {
margin-top: 2.7rem;
}
.split-intro {
align-items: start;
flex-direction: column;
gap: 1.2rem;
}
.trust-copy {
max-width: 38rem;
}
.collaboration-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.carousel-heading {
align-items: start;
flex-direction: column;
gap: 1.2rem;
}
}
@media (max-width: 560px) {
h1 {
font-size: clamp(3.65rem, 18vw, 5.1rem);
}
h2 {
font-size: clamp(2.8rem, 14vw, 4rem);
}
.section-shell {
padding-block: clamp(4.4rem, 18vw, 6rem);
}
.hero {
padding-top: 7.4rem;
}
.hero-frame {
padding: 0.55rem;
}
.hero-visual {
max-width: 16rem;
}
.hero-note-top {
left: -1rem;
top: 10%;
--note-scale: 0.75;
transform-origin: left top;
}
.hero-note-bottom {
bottom: 8%;
right: -0.6rem;
--note-scale: 0.7;
transform-origin: right bottom;
}
.hero-stamp {
bottom: 2rem;
left: -0.8rem;
--note-scale: 0.8;
transform-origin: center;
}
.hero-actions,
.hero-actions .button {
width: 100%;
}
.button-quiet {
min-height: 2.5rem;
}
.hero-metrics {
gap: 0.7rem;
justify-content: space-between;
}
.hero-metrics div {
padding-left: 0.65rem;
}
.hero-metrics dt {
font-size: 1.7rem;
}
.hero-metrics dd {
font-size: 0.54rem;
letter-spacing: 0.08em;
}
.services-grid,
.audience-grid,
.trust-cards,
.story-grid,
.contact-form {
grid-template-columns: 1fr;
}
.service-card {
min-height: 19rem;
}
.trust-card {
min-height: 12rem;
}
.proof-counts div {
padding: 1rem 0.4rem;
}
.proof-counts strong {
font-size: 2.8rem;
}
.proof-counts span {
font-size: 0.54rem;
letter-spacing: 0.07em;
}
.collaboration-grid {
gap: 0.55rem;
}
.collaboration-grid a {
font-size: 0.74rem;
min-height: 5rem;
padding: 0.8rem;
}
.perspective-card {
flex-basis: 100%;
grid-template-columns: 1fr;
grid-template-rows: auto 1fr;
}
.perspective-content blockquote {
font-size: 1.15rem;
margin: 0.75rem 0;
}
.perspective-profile {
align-items: flex-start;
flex-direction: column;
gap: 0.85rem;
}
.perspective-video {
aspect-ratio: 9 / 10;
min-height: auto;
border-radius: 1.3rem 1.3rem 0 0;
}
.perspective-video video {
object-position: var(--mobile-video-offset, center);
}
.carousel-block {
position: relative;
padding-bottom: 6rem;
}
.carousel-controls {
display: flex;
position: absolute;
bottom: 1.5rem;
right: 1.2rem;
}
.footer-grid,
.footer-base {
align-items: start;
flex-direction: column;
gap: 0.8rem;
}
.footer-links {
flex-wrap: wrap;
}
}
.polaroid-wrapper{position:absolute;top:-3.5rem;right:-2rem;z-index:10;pointer-events:none}
.polaroid-hint{position:absolute;bottom:80%;right:80%;display:flex;flex-direction:column;align-items:center;gap:.2rem;color:rgba(255,255,255,.95);z-index:12;transform:rotate(5deg)}
.polaroid-hint span{font-family:var(--font-display);font-size:.95rem;font-style:italic;white-space:nowrap}
.polaroid-arrow{width:60px;height:44px;margin-left:.7rem;object-fit:contain;filter:brightness(0) invert(1) opacity(.95);transform:rotate(10deg) translateX(-3px)}
.polaroid-photo{background:#fff;padding:.5rem .5rem 1.8rem;border-radius:4px;box-shadow:0 8px 24px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.06);cursor:pointer;pointer-events:auto;transition:transform var(--ease),box-shadow var(--ease);width:145px;height:165px}
.polaroid-photo:hover{transform:scale(1.05) rotate(0deg)!important;box-shadow:0 12px 32px rgba(0,0,0,.15),0 4px 12px rgba(0,0,0,.1);z-index:11}
.polaroid-photo img{width:100%;height:100%;object-fit:cover;border-radius:2px}
.polaroid-modal{border:none;background:0 0;padding:0;margin:auto;max-width:90vw;max-height:90vh;overflow:visible}
.polaroid-modal::backdrop{background:rgba(34,24,51,.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;transition:opacity .3s ease}
.polaroid-modal[open]::backdrop{opacity:1}
.polaroid-modal-content{position:relative;display:flex;justify-content:center;align-items:center;opacity:0;transform:scale(.95);transition:opacity .4s cubic-bezier(.22,1,.36,1),transform .4s cubic-bezier(.22,1,.36,1)}
.polaroid-modal[open] .polaroid-modal-content{opacity:1;transform:scale(1)}
.polaroid-modal-img{background:#fff;padding:.8rem .8rem 2.4rem;border-radius:8px;box-shadow:0 24px 64px rgba(0,0,0,.2);max-height:85vh;max-width:100%;object-fit:contain}
.polaroid-modal-close{position:absolute;top:-1.2rem;right:-1.2rem;background:var(--white);color:var(--ink);border:none;border-radius:50%;width:3rem;height:3rem;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 4px 12px rgba(0,0,0,.15);transition:transform var(--ease),background var(--ease);z-index:2}
.polaroid-modal-close:hover{transform:scale(1.1);background:var(--paper)}
@media (max-width:820px){.polaroid-wrapper{transform:scale(.65);transform-origin:top right;right:1rem;top:1rem}}
@media (max-width:560px){.polaroid-wrapper{top:-6rem;right:-1.5rem;transform:scale(1.15);transform-origin:top right}.polaroid-hint{bottom:75%;right:70%;transform:scale(.85) rotate(5deg);transform-origin:bottom right}.polaroid-arrow{transform:rotate(10deg) translateX(-45px)}.polaroid-modal-img{padding:.5rem .5rem 1.8rem}.polaroid-modal-close{top:-3rem;right:0}}