:root{--black:#0a0a0a;--charcoal:#141414;--dark:#1c1c1c;--gray:#2a2a2a;--silver:#888;--light:#bbb;--chrome:#ddd;--white:#fff;--success:#28a745;--error:#dc3545;--font:'Inter',sans-serif}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--black);color:var(--chrome);line-height:1.6;min-height:100vh}
a{color:var(--chrome);text-decoration:none;transition:.2s}a:hover{color:var(--white)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-family:var(--font);font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;border:none;border-radius:4px;cursor:pointer;transition:.2s}
.btn-primary{background:linear-gradient(135deg,var(--chrome),var(--silver));color:var(--black)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 20px rgba(0,0,0,.3);color:var(--black)}
.btn-secondary{background:transparent;color:var(--chrome);border:1px solid var(--gray)}
.btn-secondary:hover{background:var(--white);color:var(--black)}
.btn-sm{padding:.5rem 1rem;font-size:.75rem}
.btn-lg{padding:1rem 2rem}
.btn-block{width:100%}
.btn-danger{background:var(--error);color:var(--white)}
.form-group{margin-bottom:1.25rem}
.form-label{display:block;margin-bottom:.5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--light)}
.form-input,.form-select{width:100%;padding:.875rem 1rem;background:var(--charcoal);border:1px solid var(--gray);border-radius:4px;color:var(--white);font-family:var(--font);font-size:1rem;transition:.2s}
.form-input:focus,.form-select:focus{outline:none;border-color:var(--silver)}
.form-input::placeholder{color:var(--silver)}
.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:3rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer}
.form-checkbox input{width:18px;height:18px;accent-color:var(--silver)}
.alert{padding:1rem 1.5rem;border-radius:4px;margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem}
.alert-success{background:rgba(40,167,69,.15);border:1px solid rgba(40,167,69,.3);color:#5cb85c}
.alert-error{background:rgba(220,53,69,.15);border:1px solid rgba(220,53,69,.3);color:#ff6b6b}
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:radial-gradient(ellipse at 30% 20%,rgba(255,255,255,.02) 0%,transparent 50%),var(--black)}
.auth-container{width:100%;max-width:420px}
.auth-box{background:var(--charcoal);border:1px solid var(--gray);border-radius:8px;padding:2rem}
.auth-header{text-align:center;margin-bottom:2rem}
.auth-header img{height:70px;margin:0 auto 1rem}
.auth-header h1{font-size:1.5rem;margin-bottom:.25rem;color:var(--white)}
.auth-header p{color:var(--silver);margin:0}
.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0;color:var(--silver);font-size:.875rem}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--gray)}
.auth-footer{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--gray);color:var(--silver)}
.back-link{text-align:center;margin-top:1.5rem;color:var(--silver)}
.form-row-flex{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;font-size:.875rem}
.portal-header{background:var(--charcoal);border-bottom:1px solid var(--gray);padding:1rem 1.5rem;position:sticky;top:0;z-index:100}
.portal-header-inner{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}
.portal-logo{display:flex;align-items:center;gap:.75rem}
.portal-logo img{height:45px}
.portal-logo h1{font-size:1.25rem;font-weight:600;margin:0}
.portal-logo h1 span{color:var(--silver)}
.portal-user{display:flex;align-items:center;gap:1rem}
.portal-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--chrome),var(--silver));display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--black);font-size:.875rem}
.portal-user-info{text-align:right}
.portal-user-name{font-weight:500;color:var(--white)}
.portal-user-role{font-size:.75rem;color:var(--silver);text-transform:uppercase;letter-spacing:.05em}
.portal-nav{background:var(--dark);border-bottom:1px solid var(--gray);padding:0 1.5rem}
.portal-nav ul{display:flex;list-style:none;gap:.25rem;max-width:1200px;margin:0 auto}
.portal-nav a{display:block;padding:1rem 1.5rem;color:var(--silver);font-size:.875rem;font-weight:500;border-bottom:2px solid transparent;transition:.2s}
.portal-nav a:hover,.portal-nav a.active{color:var(--white);border-bottom-color:var(--white)}
.portal-content{padding:3rem 1.5rem;max-width:1200px;margin:0 auto}
.portal-welcome{margin-bottom:2rem}
.portal-welcome h1{margin-bottom:.25rem;color:var(--white)}
.portal-welcome p{color:var(--silver);margin:0}
.card{background:var(--charcoal);border:1px solid var(--gray);border-radius:8px;margin-bottom:1.5rem;overflow:hidden}
.card-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--gray)}
.card-header h2{font-size:1.125rem;font-weight:600;margin:0;color:var(--white)}
.card-body{padding:1.5rem}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}
.stat-card{background:var(--charcoal);border:1px solid var(--gray);border-radius:8px;padding:1.5rem}
.stat-value{font-size:2rem;font-weight:600;color:var(--white)}
.stat-label{font-size:.75rem;color:var(--silver);text-transform:uppercase;letter-spacing:.05em}
.apt-card{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:var(--dark);border-radius:4px;margin-bottom:1rem;border-left:3px solid var(--silver)}
.apt-card:last-child{margin-bottom:0}
.apt-info h4{color:var(--white);margin-bottom:.25rem;font-weight:600}
.apt-meta{display:flex;gap:1.5rem;color:var(--silver);font-size:.875rem}
.apt-meta span{display:flex;align-items:center;gap:.25rem}
.apt-meta svg{width:16px;height:16px}
.apt-status{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}
.status-confirmed{background:rgba(40,167,69,.15);color:#5cb85c}
.status-pending{background:rgba(255,193,7,.15);color:#ffc107}
.status-completed{background:rgba(23,162,184,.15);color:#17a2b8}
.status-cancelled{background:rgba(220,53,69,.15);color:#dc3545}
.empty-state{text-align:center;padding:3rem;color:var(--silver)}
.empty-state svg{width:64px;height:64px;stroke:var(--gray);margin-bottom:1rem}
.empty-state h3{color:var(--chrome);margin-bottom:.5rem}
.lang-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.95);backdrop-filter:blur(10px)}
.lang-box{background:var(--charcoal);border:1px solid var(--gray);border-radius:8px;padding:2.5rem;max-width:380px;width:90%;text-align:center}
.lang-box img{height:70px;margin:0 auto 1.5rem}
.lang-box h2{margin-bottom:.5rem;font-size:1.5rem;color:var(--white)}
.lang-box p{color:var(--silver);margin-bottom:1.5rem}
.lang-opts{display:flex;flex-direction:column;gap:1rem}
.lang-opt{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;background:var(--dark);border:2px solid var(--gray);border-radius:8px;color:var(--chrome);font-size:1rem;font-weight:500;transition:.2s}
.lang-opt:hover{border-color:var(--white);color:var(--white);background:var(--gray)}
/* Language Toggle */
.lang-toggle{display:flex;align-items:center;gap:0.5rem;padding:0.5rem 0.875rem;background:transparent;border:1px solid var(--gray);border-radius:20px;color:var(--silver);font-size:0.8125rem;font-weight:600;letter-spacing:0.5px;cursor:pointer;transition:all .2s}
.lang-toggle:hover{border-color:var(--chrome);color:var(--chrome)}
.lang-toggle svg{width:16px;height:16px}

/* Admin Styles */
.admin-nav{background:linear-gradient(90deg,var(--dark),#1a1510)}
.admin-nav a.active{border-bottom-color:#ffc107;color:#ffc107}
.admin-role{color:#ffc107}
.admin-avatar{background:linear-gradient(135deg,#ffc107,#ff8c00)}
.confirmed-indicator{display:inline-flex;align-items:center;gap:0.25rem;color:#28a745;font-size:0.75rem;margin-left:0.5rem}
.confirmed-indicator svg{width:14px;height:14px}
.stat-sub{font-size:0.75rem;color:var(--silver);margin-top:0.25rem}
.stat-sub .confirmed{color:#28a745}
.card-date{color:var(--silver)}
.client-type{color:var(--silver)}
.status-form{display:flex;gap:0.5rem}
.form-select-sm{padding:0.4rem;font-size:0.75rem;width:auto}

/* Dashboard Styles */
.dashboard-actions{margin-bottom:2rem}
.card-count{color:var(--silver)}
.apt-actions{display:flex;align-items:center;gap:1rem}
.empty-state-btn{margin-top:1rem}
.account-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}
.account-label{color:var(--silver);font-size:.75rem;text-transform:uppercase;display:block;margin-bottom:.25rem}
.account-value{color:var(--chrome);margin:0}

/* Auth page extras */
.success-btn{margin-top:1.5rem}
.reset-email{text-align:center;color:var(--silver);margin-bottom:1.5rem}
.verification-result-margin{margin-top:1rem}
.auth-footer-margin{margin-top:1.5rem}

/* Code Verification */
.code-input-container{display:flex;justify-content:center;gap:0.5rem;margin:1.5rem 0}
.code-input{width:50px;height:60px;text-align:center;font-size:1.75rem;font-weight:700;font-family:monospace;background:var(--dark);border:2px solid var(--gray);border-radius:8px;color:var(--white);transition:all 0.2s}
.code-input:focus{outline:none;border-color:var(--chrome);background:var(--charcoal)}
.code-input.filled{border-color:var(--silver)}
.code-input.error{border-color:var(--error);animation:shake 0.3s}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.email-display{background:var(--dark);border-radius:8px;padding:1rem;text-align:center;margin-bottom:1.5rem}
.email-display small{color:var(--silver)}
.email-highlight{color:var(--chrome);font-weight:600}
.resend-section{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--gray)}
.resend-section p{color:var(--silver);font-size:0.875rem;margin-bottom:0.75rem}
.resend-form{display:inline}
.hidden-input{position:absolute;opacity:0;pointer-events:none}
.code-hint{color:var(--silver);font-size:0.8rem;text-align:center;margin:1rem 0}
.verification-success{text-align:center;padding:2rem 0}
.verification-success .success-icon{width:80px;height:80px;background:linear-gradient(135deg,#28a745,#20c997);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}
.verification-success .success-icon svg{width:40px;height:40px;stroke:#fff}
.verification-success h2{color:var(--white);margin-bottom:0.5rem}
.verification-success p{color:var(--silver);margin-bottom:1.5rem}

/* Language Modal - use .active class instead of inline style */
.lang-modal.active{display:flex}

@media(max-width:768px){
    .form-row{grid-template-columns:1fr}
    .apt-card{flex-direction:column;align-items:flex-start;gap:1rem}
    .portal-nav ul{overflow-x:auto}
    .portal-nav a{white-space:nowrap;padding:1rem}
}

/* Mobile auth page fixes */
@media(max-width:480px){
    .auth-page{padding:1rem;align-items:flex-start;padding-top:2rem}
    .auth-container{max-width:100%}
    .auth-box{padding:1.5rem;border-radius:8px}
    .auth-header img{height:60px}
    .auth-header h1{font-size:1.25rem}
    .auth-header p{font-size:0.875rem}
    .btn-lg{padding:0.875rem 1.5rem;font-size:0.8125rem}
    .form-row-flex{flex-direction:column;align-items:flex-start;gap:0.75rem}
    .lang-box{padding:1.5rem;width:95%}
    .lang-box img{height:60px}
    .lang-box h2{font-size:1.25rem}
}

/* ---------------------------------------------
   Verification Styles
   --------------------------------------------- */
.verification-sent,
.verification-result {
    text-align: center;
    padding: 2rem 0;
}

.verification-sent .success-icon,
.verification-result .result-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 1.5rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.verification-sent .success-icon {
    background: rgba(40, 167, 69, 0.15);
    color: var(--success);
}

.result-icon.success {
    background: rgba(40, 167, 69, 0.15);
    color: var(--success);
}

.result-icon.error {
    background: rgba(220, 53, 69, 0.15);
    color: var(--error);
}

.result-icon.warning {
    background: rgba(255, 193, 7, 0.15);
    color: #ffc107;
}

.verification-sent .success-icon svg,
.verification-result .result-icon svg {
    width: 40px;
    height: 40px;
}

.verification-sent h3,
.verification-result h2 {
    color: var(--white);
    margin-bottom: 1rem;
}

.verification-sent p,
.verification-result p {
    color: var(--silver);
    margin-bottom: 1rem;
}

.email-note {
    font-weight: 600;
    color: var(--chrome) !important;
}

.spam-note {
    font-size: 0.875rem;
    color: var(--silver) !important;
}

.form-hint {
    display: block;
    margin-top: 0.375rem;
    font-size: 0.75rem;
    color: var(--silver);
}

.recaptcha-notice {
    margin-top: 1rem;
    font-size: 0.75rem;
    color: var(--silver);
    text-align: center;
}

.recaptcha-notice a {
    color: var(--light);
}

.recaptcha-notice a:hover {
    color: var(--white);
}

/* Hide reCAPTCHA badge - we show notice instead */
.grecaptcha-badge {
    visibility: hidden !important;
}

/* ---------------------------------------------
   Loading Spinner Overlay
   --------------------------------------------- */
.loading-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(10, 10, 10, 0.9);
    display: none;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 1.5rem;
}

.loading-overlay.active {
    display: flex;
}

.loading-spinner {
    width: 60px;
    height: 60px;
    animation: spin 1s linear infinite;
}

.loading-spinner img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.loading-text {
    color: var(--silver);
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}
/* ---------------------------------------------
   Error Page Styles
   --------------------------------------------- */
.error-page {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
}

.error-container {
    text-align: center;
    max-width: 400px;
}

.error-container h1 {
    font-size: 1.5rem;
    margin-bottom: 1rem;
    color: var(--white);
}

.error-container p {
    color: var(--silver);
    margin-bottom: 1.5rem;
    line-height: 1.6;
}

.error-contact {
    margin-top: 2rem;
    font-size: 0.875rem;
    color: var(--silver);
}

/* =============================================
   Portal Header Mobile Fixes
   Add these styles to portal.css
   ============================================= */

/* Avatar as clickable link */
.portal-avatar-link {
    text-decoration: none;
    display: flex;
}

.portal-avatar-link:hover .portal-avatar {
    transform: scale(1.05);
    box-shadow: 0 0 0 2px var(--chrome);
}

.portal-avatar {
    transition: all 0.2s ease;
}

/* Language toggle styling */
.lang-toggle {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    background: transparent;
    border: 1px solid var(--gray);
    border-radius: 20px;
    color: var(--silver);
    font-size: 0.8125rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
}

.lang-toggle:hover {
    border-color: var(--chrome);
    color: var(--chrome);
}

.lang-icon {
    display: flex;
    align-items: center;
}

.lang-icon svg {
    width: 16px;
    height: 16px;
}

.lang-label {
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 1px;
}

/* =============================================
   Mobile Responsive - Portal Header
   ============================================= */
@media (max-width: 768px) {
    /* Hide "Benji's Cuts" text on mobile */
    .portal-logo-text,
    .portal-logo h1 {
        display: none;
    }
    
    /* Hide user name and role on mobile */
    .portal-user-info {
        display: none;
    }
    
    /* Adjust header padding */
    .portal-header {
        padding: 0.75rem 1rem;
    }
    
    /* Smaller logo */
    .portal-logo img {
        height: 36px;
    }
    
    /* Smaller avatar */
    .portal-avatar {
        width: 34px;
        height: 34px;
        font-size: 0.75rem;
    }
    
    /* Tighter spacing */
    .portal-user {
        gap: 0.5rem;
    }
    
    /* Smaller logout button */
    .portal-user .btn-sm {
        padding: 0.375rem 0.625rem;
        font-size: 0.7rem;
    }
    
    /* Smaller lang toggle */
    .lang-toggle {
        padding: 0.375rem 0.5rem;
        gap: 0.375rem;
    }
    
    .lang-icon svg {
        width: 14px;
        height: 14px;
    }
    
    .lang-label {
        font-size: 0.7rem;
    }
    
    /* Nav tabs - smaller text, tighter spacing */
    .portal-nav {
        padding: 0 0.5rem;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    
    .portal-nav ul {
        gap: 0;
    }
    
    .portal-nav a {
        padding: 0.75rem 0.75rem;
        font-size: 0.75rem;
        white-space: nowrap;
    }
}

@media (max-width: 480px) {
    .portal-header {
        padding: 0.5rem 0.75rem;
    }
    
    .portal-logo img {
        height: 32px;
    }
    
    .portal-avatar {
        width: 30px;
        height: 30px;
        font-size: 0.65rem;
    }
    
    .portal-user {
        gap: 0.375rem;
    }
    
    .portal-nav a {
        padding: 0.625rem 0.5rem;
        font-size: 0.7rem;
    }
}