/* Roadmap page — premium content unlock visual
   Uses site-global tokens from styles.css. */

.roadmap-page{position:relative;z-index:1}

/* HERO */
.rm-hero{
    padding:180px 0 80px;  /* clears topbar + navbar with breathing room */
    text-align:center;
}
.rm-eyebrow{
    font-family:'Cinzel',serif;
    letter-spacing:5px;font-size:.78rem;
    color:var(--gold);
    text-transform:uppercase;
    margin-bottom:22px;
    font-weight:600;
    display:inline-flex;align-items:center;gap:14px;
}
.rm-eyebrow::before,.rm-eyebrow::after{
    content:"";display:inline-block;width:40px;height:1px;
    background:linear-gradient(90deg, transparent 0%, var(--gold) 100%);
}
.rm-eyebrow::after{background:linear-gradient(90deg, var(--gold) 0%, transparent 100%)}
.rm-title{
    font-family:'Cinzel',serif;
    font-size:clamp(2.4rem, 6.5vw, 5rem);
    font-weight:700;
    letter-spacing:4px;
    text-transform:uppercase;
    background:linear-gradient(180deg, #fff7e3 0%, var(--gold-bright) 45%, var(--gold) 75%, var(--gold-deep) 100%);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;
    filter:drop-shadow(0 4px 24px rgba(201,161,78,.35));
    line-height:1.1;margin-bottom:20px;
}
.rm-title span{
    display:block;font-size:.5em;letter-spacing:6px;opacity:.85;
    margin-top:10px;
    font-weight:600;
}
.rm-sub{
    font-size:1.05rem;color:var(--text-dim);
    max-width:700px;margin:0 auto 50px;
    line-height:1.65;letter-spacing:.3px;
}

/* Hero progress bar */
.rm-progress-hero{
    max-width:780px;margin:0 auto;
    background:var(--bg-glass);
    border:1px solid var(--line-strong);
    border-radius:var(--radius-lg);
    padding:26px 30px;
    backdrop-filter:blur(14px) saturate(140%);
    box-shadow:var(--shadow), inset 0 1px 0 rgba(245,217,134,.06);
    position:relative;
}
.rm-progress-hero::before{
    content:"";position:absolute;top:0;left:0;right:0;height:2px;
    background:linear-gradient(90deg, transparent 0%, var(--gold) 50%, transparent 100%);
    opacity:.6;
}
.rm-progress-bar{
    height:10px;border-radius:5px;
    background:rgba(0,0,0,.4);
    border:1px solid var(--line-cold);
    overflow:hidden;position:relative;margin-bottom:18px;
}
.rm-progress-fill{
    height:100%;
    background:linear-gradient(90deg, var(--gold-deep) 0%, var(--gold) 50%, var(--gold-bright) 100%);
    box-shadow:0 0 14px rgba(201,161,78,.6);
    border-radius:5px;
    position:relative;
    transition:width 1s ease;
}
.rm-progress-fill::after{
    content:"";position:absolute;inset:0;
    background:linear-gradient(90deg, transparent, rgba(255,238,180,.45), transparent);
    animation:shimmer 2.5s linear infinite;
}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.rm-progress-info{
    display:flex;justify-content:center;align-items:center;gap:16px;
    font-size:1.05rem;color:var(--text);
    flex-wrap:wrap;
}
.rm-progress-info strong{
    font-family:'Cinzel',serif;font-size:1.6rem;
    color:var(--gold-bright);
    text-shadow:0 0 12px rgba(201,161,78,.4);
}
.rm-light{color:var(--text-dim);font-size:.85rem;letter-spacing:.5px}
.rm-divider{color:var(--text-mute);opacity:.6}

/* TIMELINE — premium phase cards */
.rm-timeline-section{padding:40px 0 100px}
.rm-timeline{
    display:flex;flex-direction:column;gap:18px;
    position:relative;
}
.rm-timeline::before{
    content:"";position:absolute;left:40px;top:30px;bottom:30px;
    width:2px;
    background:linear-gradient(180deg, transparent, var(--gold-deep) 5%, var(--gold) 50%, var(--gold-deep) 95%, transparent);
    opacity:.5;
    z-index:0;
}
.rm-loading{text-align:center;color:var(--text-mute);padding:60px;font-style:italic}

/* Phase card */
.rm-phase{
    position:relative;z-index:1;
    display:grid;grid-template-columns:90px 1fr;gap:24px;
    background:var(--bg-glass);
    border:1px solid var(--line);
    border-radius:var(--radius-lg);
    overflow:hidden;
    backdrop-filter:blur(14px) saturate(140%);
    box-shadow:var(--shadow);
    transition:all var(--t);
}
.rm-phase:hover{
    transform:translateX(6px);
    border-color:var(--line-strong);
    box-shadow:var(--shadow-lg), var(--shadow-gold);
}

/* Status states */
.rm-phase.is-open{border-color:rgba(95,176,105,.4)}
.rm-phase.is-open::before{
    content:"";position:absolute;top:0;left:0;right:0;height:2px;
    background:linear-gradient(90deg, transparent, var(--ok), transparent);
}
.rm-phase.is-current{
    border-color:var(--gold);
    box-shadow:var(--shadow-lg), 0 0 40px rgba(201,161,78,.2), inset 0 1px 0 rgba(245,217,134,.1);
}
.rm-phase.is-current::before{
    content:"";position:absolute;top:0;left:0;right:0;height:2px;
    background:linear-gradient(90deg, transparent, var(--gold-bright), transparent);
    animation:shimmer 3s linear infinite;
}
.rm-phase.is-locked{opacity:.6}
.rm-phase.is-locked::before{
    content:"";position:absolute;top:0;left:0;right:0;height:2px;
    background:linear-gradient(90deg, transparent, var(--text-mute), transparent);
}

/* Left rail — phase number */
.rm-phase-num{
    background:linear-gradient(180deg, rgba(201,161,78,.12) 0%, rgba(201,161,78,.03) 100%);
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    border-right:1px solid var(--line);
    padding:24px 0;
    position:relative;
}
.rm-phase-num-big{
    font-family:'Cinzel',serif;font-size:2.4rem;
    color:var(--gold-bright);
    text-shadow:0 0 16px rgba(201,161,78,.5);
    line-height:1;
    font-weight:700;
}
.rm-phase-num-lbl{
    font-family:'Cinzel',serif;
    font-size:.68rem;color:var(--text-mute);
    text-transform:uppercase;letter-spacing:2px;
    margin-top:8px;
    font-weight:600;
}
.rm-phase.is-open .rm-phase-num{background:linear-gradient(180deg, rgba(95,176,105,.15) 0%, rgba(95,176,105,.04) 100%)}
.rm-phase.is-open .rm-phase-num-big{color:var(--ok);text-shadow:0 0 14px rgba(95,176,105,.5)}
.rm-phase.is-locked .rm-phase-num-big{color:var(--text-mute);text-shadow:none}
.rm-phase.is-locked .rm-phase-num{background:rgba(40,32,24,.2)}

/* Card body */
.rm-phase-body{padding:22px 24px;display:flex;flex-direction:column;gap:14px}
.rm-phase-header{
    display:flex;justify-content:space-between;align-items:flex-start;
    flex-wrap:wrap;gap:12px;
}
.rm-phase-title{
    font-family:'Cinzel',serif;font-size:1.3rem;font-weight:700;
    color:var(--text-bright);letter-spacing:1.5px;
    line-height:1.2;
    text-transform:uppercase;
}
.rm-phase-status{
    font-family:'Cinzel',serif;font-size:.7rem;font-weight:700;
    padding:6px 14px;border-radius:var(--radius);
    text-transform:uppercase;letter-spacing:1.5px;
    white-space:nowrap;flex-shrink:0;
}
.rm-status-open{background:rgba(95,176,105,.15);color:var(--ok);border:1px solid var(--ok)}
.rm-status-current{background:rgba(201,161,78,.18);color:var(--gold-bright);border:1px solid var(--gold);box-shadow:0 0 14px rgba(201,161,78,.3)}
.rm-status-upcoming{background:rgba(201,161,78,.06);color:var(--gold);border:1px solid var(--line-strong)}
.rm-status-locked{background:rgba(80,75,65,.15);color:var(--text-mute);border:1px solid var(--line)}

.rm-phase-date{
    display:flex;align-items:center;gap:10px;
    font-size:.85rem;color:var(--text-dim);
}
.rm-phase-date strong{color:var(--gold-bright);font-weight:600}
.rm-phase-countdown{
    display:inline-flex;align-items:center;gap:6px;
    padding:6px 12px;border-radius:var(--radius);
    background:rgba(201,161,78,.08);border:1px solid var(--line-strong);
    font-family:'Cinzel',serif;
    font-size:.78rem;color:var(--gold-bright);font-weight:700;
    letter-spacing:.5px;
}

/* Content lists */
.rm-content-grid{
    display:grid;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
    gap:14px;margin-top:6px;
}
.rm-content-section{
    background:rgba(0,0,0,.3);
    border:1px solid var(--line);
    border-radius:var(--radius);padding:14px;
}
.rm-content-section-title{
    font-family:'Cinzel',serif;
    font-size:.72rem;color:var(--gold);
    text-transform:uppercase;letter-spacing:1.5px;
    margin-bottom:10px;font-weight:700;
    display:flex;align-items:center;gap:8px;
}
.rm-content-section-title-icon{font-size:.95rem}
.rm-content-list{
    list-style:none;padding:0;margin:0;
    display:flex;flex-direction:column;gap:5px;
}
.rm-content-list li{
    font-size:.82rem;color:var(--text);
    display:flex;align-items:center;gap:6px;line-height:1.4;
}
.rm-content-list .rm-content-lvl{
    color:var(--text-mute);font-size:.72rem;
    margin-left:auto;font-weight:600;
}
.rm-content-list .rm-content-bullet{color:var(--gold);font-size:.55rem}

/* WHY block */
.rm-why{padding:80px 0 100px}
.rm-section-title{
    font-family:'Cinzel',serif;font-size:clamp(1.4rem, 3vw, 2rem);
    text-align:center;letter-spacing:4px;
    color:var(--text-bright);margin-bottom:50px;
    text-transform:uppercase;
    font-weight:700;
    position:relative;
}
.rm-section-title::after{
    content:"";display:block;
    width:80px;height:2px;
    background:linear-gradient(90deg, transparent 0%, var(--gold) 50%, transparent 100%);
    margin:14px auto 0;
}
.rm-why-grid{
    display:grid;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
    gap:20px;max-width:1100px;margin:0 auto;
}
.rm-why-card{
    background:var(--bg-glass);
    border:1px solid var(--line);
    border-radius:var(--radius-lg);
    padding:30px 26px;text-align:center;
    transition:all var(--t);
}
.rm-why-card:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:var(--shadow), var(--shadow-gold)}
.rm-why-icon{
    font-size:2.4rem;margin-bottom:16px;
    color:var(--gold-bright);
    filter:drop-shadow(0 0 14px rgba(201,161,78,.45));
}
.rm-why-card h3{
    font-family:'Cinzel',serif;font-size:1.05rem;
    color:var(--gold-bright);letter-spacing:1.5px;
    margin-bottom:12px;
    text-transform:uppercase;
}
.rm-why-card p{font-size:.88rem;color:var(--text-dim);line-height:1.6}

/* Mobile */
@media (max-width:640px){
    .rm-phase{grid-template-columns:60px 1fr;gap:16px}
    .rm-phase-num-big{font-size:1.8rem}
    .rm-phase-body{padding:18px}
    .rm-content-grid{grid-template-columns:1fr}
    .rm-hero{padding:120px 0 60px}
}
