:root {
--accent:    #c36c4b;
--accent-d:  #9e5238;
--accent-l:  #d98b70;
--slate:     #404e56;
--slate-d:   #2c3840;
--slate-l:   #566470;
--bg0:       #1e2a30;
--bg1:       #243038;
--bg2:       #2c3840;
--bg3:       #354048;
--border:    rgba(195,108,75,0.18);
--border-s:  rgba(86,100,112,0.55);
--text:      #e8e2db;
--muted:     #8a9099;
--font-head: 'Rajdhani', sans-serif;
--font-body: 'Exo 2', sans-serif;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
background: var(--bg0);
color: var(--text);
font-family: var(--font-body);
min-height: 100vh;
}
body::before {
content: '';
position: fixed; inset: 0;
background-image:
    linear-gradient(rgba(195,108,75,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(64,78,86,0.07) 1px, transparent 1px);
background-size: 48px 48px;
pointer-events: none; z-index: 0;
}

.page { position: relative; z-index: 1; max-width: 820px; margin: 0 auto; padding: 2rem 1.5rem 4rem; }

/* ── Header ── */
.header {
display: flex; align-items: center; justify-content: space-between;
padding-bottom: 1.5rem;
border-bottom: 1px solid var(--border-s);
margin-bottom: 2.5rem;
}
.logo {
font-family: var(--font-head); font-size: 1.55rem; font-weight: 700;
letter-spacing: 4px; color: var(--accent-l); text-transform: uppercase;
}
.logo span { color: var(--text); opacity: .65; }
.header-badge {
font-size: 0.68rem; font-weight: 600; letter-spacing: 2px;
text-transform: uppercase; color: var(--muted);
border: 1px solid var(--border-s); border-radius: 4px; padding: 4px 10px;
}

/* ── Profile card ── */
.profile.card {
display: flex; align-items: center; gap: 1.5rem;
position: relative; overflow: hidden;
}
.profile.card::before {
content: '';
position: absolute; top: 0; left: 0; right: 0; height: 3px;
background: linear-gradient(90deg, var(--accent), var(--accent-l), transparent);
}
.avatar-placeholder {
width: 70px; height: 70px; border-radius: 50%; flex-shrink: 0;
background: linear-gradient(135deg, var(--slate-d), var(--bg3));
border: 2px solid var(--accent);
box-shadow: 0 0 0 4px rgba(195,108,75,0.12);
display: flex; align-items: center; justify-content: center;
font-family: var(--font-head); font-size: 1.55rem; font-weight: 700;
color: var(--accent-l);
}
.profile-info { flex: 1; }
.pseudo {
font-family: var(--font-head); font-size: 1.65rem; font-weight: 700;
letter-spacing: 1px; line-height: 1; color: #fff; margin-bottom: 8px;
}
.profile-meta { display: flex; gap: 1.5rem; }
.meta-item { font-size: 0.76rem; color: var(--muted); }
.meta-item strong { display: block; font-size: 0.86rem; color: var(--text); font-weight: 500; }

.coins-display {
display: flex; flex-direction: column; align-items: center;
background: var(--bg3); border: 1px solid var(--border);
border-radius: 10px; padding: 0.85rem 1.25rem; min-width: 105px;
}
.coins-icon { font-size: 1.2rem; margin-bottom: 3px; }
.coins-label { font-size: 0.6rem; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-bottom: 2px; }
.coins-val { font-family: var(--font-head); font-size: 1.45rem; font-weight: 700; color: var(--accent-l); }

/* ── Section title ── */
.section-title {
font-family: var(--font-head); font-size: 0.68rem; font-weight: 600;
letter-spacing: 3px; text-transform: uppercase; color: var(--accent-l);
margin-bottom: 0.9rem; display: flex; align-items: center; gap: 8px;
}
.section-title::after { content: ''; flex: 1; height: 1px; background: var(--border-s); }

/* ── Pills ── */
.pill {
font-size: 0.6rem; letter-spacing: 1.5px;
text-transform: uppercase; padding: 3px 8px; border-radius: 20px; font-weight: 600;
float: right;
}
.pill.orange { background: rgba(195,108,75,0.18); color: var(--accent-l); border: 1px solid rgba(195,108,75,0.35); }
.pill.slate  { background: rgba(64,78,86,0.45); color: #a8b5be; border: 1px solid rgba(86,100,112,0.5); }
.pill.green  { background: rgba(60,180,100,0.14); color: #72d49a; border: 1px solid rgba(60,180,100,0.28); }
.pill.red    { background: rgba(220,60,60,0.14); color: #e08585; border: 1px solid rgba(220,60,60,0.28); }
.pill.amber  { background: rgba(220,160,50,0.14); color: #e8c06a; border: 1px solid rgba(220,160,50,0.28); }

/* Pass actif banner */
.pass-banner {
background: linear-gradient(120deg, rgba(195,108,75,0.13), rgba(64,78,86,0.25));
border: 1px solid rgba(195,108,75,0.3);
border-radius: 10px; padding: 1.1rem 1.3rem;
display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem;
margin: 1.25rem 0;
}
.pass-badge {
font-family: var(--font-head); font-size: 0.62rem; font-weight: 700;
letter-spacing: 2.5px; text-transform: uppercase;
background: var(--accent); color: #fff;
border-radius: 4px; padding: 3px 9px;
display: inline-block; margin-bottom: 7px;
}
.pass-name {
font-family: var(--font-head); font-size: 1.4rem; font-weight: 700;
color: #fff; line-height: 1; margin-bottom: 7px;
}
.pass-dates { font-size: 0.74rem; color: var(--muted); line-height: 1.7; }
.pass-dates strong { color: var(--text); font-weight: 500; }
.pass-right { text-align: right; flex-shrink: 0; }
.pass-right-label { font-size: 0.6rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 3px; }
.pass-right-val {
font-family: var(--font-head); font-size: 1.75rem; font-weight: 700;
color: var(--accent-l); line-height: 1;
}

/* Temps cards */
.time-row { display: flex; gap: 1rem; flex-wrap: wrap; }
.time-cell {
background: var(--bg3); border: 1px solid var(--border-s);
border-radius: 10px; padding: 1rem 1.25rem; flex: 1; min-width: 135px;
}
.time-cell-label { font-size: 0.63rem; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-bottom: 6px; }
.time-cell-val { font-family: var(--font-head); font-size: 1.9rem; font-weight: 700; line-height: 1; color: #fff; }
.time-cell-val.accent { color: var(--accent-l); }
.time-cell-sub { font-size: 0.68rem; color: var(--muted); margin-top: 4px; }

/* Progress */
.progress-track {
width: 100%; height: 5px; background: var(--bg3);
border-radius: 99px; overflow: hidden; margin-top: 1.15rem;
}
.progress-fill {
height: 100%; border-radius: 99px;
background: linear-gradient(90deg, var(--accent-d), var(--accent), var(--accent-l));
}
.progress-meta {
display: flex; justify-content: space-between;
font-size: 0.66rem; color: var(--muted); margin-top: 6px;
}

/* Cumul note */
.cumul-note {
margin-top: 1.15rem;
background: rgba(54,64,72,0.6); border: 1px solid var(--border-s);
border-left: 3px solid var(--accent);
border-radius: 0 8px 8px 0; padding: 0.75rem 1rem;
font-size: 0.75rem; color: var(--muted); line-height: 1.6;
}
.cumul-note strong { color: var(--text); font-weight: 500; }

/* ── PC block ── */
.availability.card {
background: var(--bg2); border: 1px solid var(--border-s);
border-radius: 14px; padding: 1.5rem 1.8rem;
margin-bottom: 1.75rem;
animation: fadein .4s ease .1s both;
display: flex; align-items: center; gap: 1.5rem;
}
.pc-count-wrap {
background: var(--bg3); border: 1px solid var(--border);
border-radius: 10px; padding: 0.9rem 1.6rem; text-align: center; flex-shrink: 0;
}
.pc-count {
font-family: var(--font-head); font-size: 3rem; font-weight: 700;
line-height: 1; color: var(--accent-l);
}
.pc-count-sub { font-size: 0.62rem; letter-spacing: 2px; text-transform: uppercase; color: var(--muted); margin-top: 3px; }
.pc-detail { flex: 1; }
.pc-title { font-family: var(--font-head); font-size: 1.1rem; font-weight: 600; color: #fff; margin-bottom: 4px; }
.pc-desc { font-size: 0.74rem; color: var(--muted); line-height: 1.55; }
.pc-affluence { display: flex; align-items: center; gap: 6px; margin-top: 10px; }
.affluence-label { font-size: 0.7rem; color: var(--muted); }

.footer { text-align: center; font-size: 0.67rem; color: var(--muted); margin-top: 3rem; letter-spacing: 1px; }

@keyframes fadein {
from { opacity: 0; transform: translateY(12px); }
to   { opacity: 1; transform: translateY(0); }
}

@media (max-width: 560px) {
.profile.card { flex-direction: column; text-align: center; }
.profile-meta { justify-content: center; }
.coins-display { width: 100%; }
.pass-banner { flex-direction: column; }
.pass-right { text-align: left; }
.availability.card { flex-direction: column; text-align: center; }
.pc-count-wrap { width: 100%; }
.pc-affluence { justify-content: center; }
.stream.card { flex-direction: column; gap: 1rem; text-align: center; }
}

/* ================================================================================ */
/* Card */
.card {
    background: var(--bg2);
    border: 1px solid var(--border-s);
    border-radius: 14px;
    padding: 24px;
    animation: fadein .4s ease .15s both;
}

.card:not(:last-of-type) {
    margin-top: 1.75rem;
    margin-bottom: 1.75rem;
}

/* Button */
.btn {
    background: rgba(195,108,75,0.14); border: 1px solid rgba(195,108,75,0.38);
    color: var(--accent-l); font-family: var(--font-body); font-weight: 600;
    font-size: 0.8rem; letter-spacing: 0.5px;
    padding: 8px 18px; border-radius: 8px; cursor: pointer; transition: all .2s;
}
.btn:hover { background: rgba(195,108,75,0.24); }

/* Stream */
.stream.card {
    /* display: flex;
    align-items: center;
    justify-content: space-between; */
    align-items: left;
}

.stream.card iframe {
    border: none;
    border-radius: 12px;
    margin-top: 12px;
}

.stream-info { display: flex; align-items: center; gap: 1rem; }

/* .stream-info > *:last-child {
    margin-left: auto;
} */
.stream-icon {
width: 42px; height: 42px; border-radius: 10px;
background: rgba(195,108,75,0.12);
display: flex; align-items: center; justify-content: center; color: var(--accent-l);
}
.stream-icon svg { width: 20px; height: 20px; }
.stream-label { font-size: 0.64rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); margin-bottom: 3px; }
.stream-status { font-family: var(--font-head); font-size: 1.1rem; font-weight: 600; color: #fff; }
.dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex-shrink: 0; }





















/* ================================================================================ */
/* ── Login page ── */
.login-page {
    position: relative;
    z-index: 1;
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1.5rem;
}

.login-wrap {
    width: 100%;
    max-width: 420px;
}

.login-card {
    position: relative;
    overflow: hidden;
    padding: 2rem 2.25rem;
}
.login-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--accent), var(--accent-l), transparent);
}

.login-title {
    font-family: var(--font-head);
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 1px;
    color: #fff;
    margin-bottom: 6px;
    line-height: 1;
}

.login-subtitle {
    font-size: 0.78rem;
    color: var(--muted);
    margin-bottom: 1.75rem;
    line-height: 1.5;
}

.login-error {
    background: rgba(220,60,60,0.14);
    border: 1px solid rgba(220,60,60,0.28);
    border-left: 3px solid #e08585;
    border-radius: 0 8px 8px 0;
    padding: 0.7rem 1rem;
    color: #e08585;
    font-size: 0.78rem;
    line-height: 1.5;
    margin-bottom: 1.25rem;
}

.form-group {
    margin-bottom: 1.15rem;
}

.form-label {
    display: block;
    font-family: var(--font-head);
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--muted);
    margin-bottom: 7px;
}

.form-input {
    width: 100%;
    background: var(--bg3);
    border: 1px solid var(--border-s);
    border-radius: 8px;
    padding: 11px 14px;
    font-family: var(--font-body);
    font-size: 0.9rem;
    color: var(--text);
    outline: none;
    transition: border-color .2s, background .2s, box-shadow .2s;
}
.form-input:hover {
    border-color: rgba(195,108,75,0.35);
}
.form-input:focus {
    border-color: var(--accent);
    background: var(--bg2);
    box-shadow: 0 0 0 3px rgba(195,108,75,0.14);
}

.btn-block {
    width: 100%;
    margin-top: 0.5rem;
    padding: 12px 18px;
    font-size: 0.78rem;
    letter-spacing: 2px;
    text-transform: uppercase;
}

@media (max-width: 480px) {
    .login-card { padding: 1.75rem 1.5rem; }
}