/* ============================================================
   VIRTUOSA AUTH v1.1 - Premium Mobile-First
   ============================================================ */
.auth-page{
    min-height:100vh;
    background:
        radial-gradient(circle at 20% 10%,rgba(232,164,184,.25) 0%,transparent 50%),
        radial-gradient(circle at 80% 80%,rgba(212,175,122,.2) 0%,transparent 50%),
        linear-gradient(180deg,#FFE8EE 0%,#FFF0F3 40%,#FFF5F0 100%);
    display:flex;align-items:center;justify-content:center;
    padding:20px;position:relative;overflow:hidden;
}
.auth-page::before,.auth-page::after{
    content:'';position:absolute;width:300px;height:300px;border-radius:50%;
    filter:blur(80px);opacity:.4;pointer-events:none;
    animation:float 8s ease-in-out infinite;
}
.auth-page::before{background:#E8A4B8;top:-100px;left:-100px}
.auth-page::after{background:#D4AF7A;bottom:-100px;right:-100px;animation-delay:-4s}
@keyframes float{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-20px) scale(1.1)}}

.auth-card{
    background:rgba(255,255,255,.85);
    backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);
    border-radius:32px;padding:40px 30px;max-width:440px;width:100%;
    box-shadow:0 20px 60px rgba(214,122,149,.2);
    border:1px solid rgba(255,255,255,.6);
    position:relative;z-index:1;
    animation:slideUp .6s cubic-bezier(.4,0,.2,1);
}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

.auth-logo{text-align:center;margin-bottom:30px}
.auth-logo .flower{font-size:52px;display:inline-block;animation:bloom 3s ease-in-out infinite}
@keyframes bloom{0%,100%{transform:rotate(-5deg) scale(1)}50%{transform:rotate(5deg) scale(1.05)}}
.auth-logo h1{
    font-family:'Playfair Display',serif;font-size:32px;
    background:linear-gradient(135deg,#D67A95,#D4AF7A);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;margin-top:8px;
}
.auth-logo p{color:#6B5358;font-size:14px;margin-top:4px;font-style:italic}

.auth-title{font-family:'Playfair Display',serif;font-size:26px;color:#3D2B2F;text-align:center;margin-bottom:6px}
.auth-subtitle{text-align:center;color:#6B5358;font-size:14px;margin-bottom:26px}

.auth-form{display:flex;flex-direction:column;gap:14px}
.field{position:relative}
.field label{
    display:block;font-size:12px;font-weight:600;color:#6B5358;
    margin-bottom:6px;margin-left:4px;
    text-transform:uppercase;letter-spacing:.5px;
}
.field input,.field select,.field textarea{
    width:100%;padding:14px 16px 14px 46px;
    border:1.5px solid rgba(232,164,184,.3);
    border-radius:14px;font-size:15px;
    background:rgba(255,255,255,.7);font-family:inherit;color:#3D2B2F;
    transition:.25s;
}
.field input:focus,.field select:focus{
    outline:none;border-color:#D67A95;background:#fff;
    box-shadow:0 0 0 4px rgba(232,164,184,.15);
}
.field .icon{
    position:absolute;left:16px;top:38px;
    color:#D67A95;font-size:18px;pointer-events:none;
}
.field .toggle-pass{
    position:absolute;right:14px;top:34px;
    background:none;border:none;color:#6B5358;font-size:18px;
    cursor:pointer;padding:4px;
}

.auth-options{display:flex;justify-content:space-between;align-items:center;font-size:13px;margin:6px 0 4px}
.remember-me{display:flex;align-items:center;gap:8px;color:#6B5358;cursor:pointer}
.remember-me input{width:18px;height:18px;accent-color:#D67A95}
.forgot-link{color:#D67A95;text-decoration:none;font-weight:600}
.forgot-link:hover{text-decoration:underline}

.btn-auth{
    width:100%;padding:15px;
    background:linear-gradient(135deg,#E8A4B8,#D67A95);color:#fff;
    border:none;border-radius:14px;font-size:15px;font-weight:700;
    cursor:pointer;margin-top:10px;
    box-shadow:0 8px 24px rgba(214,122,149,.35);transition:.25s;
    display:flex;align-items:center;justify-content:center;gap:8px;
}
.btn-auth:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(214,122,149,.45)}
.btn-auth:disabled{opacity:.6;cursor:wait}

.btn-social-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.btn-social{
    padding:13px;background:#fff;color:#3D2B2F;
    border:1.5px solid rgba(232,164,184,.3);
    border-radius:14px;font-size:14px;font-weight:600;
    cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;
    transition:.2s;
}
.btn-social:hover{border-color:#D67A95;background:rgba(255,232,238,.5)}

.divider{display:flex;align-items:center;color:#9B8388;font-size:12px;margin:18px 0;gap:12px}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,transparent,#E8C9D2,transparent)}

.auth-footer{text-align:center;margin-top:20px;color:#6B5358;font-size:14px}
.auth-footer a{color:#D67A95;text-decoration:none;font-weight:700}

.alert{
    padding:12px 16px;border-radius:12px;font-size:13px;margin-bottom:14px;
    display:flex;align-items:center;gap:10px;animation:slideIn .3s ease;
}
@keyframes slideIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.alert-error{background:#FFEBEE;color:#C62828;border-left:4px solid #C62828}
.alert-success{background:#E8F5E9;color:#2E7D32;border-left:4px solid #2E7D32}
.alert-info{background:#FFF8E1;color:#856404;border-left:4px solid #FFC107}

.onboard-progress{display:flex;gap:6px;margin-bottom:24px;justify-content:center}
.onboard-progress span{width:36px;height:6px;border-radius:999px;background:#FFE8EE;transition:.3s}
.onboard-progress span.active{background:linear-gradient(90deg,#E8A4B8,#D4AF7A)}

.onboard-step{display:none;animation:slideUp .5s ease}
.onboard-step.active{display:block}

.option-card{
    display:flex;align-items:center;gap:14px;padding:16px;
    background:rgba(255,255,255,.7);
    border:2px solid rgba(232,164,184,.2);border-radius:16px;
    cursor:pointer;margin-bottom:10px;transition:.2s;
}
.option-card:hover{border-color:#D67A95;background:#fff}
.option-card.selected{
    border-color:#D67A95;
    background:linear-gradient(135deg,#FFE8EE,#FFF8F3);
    box-shadow:0 4px 14px rgba(214,122,149,.2);
}
.option-card .emoji{font-size:32px}
.option-card .txt strong{display:block;color:#3D2B2F;font-size:15px}
.option-card .txt span{color:#6B5358;font-size:12px}

.onboard-nav{display:flex;justify-content:space-between;margin-top:24px;gap:10px}
.onboard-nav button{
    flex:1;padding:13px;border-radius:12px;
    font-weight:600;cursor:pointer;border:none;font-size:14px;
}
.btn-prev{background:#fff;color:#6B5358;border:1.5px solid rgba(232,164,184,.3) !important}
.btn-next{background:linear-gradient(135deg,#E8A4B8,#D67A95);color:#fff}

.profile-hero{text-align:center;padding:30px 20px;background:linear-gradient(180deg,#FFE8EE,transparent)}
.profile-avatar{
    width:110px;height:110px;border-radius:50%;
    border:5px solid #fff;box-shadow:0 8px 24px rgba(214,122,149,.25);
    margin:0 auto 14px;display:block;object-fit:cover;
    background:linear-gradient(135deg,#E8A4B8,#D4AF7A);
}
.profile-name{font-family:'Playfair Display',serif;font-size:24px;color:#3D2B2F}
.profile-bio{color:#6B5358;font-size:14px;margin-top:6px;padding:0 20px}
.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:20px}
.profile-stats .stat{
    background:#fff;border-radius:14px;padding:14px 8px;text-align:center;
    box-shadow:0 4px 12px rgba(214,122,149,.08);
}
.profile-stats strong{display:block;font-size:20px;color:#D67A95;font-family:'Playfair Display',serif}
.profile-stats span{font-size:11px;color:#6B5358}

.profile-menu{padding:0 20px 30px}
.menu-item{
    display:flex;align-items:center;gap:14px;padding:16px;
    background:#fff;border-radius:14px;margin-bottom:10px;
    text-decoration:none;color:#3D2B2F;
    box-shadow:0 4px 12px rgba(214,122,149,.06);transition:.2s;
}
.menu-item:hover{transform:translateX(4px);box-shadow:0 6px 18px rgba(214,122,149,.12)}
.menu-item .mi-ic{
    width:42px;height:42px;border-radius:12px;
    background:#FFE8EE;color:#D67A95;
    display:inline-flex;align-items:center;justify-content:center;font-size:20px;
}
.menu-item .mi-txt{flex:1}
.menu-item .mi-txt strong{display:block;font-size:15px}
.menu-item .mi-txt small{color:#6B5358;font-size:12px}
.menu-item .arrow{color:#D67A95;font-size:18px}
.menu-item.danger .mi-ic{background:#FFEBEE;color:#C62828}
.menu-item.danger strong{color:#C62828}

.spinner{
    width:18px;height:18px;
    border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;
    border-radius:50%;animation:spin .7s linear infinite;display:inline-block;
}
@keyframes spin{to{transform:rotate(360deg)}}

@media(max-width:480px){
    .auth-card{padding:30px 22px;border-radius:24px}
    .auth-logo h1{font-size:28px}
}