/* ====================================
   JB PLANERING — mobil planerarvy
   ==================================== */

:root {
    --bla: #1d4ed8;
    --bla-mork: #1e3a8a;
    --bakgrund: #f1f5f9;
    --kort: #ffffff;
    --text: #0f172a;
    --text-svag: #64748b;
    --linje: #e2e8f0;
    --fel: #b91c1c;
    --fel-bg: #fef2f2;
    --rod: #dc2626;
    --rod-bg: #fef2f2;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    background: var(--bakgrund);
    color: var(--text);
    font-size: 16px;
    line-height: 1.4;
    min-height: 100vh;
    padding-bottom: env(safe-area-inset-bottom);
}

/* ---------- Login ---------- */
#loginView {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    min-height: 100vh; padding: 24px; gap: 8px;
}
#loginView h1 { font-size: 26px; color: var(--bla-mork); margin-bottom: 16px; }
#loginForm { width: 100%; max-width: 320px; display: flex; flex-direction: column; gap: 12px; }
#pinInput {
    font-size: 28px; text-align: center; letter-spacing: 8px; padding: 14px;
    border: 2px solid var(--linje); border-radius: 12px; background: var(--kort);
}
#pinInput:focus { outline: none; border-color: var(--bla); }
#loginBtn {
    font-size: 19px; font-weight: 600; padding: 14px; border: none;
    border-radius: 12px; background: var(--bla); color: white;
}
#loginBtn:disabled { opacity: 0.6; }
#loginStatus { color: var(--fel); text-align: center; min-height: 24px; font-size: 15px; }

/* ---------- App ---------- */
#appView { display: none; max-width: 560px; margin: 0 auto; padding: 8px 10px 40px; }

.app-header {
    display: flex; align-items: center; gap: 8px; padding: 6px 2px 12px;
}
.vecko-info { flex: 1; text-align: center; }
#veckoNr { font-size: 18px; font-weight: 600; color: var(--bla-mork); }
#veckoDatum { font-size: 13px; color: var(--text-svag); }
.navknapp, .ikonknapp {
    border: 1px solid var(--linje); background: var(--kort); border-radius: 10px;
    font-size: 20px; line-height: 1; padding: 8px 12px; color: var(--text);
}
.ikonknapp { font-size: 17px; }
#refreshBtn.spinning { animation: snurr 0.8s linear infinite; }
@keyframes snurr { to { transform: rotate(360deg); } }

#errorBanner {
    display: none; background: var(--fel-bg); color: var(--fel); border-radius: 10px;
    padding: 10px 14px; margin-bottom: 10px; font-size: 14px;
}

/* ---------- Dagremsa ---------- */
.dag-strip { display: flex; gap: 5px; margin-bottom: 12px; }
.dagpill {
    flex: 1; padding: 7px 0; border: 1px solid var(--linje); border-radius: 10px;
    background: var(--kort); display: flex; flex-direction: column; align-items: center; gap: 1px;
}
.dagpill .dp-kort { font-size: 11px; color: var(--text-svag); }
.dagpill .dp-dat { font-size: 15px; font-weight: 600; }
.dagpill .dp-cnt { font-size: 10px; color: var(--text-svag); }
.dagpill.active { background: var(--bla); border-color: var(--bla); }
.dagpill.active .dp-kort, .dagpill.active .dp-dat, .dagpill.active .dp-cnt { color: white; }
.dagpill.rod .dp-kort, .dagpill.rod .dp-dat { color: var(--rod); }
.dagpill.rod.active { background: var(--rod); border-color: var(--rod); }
.dagpill.rod.active .dp-kort, .dagpill.rod.active .dp-dat { color: white; }

/* ---------- Dagrubrik + förarlista ---------- */
.dag-rubrikrad {
    display: flex; align-items: baseline; justify-content: space-between; padding: 2px 4px 8px;
}
#dagRubrik { font-size: 16px; font-weight: 600; }
#dagSummering { font-size: 13px; color: var(--text-svag); }

.grupp-rubrik { font-size: 12px; color: var(--text-svag); padding: 14px 4px 4px; }
.empty-state { text-align: center; color: var(--text-svag); padding: 40px 12px; font-size: 15px; line-height: 1.6; }

.forare-rad {
    width: 100%; text-align: left; display: flex; align-items: center; justify-content: space-between;
    gap: 10px; padding: 11px 8px; border: none; border-bottom: 1px solid var(--linje);
    background: transparent;
}
.forare-rad.ledig { opacity: 0.6; }
.fr-namn { display: flex; align-items: center; gap: 8px; min-width: 0; }
.kort-badge {
    flex-shrink: 0; font-size: 10px; font-weight: 600; color: var(--text-svag);
    border: 1px solid var(--linje); border-radius: 4px; padding: 1px 5px;
}
.fr-namn > :last-child { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-size: 15px; }
.fr-hoger { flex-shrink: 0; }
.uppdrag-chip {
    display: inline-block; padding: 4px 11px; border-radius: 8px; font-size: 14px; font-weight: 500;
    background: var(--bla); color: white;
}
.tilldela { font-size: 14px; color: var(--text-svag); }

/* ---------- Redigerings-sheet ---------- */
#backdrop {
    display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.45); z-index: 10;
}
#sheet {
    display: none; position: fixed; left: 0; right: 0; bottom: 0; z-index: 11;
    background: var(--kort); border-top-left-radius: 18px; border-top-right-radius: 18px;
    padding: 14px 16px calc(18px + env(safe-area-inset-bottom));
    max-width: 560px; margin: 0 auto; max-height: 88vh; overflow-y: auto;
}
.sheet-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.sheet-namn { font-size: 17px; font-weight: 600; }
.sheet-sub { font-size: 12px; color: var(--text-svag); margin: 12px 0 7px; text-transform: uppercase; letter-spacing: .03em; }
.opts { display: flex; flex-wrap: wrap; gap: 7px; }
.opt {
    padding: 7px 12px; border: 1px solid var(--linje); border-radius: 9px; background: var(--kort);
    font-size: 14px;
}
.opt.on { background: var(--bla); border-color: var(--bla); color: white; }
#sheetText {
    width: 100%; margin-top: 10px; font-size: 16px; padding: 11px 12px;
    border: 1px solid var(--linje); border-radius: 10px;
}
#sheetText:focus { outline: none; border-color: var(--bla); }
.dagtogs { display: flex; gap: 5px; }
.dagtog {
    flex: 1; padding: 9px 0; border: 1px solid var(--linje); border-radius: 9px;
    background: var(--kort); font-size: 13px; font-weight: 500;
}
.dagtog.on { background: var(--bla); border-color: var(--bla); color: white; }
.snabbval { display: flex; gap: 7px; margin-top: 8px; }
.snabbval button {
    flex: 1; padding: 8px 0; border: 1px solid var(--linje); border-radius: 9px;
    background: var(--kort); font-size: 13px; color: var(--bla-mork);
}
.sheet-knappar { display: flex; gap: 8px; margin-top: 16px; }
.dangerbtn {
    flex: 0 0 auto; padding: 12px 16px; border: 1px solid #fca5a5; border-radius: 11px;
    background: var(--kort); color: var(--fel); font-size: 15px; font-weight: 600;
}
.primarybtn {
    flex: 1; padding: 12px; border: none; border-radius: 11px;
    background: var(--bla); color: white; font-size: 16px; font-weight: 600;
}
.primarybtn:disabled, .dangerbtn:disabled { opacity: 0.6; }

/* ---------- Uppdateringsbanner ---------- */
#updateBanner {
    display: none; position: fixed; left: 12px; right: 12px;
    bottom: calc(12px + env(safe-area-inset-bottom));
    background: var(--bla-mork); color: white; border-radius: 12px; padding: 12px 16px;
    align-items: center; justify-content: space-between; gap: 12px; z-index: 20;
}
#updateReloadBtn {
    border: none; background: white; color: var(--bla-mork); font-weight: 600;
    border-radius: 8px; padding: 8px 14px; font-size: 15px;
}
