/* ==========================================================================
   ULTRA-PREMIUM (LUXURY BOUTIQUE) DENTAL DESIGN
   ========================================================================== */

/* Shared Luxury Utilities */
.lux-eyebrow {
    display: block;
    font-family: var(--font-body);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: var(--primary);
    margin-bottom: 25px;
}
.lux-eyebrow--light {
    color: #ffffff;
}
.lux-eyebrow--accent {
    color: var(--accent);
}

.lux-title-hero {
    font-size: clamp(36px, 4.4vw, 56px);
    line-height: 1.08;
    color: #ffffff;
    margin: 0;
    letter-spacing: -0.03em;
}

.lux-title-section {
    font-size: clamp(28px, 3vw, 40px);
    line-height: 1.18;
    margin-bottom: 30px;
    color: var(--primary);
}

.lux-title-statement {
    font-size: clamp(24px, 2.8vw, 34px);
    line-height: 1.4;
    color: var(--primary);
    margin-bottom: 40px;
    font-style: normal;
    font-weight: 500;
}

.lux-text-body {
    font-family: var(--font-body);
    font-size: 15px;
    line-height: 2;
    color: var(--text-light);
    font-weight: 300;
}

/* --------------------------------------------------------------------------
   Sinematik Hero (Cinematic Hero)
   -------------------------------------------------------------------------- */
.lux-hero {
    position: relative;
    height: 100vh;
    min-height: 700px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 0 40px;
    overflow: hidden;
}

.lux-hero__bg {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    z-index: 0;
    background:
        radial-gradient(circle at 75% 20%, rgba(181,154,90,.18), transparent 32%),
        linear-gradient(135deg, #1c1c1c 0%, #2a2925 48%, #111 100%);
}
.lux-hero__bg img {
    width: 100%; height: 100%; object-fit: cover;
    filter: brightness(0.7) contrast(1.1);
    transform: scale(1.025);
    animation: lux-hero-breath 14s ease-in-out infinite alternate;
}
.lux-hero__overlay {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background: linear-gradient(to bottom, rgba(28,28,28,0.8) 0%, rgba(28,28,28,0.2) 25%, rgba(28,28,28,0.8) 100%);
}

.lux-hero__content {
    position: relative;
    z-index: 1;
    max-width: 900px;
    margin-top: 18px; /* Offset for transparent header */
}
.lux-hero__lead {
    max-width: 650px;
    margin: 24px auto;
    color: #ffffff;
    opacity: .8;
}
.lux-hero__actions {
    display: flex;
    gap: 30px;
    align-items: center;
    justify-content: center;
    margin-top: 42px;
    margin-bottom: 74px;
}
.lux-hero__text-link {
    border-bottom: 1px solid rgba(255,255,255,.3);
    color: #ffffff;
    padding-bottom: 5px;
    font-family: var(--font-body);
    font-size: 11px;
    letter-spacing: 3px;
    text-transform: uppercase;
}
.lux-hero__text-link:hover {
    border-color: var(--accent);
    color: var(--accent);
}

.lux-hero__scroll {
    position: absolute;
    bottom: 28px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
}
.lux-scroll-text {
    font-family: var(--font-body);
    font-size: 9px;
    letter-spacing: 4px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.6);
}
.lux-scroll-line {
    width: 1px;
    height: 44px;
    background-color: rgba(255,255,255,0.3);
    position: relative;
    overflow: hidden;
}
.lux-scroll-line::after {
    content: '';
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background-color: #ffffff;
    animation: scroll-down 2s infinite cubic-bezier(0.65, 0, 0.35, 1);
}
.lux-hero__badges {
    position: absolute;
    right: 0;
    bottom: 40px;
    left: 0;
    z-index: 1;
    display: flex;
    justify-content: space-between;
    padding: 0 60px;
    box-sizing: border-box;
}
.lux-hero__badge {
    max-width: 250px;
    text-align: left;
}
.lux-hero__badge--right {
    text-align: right;
}
.lux-hero__badge strong,
.lux-hero__badge span {
    display: block;
}
.lux-hero__badge strong {
    margin-bottom: 5px;
    color: var(--accent);
    font-family: var(--font-heading);
    font-size: 20px;
    font-weight: 400;
}
.lux-hero__badge span {
    color: #ffffff;
    font-family: var(--font-body);
    font-size: 10px;
    letter-spacing: 2px;
    line-height: 1.6;
    opacity: .5;
    text-transform: uppercase;
}
@keyframes scroll-down {
    0% { transform: translateY(-100%); }
    50% { transform: translateY(0); }
    100% { transform: translateY(100%); }
}
@keyframes lux-hero-breath {
    from { transform: scale(1.025); }
    to { transform: scale(1.06); }
}

/* --------------------------------------------------------------------------
   Manifesto (Statement)
   -------------------------------------------------------------------------- */
.lux-manifesto {
    padding: 160px 0;
    text-align: center;
    background-color: var(--background);
}
.lux-manifesto__inner {
    max-width: 800px;
    margin: 0 auto;
}
.lux-manifesto__author {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
}
.lux-author-name {
    font-family: var(--font-heading);
    font-size: 20px;
    color: var(--primary);
}
.lux-author-title {
    font-family: var(--font-body);
    font-size: 10px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--text-light);
}

/* --------------------------------------------------------------------------
   Artistic Editorial About
   -------------------------------------------------------------------------- */
.lux-editorial {
    padding: 100px 0 160px;
    background-color: var(--background);
}
.lux-editorial__grid {
    display: flex;
    align-items: center;
    gap: 120px;
}
.lux-editorial__text-col {
    flex: 1;
    max-width: 500px;
}
.lux-editorial__img-col {
    flex: 1.2;
}
.lux-img-frame {
    position: relative;
    padding-bottom: 130%;
    overflow: hidden;
}
.lux-img-frame img {
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    object-fit: cover;
    filter: grayscale(20%) contrast(1.1);
    transition: transform 1.2s cubic-bezier(0.16, 1, 0.3, 1), filter 1.2s ease;
}
.lux-img-frame:hover img {
    transform: scale(1.035);
    filter: grayscale(8%) contrast(1.08);
}
.lux-img-frame__placeholder {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at 70% 20%, rgba(181,154,90,.16), transparent 30%),
        linear-gradient(135deg, #efece4, #faf9f6);
    color: var(--primary);
    text-align: center;
}
.lux-img-frame__placeholder span {
    display: block;
    font-family: var(--font-heading);
    font-size: 72px;
    line-height: 1;
}
.lux-img-frame__placeholder small {
    display: block;
    margin-top: 10px;
    color: var(--text-light);
    font-size: 10px;
    letter-spacing: 2px;
    text-transform: uppercase;
}
.lux-img-frame::after {
    content: '';
    position: absolute;
    top: 20px; right: -20px; bottom: -20px; left: 20px;
    border: 1px solid var(--accent);
    z-index: -1;
}

.lux-editorial__signature {
    margin: 40px 0;
    padding-left: 20px;
    border-left: 1px solid var(--border);
}
.lux-editorial__quote {
    margin-bottom: 30px;
    color: var(--accent);
    font-family: var(--font-heading);
    font-size: 21px;
    font-style: normal;
    font-weight: 500;
}
.lux-editorial__bullets {
    margin: 40px 0;
    border-top: 1px solid var(--border);
    padding: 30px 0 0;
    list-style: none;
}
.lux-editorial__bullets li {
    position: relative;
    margin-bottom: 15px;
    padding-left: 25px;
    color: var(--text);
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 300;
}
.lux-editorial__bullets span {
    position: absolute;
    left: 0;
    color: var(--accent);
    font-weight: 500;
}
.lux-editorial__signature strong {
    display: block;
    font-family: var(--font-heading);
    font-size: 24px;
    color: var(--primary);
    font-weight: 400;
}
.lux-editorial__signature span {
    font-family: var(--font-body);
    font-size: 11px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--text-light);
    margin-top: 5px;
    display: block;
}

/* --------------------------------------------------------------------------
   Avant-Garde Services List
   -------------------------------------------------------------------------- */
.lux-services {
    padding: 140px 0;
    background-color: var(--white);
}
.lux-services__head {
    margin-bottom: 80px;
}
.lux-services__intro {
    max-width: 500px;
}
.lux-services__list {
    border-top: 1px solid var(--border);
    margin-bottom: 60px;
}
.lux-service-row {
    display: flex;
    align-items: center;
    padding: 40px 0;
    border-bottom: 1px solid var(--border);
    transition: background-color 0.4s ease, padding 0.4s ease;
}
.lux-service-row,
.lux-process__item,
.lux-stat-item {
    transition-delay: var(--delay, 0s);
}
.lux-service-row:nth-child(2) { --delay: .1s; }
.lux-service-row:nth-child(3) { --delay: .2s; }
.lux-service-row:nth-child(4) { --delay: .3s; }
.lux-service-row:nth-child(5) { --delay: .4s; }
.lux-process__item:nth-child(2),
.lux-stat-item:nth-child(2) { --delay: .2s; }
.lux-process__item:nth-child(3),
.lux-stat-item:nth-child(3) { --delay: .4s; }
.lux-service-row:hover {
    background-color: var(--background);
    padding: 40px 20px;
}
.lux-service-row__num {
    font-family: var(--font-body);
    font-size: 12px;
    font-weight: 300;
    color: var(--accent);
    width: 60px;
}
.lux-service-row__content {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 40px;
}
.lux-service-row__title {
    font-size: 26px;
    margin: 0;
    flex: 0 0 300px;
    transition: color 0.4s ease;
}
.lux-service-row:hover .lux-service-row__title {
    color: var(--accent);
}
.lux-service-row__desc {
    font-family: var(--font-body);
    font-size: 14px;
    color: var(--text-light);
    margin: 0;
    font-weight: 300;
    max-width: 450px;
}
.lux-service-row__icon {
    width: 40px;
    height: 40px;
    border: 1px solid var(--border);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--primary);
    transition: all 0.4s ease;
}
.lux-service-row:hover .lux-service-row__icon {
    background-color: var(--primary);
    border-color: var(--primary);
    color: var(--white);
    transform: translateX(6px);
}

.lux-services__action {
    text-align: center;
}

/* --------------------------------------------------------------------------
   Patient Reviews
   -------------------------------------------------------------------------- */
.lux-reviews {
    padding: 130px 0;
    background: var(--background);
}

.lux-reviews__head {
    display: grid;
    grid-template-columns: minmax(0, .8fr) minmax(0, .6fr);
    gap: 60px;
    align-items: end;
    margin-bottom: 58px;
}

.lux-reviews__head .lux-title-section {
    margin-bottom: 0;
}

.lux-reviews__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 22px;
}

.lux-review-card {
    display: flex;
    min-height: 330px;
    flex-direction: column;
    justify-content: space-between;
    border: 1px solid var(--border);
    background: #fff;
    padding: 36px;
}

.lux-review-card__stars {
    color: var(--accent);
    font-size: 13px;
    letter-spacing: 4px;
}

.lux-review-card blockquote {
    margin: 36px 0;
    color: var(--primary);
    font-family: var(--font-heading);
    font-size: 22px;
    line-height: 1.55;
}

.lux-review-card footer {
    display: grid;
    gap: 6px;
    border-top: 1px solid var(--border);
    padding-top: 22px;
}

.lux-review-card strong {
    color: var(--primary);
    font-family: var(--font-heading);
    font-size: 18px;
}

.lux-review-card span {
    color: var(--text-light);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
}

.theme-obsidian .lux-reviews {
    background: #0a0a0a;
}

.theme-obsidian .lux-review-card {
    border-color: rgba(181,154,90,.22);
    background: #121212;
}

.theme-obsidian .lux-review-card blockquote,
.theme-obsidian .lux-review-card strong {
    color: #f6f2e8;
}

.theme-obsidian .lux-review-card span,
.theme-obsidian .lux-reviews__head .lux-text-body {
    color: #c5beb1;
}

/* --------------------------------------------------------------------------
   Process
   -------------------------------------------------------------------------- */
.lux-process {
    border-top: 1px solid var(--border);
    background-color: var(--white);
    padding: 140px 0;
}
.lux-process__head {
    margin-bottom: 100px;
    text-align: center;
}
.lux-process__head .lux-text-body {
    max-width: 600px;
    margin: 0 auto;
}
.lux-process__grid {
    display: flex;
    flex-wrap: wrap;
    gap: 60px;
    justify-content: center;
}
.lux-process__item {
    position: relative;
    flex: 1;
    min-width: 250px;
    max-width: 350px;
    text-align: center;
    transition: transform 0.35s ease;
}
.lux-process__item:hover {
    transform: translateY(-6px);
}
.lux-process__number {
    position: absolute;
    top: -60px;
    left: 50%;
    z-index: 0;
    color: var(--text-light);
    font-family: var(--font-heading);
    font-size: 64px;
    font-weight: 300;
    line-height: 1;
    opacity: .15;
    transform: translateX(-50%);
}
.lux-process__content {
    position: relative;
    z-index: 1;
    padding-top: 40px;
}
.lux-process__content h3 {
    margin-bottom: 20px;
    color: var(--primary);
    font-family: var(--font-heading);
    font-size: 24px;
    font-weight: 600;
}
.lux-process__content .lux-text-body {
    font-size: 14px;
    line-height: 1.8;
}

/* --------------------------------------------------------------------------
   Floating Premium Stats
   -------------------------------------------------------------------------- */
.lux-stats {
    padding: 120px 0;
    background-color: var(--background);
}
.lux-stats__grid {
    display: flex;
    justify-content: space-around;
}
.lux-stat-item {
    text-align: center;
    transition: transform 0.35s ease;
}
.lux-stat-item:hover {
    transform: translateY(-5px);
}
.lux-stat-item__val {
    font-family: var(--font-heading);
    font-size: 56px;
    line-height: 1;
    color: var(--primary);
    margin-bottom: 10px;
}
.lux-stat-item__label {
    font-family: var(--font-body);
    font-size: 11px;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--accent);
}

/* --------------------------------------------------------------------------
   The Concierge (CTA) & Hours
   -------------------------------------------------------------------------- */
.lux-concierge {
    background-color: var(--background);
    padding: 0 40px 120px;
}
.lux-visit-card {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 40px;
    border: 1px solid var(--border);
    background-color: var(--background);
    padding: 60px;
}
.lux-visit-card__title {
    margin-bottom: 15px;
    font-size: 36px;
}
.lux-visit-card__location {
    color: var(--text-light);
    font-family: var(--font-body);
    font-size: 11px;
    letter-spacing: 2px;
    line-height: 2;
    text-transform: uppercase;
}
.lux-visit-card__location strong {
    color: var(--primary);
}
.lux-visit-card__button {
    border-color: var(--primary);
    color: var(--primary) !important;
}
.lux-open-status {
    min-width: 260px;
    margin-bottom: 18px;
    border: 1px solid rgba(15,61,76,.14);
    background: #fff;
    padding: 18px 20px;
    box-shadow: 0 18px 44px rgba(15,61,76,.07);
}
.lux-open-status span {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    color: var(--text-light);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.lux-open-status i {
    width: 9px;
    height: 9px;
    border-radius: 999px;
    background: #c9a86a;
    box-shadow: 0 0 0 6px rgba(201,168,106,.15);
}
.lux-open-status.is-open i {
    background: #789d8e;
    box-shadow: 0 0 0 6px rgba(120,157,142,.15);
}
.lux-open-status strong {
    display: block;
    margin-top: 10px;
    color: var(--primary);
    font-family: var(--font-heading);
    font-size: 20px;
    font-weight: 500;
}
.lux-open-status small {
    display: block;
    margin-top: 5px;
    color: var(--text-light);
}
.lux-concierge__inner {
    background-color: var(--primary);
    padding: 120px 40px;
    border: 1px solid var(--primary-light);
    position: relative;
    overflow: hidden;
}

.lux-concierge__watermark {
    position: absolute;
    top: -50%;
    right: -20%;
    width: 800px;
    height: 800px;
    color: var(--accent);
    opacity: 0.05;
    pointer-events: none;
    z-index: 0;
}

.lux-concierge__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    position: relative;
    z-index: 1;
    text-align: left;
}

.lux-concierge__cta {
    padding-right: 40px;
    border-right: 1px solid rgba(255,255,255,0.1);
}

.lux-concierge__actions {
    display: flex;
    align-items: flex-start;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 40px;
}
.lux-concierge__title {
    margin-bottom: 30px;
    color: #ffffff;
}
.lux-concierge__text {
    max-width: 400px;
    margin-bottom: 50px;
    color: #A0A0A0;
}

.lux-concierge__phone {
    display: flex;
    flex-direction: column;
    gap: 8px;
    text-align: left;
}
.lux-concierge__phone span {
    font-family: var(--font-body);
    font-size: 10px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.4);
}
.lux-concierge__phone a {
    font-family: var(--font-heading);
    font-size: 21px;
    color: var(--accent);
}

/* Working Hours List */
.lux-hours-summary {
    display: grid;
    gap: 5px;
    margin-top: 18px;
    border: 1px solid rgba(255,255,255,.1);
    background: rgba(255,255,255,.045);
    padding: 18px 20px;
}
.lux-hours-summary span {
    color: rgba(255,255,255,.48);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .16em;
    text-transform: uppercase;
}
.lux-hours-summary strong {
    color: #fff;
    font-family: var(--font-heading);
    font-size: 20px;
    font-weight: 500;
}

.lux-hours-list {
    list-style: none;
    padding: 0;
    margin: 40px 0 0;
}

.lux-hours-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 18px 0;
    border-bottom: 1px solid rgba(255,255,255,0.08);
}

.lux-hours-item:last-child {
    border-bottom: none;
}

.lux-hours-day {
    font-family: var(--font-body);
    font-size: 14px;
    color: rgba(255,255,255,0.8);
    font-weight: 300;
    letter-spacing: 1px;
}

.lux-hours-time {
    font-family: var(--font-heading);
    font-size: 18px;
    color: var(--accent);
}

.lux-hours-sep {
    margin: 0 5px;
    opacity: 0.5;
    font-weight: 300;
}

.lux-hours-closed {
    color: rgba(255,255,255,0.3);
    font-family: var(--font-body);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 2px;
}

/* --------------------------------------------------------------------------
   Responsive Layout
   -------------------------------------------------------------------------- */
@media (max-width: 1024px) {
    .lux-editorial__grid {
        flex-direction: column;
        gap: 60px;
    }
    .lux-service-row__content {
        flex-direction: column;
        align-items: flex-start;
        gap: 15px;
    }
    .lux-service-row__title {
        flex: none;
    }
    .lux-concierge__grid {
        grid-template-columns: 1fr;
        gap: 60px;
    }
    .lux-concierge__cta {
        padding-right: 0;
        border-right: none;
        border-bottom: 1px solid rgba(255,255,255,0.1);
        padding-bottom: 60px;
    }
    .lux-reviews__head,
    .lux-reviews__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .lux-title-hero { font-size: 38px; }
    .lux-title-section { font-size: 30px; }
    .lux-manifesto { padding: 100px 0; }
    .lux-stats__grid {
        flex-direction: column;
        gap: 60px;
    }
    .lux-service-row { padding: 30px 0; }
    .lux-service-row:hover { padding: 30px 10px; }
    .lux-concierge__inner { padding: 80px 20px; }
    .lux-hero__actions {
        flex-direction: column;
        gap: 20px;
    }
    .lux-hero__badges {
        display: none;
    }
    .lux-process {
        padding: 100px 0;
    }
    .lux-process__grid {
        gap: 70px;
    }
    .lux-visit-card {
        padding: 32px 24px;
    }
}
