/* GRUNDLOGG – mobilanpassad stil. Stora knappar, byggarbetsplatsvänlig. */
:root{
  --bg:#0f1720; --card:#18222e; --line:#2a3744; --text:#eef3f8; --muted:#9fb0c0;
  --primary:#15a06a; --primary-d:#0b5d3b; --danger:#e0524d; --warn:#e0a23a;
  --ok:#2ecc71; --radius:14px; --tap:54px;
}
[data-theme="light"]{
  --bg:#f3f6f9; --card:#fff; --line:#dde5ee; --text:#16202b; --muted:#5b6b7b;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  background:var(--bg); color:var(--text); font-size:17px; line-height:1.4;
  -webkit-tap-highlight-color:transparent;
}
a{color:var(--primary)}
.hidden{display:none !important}

/* Topbar */
.topbar{
  position:sticky; top:0; z-index:20; display:flex; align-items:center; gap:10px;
  background:var(--primary-d); color:#fff; padding:12px 14px; padding-top:max(12px,env(safe-area-inset-top));
}
.topbar h1{font-size:18px; margin:0; flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.topbar button{background:rgba(255,255,255,.15); color:#fff; border:0; border-radius:10px; padding:8px 10px; font-size:16px}
.project-pill{font-size:13px; opacity:.9}

/* Innehåll */
main{padding:14px; padding-bottom:96px; max-width:760px; margin:0 auto}
.card{background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:14px; margin-bottom:14px}
.card h2{margin:0 0 10px; font-size:17px}
.muted{color:var(--muted); font-size:14px}

/* Knappar */
.btn{
  display:flex; align-items:center; justify-content:center; gap:8px;
  width:100%; min-height:var(--tap); border:0; border-radius:12px;
  background:var(--primary); color:#fff; font-size:18px; font-weight:600; padding:0 16px;
  cursor:pointer; margin-top:6px;
}
.btn.secondary{background:var(--card); color:var(--text); border:1px solid var(--line)}
.btn.danger{background:var(--danger)}
.btn.small{min-height:42px; font-size:15px; width:auto; padding:0 14px}

/* Snabbknappsrutnät */
.quick-grid{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.quick{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius);
  min-height:96px; display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:6px; font-weight:600; font-size:15px; color:var(--text); text-align:center; padding:8px;
}
.quick .ico{font-size:28px}

/* Formulär */
label{display:block; margin:12px 0 6px; font-weight:600; font-size:15px}
input,select,textarea{
  width:100%; min-height:var(--tap); background:var(--bg); color:var(--text);
  border:1px solid var(--line); border-radius:12px; padding:12px 14px; font-size:17px;
}
textarea{min-height:96px; resize:vertical}
.row{display:flex; gap:10px}
.row>*{flex:1}

/* Statusfärger */
.badge{display:inline-block; padding:3px 10px; border-radius:999px; font-size:13px; font-weight:600}
.badge.b-pagar{background:#1d3b57; color:#9cd}
.badge.b-klar,.badge.b-godkand{background:#15402c; color:#7fe0a8}
.badge.b-avvikelse,.badge.b-kritisk{background:#4a1f1d; color:#f0a; color:#ffb3ae}
.badge.b-hog{background:#4a3a1d; color:#ffd58a}

/* Listrader */
.list-item{display:flex; gap:12px; align-items:center; padding:12px 0; border-bottom:1px solid var(--line)}
.list-item:last-child{border-bottom:0}
.list-item .grow{flex:1; min-width:0}
.list-item .grow b{display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}

/* Galleri */
.gallery{display:grid; grid-template-columns:repeat(3,1fr); gap:6px}
.gallery img{width:100%; aspect-ratio:1; object-fit:cover; border-radius:10px}

/* Synkbanner */
#sync-banner{
  position:fixed; left:0; right:0; bottom:72px; margin:0 14px; z-index:30;
  background:var(--warn); color:#1a1206; border-radius:12px; padding:10px 14px; font-weight:600;
  display:none; text-align:center;
}
#sync-banner.show{display:block}

/* Bottennavigering */
.bottomnav{
  position:fixed; left:0; right:0; bottom:0; z-index:25; display:flex;
  background:var(--card); border-top:1px solid var(--line);
  padding-bottom:env(safe-area-inset-bottom);
}
.bottomnav a{
  flex:1; text-align:center; padding:10px 4px; color:var(--muted);
  text-decoration:none; font-size:11px; display:flex; flex-direction:column; gap:3px;
}
.bottomnav a .ico{font-size:22px}
.bottomnav a.active{color:var(--primary)}

/* Login */
.login-wrap{max-width:420px; margin:8vh auto; padding:0 18px}
.login-wrap .logo{font-size:34px; text-align:center; margin-bottom:6px}
.msg-error{background:#4a1f1d; color:#ffb3ae; padding:12px; border-radius:12px; margin:10px 0}
.msg-ok{background:#15402c; color:#7fe0a8; padding:12px; border-radius:12px; margin:10px 0}
.toast{
  position:fixed; bottom:90px; left:50%; transform:translateX(-50%); z-index:50;
  background:#222; color:#fff; padding:12px 18px; border-radius:12px; opacity:0; transition:.25s;
}
.toast.show{opacity:1}
.coord-box{background:var(--bg); border:1px dashed var(--line); border-radius:12px; padding:10px; font-size:14px; margin-top:8px}
