.testimonial-section {
padding: 100px 0;
background-color: var(--bg-cream);
overflow: hidden; 
}
.testimonial-header {
display: flex;
justify-content: space-between;
align-items: flex-end;
margin-bottom: 48px;
}
.testimonial-scroll-hint {
display: flex;
align-items: center;
gap: 12px;
color: var(--primary-gold);
font-weight: 500;
font-size: 0.9rem;
text-transform: uppercase;
letter-spacing: 1px;
}
@media screen and (max-width: 768px) {
.testimonial-header {
flex-direction: column;
align-items: flex-start;
gap: 16px;
}
}
.testimonial-track {
display: flex;
gap: 24px;
overflow-x: auto;
padding-bottom: 40px; 
scroll-snap-type: x mandatory;
scroll-behavior: smooth;
scrollbar-width: none; 
-ms-overflow-style: none; 
}
.testimonial-track::-webkit-scrollbar {
display: none; 
}
.testimonial-card {
flex: 0 0 400px;
scroll-snap-align: start;
background: #fff;
border-radius: 16px;
padding: 40px;
display: flex;
flex-direction: column;
position: relative;
box-shadow: 0 10px 40px rgba(0,0,0,0.03);
border: 1px solid rgba(197, 168, 128, 0.15);
transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.testimonial-card:hover {
transform: translateY(-5px);
box-shadow: 0 15px 50px rgba(197, 168, 128, 0.1);
}
@media screen and (max-width: 479px) {
.testimonial-card {
flex: 0 0 85vw;
padding: 30px 24px;
}
}
.testimonial-quote-mark {
position: absolute;
top: 20px;
right: 30px;
font-size: 120px;
line-height: 1;
font-family: serif;
color: var(--primary-gold);
opacity: 0.15;
pointer-events: none;
}
.testimonial-stars {
color: var(--primary-gold);
font-size: 1.2rem;
letter-spacing: 2px;
margin-bottom: 24px;
}
.testimonial-text {
font-size: 1.15rem;
line-height: 1.6;
color: var(--text-dark);
flex: 1; 
margin-bottom: 40px;
font-style: italic;
}
.testimonial-author {
display: flex;
align-items: center;
gap: 16px;
margin-top: auto;
}
.testimonial-avatar {
width: 56px;
height: 56px;
border-radius: 50%;
object-fit: cover;
border: 2px solid var(--accent-gold);
}
.testimonial-name {
font-weight: 700;
font-size: 1.05rem;
color: var(--text-dark);
}
.testimonial-role {
font-size: 0.85rem;
color: #777;
text-transform: uppercase;
letter-spacing: 0.5px;
margin-top: 4px;
}
.ambiance-bento-grid {
display: grid;
grid-template-columns: repeat(6, 1fr);
grid-template-rows: repeat(2, minmax(240px, auto));
gap: 30px;
width: 100%;
}
.ambiance-bento-grid .team-card {
width: 100% !important;
margin: 0 !important;
display: flex;
flex-direction: column;
}
.ambiance-bento-grid .team-cover {
height: 100%;
width: 100%;
border-radius: 12px;
overflow: hidden;
margin-bottom: 20px;
}
.ambiance-bento-grid .team-cover img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.5s ease;
}
.ambiance-bento-grid .team-card:hover .team-cover img {
transform: scale(1.05);
}
.bento-1 {
grid-column: 1 / span 4;
grid-row: 1 / span 2;
}
.bento-1 .team-cover { min-height: 480px; }
.bento-2 {
grid-column: 5 / span 2;
grid-row: 1 / span 1;
}
.bento-2 .team-cover { min-height: 240px; }
.bento-3 {
grid-column: 5 / span 1;
grid-row: 2 / span 1;
}
.bento-3 .team-cover { min-height: 200px; }
.bento-4 {
grid-column: 6 / span 1;
grid-row: 2 / span 1;
}
.bento-4 .team-cover { min-height: 200px; }
.bento-1 .body-large {
font-size: 2.2rem !important;
line-height: 1.2;
margin-bottom: 8px;
}
@media screen and (max-width: 991px) {
.ambiance-bento-grid {
grid-template-columns: repeat(2, 1fr);
grid-template-rows: auto;
}
.bento-1 { grid-column: 1 / span 2; grid-row: 1; }
.bento-1 .team-cover { height: 350px; }
.bento-2 { grid-column: 1 / span 2; grid-row: 2; }
.bento-2 .team-cover { height: 300px; }
.bento-3, .bento-4 { grid-column: span 1; grid-row: 3; }
.bento-3 .team-cover, .bento-4 .team-cover { height: 220px; }
}
@media screen and (max-width: 767px) {
.ambiance-bento-grid {
display: flex;
flex-direction: column;
gap: 30px;
}
.bento-1 .team-cover,
.bento-2 .team-cover,
.bento-3 .team-cover,
.bento-4 .team-cover {
height: 250px;
}
}
.menu-showcase-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 40px;
width: 100%;
}
.menu-showcase-grid .menu-card {
width: 100%;
}
.menu-showcase-grid .blog-card {
flex-direction: column !important;
align-items: stretch !important;
gap: 24px !important;
padding: 0 !important;
border: none !important;
background: transparent !important;
height: 100%;
}
.menu-showcase-grid .blog-cover {
width: 100% !important;
max-width: 100% !important;
height: 420px;
border-radius: 16px;
overflow: hidden;
margin: 0 !important;
}
.menu-showcase-grid .blog-cover img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.6s ease;
}
.menu-showcase-grid .blog-card:hover .blog-cover img {
transform: scale(1.04);
}
.menu-showcase-grid .blog-data {
padding: 0 5px;
flex: 1;
display: flex;
flex-direction: column;
}
.menu-showcase-grid .blog-top div:first-child {
text-transform: uppercase;
font-size: 0.85rem;
letter-spacing: 1px;
color: #d4af37;
margin-bottom: 8px;
font-weight: 600;
}
.menu-showcase-grid .body-large {
font-size: 1.8rem !important;
line-height: 1.2;
}
@media screen and (max-width: 991px) {
.menu-showcase-grid {
grid-template-columns: repeat(2, 1fr);
}
}
@media screen and (max-width: 767px) {
.menu-showcase-grid {
grid-template-columns: 1fr;
gap: 40px;
}
.menu-showcase-grid .blog-cover {
height: 350px;
}
}
.menu-highlight-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 28px;
margin-top: 48px;
}
.menu-highlight-card {
position: relative;
background: #0e0d09;
border-radius: 16px;
overflow: hidden;
display: flex;
flex-direction: column;
border: 1px solid rgba(212, 175, 55, 0.12);
transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94), box-shadow 0.4s ease, border-color 0.4s ease;
}
.menu-highlight-card:hover {
transform: translateY(-10px);
box-shadow: 0 24px 60px rgba(0, 0, 0, 0.45), 0 0 0 1px rgba(212, 175, 55, 0.35);
border-color: rgba(212, 175, 55, 0.35);
}
.menu-card-img-wrap {
width: 100%;
height: 260px;
overflow: hidden;
position: relative;
}
.menu-card-img-wrap::after {
content: '';
position: absolute;
inset: 0;
background: linear-gradient(to bottom, transparent 40%, rgba(14, 13, 9, 0.7) 100%);
pointer-events: none;
}
.menu-card-img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.55s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.menu-highlight-card:hover .menu-card-img {
transform: scale(1.08);
}
.menu-card-badge {
position: absolute;
top: 18px;
left: 18px;
background: rgba(212, 175, 55, 0.95);
color: #0e0d09;
font-size: 0.7rem;
font-weight: 700;
letter-spacing: 0.12em;
text-transform: uppercase;
padding: 5px 12px;
border-radius: 100px;
z-index: 2;
backdrop-filter: blur(4px);
}
.menu-card-body {
padding: 28px;
display: flex;
flex-direction: column;
flex: 1;
border-top: 3px solid #d4af37;
}
.menu-card-name {
font-size: 1.15rem;
font-weight: 700;
color: #ffffff;
margin: 0 0 10px 0;
line-height: 1.3;
}
.menu-card-desc {
font-size: 0.875rem;
color: rgba(255, 255, 255, 0.55);
line-height: 1.6;
margin: 0 0 20px 0;
flex: 1;
}
.menu-card-footer {
display: flex;
align-items: center;
justify-content: space-between;
padding-top: 16px;
border-top: 1px solid rgba(255, 255, 255, 0.07);
}
.menu-card-price {
font-size: 1.1rem;
font-weight: 700;
color: #d4af37;
letter-spacing: 0.02em;
}
.menu-card-cta {
display: flex;
align-items: center;
gap: 6px;
font-size: 0.78rem;
font-weight: 600;
color: rgba(255, 255, 255, 0.4);
letter-spacing: 0.08em;
text-transform: uppercase;
transition: color 0.3s ease;
text-decoration: none;
}
.menu-highlight-card:hover .menu-card-cta {
color: #d4af37;
}
.menu-card-cta-arrow {
width: 16px;
height: 16px;
transition: transform 0.3s ease;
}
.menu-highlight-card:hover .menu-card-cta-arrow {
transform: translateX(4px);
}
@media (max-width: 991px) {
.menu-highlight-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
.menu-highlight-grid { grid-template-columns: 1fr; }
}
