*{box-sizing:border-box;margin:0;padding:0}
:root{
    --bg:#0d0d0d;
    --card:#111811;
    --card2:#111;
    --border:#1a2a1a;
    --border2:#1e1e1e;
    --red:#E24B4A;
    --green:#2ECC71;
    --amber:#EF9F27;
    --text:#f0f5f0;
    --text2:#2a4a2a;
    --text3:#3a5a3a;
}

html,body{
    background:var(--bg);
    color:var(--text);
    font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
    font-size:14px;
    line-height:1.4;
    -webkit-font-smoothing:antialiased;
    overscroll-behavior-y:contain;
    min-height:100vh;
    min-height:100dvh;
}

a{color:inherit;text-decoration:none}
button{font-family:inherit}

/* ====== APP SHELL ====== */
.app{
    max-width:500px;
    margin:0 auto;
    min-height:100vh;
    min-height:100dvh;
    display:flex;
    flex-direction:column;
    background:var(--bg);
    position:relative;
}

/* ====== TOPBAR ====== */
.topbar{
    background:#0a0a0a;
    border-bottom:0.5px solid #161e16;
    padding:14px 16px;
    display:flex;
    align-items:center;
    gap:10px;
    position:sticky;
    top:0;
    z-index:10;
}
.topbar-logo{display:flex;align-items:center;gap:8px;flex:1}
.logo-text{font-size:16px;font-weight:600;letter-spacing:-0.3px}
.logo-t{color:var(--red)}
.logo-r{color:var(--text)}
.topbar-title{font-size:16px;font-weight:500;color:var(--text);flex:1}
.back-btn{font-size:13px;color:var(--text3);cursor:pointer;padding:4px 0;background:transparent;border:none}
.back-btn:hover{color:var(--text)}
.plus-btn{
    width:30px;height:30px;border-radius:50%;
    background:#0a1f0a;border:1px solid var(--green);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;flex-shrink:0;text-decoration:none;
}

/* ====== CONTENT ====== */
.content{flex:1;padding:14px 16px;padding-bottom:80px}

.slbl{
    font-size:10px;font-weight:600;letter-spacing:0.08em;
    color:var(--text2);text-transform:uppercase;
    margin-bottom:8px;margin-top:4px;
}

/* ====== CARDS (челленджи) ====== */
.ch-card{
    background:var(--card);
    border:0.5px solid var(--border);
    border-radius:14px;
    padding:13px 14px;
    margin-bottom:9px;
    cursor:pointer;
    transition:border-color 0.15s;
    display:block;
    color:inherit;
}
.ch-card:hover{border-color:#2a4a2a}
.ch-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2px;gap:8px}
.ch-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.2;flex:1}
.ch-meta{font-size:10px;color:var(--text2);margin-bottom:10px;margin-top:2px}
.draft-tag{
    font-size:9px;padding:2px 7px;border-radius:20px;
    background:#2a1e00;color:var(--amber);
    border:0.5px solid #4a3a00;
    margin-left:6px;vertical-align:middle;
    display:inline-block;
}

/* ====== TRACK (шкала прогресса) ====== */
.track{position:relative;height:4px;margin-bottom:18px;margin-top:4px}
.track-bg{position:absolute;left:0;right:0;height:4px;background:#1e1e1e;border-radius:2px}
.track-fill{position:absolute;left:0;height:4px;background:var(--green);border-radius:2px}
.cp{position:absolute;width:10px;height:10px;border-radius:50%;top:50%;margin-top:-5px;transform:translateX(-50%)}
.cp.d{background:var(--green);border:2px solid var(--bg)}
.cp.n{background:var(--bg);border:2px solid var(--green)}
.cp.r{background:var(--bg);border:2px solid var(--red)}
.cp.p{background:#1a2a1a;border:1px solid #2a3a2a}
.cp-lbl{position:absolute;font-size:7px;top:12px;transform:translateX(-50%);white-space:nowrap}
.cp-lbl.d{color:#1a3a1a}
.cp-lbl.n{color:var(--green)}
.cp-lbl.r{color:var(--red)}
.cp-lbl.p{color:#1a2a1a}

/* ====== CARD FOOTER ====== */
.ch-foot{display:flex;align-items:center;justify-content:space-between;gap:8px}
.ch-foot-txt{font-size:10px;color:var(--text2)}

.pill-red{font-size:9px;padding:3px 9px;border-radius:20px;background:#1a0505;color:var(--red);border:0.5px solid #3a1010}
.pill-green{font-size:9px;padding:3px 9px;border-radius:20px;background:#0a1f0a;color:var(--green);border:0.5px solid #1a3a1a}
.pill-amber{font-size:9px;padding:3px 9px;border-radius:20px;background:#1a1000;color:var(--amber);border:0.5px solid #3a2a00}

.run-btn{
    background:var(--red);color:#fff;
    font-size:11px;font-weight:600;
    border:none;border-radius:7px;padding:6px 12px;
    cursor:pointer;flex-shrink:0;text-decoration:none;
    display:inline-block;
}

/* ====== BUTTONS ====== */
.btn-green{
    width:100%;padding:13px;
    background:var(--green);color:#031003;
    border:none;border-radius:10px;
    font-size:14px;font-weight:600;
    cursor:pointer;margin-top:8px;
    text-align:center;text-decoration:none;
    display:block;
}
.btn-green:hover{background:#25a85d}
.btn-green:disabled{opacity:0.5;cursor:not-allowed}

.btn-red{
    width:100%;padding:13px;
    background:#1a0505;color:var(--red);
    border:1px solid #3a1010;border-radius:10px;
    font-size:14px;font-weight:600;
    cursor:pointer;margin-top:8px;
    text-align:center;text-decoration:none;
    display:block;
}

.btn-outline{
    width:100%;padding:11px;
    background:transparent;color:var(--text);
    border:0.5px solid #2a3a2a;border-radius:10px;
    font-size:13px;cursor:pointer;margin-top:8px;
    text-align:center;text-decoration:none;
    display:block;
}

/* ====== STATS ====== */
.stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px}
.stat3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:14px}
.stat{background:var(--card);border:0.5px solid var(--border);border-radius:10px;padding:11px}
.stat-val{font-size:22px;font-weight:600;color:var(--text)}
.stat-lbl{font-size:10px;color:var(--text2);margin-top:1px}

/* ====== MILESTONES ROWS ====== */
.ms-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:0.5px solid #161e16}
.ms-row:last-child{border-bottom:none}
.ms-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.ms-dot.d{background:var(--green)}
.ms-dot.n{background:var(--bg);border:2px solid var(--green)}
.ms-dot.p{background:#1a2a1a;border:1.5px solid #2a3a2a}
.ms-info{flex:1}
.ms-km{font-size:12px;font-weight:500;color:var(--text)}
.ms-sub{font-size:10px;color:var(--text2);margin-top:1px}
.badge-on{font-size:9px;padding:2px 8px;border-radius:20px;background:#0a1f0a;color:var(--green);border:0.5px solid #1a3a1a;cursor:pointer;white-space:nowrap;display:inline-block}
.badge-off{font-size:9px;padding:2px 8px;border-radius:20px;background:#111;color:#2a3a2a;border:0.5px solid #1a2a1a;white-space:nowrap;display:inline-block}

/* ====== FORMS ====== */
input[type=text],input[type=number],input[type=email],select{
    width:100%;padding:10px 12px;
    border:0.5px solid #1a2a1a;border-radius:8px;
    font-size:13px;color:var(--text);background:#111811;
    margin-bottom:9px;font-family:inherit;
}
input:focus,select:focus{outline:none;border-color:var(--green)}
input::placeholder{color:#2a3a2a}

.beep-row{display:flex;gap:7px;margin-bottom:12px}
.beep-btn{
    flex:1;padding:8px;font-size:12px;
    background:transparent;color:var(--text3);
    border:0.5px solid #1a2a1a;border-radius:8px;
    cursor:pointer;font-family:inherit;
    text-align:center;text-decoration:none;
}
.beep-btn.sel{background:#0a1f0a;color:var(--green);border-color:var(--green)}

.add-ms-row{display:flex;gap:5px;align-items:stretch;margin-bottom:9px}
.add-ms-row input{margin-bottom:0}
.btn-icon{
    padding:0 11px;background:transparent;
    border:0.5px solid #1a2a1a;border-radius:8px;
    cursor:pointer;font-size:17px;color:var(--text3);
    flex-shrink:0;font-family:inherit;
}
.btn-icon:hover{color:var(--green);border-color:var(--green)}

.km-rem{font-size:11px;border-radius:6px;padding:6px 10px;margin-bottom:9px;display:none}
.km-rem.show{display:block}
.km-rem.ok{background:#0a1f0a;color:var(--green)}
.km-rem.warn{background:#1a1000;color:var(--amber)}
.km-rem.err{background:#1a0505;color:var(--red)}

.err-msg{font-size:11px;color:var(--red);margin-bottom:7px}
.err-msg:empty{display:none}

/* ====== BOTTOM NAV ====== */
.nav{
    background:#080f08;border-top:0.5px solid #111811;
    display:flex;
    position:fixed;bottom:0;left:50%;transform:translateX(-50%);
    width:100%;max-width:500px;z-index:10;
    padding-bottom:env(safe-area-inset-bottom, 0);
}
.nav-btn{
    flex:1;padding:11px 0 9px;text-align:center;
    cursor:pointer;font-size:10px;color:#1a2a1a;
    border:none;background:transparent;
    text-decoration:none;display:block;
}
.nav-btn.on{color:var(--green)}
.nav-btn svg{display:block;margin:0 auto 3px;width:18px;height:18px}

/* ====== FLASH ====== */
.flash{
    padding:10px 12px;border-radius:8px;
    margin:0 16px 12px;font-size:12px;
}
.flash-success{background:#0a1f0a;color:var(--green);border:0.5px solid #1a3a1a}
.flash-error{background:#1a0505;color:var(--red);border:0.5px solid #3a1010}
.flash-info{background:#1a1000;color:var(--amber);border:0.5px solid #3a2a00}

/* ====== COVER PICKER ====== */
.cover-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin-bottom:12px}
.cover-item{
    border-radius:8px;overflow:hidden;
    aspect-ratio:1;cursor:pointer;
    border:2px solid transparent;
    position:relative;background:#0a0a0a;
}
.cover-item:hover{border-color:#2a4a2a}
.cover-item.sel{border-color:var(--green)}
.cover-item img,.cover-item svg{width:100%;height:100%;display:block;object-fit:cover}
.cover-check{
    position:absolute;top:3px;right:3px;
    width:14px;height:14px;border-radius:50%;
    background:var(--green);
    display:none;
    align-items:center;justify-content:center;
}
.cover-item.sel .cover-check{display:flex}

.cover-cats{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:10px}
.cover-cat{
    font-size:9px;padding:3px 9px;border-radius:20px;
    border:0.5px solid #1a2a1a;background:transparent;
    color:var(--text3);cursor:pointer;font-family:inherit;
}
.cover-cat.on{background:#0a1f0a;color:var(--green);border-color:var(--green)}

.cover-preview-bar{
    background:var(--card);border:0.5px solid var(--border);
    border-radius:12px;padding:11px;margin-bottom:12px;
    display:flex;align-items:center;gap:10px;
}
.cover-preview-bar-img{width:40px;height:40px;border-radius:7px;overflow:hidden;flex-shrink:0;background:#0a0a0a}
.cover-preview-bar-img img{width:100%;height:100%;display:block}

/* ====== PROFILE / AVATAR ====== */
.avatar{
    width:64px;height:64px;border-radius:50%;
    background:#1a0505;border:2px solid var(--red);
    display:flex;align-items:center;justify-content:center;
    font-size:22px;font-weight:600;color:var(--red);
    margin:0 auto 10px;
}

/* ====== ACHIEVEMENT ITEMS ====== */
.ach-item{
    background:var(--card);border:0.5px solid var(--border);
    border-radius:10px;padding:11px;
    cursor:pointer;margin-bottom:8px;
}
.ach-item:hover{border-color:#2a4a2a}
.ach-item.locked{opacity:0.35;cursor:default}
.ach-row2{display:flex;align-items:center;gap:10px}
.ach-star{
    width:34px;height:34px;border-radius:50%;
    background:#0a1f0a;
    display:flex;align-items:center;justify-content:center;
    flex-shrink:0;
}
.ach-star.locked{background:#1a1a1a}
.ach-detail{border-top:0.5px solid #1a2a1a;margin-top:8px;padding-top:8px;display:none}
.ach-detail.open{display:block}
.ach-dr{display:flex;justify-content:space-between;font-size:10px;padding:2px 0}
.ach-dl{color:var(--text2)}
.ach-dv{color:var(--text)}

/* ====== RUN screen ====== */
.big-km{font-size:60px;font-weight:600;color:var(--text);text-align:center;line-height:1;letter-spacing:-2px;margin:6px 0 2px}
.big-lbl{font-size:11px;color:var(--text2);text-align:center;margin-bottom:8px}
.timer{font-size:32px;font-weight:500;color:var(--text);text-align:center;margin:0 0 14px;font-family:monospace;letter-spacing:1px}
.gps-row{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:12px;font-size:11px;color:var(--text3)}
.gps-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.gps-dot.a{background:var(--green);animation:pulse 1.5s infinite}
.gps-dot.p{background:var(--amber)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.3}}

.next-ms-block{background:#0a1f0a;border-radius:10px;padding:11px 13px;margin-bottom:12px}
.nml{font-size:9px;color:#1D9E75;font-weight:600;letter-spacing:0.07em;text-transform:uppercase;margin-bottom:5px}
.nmn{font-size:13px;color:var(--green);font-weight:500}

.tw{
    background:#1a1000;border:0.5px solid #4a3a00;
    border-radius:8px;padding:9px 12px;
    font-size:11px;color:var(--amber);
    text-align:center;margin-bottom:10px;
}

/* ====== ONBOARDING ====== */
.onb-logo{text-align:center;padding:40px 0 20px}
.onb-title{font-size:32px;font-weight:700;color:var(--text);text-align:center;margin-bottom:6px}
.onb-sub{font-size:14px;color:var(--text2);text-align:center;margin-bottom:32px;line-height:1.5}

/* ====== CATALOG ====== */
.cat-card{background:var(--card);border:0.5px solid var(--border);border-radius:14px;padding:13px 14px;margin-bottom:9px;cursor:pointer;display:block;color:inherit}
.cat-card:hover{border-color:#2a4a2a}
.cat-cover{width:44px;height:44px;border-radius:8px;overflow:hidden;flex-shrink:0;background:#0a0a0a}
.cat-cover img{width:100%;height:100%;display:block}
.runners{font-size:10px;color:var(--green);margin-top:3px}

/* ====== OVERLAYS (modal, bottom sheet) ====== */
.overlay{
    position:fixed;inset:0;
    background:rgba(0,0,0,0.88);
    display:flex;align-items:center;justify-content:center;
    z-index:100;padding:16px;
}
.modal{
    background:var(--card);border-radius:16px;
    padding:26px 22px;text-align:center;
    width:100%;max-width:320px;
    border:0.5px solid var(--border);
}
.modal-icon{
    width:60px;height:60px;border-radius:50%;
    margin:0 auto 13px;
    display:flex;align-items:center;justify-content:center;
}
.modal-title{font-size:18px;font-weight:600;color:var(--text);margin-bottom:5px}
.modal-sub{font-size:12px;color:var(--text2);margin-bottom:9px}
.modal-badge{
    font-size:12px;padding:5px 14px;border-radius:20px;
    background:#0a1f0a;color:var(--green);
    border:0.5px solid #1a3a1a;
    display:inline-block;margin-bottom:13px;
}

.bs-overlay{
    position:fixed;inset:0;
    background:rgba(0,0,0,0.75);
    display:flex;align-items:flex-end;justify-content:center;
    z-index:100;
}
.bs{
    background:var(--card);border-radius:16px 16px 0 0;
    padding:22px 18px;width:100%;max-width:500px;
    border-top:0.5px solid var(--border);
}
.bs-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:5px}
.bs-sub{font-size:12px;color:var(--text2);margin-bottom:18px}

/* ====== UTILS ====== */
.hidden{display:none !important}
.text-center{text-align:center}
.mt-8{margin-top:8px}
.mt-16{margin-top:16px}
.mb-16{margin-bottom:16px}


/* ====================================================
   ДОПИСАТЬ В КОНЕЦ teufelrun.com/public/css/app.css
   ==================================================== */
 
/* Значок ачивки не должен выдавливать текст */
.ms-row {
    flex-wrap: wrap;
}
.ms-info {
    min-width: 0;
    overflow: hidden;
}
.ms-km {
    overflow: hidden;
    text-overflow: ellipsis;
}
 
/* Раскрывающаяся деталь ачивки должна занимать всю ширину */
.ach-detail {
    width: 100%;
    flex-basis: 100%;
}
 
/* Выключенный значок должен быть виден */
.badge-off {
    background: #111 !important;
    color: #2a3a2a !important;
}
 
/* Кнопка удаления в bs-overlay */
.bs form button.btn-red {
    margin-top: 0;
}