html,
body {
    background: #f6f6f8;
    color: #222;
    margin: 0;
    padding: 0;
}

html {
    min-height: 100%;
}

body {
    min-height: 100vh;
}

.navbar {
    margin-top: 0 !important;
    border-radius: 0 !important;
}

.login-page,
.client-login-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
}

.sidebar {
    min-height: calc(100vh - 56px);
    background: #fff;
    border-right: 1px solid #e9ecef;
    box-shadow: 12px 0 28px rgba(26, 18, 22, 0.04);
}

.dashboard-menu {
    gap: 8px;
}

.dashboard-menu .list-group-item {
    border: 1px solid #e8e3e6;
    padding: 14px 18px;
    font-weight: 600;
    background: #fff;
}

.dashboard-menu > .list-group-item.active {
    background: #1f6fff;
    border-color: #1f6fff;
    color: #fff;
}

.dashboard-menu-group {
    display: grid;
    gap: 8px;
}

.dashboard-menu-toggle {
    position: relative;
    text-align: left;
    font-weight: 500;
    min-height: 56px;
    padding-right: 52px !important;
    white-space: normal;
}

.dashboard-menu-toggle::after {
    content: '+';
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    font-weight: 700;
    color: #7b6d70;
    width: 26px;
    height: 26px;
    border-radius: 999px;
    background: #f7f2f4;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.dashboard-menu-toggle.is-open::after {
    content: '−';
}

.dashboard-menu-panel {
    display: grid;
    gap: 8px;
}

.dashboard-menu-panel[hidden] {
    display: none !important;
}

.dashboard-subitem {
    margin-left: 0;
    border-left: 3px solid rgba(13, 110, 253, 0.14);
    padding-left: 14px;
    font-weight: 500 !important;
    background: #fcfafb !important;
}

.table,
.form-control,
.form-select,
.btn,
.card,
.list-group-item,
.alert,
.badge {
    border-radius: 12px !important;
}

.card-stat {
    border: 0;
    box-shadow: 0 6px 24px rgba(0,0,0,0.05);
}

.auth-lux-page {
    position: relative;
    background:
        radial-gradient(circle at top left, rgba(222, 197, 170, 0.28), transparent 28%),
        linear-gradient(135deg, #f6f0eb 0%, #f0e3e5 48%, #eee7e3 100%);
}

.auth-shell {
    position: relative;
    z-index: 2;
}

.auth-showcase,
.auth-card {
    border-radius: 32px;
    box-shadow: 0 24px 70px rgba(65, 34, 43, 0.12);
    backdrop-filter: blur(6px);
}

.auth-showcase {
    min-height: 640px;
    padding: 42px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    color: #fff7f5;
    background:
        linear-gradient(180deg, rgba(10, 9, 11, 0.06) 0%, rgba(10, 8, 10, 0.72) 52%, rgba(10, 8, 10, 0.92) 100%),
        url('../img/beauty-woman-bg.svg') center top / cover no-repeat;
    border: 1px solid rgba(255,255,255,0.12);
}

.auth-showcase-dark {
    box-shadow: 0 24px 70px rgba(24, 10, 17, 0.28);
}

.auth-chip,
.auth-card-topline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border-radius: 999px;
    font-weight: 600;
    letter-spacing: 0.01em;
}

.auth-chip {
    width: fit-content;
    margin-bottom: 24px;
    background: rgba(255, 241, 233, 0.12);
    border: 1px solid rgba(255,255,255,0.18);
    color: #f7ddd2;
}

.auth-showcase h1 {
    max-width: 530px;
    margin: 0 0 16px;
    font-size: clamp(2.2rem, 4vw, 4rem);
    line-height: 1.04;
    font-family: Georgia, 'Times New Roman', serif;
}

.auth-showcase p {
    max-width: 480px;
    color: rgba(255,245,241,0.82);
    font-size: 1.1rem;
    line-height: 1.75;
}

.auth-feature-list {
    list-style: none;
    padding: 0;
    margin: 28px 0 0;
    display: grid;
    gap: 14px;
}

.auth-feature-list li {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.09);
    padding: 14px 18px;
    border-radius: 18px;
    color: #fff4ee;
}

.auth-card {
    background: rgba(255,255,255,0.88);
    border: 1px solid rgba(177, 132, 111, 0.14);
    padding: 36px 34px 28px;
}

.auth-card-dark {
    background: rgba(255,255,255,0.92);
}

.auth-card-compact {
    padding: 42px 38px 34px;
}

.auth-card-topline {
    margin-bottom: 20px;
    background: #fbf5ef;
    border: 1px solid #f0dfd1;
    color: #8a736f;
}

.auth-title {
    margin: 0 0 10px;
    font-size: clamp(2rem, 3vw, 3rem);
    line-height: 1.05;
    font-family: Georgia, 'Times New Roman', serif;
    color: #7a6d6e;
    text-align: center;
}

.auth-subtitle {
    margin: 0 0 24px;
    text-align: center;
    color: #b49d9d;
    line-height: 1.8;
    font-size: 1.05rem;
}

.auth-form .form-label {
    color: #716465;
    font-size: 1.05rem;
    margin-bottom: 8px;
}

.input-icon-wrap {
    position: relative;
}

.input-icon {
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    color: #ae936e;
    pointer-events: none;
    font-size: 1.05rem;
    transition: opacity .18s ease, transform .18s ease;
}

.input-icon-wrap:focus-within .input-icon,
.input-icon.is-hidden {
    opacity: 0;
    transform: translateY(-50%) scale(.92);
}

.auth-form .form-control {
    min-height: 58px;
    padding-left: 48px;
    border: 1px solid #e7c89b;
    background: #eef4ff;
    box-shadow: none;
}

.auth-form .form-control:focus {
    border-color: #d8a24e;
    box-shadow: 0 0 0 0.24rem rgba(216, 162, 78, 0.16);
}

.auth-submit {
    min-height: 54px;
    border: 0;
    border-radius: 16px !important;
    color: #fff;
    font-weight: 700;
    font-size: 1.08rem;
    background: linear-gradient(90deg, #5c5359 0%, #9c7681 100%);
    box-shadow: 0 14px 28px rgba(119, 84, 94, 0.26);
}

.auth-submit:hover {
    color: #fff;
    filter: brightness(1.03);
}

.auth-alert {
    border-radius: 18px !important;
    border-color: #f0c8c4;
    background: #fff0ef;
    color: #b04d49;
    padding: 16px 18px;
}

.auth-note {
    margin-top: 24px;
    padding: 16px 18px;
    border-radius: 18px;
    background: #fbf6f1;
    border: 1px solid #f1e0d3;
    color: #9f8784;
    font-size: 0.96rem;
}

.auth-footer-link {
    margin-top: 16px;
    text-align: center;
}

.auth-footer-link a {
    color: #8f5f63;
    text-decoration: none;
    font-weight: 600;
}

.appointment-policy-note {
    padding: 16px 18px;
    border-radius: 18px;
    background: #fff6eb;
    border: 1px solid #f0d3a8;
    color: #8b5c18;
    font-weight: 600;
}

@media (max-width: 991.98px) {
    .sidebar {
        min-height: auto;
        border-right: 0;
        box-shadow: none;
    }

    .auth-showcase {
        min-height: 420px;
        padding: 30px;
    }

    .auth-card,
    .auth-card-compact {
        padding: 28px 24px 24px;
    }
}

.raspa-beauty-page {
    position: relative;
    min-height: 100vh;
    color: #fff;
    overflow-x: hidden;
    background: #070608;
}

.raspa-scene,
.raspa-overlay {
    position: fixed;
    inset: 0;
}

.raspa-scene {
    background:
        linear-gradient(90deg, rgba(6,4,5,0.98) 0%, rgba(8,6,8,0.65) 35%, rgba(9,7,8,0.72) 100%),
        url('../img/beauty-woman-bg.svg') right center / cover no-repeat;
    z-index: 0;
}

.raspa-overlay {
    background:
        radial-gradient(circle at 12% 16%, rgba(194, 127, 143, 0.20), transparent 16%),
        radial-gradient(circle at 78% 26%, rgba(224, 176, 94, 0.16), transparent 14%),
        linear-gradient(180deg, rgba(8,6,7,0.10) 0%, rgba(8,6,7,0.72) 100%);
    z-index: 1;
}

.raspa-topbar,
.raspa-info-card,
.raspa-card-wrap,
.raspa-result-card {
    position: relative;
    z-index: 2;
}

.raspa-mini-label,
.raspa-info-chip,
.raspa-card-badge,
.raspa-revealed-pill {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,0.12);
    background: rgba(255,255,255,0.06);
    color: #f7dfc9;
    padding: 9px 16px;
    font-weight: 600;
}

.raspa-page-title {
    font-family: Georgia, 'Times New Roman', serif;
    font-size: clamp(2rem, 4vw, 3.3rem);
    color: #fff1ec;
}

.raspa-back-btn {
    border-radius: 16px !important;
    padding: 12px 22px;
}

.raspa-info-card,
.raspa-card-wrap,
.raspa-result-card {
    border-radius: 30px;
    border: 1px solid rgba(255,255,255,0.10);
    background: rgba(17, 11, 14, 0.68);
    box-shadow: 0 24px 70px rgba(0,0,0,0.30);
    backdrop-filter: blur(8px);
}

.raspa-info-card {
    padding: 34px;
    min-height: 100%;
}

.raspa-info-card h2,
.raspa-card-wrap h2,
.raspa-result-title {
    font-family: Georgia, 'Times New Roman', serif;
}

.raspa-info-card h2 {
    font-size: clamp(2rem, 4vw, 3rem);
    color: #fff1eb;
    margin: 18px 0 14px;
    line-height: 1.05;
}

.raspa-info-card p,
.raspa-card-copy,
.raspa-result-meta {
    color: rgba(255,243,238,0.76);
    line-height: 1.85;
}

.raspa-perks {
    display: grid;
    gap: 14px;
    margin-top: 28px;
}

.raspa-perk-item {
    padding: 15px 18px;
    border-radius: 18px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
    color: #ffe9da;
}

.raspa-card-wrap,
.raspa-result-card {
    padding: 32px;
}

.raspa-card-header {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: start;
    margin-bottom: 12px;
}

.raspa-card-kicker {
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-size: 0.82rem;
    color: #f2c98b;
    margin-bottom: 10px;
}

.raspa-card-wrap h2 {
    font-size: clamp(1.8rem, 3vw, 2.7rem);
    color: #fff6f1;
    margin: 0;
}

.luxury-scratch-card {
    margin-top: 24px;
    position: relative;
    max-width: 520px;
    min-height: 290px;
    border-radius: 30px;
    overflow: hidden;
    background: linear-gradient(135deg, #fff9f4, #f8d6df 58%, #f4e6d1 100%);
    border: 1px solid rgba(255,255,255,0.18);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.35), 0 18px 50px rgba(9, 6, 8, 0.28);
}

.scratch-decor {
    position: absolute;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255,255,255,0.82) 0%, rgba(255,255,255,0.12) 58%, transparent 72%);
    z-index: 1;
    pointer-events: none;
}

.scratch-decor-top {
    top: -72px;
    right: -48px;
}

.scratch-decor-bottom {
    left: -62px;
    bottom: -92px;
}

.scratch-prize {
    position: absolute;
    inset: 0;
    z-index: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 28px;
    font-size: clamp(1.8rem, 4vw, 2.7rem);
    line-height: 1.15;
    font-weight: 700;
    color: #6e2741;
    font-family: Georgia, 'Times New Roman', serif;
}

#scratchCanvas {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    touch-action: none;
    cursor: crosshair;
    z-index: 2;
}

.scratch-label {
    position: absolute;
    top: 18px;
    left: 18px;
    z-index: 3;
    background: rgba(255,255,255,0.92);
    color: #6d4a2e;
    padding: 9px 16px;
    border-radius: 999px;
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: 0.04em;
}

.raspa-primary-btn {
    border: 0;
    border-radius: 16px !important;
    color: #fff;
    font-weight: 700;
    background: linear-gradient(90deg, #a97543, #e6b56a 55%, #8d5a37);
    box-shadow: 0 16px 34px rgba(146, 103, 63, 0.28);
}

.raspa-result-title {
    font-size: clamp(2rem, 4vw, 3rem);
    margin: 22px 0 16px;
    color: #fff2ea;
}

@media (max-width: 991.98px) {
    .auth-showcase {
        min-height: 420px;
    }
    .auth-card,
    .auth-showcase,
    .raspa-info-card,
    .raspa-card-wrap,
    .raspa-result-card {
        border-radius: 24px;
    }
    .raspa-card-header {
        flex-direction: column;
    }
}

@media (max-width: 575.98px) {
    .auth-card {
        padding: 26px 20px 22px;
    }
    .auth-showcase {
        padding: 28px 22px;
    }
    .raspa-info-card,
    .raspa-card-wrap,
    .raspa-result-card {
        padding: 24px 20px;
    }
    .luxury-scratch-card {
        min-height: 250px;
    }
}

.prize-pill {
    display: inline-block;
    padding: 8px 14px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid #ead5df;
    margin: 4px 6px 0 0;
}

.site-upload-box {
    display: grid;
    grid-template-columns: 180px 1fr;
    gap: 18px;
    align-items: center;
    padding: 16px;
    border: 1px dashed #d7b7bf;
    border-radius: 22px;
    background: linear-gradient(135deg, #fff, #fff7f4);
}

.site-upload-preview {
    width: 100%;
    height: 118px;
    object-fit: cover;
    border-radius: 18px;
    background: #f1e3df;
    box-shadow: 0 14px 34px rgba(35, 26, 29, 0.12);
}

.site-upload-preview-portrait {
    height: 180px;
}

.site-upload-content {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 14px;
    align-items: center;
}

.site-upload-status {
    color: #8a6d74;
    font-size: 0.92rem;
    line-height: 1.45;
}

@media (max-width: 575.98px) {
    .site-upload-box {
        grid-template-columns: 1fr;
    }

    .site-upload-preview {
        height: 180px;
    }
}


/* ===== SITE DO SALÃO INTEGRADO ===== */
.site-page {
    background:
        radial-gradient(circle at top right, rgba(184,130,147,.14), transparent 28%),
        radial-gradient(circle at left bottom, rgba(199,160,106,.12), transparent 25%),
        #fff8f7;
    color: #231a1d;
    font-family: 'Inter', Arial, sans-serif;
}
.site-page * { box-sizing: border-box; }
.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(255,248,247,.92);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(35,26,29,.08);
}
.site-nav-wrap {
    min-height: 88px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
}
.site-brand { display:flex; align-items:center; gap:14px; text-decoration:none; color:inherit; }
.site-brand-mark {
    width:54px;height:54px;border-radius:50%;display:grid;place-items:center;
    background:linear-gradient(135deg,#24181b,#7f5260); color:#fff; font-family:Georgia,serif;
    font-size:28px;font-weight:700; box-shadow:0 20px 60px rgba(35,26,29,.08);
}
.site-brand-text { display:flex; flex-direction:column; }
.site-brand-text strong { font-family:Georgia,serif; font-size:31px; line-height:1; }
.site-brand-text small { font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:#7d6c71; margin-top:5px; }
.site-nav { display:flex; align-items:center; gap:28px; }
.site-nav a { color:#3b2e32; text-decoration:none; font-weight:600; }
.site-nav-cta { padding:12px 18px; border-radius:999px; background:#1f1719; color:#fff !important; }
.site-section { padding: 90px 0; }
.site-grid { display:grid; grid-template-columns: 1.05fr .95fr; gap:40px; align-items:center; }
.site-eyebrow {
    display:inline-flex; padding:10px 16px; border-radius:999px; background:#fff;
    border:1px solid rgba(35,26,29,.08); color:#8a5767; font-size:13px; font-weight:700; text-transform:uppercase;
}
.site-eyebrow-dark {
    background: rgba(255,255,255,.08);
    border-color: rgba(255,255,255,.12);
    color: #f2d8df;
}
.site-copy h1, .site-copy h2, .site-section-head h2, .site-card-floating h3, .site-service-card h3, .site-team-info h3, .site-footer h3 {
    font-family: Georgia, 'Times New Roman', serif;
}
.site-copy h1 { font-size: 68px; margin: 18px 0; line-height: 1.02; }
.site-copy h2, .site-section-head h2 { font-size: 54px; margin: 16px 0; line-height: 1.04; }
.site-copy p, .site-section-head p, .site-service-card p, .site-team-info p { color:#7d6c71; line-height:1.8; }
.site-actions { display:flex; gap:16px; flex-wrap:wrap; margin:30px 0; }
.site-btn {
    display:inline-flex; align-items:center; justify-content:center; padding:15px 24px;
    border-radius:999px; text-decoration:none; font-weight:700; border:1px solid transparent;
}
.site-btn-gold { background:linear-gradient(135deg,#d8b47d,#c79a57); color:#1c1416; box-shadow:0 18px 35px rgba(199,160,106,.25); }
.site-btn-outline { background:#fff; color:#24181b; border-color:rgba(35,26,29,.08); }
.site-btn-full { width:100%; }
.site-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:20px; }
.site-stats article { background:#fff; padding:18px; border-radius:18px; box-shadow:0 20px 60px rgba(35,26,29,.08); }
.site-stats strong { display:block; font-size:28px; font-family:Georgia,serif; }
.site-stats span { color:#7d6c71; font-size:14px; }
.site-visual { position:relative; min-height:620px; }
.site-card { position:absolute; background:#fff; border-radius:36px; box-shadow:0 22px 60px rgba(31,23,25,.18); overflow:hidden; }
.site-card-main { inset:0 44px 60px 0; background:linear-gradient(180deg,#312328,#201719); }
.site-card-main img { width:100%; height:100%; object-fit:cover; }
.site-card-floating { right:0; bottom:0; width:330px; padding:26px; background:rgba(255,255,255,.96); }
.site-section-light { background:#fff; }
.site-section-dark { background:#201719; color:#fff; }
.site-media-box { border-radius:28px; overflow:hidden; box-shadow:0 20px 60px rgba(35,26,29,.08); }
.site-media-box img { width:100%; display:block; object-fit:cover; }
.site-feature-list { display:grid; gap:18px; margin-top:28px; }
.site-feature-list article, .site-service-card, .site-team-card, .site-booking-form {
    background:#fff; border:1px solid rgba(35,26,29,.08); border-radius:20px; box-shadow:0 20px 60px rgba(35,26,29,.08);
}
.site-feature-list article, .site-service-card, .site-booking-form { padding:20px 22px; }
.site-section-head { margin-bottom:36px; }
.site-section-head-light p, .site-section-head-light h2 { color:#fff; }
.site-services-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.site-service-icon { width:64px; height:64px; border-radius:20px; background:#f7ece9; display:grid; place-items:center; font-size:28px; }
.site-service-card h3 { font-size:28px; margin:18px 0 10px; }
.site-service-card a { font-weight:700; color:#8a5767; text-decoration:none; }
.site-team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.site-team-card { overflow:hidden; }
.site-team-card img { width:100%; height:340px; object-fit:cover; background:#f0dfdc; }
.site-team-info { padding:24px; }
.site-team-info span { color:#8a5767; font-weight:700; font-size:14px; text-transform:uppercase; }
.site-booking-form input, .site-booking-form select, .site-booking-form textarea {
    width:100%; border:none; background:#f8efed; border-radius:18px; padding:15px 16px; color:#24181b;
    outline:none; border:1px solid transparent; transition:.2s ease;
}
.site-booking-form input:focus, .site-booking-form select:focus, .site-booking-form textarea:focus {
    border-color:#b88293; background:#fff;
}
.site-form-row { margin-bottom:16px; }
.site-form-two { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.site-form-row label { display:block; font-size:14px; font-weight:700; margin-bottom:8px; color:#49363b; }
.site-note { margin:14px 0 0; color:#8a5767; font-size:14px; }
.site-footer { background:#1d1517; color:rgba(255,255,255,.75); padding:56px 0; }
.site-footer-grid { display:grid; grid-template-columns:1.2fr .9fr .9fr; gap:30px; }
.site-footer h3 { color:#fff; font-size:28px; }

@media (max-width:1080px){
    .site-grid { grid-template-columns:1fr; }
    .site-services-grid, .site-team-grid, .site-footer-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:840px){
    .site-nav { display:none; }
    .site-copy h1, .site-copy h2, .site-section-head h2 { font-size:46px; }
    .site-stats, .site-services-grid, .site-team-grid, .site-footer-grid, .site-form-two { grid-template-columns:1fr; }
    .site-card-main { inset:0 26px 110px 0; }
    .site-card-floating { width:auto; left:36px; right:0; }
}
@media (max-width:560px){
    .site-copy h1, .site-copy h2, .site-section-head h2 { font-size:38px; }
    .site-card-main { inset:0 0 130px 0; }
    .site-card-floating { left:18px; right:18px; padding:20px; }
}
.site-upload-preview-logo {
    height: 180px;
    object-fit: contain;
    padding: 18px;
    background: radial-gradient(circle at top left, #fff, #f7ece8);
}
