/* ===========================
   StoneFlow / Grabmalwerk – Mobile-First Styles
   Ziel: aktueller Look bleibt, alles wird responsive
   =========================== */

/* Farben & Grundwerte */
:root{
  --brand:#D96F32;
  --brand-dark:#c05827;
  --text:#111;
  --muted:#666;
  --bg:#f9f9f9;
  --white:#fff;
  --danger:#ef4444;
  --shadow:0 0 10px rgba(0,0,0,.08);
}

/* Basis */
*{box-sizing:border-box}
html,body{height:100%}
body{
  font-family: "Futura","Segoe UI",Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  margin:0;
  line-height:1.45;
  -webkit-text-size-adjust:100%;
}
img{max-width:100%;height:auto}
a{color:#0055aa;text-decoration:none}
a:hover{text-decoration:underline}

/* Container-Utility, falls gebraucht */
.container, .login-box, form, .task{
  background:var(--white);
  border-radius:10px;
  box-shadow:var(--shadow);
}

/* Buttons – matcht deine bestehenden Klassen */
.button,
button,
.logout,
.admin-button,
.button-secondary,
a.button-link{
  display:inline-block;
  border:none;
  border-radius:8px;
  padding:12px 16px;
  font-size:16px;            /* 16px verhindert iOS-Zoom */
  line-height:1.2;
  cursor:pointer;
  text-decoration:none;
}

/* Primäre Buttons (dein Brand) */
.button,
button:not(.button-secondary):not(.admin-button):not(.logout),
.admin-button,
.logout,
a.button-link{
  background:var(--brand);
  color:var(--white);
}
.button:hover,
button:hover,
.admin-button:hover,
.logout:hover,
a.button-link:hover{ background:var(--brand-dark); }

/* Sekundär */
.button-secondary{
  background:#888; color:#fff;
}
.button-secondary:hover{ background:#666; }

/* Formulare */
input, select, textarea{
  width:100%;
  padding:10px 12px;
  border:1px solid #ddd;
  border-radius:6px;
  font-size:16px;            /* 16px verhindert iOS-Zoom */
  background:#fff;
}
label{display:block;margin:8px 0 6px;font-weight:600}
small, .hint{color:var(--muted);font-size:12px}

/* Kopfzeile/Logout-Bereich */
.top-right{
  position:fixed;            /* bleibt sichtbar, stört nicht beim Scrollen */
  top:12px; right:12px;
  display:flex; gap:8px;
  z-index:50;
}

/* Dashboard */
.logo{max-width:260px;height:auto;display:block;margin:60px auto 10px}
.row{
  display:flex; flex-wrap:wrap;
  gap:16px; justify-content:center;
}
.row .button{min-width:220px}

/* Badges auf Buttons */
.btn-wrap{ position:relative; display:inline-block; }
.badge{
  position:absolute; top:6px; right:10px;
  min-width:24px; height:24px; padding:0 6px;
  border-radius:12px; background:var(--danger);
  color:#fff; font-size:13px; line-height:24px; font-weight:700;
  box-shadow:0 0 0 2px var(--bg);
}

/* Login */
.login-box{
  width:100%;
  max-width:380px;
  margin:90px auto 24px;
  padding:24px;
}

/* Grids in Formularen (z.B. create_offer.html) */
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px 24px;
}
.form-grid .full{ grid-column:1 / -1 }

/* Tabellen – mobil ohne Umbau nutzbar (horizontales Scrollen) */
table{ width:100%; border-collapse:collapse; }
th,td{ border:1px solid #ddd; padding:8px; vertical-align:top; }
th{ background:#f4f4f4; text-align:left; }
.table-wrap{ overflow-x:auto; } /* Optionaler Wrapper */

/* Karten/Listen (Tasks/Archiv) */
.task{
  width:100%;
  max-width:680px;
  margin:14px auto;
  padding:14px;
  text-align:left;
}

/* Headings-Farbe in create_offer via Template-Variable bleibt erhalten:
   Wir überschreiben NICHT absichtlich die h2-Farbe. */

/* ===========================
   Responsive Breakpoints
   =========================== */

@media (max-width: 1024px){
  .row .button{ min-width:260px }
}

@media (max-width: 768px){
  body{ padding:12px }
  .logo{ max-width:220px; margin-top:70px }

  /* Buttons & Layout einspaltig */
  .row{ gap:12px }
  .row .button{ width:100%; min-width:0 }

  /* Form-Grids werden einspaltig */
  .form-grid{ grid-template-columns:1fr }
  .form-grid .full{ grid-column:auto }

  /* Tabellen bleiben „Tabelle“, aber bekommen Scroll, falls zu breit */
  table{ display:table; }
  .table-wrap{ overflow-x:auto; -webkit-overflow-scrolling:touch; }

  /* Kopfzeilen-Buttons enger */
  .top-right{ gap:6px }
}

/* Sehr kleine Geräte */
@media (max-width: 420px){
  .logo{ max-width:200px }
  .login-box{ padding:18px }
  .btn-wrap .badge{ top:4px; right:8px }
}