:root{
  --bg:#f7f1df;
  --card:#ffffff;
  --ink:#1f1f1f;
  --muted:#5a5a5a;
  --line:#e8e2cf;
  --accent:#2e7d32;
  --danger:#b00020;
  --shadow:0 10px 30px rgba(0,0,0,.06);
  --radius:16px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}

.wrap{max-width:1000px; margin:0 auto; padding:20px 16px}
.header{display:flex; align-items:center; justify-content:space-between; padding:8px 0}
.brand{font-weight:800; letter-spacing:.2px}

.h1{font-size:clamp(22px,4.5vw,32px); margin:.2rem 0 .6rem}
.h2{font-size:clamp(18px,3.5vw,24px); margin:.8rem 0 .6rem}
.p{margin:.4rem 0 1rem}
.p.small{font-size:.95rem; color:var(--muted)}
.muted{color:var(--muted)}
.note{background:#fff; border:1px dashed var(--line); border-radius:12px; padding:10px 12px}

.box{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:16px;
  margin:12px 0 18px;
}

/* Form */
.row{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.in{
  flex:1 1 280px; min-width:220px;
  padding:12px 14px; border:1px solid var(--line); border-radius:12px;
  background:#fff; color:var(--ink);
}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 14px; min-height:44px; border-radius:12px;
  border:1px solid var(--line); background:#fff; cursor:pointer; text-decoration:none; color:var(--ink);
  box-shadow:var(--shadow);
}
.btn.primary{background:var(--accent); color:#fff; border-color:transparent; font-weight:700}
.btn.ghost{background:#fff}
.btn.danger{background:#fff0f0; border-color:#ffd5d5; color:#8b0000}
.remember{display:flex; align-items:center; gap:8px; color:var(--muted)}

/* Messages */
.msg{margin-top:8px; padding:10px 12px; border-radius:10px; border:1px solid var(--line); background:#fff}
.msg.ok{border-color:#cfe9cf; background:#f4fbf4}
.msg.error{border-color:#f2c6c6; background:#fff5f5}

/* Grid der Lizenzen */
.grid{
  display:grid; gap:14px;
  grid-template-columns:repeat(12,1fr);
}
@media (max-width: 860px){
  .grid{grid-template-columns:repeat(6,1fr)}
}
@media (max-width: 520px){
  .grid{grid-template-columns:repeat(2,1fr)}
}

/* Lizenz-Karten */
.lic{
  grid-column:span 6;
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:14px;
  box-shadow:var(--shadow);
}
@media (max-width: 860px){ .lic{grid-column:span 6} }
@media (max-width: 520px){ .lic{grid-column:span 2} }

.lic-head{display:flex; align-items:flex-start; justify-content:space-between; gap:10px; margin-bottom:8px}
.lic-title{font-weight:700; font-size:1.05rem; margin-bottom:2px}
.lic-meta{color:var(--muted); font-size:.95rem}
.lic-body{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:6px; font-size:.95rem}
@media (max-width:520px){ .lic-body{grid-template-columns:1fr} }

/* Status-Badges */
.status{
  display:inline-block; padding:4px 8px;
  border-radius:999px; font-size:.85rem; border:1px solid var(--line); background:#fff;
}
.status.green{background:#e9f6ea; border-color:#cce7cf}
.status.amber{background:#fff7db; border-color:#ffe7a8}
.status.red{background:#ffe9e9; border-color:#ffc8c8}

/* Divider & Footer */
.hr{height:1px; background:var(--line); margin:14px 0}
.footer{margin:20px 0; color:var(--muted); font-size:.95rem; text-align:center}
