.rua-wrap {
--rua-bg:          var(--rooms-color-bg,          #fff);
--rua-bg-alt:      var(--rooms-color-surface,     #f6f6f6);
--rua-border:      var(--rooms-color-border,      #e0e0e0);
--rua-accent:      var(--rooms-color-accent,      #2271b1);
--rua-accent-dark: var(--rooms-color-accent-dark, #135e96);
--rua-text:        var(--rooms-color-text,        #1a1a1a);
--rua-text-muted:  var(--rooms-color-text-muted,  #6c6c6c);
--rua-radius:      10px;
--rua-shadow:      0 2px 8px rgba(0,0,0,.07);
--rua-font:        var(--rooms-font-body,         system-ui, sans-serif);
font-family: var(--rua-font);
color: var(--rua-text);
max-width: 780px;
margin: 0 auto;
padding: clamp(16px, 4vw, 32px);
} .rua-login-box {
background: var(--rua-bg);
border: 1px solid var(--rua-border);
border-radius: var(--rua-radius);
box-shadow: var(--rua-shadow);
padding: 40px 32px;
text-align: center;
max-width: 460px;
margin: 0 auto;
}
.rua-login-icon {
font-size: 2.8rem;
margin-bottom: 12px;
line-height: 1;
}
.rua-login-title {
font-size: var(--rooms-font-size-lg, 1.5rem);
font-weight: 700;
margin: 0 0 8px;
color: var(--rua-text);
}
.rua-login-subtitle {
color: var(--rua-text-muted);
font-size: .9rem;
margin: 0 0 16px;
line-height: 1.5;
} .rua-tabs {
display: flex;
border-bottom: 2px solid var(--rua-border);
margin-bottom: 20px;
gap: 0;
}
.rua-tab-btn {
flex: 1;
padding: 10px 16px;
border: none;
background: transparent;
font-size: .9rem;
font-weight: 600;
color: var(--rua-text-muted);
cursor: pointer;
border-bottom: 3px solid transparent;
margin-bottom: -2px;
transition: color .15s, border-color .15s;
}
.rua-tab-btn:hover { color: var(--rua-accent); }
.rua-tab-btn--active {
color: var(--rua-accent);
border-bottom-color: var(--rua-accent);
}
.rua-tab-panel--hidden { display: none; } .rua-form-row { display: flex; gap: 12px; }
.rua-form-row--2col > .rua-form-group { flex: 1; min-width: 0; }
.rua-form-group {
display: flex;
flex-direction: column;
gap: 4px;
margin-bottom: 14px;
}
.rua-form-group label {
font-size: .85rem;
font-weight: 600;
color: var(--rua-text);
}
.rua-form-group input[type="text"],
.rua-form-group input[type="email"],
.rua-form-group input[type="password"],
.rua-form-group input[type="tel"],
.rua-form-group input[type="date"] {
width: 100%;
padding: 9px 12px;
border: 1px solid var(--rua-border);
border-radius: 6px;
font-size: .95rem;
background: var(--rua-bg);
color: var(--rua-text);
transition: border-color .15s;
box-sizing: border-box;
font-family: var(--rua-font);
}
.rua-form-group input:focus,
.rua-select:focus {
outline: none;
border-color: var(--rua-accent);
box-shadow: 0 0 0 2px color-mix(in srgb, var(--rua-accent) 15%, transparent);
}
.rua-select {
width: 100%;
padding: 9px 32px 9px 12px;
border: 1px solid var(--rua-border);
border-radius: 6px;
font-size: .95rem;
background: var(--rua-bg);
color: var(--rua-text);
transition: border-color .15s;
box-sizing: border-box;
font-family: var(--rua-font);
cursor: pointer;
appearance: none;
-webkit-appearance: none;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
background-repeat: no-repeat;
background-position: right 12px center;
} .rua-cpicker {
position: relative;
width: 100%;
}
.rua-cpicker-trigger {
width: 100%;
padding: 9px 12px;
border: 1px solid var(--rua-border);
border-radius: 6px;
font-size: .95rem;
background: var(--rua-bg);
color: var(--rua-text);
font-family: var(--rua-font);
cursor: pointer;
display: flex;
align-items: center;
gap: 8px;
text-align: left;
transition: border-color .15s;
box-sizing: border-box;
}
.rua-cpicker-trigger:hover,
.rua-cpicker-trigger[aria-expanded="true"] {
border-color: var(--rua-accent);
}
.rua-cpicker-trigger[aria-expanded="true"] {
box-shadow: 0 0 0 2px color-mix(in srgb, var(--rua-accent) 15%, transparent);
border-radius: 6px 6px 0 0;
}
.rua-cpicker-flag { font-size: 1.2rem; line-height: 1; flex-shrink: 0; }
.rua-cpicker-label { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rua-cpicker-arrow { color: var(--rua-text-muted); flex-shrink: 0; transition: transform .2s; }
.rua-cpicker-trigger[aria-expanded="true"] .rua-cpicker-arrow { transform: rotate(180deg); } .rua-cpicker-dropdown {
position: absolute;
top: 100%;
left: 0;
right: 0;
z-index: 999;
background: var(--rua-bg);
border: 1px solid var(--rua-accent);
border-top: none;
border-radius: 0 0 6px 6px;
box-shadow: 0 6px 20px rgba(0,0,0,.12);
overflow: hidden;
}
.rua-cpicker-dropdown[hidden] { display: none; } .rua-cpicker-search-wrap {
padding: 8px 10px;
border-bottom: 1px solid var(--rua-border);
background: var(--rua-bg-alt);
}
.rua-cpicker-search {
width: 100%;
padding: 7px 10px;
border: 1px solid var(--rua-border);
border-radius: 5px;
font-size: .88rem;
font-family: var(--rua-font);
background: var(--rua-bg);
color: var(--rua-text);
box-sizing: border-box;
}
.rua-cpicker-search:focus { outline: none; border-color: var(--rua-accent); } .rua-cpicker-list {
list-style: none;
margin: 0;
padding: 4px 0;
max-height: 220px;
overflow-y: auto;
overscroll-behavior: contain;
}
.rua-cpicker-option {
display: flex;
align-items: center;
gap: 10px;
padding: 8px 12px;
cursor: pointer;
font-size: .9rem;
color: var(--rua-text);
transition: background .1s;
}
.rua-cpicker-option:hover,
.rua-cpicker-option--focused {
background: color-mix(in srgb, var(--rua-accent) 8%, transparent);
}
.rua-cpicker-option--selected {
background: color-mix(in srgb, var(--rua-accent) 12%, transparent);
font-weight: 600;
}
.rua-cpicker-option--empty { color: var(--rua-text-muted); font-style: italic; }
.rua-cpicker-option--hidden { display: none; }
.rua-cpicker-opt-flag { font-size: 1.15rem; line-height: 1; flex-shrink: 0; }
.rua-cpicker-opt-name { flex: 1; } .rua-cpicker-no-results {
padding: 10px 14px;
color: var(--rua-text-muted);
font-size: .88rem;
font-style: italic;
display: none;
}
.rua-required { color: #d63638; margin-left: 2px; }
.rua-submit-btn {
width: 100%;
padding: 11px 20px;
background: var(--rua-accent);
color: #fff;
border: none;
border-radius: 6px;
font-size: 1rem;
font-weight: 600;
cursor: pointer;
transition: background .15s;
margin-top: 4px;
font-family: var(--rua-font);
}
.rua-submit-btn:hover:not(:disabled) { background: var(--rua-accent-dark); }
.rua-submit-btn:disabled { opacity: .65; cursor: not-allowed; }
.rua-cancel-btn {
padding: 10px 20px;
background: transparent;
border: 1px solid var(--rua-border);
border-radius: 6px;
font-size: .9rem;
color: var(--rua-text-muted);
cursor: pointer;
transition: all .15s;
font-family: var(--rua-font);
}
.rua-cancel-btn:hover { border-color: #d63638; color: #d63638; } .rua-form-msg {
font-size: .88rem;
padding: 0;
border-radius: 6px;
margin-bottom: 10px;
min-height: 0;
transition: all .2s;
}
.rua-form-msg:not(:empty) { padding: 10px 14px; }
.rua-msg--ok    { background: #d1e7dd; color: #0f5132; }
.rua-msg--error { background: #f8d7da; color: #842029; } #rua-login-form {
text-align: left;
}
#rua-login-form p {
margin-bottom: 14px;
}
#rua-login-form label {
display: block;
font-size: .85rem;
font-weight: 600;
margin-bottom: 4px;
color: var(--rua-text);
}
#rua-login-form input[type="text"],
#rua-login-form input[type="password"] {
width: 100%;
padding: 9px 12px;
border: 1px solid var(--rua-border);
border-radius: 6px;
font-size: .95rem;
background: var(--rua-bg);
color: var(--rua-text);
transition: border-color .15s;
box-sizing: border-box;
}
#rua-login-form input[type="text"]:focus,
#rua-login-form input[type="password"]:focus {
outline: none;
border-color: var(--rua-accent);
}
#rua-login-form .forgetmenot {
display: flex;
align-items: center;
gap: 6px;
font-size: .85rem;
color: var(--rua-text-muted);
}
#rua-login-form input[type="submit"] {
width: 100%;
padding: 10px 20px;
background: var(--rua-accent);
color: #fff;
border: none;
border-radius: 6px;
font-size: 1rem;
font-weight: 600;
cursor: pointer;
transition: background .15s;
margin-top: 4px;
}
#rua-login-form input[type="submit"]:hover {
background: var(--rua-accent-dark);
}
.rua-register-link {
margin-top: 20px;
font-size: .85rem;
color: var(--rua-text-muted);
}
.rua-register-link a {
color: var(--rua-accent);
text-decoration: none;
font-weight: 600;
}
.rua-register-link a:hover { text-decoration: underline; }
.rua-lost-password {
margin-top: 12px;
text-align: center;
font-size: .83rem;
}
.rua-lost-password a {
color: var(--rua-text-muted);
text-decoration: none;
}
.rua-lost-password a:hover {
color: var(--rua-accent);
text-decoration: underline;
} .rua-welcome {
display: flex;
align-items: center;
gap: 16px;
background: var(--rua-bg);
border: 1px solid var(--rua-border);
border-radius: var(--rua-radius);
box-shadow: var(--rua-shadow);
padding: 20px 24px;
margin-bottom: 24px;
flex-wrap: wrap;
}
.rua-avatar {
border-radius: 50%;
display: block;
}
.rua-welcome-text {
flex: 1;
min-width: 180px;
}
.rua-welcome-name {
font-size: 1.15rem;
margin: 0 0 4px;
color: var(--rua-text);
}
.rua-welcome-sub {
font-size: .8rem;
color: var(--rua-text-muted);
margin: 0 0 2px;
}
.rua-welcome-email {
font-size: .8rem;
color: var(--rua-text-muted);
margin: 0;
opacity: .85;
}
.rua-logout-btn {
padding: 7px 16px;
border: 1px solid var(--rua-border);
border-radius: 6px;
font-size: .85rem;
color: var(--rua-text-muted);
text-decoration: none;
transition: all .15s;
white-space: nowrap;
}
.rua-logout-btn:hover {
border-color: #d63638;
color: #d63638;
} .rua-section {
background: var(--rua-bg);
border: 1px solid var(--rua-border);
border-radius: var(--rua-radius);
box-shadow: var(--rua-shadow);
overflow: hidden;
}
.rua-section-title {
font-size: 1rem;
font-weight: 700;
padding: 16px 20px;
margin: 0;
border-bottom: 1px solid var(--rua-border);
background: var(--rua-bg-alt);
color: var(--rua-text);
} .rua-empty {
text-align: center;
padding: 48px 24px;
color: var(--rua-text-muted);
}
.rua-empty-icon {
font-size: 2.5rem;
margin-bottom: 12px;
}
.rua-empty p {
margin: 0;
font-size: .95rem;
} .rua-bookings-list {
padding: 16px;
display: flex;
flex-direction: column;
gap: 12px;
}
.rua-booking-card {
background: var(--rua-bg);
border: 1px solid var(--rua-border);
border-radius: 8px;
overflow: hidden;
transition: box-shadow .2s;
position: relative;
}
.rua-booking-card:hover {
box-shadow: 0 4px 16px rgba(0,0,0,.10);
}
.rua-booking-card--upcoming {
border-left: 4px solid var(--rua-accent);
}
.rua-booking-card--active {
border-left: 4px solid #1a7a4a;
background: color-mix(in srgb, #1a7a4a 4%, var(--rua-bg));
} .rua-booking-card-top {
display: flex;
align-items: center;
justify-content: space-between;
padding: 12px 16px 8px;
gap: 12px;
flex-wrap: wrap;
}
.rua-booking-ref {
display: flex;
align-items: center;
gap: 6px;
font-size: .8rem;
}
.rua-ref-label {
color: var(--rua-text-muted);
}
.rua-ref-code {
font-family: monospace;
font-weight: 700;
font-size: .85rem;
color: var(--rua-text);
background: var(--rua-bg-alt);
border: 1px solid var(--rua-border);
border-radius: 4px;
padding: 1px 7px;
letter-spacing: .5px;
} .rua-status {
font-size: .75rem;
font-weight: 700;
padding: 3px 10px;
border-radius: 20px;
text-transform: uppercase;
letter-spacing: .5px;
}
.rua-status--pending   { background: #fff3cd; color: #856404; }
.rua-status--confirmed { background: #d1e7dd; color: #0f5132; }
.rua-status--cancelled { background: #f8d7da; color: #842029; }
.rua-status--completed { background: #e2e3e5; color: #41464b; } .rua-status-wrap {
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 3px;
} .rua-countdown {
font-size: .65rem;
font-weight: 600;
color: #b45309; letter-spacing: .15px;
white-space: nowrap;
line-height: 1;
}
.rua-countdown--urgent {
color: #dc2626; animation: rua-pulse 1s ease-in-out infinite;
}
.rua-countdown--expired {
color: var(--rua-text-muted);
font-weight: 400;
}
@keyframes rua-pulse {
0%, 100% { opacity: 1; }
50%       { opacity: .55; }
} .rua-booking-room {
padding: 0 16px 8px;
font-size: .9rem;
color: var(--rua-text-muted);
font-weight: 500;
} .rua-booking-dates {
display: flex;
align-items: center;
gap: 10px;
padding: 10px 16px;
background: var(--rua-bg-alt);
flex-wrap: wrap;
}
.rua-date-block {
display: flex;
flex-direction: column;
gap: 2px;
min-width: 80px;
}
.rua-nights-block {
min-width: 50px;
}
.rua-date-label {
font-size: .7rem;
color: var(--rua-text-muted);
text-transform: uppercase;
letter-spacing: .5px;
}
.rua-date-val {
font-size: .9rem;
font-weight: 600;
color: var(--rua-text);
}
.rua-date-arrow {
color: var(--rua-text-muted);
font-size: 1rem;
padding: 0 4px;
margin-top: 10px;
} .rua-booking-meta {
display: flex;
align-items: center;
gap: 10px;
padding: 10px 16px;
flex-wrap: wrap;
}
.rua-meta-item {
font-size: .8rem;
color: var(--rua-text-muted);
display: flex;
align-items: center;
gap: 4px;
}
.rua-payment-badge {
font-weight: 600;
color: var(--rua-text);
} .rua-booking-footer {
display: flex;
align-items: center;
justify-content: space-between;
padding: 12px 16px;
border-top: 1px solid var(--rua-border);
}
.rua-total-label {
font-size: .8rem;
color: var(--rua-text-muted);
text-transform: uppercase;
letter-spacing: .5px;
}
.rua-total-amount {
font-size: 1.15rem;
font-weight: 700;
color: var(--rua-text);
} .rua-active-badge,
.rua-upcoming-badge {
font-size: .8rem;
font-weight: 600;
padding: 6px 16px;
border-top: 1px solid var(--rua-border);
}
.rua-active-badge   { background: #d1e7dd; color: #0f5132; }
.rua-upcoming-badge { background: #cfe2ff; color: #084298; } .rua-profile-section {
margin-bottom: 24px;
}
.rua-profile-header {
display: flex;
align-items: center;
justify-content: space-between;
}
.rua-profile-edit-btn {
font-size: .8rem;
font-weight: 600;
padding: 5px 12px;
border: 1px solid var(--rua-border);
border-radius: 6px;
background: var(--rua-bg);
color: var(--rua-accent);
cursor: pointer;
transition: all .15s;
font-family: var(--rua-font);
}
.rua-profile-edit-btn:hover {
border-color: var(--rua-accent);
background: color-mix(in srgb, var(--rua-accent) 6%, transparent);
} .rua-profile-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 0;
padding: 16px;
}
.rua-profile-item {
display: flex;
flex-direction: column;
gap: 3px;
padding: 10px 12px;
border-bottom: 1px solid var(--rua-border);
border-right: 1px solid var(--rua-border);
}
.rua-profile-item:nth-child(even) { border-right: none; }
.rua-profile-item:nth-last-child(-n+2) { border-bottom: none; }
.rua-profile-label {
font-size: .7rem;
text-transform: uppercase;
letter-spacing: .5px;
color: var(--rua-text-muted);
font-weight: 500;
}
.rua-profile-val {
font-size: .95rem;
font-weight: 500;
color: var(--rua-text);
} .rua-profile-view--hidden { display: none; }
.rua-profile-edit--hidden { display: none; } .rua-form-group--email-ro { justify-content: center; }
.rua-email-readonly {
font-size: .9rem;
color: var(--rua-text-muted);
padding: 9px 0;
} .rua-profile-actions {
display: flex;
gap: 10px;
margin-top: 4px;
}
.rua-profile-actions .rua-submit-btn { flex: 1; } #rua-profile-edit-form .rua-profile-grid {
padding-bottom: 0;
}
#rua-profile-edit-form {
padding: 16px;
} .rua-stats-strip {
display: flex;
align-items: stretch;
background: var(--rua-bg);
border: 1px solid var(--rua-border);
border-radius: var(--rua-radius);
box-shadow: var(--rua-shadow);
overflow: hidden;
margin-bottom: 24px;
}
.rua-stat-item {
flex: 1;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 18px 12px;
gap: 4px;
text-align: center;
}
.rua-stat-value {
font-size: 1.5rem;
font-weight: 700;
color: var(--rua-text);
line-height: 1.1;
}
.rua-stat-label {
font-size: .72rem;
text-transform: uppercase;
letter-spacing: .6px;
color: var(--rua-text-muted);
font-weight: 500;
}
.rua-stat-divider {
width: 1px;
background: var(--rua-border);
align-self: stretch;
} @media (max-width: 560px) {
.rua-form-row--2col { flex-direction: column; gap: 0; }
.rua-profile-grid   { grid-template-columns: 1fr; }
.rua-profile-item   { border-right: none; }
.rua-profile-item:nth-last-child(-n+2) { border-bottom: 1px solid var(--rua-border); }
.rua-profile-item:last-child           { border-bottom: none; }
}
@media (max-width: 480px) {
.rua-wrap { padding: 16px 12px; }
.rua-login-box { padding: 28px 20px; }
.rua-welcome { padding: 16px; gap: 12px; }
.rua-booking-dates { gap: 6px; }
.rua-date-arrow { display: none; }
.rua-stat-value { font-size: 1.2rem; }
.rua-stat-item  { padding: 14px 8px; }
.rua-profile-actions { flex-direction: column; }
} .rua-danger-zone {
border: 1px solid #fca5a5;
border-radius: 8px;
padding: 20px 24px;
margin-top: 40px;
background: #fff5f5;
}
.rua-danger-title {
margin: 0 0 8px;
font-size: 15px;
font-weight: 700;
color: #991b1b;
}
.rua-danger-desc {
margin: 0 0 16px;
font-size: 13px;
color: #7f1d1d;
line-height: 1.6;
}
.rua-btn--danger {
display: inline-block;
padding: 9px 20px;
background: #dc2626;
color: #fff;
border: 1px solid #b91c1c;
border-radius: 6px;
font-size: 13px;
font-weight: 600;
cursor: pointer;
line-height: 1.4;
transition: background .15s ease, transform .1s ease;
}
.rua-btn--danger:hover {
background: #b91c1c;
border-color: #991b1b;
}
.rua-btn--danger:active {
transform: scale(.98);
}
.rua-btn--danger:disabled {
opacity: .6;
cursor: not-allowed;
} .rua-section-hd {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 8px;
margin-bottom: 16px;
}
.rua-section-hd .rua-section-title {
margin: 0;
display: flex;
align-items: center;
gap: 8px;
}
.rua-bookings-badge {
display: inline-flex;
align-items: center;
justify-content: center;
min-width: 22px;
height: 22px;
padding: 0 6px;
background: var(--rooms-color-accent, #2271b1);
color: #fff;
border-radius: 11px;
font-size: 11px;
font-weight: 700;
line-height: 1;
flex-shrink: 0;
}
.rua-toggle-btn {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 7px 14px;
background: transparent;
border: 1px solid var(--rooms-color-accent, #2271b1);
color: var(--rooms-color-accent, #2271b1);
border-radius: 6px;
font-size: 13px;
font-weight: 500;
cursor: pointer;
transition: background .15s, color .15s, border-color .15s;
white-space: nowrap;
}
.rua-toggle-btn:hover {
background: var(--rooms-color-accent, #2271b1);
color: #fff;
}
.rua-toggle-chevron {
display: inline-block;
font-size: 10px;
transition: transform .25s ease;
} .rua-bookings-body[hidden] {
display: none !important;
} .rua-status--deposit { background: #dbeafe; color: #1e40af; } .rua-passport-row {
display: flex;
align-items: center;
gap: 6px;
padding: 6px 14px;
font-size: .82rem;
color: var(--rua-text-muted, #6b7280);
border-top: 1px solid var(--rua-border);
}
.rua-passport-label { font-weight: 600; }
.rua-passport-value { font-family: monospace; letter-spacing: .5px; } .rua-deposit-row {
display: flex;
flex-wrap: wrap;
align-items: center;
gap: 4px 10px;
padding: 6px 14px;
font-size: .82rem;
border-top: 1px solid var(--rua-border);
background: #f0fdf4;
}
.rua-deposit-label  { color: #065f46; font-weight: 600; }
.rua-deposit-value  { color: #065f46; font-weight: 700; }
.rua-deposit-balance{ color: #374151; font-size: .79rem; } .rua-receipt-row {
padding: 8px 14px;
border-top: 1px solid var(--rua-border);
}
.rua-receipt-link {
display: inline-flex;
align-items: center;
gap: 5px;
font-size: .82rem;
font-weight: 600;
color: var(--rua-accent, #2271b1);
text-decoration: none;
transition: color .15s;
}
.rua-receipt-link:hover { color: var(--rua-accent-dark, #135e96); text-decoration: underline; }
@media (max-width: 480px) {
.rua-section-hd { flex-direction: column; align-items: flex-start; }
.rua-toggle-btn { width: 100%; justify-content: center; }
}