/* ==========================================================================
   login.css — SmartKpark Grün-Theme mit gebrandetem Mesh-Background
   Für Startseite: Header-Login + (links) Flyer + (rechts) Formular
   ========================================================================== */

/* Global: verhindert Overflow durch Padding/Border */
*, *::before, *::after { box-sizing: border-box; }

:root {
  --brand: rgba(167,198,0,1);
  --brand-weak: #f3f9dd;
  --accent: #0f172a;
  --ink: #0f172a;
  --paper: #ffffff;
  --border: #e5e7eb;
  --muted: #64748b;
  --ring: 0 0 0 3px rgba(167,198,0,.35);

  --bg-dark: #0b1220;
  --bg-dark-2: #0f1830;
  --fg-light: #f6f8ff;
  --ok: #16a34a;
  --warn: #f59e0b;
  --err: #ef4444;
}

/* Seite + Brand-Hintergrund (Mesh + Noise) */
html, body { height: 100%; }
body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--ink);
  background:
    radial-gradient(1200px 800px at 10% 10%, rgba(167,198,0,.22), transparent 60%),
    radial-gradient(900px 700px at 85% 20%, rgba(34,197,94,.18), transparent 55%),
    radial-gradient(800px 600px at 50% 90%, rgba(59,130,246,.12), transparent 60%),
    conic-gradient(from 210deg at 60% 40%, rgba(167,198,0,.28), rgba(56,189,248,.18), rgba(167,198,0,.28)),
    #f6f8fc;
  position: relative;
  overflow-x: hidden;
}
body::before{
  content:"";
  position:fixed; inset:-2px;
  pointer-events:none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140' viewBox='0 0 140 140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3CfeComponentTransfer%3E%3CfeFuncA type='table' tableValues='0 0 0 .06 .12 .06 0 0'/%3E%3C/feComponentTransfer%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.7;
}
@media (prefers-reduced-motion: no-preference){
  body{ background-attachment: fixed; }
  body::before{ animation: grainMove 18s linear infinite; }
}
@keyframes grainMove{
  0%{ transform: translate3d(0,0,0); }
  50%{ transform: translate3d(-2%, -2%, 0); }
  100%{ transform: translate3d(0,0,0); }
}

/* ==========================================================================
   Header mit Login + Logo (nicht sticky)
   ========================================================================== */
.site-header {
  position: static;      /* nicht klebend */
  top: auto;
  z-index: 50;
  background: linear-gradient(180deg,var(--bg-dark),var(--bg-dark-2));
  color: var(--fg-light);
  border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: saturate(140%) blur(6px);
}
.nav {
  max-width: 1200px; margin: 0 auto; padding: .65rem 1rem;
  display: grid; grid-template-columns: 1fr auto; gap: 1rem; align-items: center;
}
.brand { display:flex; align-items:center; gap:.65rem; font-weight:700; color:#e8eefc; }
.brand img{ height:28px; width:auto; display:block; }
@media (min-width: 920px){ .brand img{ height:32px; } }

/* Login rechts im Header */
.login-inline { display:flex; gap:.5rem; align-items:end; flex-wrap:wrap; justify-content:flex-end; }
.login-inline label { font-size:.75rem; color:#cdd5e8; display:block; margin-bottom:.25rem; }
.login-inline input{
  height:36px; border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.10); color:#fff;
  border-radius:10px; padding:.4rem .65rem; min-width:180px;
  outline:none; width:auto; max-width:100%;
}
.login-inline input::placeholder{ color:#c9d1e8; }
.login-inline button{
  height:36px; padding:0 .9rem; border-radius:10px; border:none;
  background: var(--brand); color:#fff; font-weight:600; cursor:pointer;
  box-shadow: 0 6px 18px rgba(167,198,0,.35);
  transition: transform .08s ease, filter .2s ease, box-shadow .2s ease;
}
.login-inline button:hover{ transform: translateY(-1px); filter: brightness(.95); }
.login-inline button[disabled]{ opacity:.6; cursor:not-allowed; }

/* Human-Check Pill */
.human-pill { display:flex; align-items:center; gap:.4rem; font-size:.8rem; color:#cbd5e1; }
.human-pill .dot { width:8px; height:8px; border-radius:999px; }
.human-pill.pending .dot { background: var(--warn); }
.human-pill.ok .dot { background: var(--ok); }
.human-pill.fail .dot { background: var(--err); }

/* ==========================================================================
   Hero + Content-Layout
   ========================================================================== */
.hero { border-bottom: 1px solid var(--border); background: rgba(255,255,255,.72); backdrop-filter: blur(6px) saturate(120%); }
.hero-inner { max-width:1200px; margin:0 auto; padding:1.2rem 1rem 1.4rem; }
.hero h1 { margin:.2rem 0; font-size:1.7rem; letter-spacing:.2px; color:var(--accent); }
.hero p { margin:0; color:#475569; }

.page { max-width:1200px; margin:0 auto; padding:1.25rem 1rem; }
.grid { display:grid; gap:1rem; grid-template-columns: 1.25fr .75fr; }

/* Karten */
.card {
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 6px 24px rgba(15,23,42,.06);
  padding: 1rem;
  overflow: hidden;      /* Clippt Überstand von Controls */
}
.card h2 { margin:.1rem 0 .75rem; font-size:1.15rem; color:var(--accent); }

/* Promo-Bild (flyer1.jpg) */
.promo-card img{
  width:100%; height:auto; display:block; border-radius:14px;
  box-shadow: 0 10px 24px rgba(15,23,42,.08);
}

/* ==========================================================================
   Formular (rechts) — Overflow-Schutz + Date-Fix
   ========================================================================== */
.user-form { width:100%; }
.user-form label{ display:block; text-align:left; margin:.8rem 0 .3rem; font-weight:700; color:var(--accent); }
.user-form input,
.user-form select,
.user-form textarea{
  width:100%;
  max-width:100%;
  inline-size:100%;
  max-inline-size:100%;
  min-width:0;
  padding:.6rem;
  border:1px solid var(--border);
  border-radius:10px;
  margin-bottom:1rem;
  font-size:1rem;
  background:#fff;
  color:var(--ink);
  outline:none;
}

/* Spezieller Fix für Mobile (iOS/Chrome): Date-Input */
.user-form input[type="date"]{
  -webkit-appearance:none;
  appearance:none;
  display:block;
  width:100%;
  max-width:100%;
  inline-size:100%;
  max-inline-size:100%;
  min-width:0;
  background-clip: padding-box;
}
.user-form input[type="date"]::-webkit-calendar-picker-indicator{
  margin:0; padding:0;
}
.user-form input[type="date"]::-webkit-date-and-time-value{
  text-align:left;
}

.user-form input::placeholder{ color:var(--muted); }
.user-form input:focus, .user-form select:focus, .user-form textarea:focus{
  border-color: var(--brand); box-shadow: var(--ring);
}
.user-form button{
  width:100%;
  max-width:100%;
  padding:.85rem; border:none; border-radius:12px; background:var(--brand); color:#fff; font-weight:750;
  box-shadow: 0 12px 32px rgba(167,198,0,.35);
  transition: transform .08s ease, filter .2s ease;
}
.user-form button:hover{ transform: translateY(-1px); filter: brightness(.95); }

.user-form a{ color:var(--brand); text-decoration: underline; }
.user-form a:hover{ filter:brightness(.95); }

/* Status & Hinweise */
.success{ background: var(--brand-weak); color: var(--accent); padding:.85rem; border-radius:12px; border:1px solid #dfecc2; margin-bottom:.9rem; }
.error{ background:#fdecec; border:1px solid #f3b5b5; padding:.85rem; border-radius:12px; margin-bottom:.9rem; }
.hint{ font-size:.85rem; color:#64748b; margin-top:.5rem; }
.muted{ color: var(--muted); font-size:.92rem; }

/* Inline-Toast (Fehler unter Header) */
.toast-inline{ position:fixed; top:70px; left:0; right:0; display:flex; justify-content:center; pointer-events:none; }
.toast-inline .inner{ pointer-events:auto; max-width:800px; padding:0 1rem; width:100%; }

/* Barrierefreiheit */
.visually-hidden{
  position:absolute !important;
  height:1px; width:1px;
  overflow:hidden; clip:rect(1px,1px,1px,1px);
  white-space:nowrap; clip-path: inset(50%);
  border:0; padding:0; margin:-1px;
}

/* (Alt) Auth-Card/Fallback */
.auth-page{ display:flex; align-items:center; justify-content:center; width:100%; padding:2rem 1rem; }
.auth-card{
  background: var(--paper); color: var(--ink);
  padding: 2rem; border-radius: 12px; box-shadow: 0 8px 20px rgba(0,0,0,0.15);
  width: 100%; max-width: 400px; text-align: center;
}
.auth-title{ margin-bottom:1.5rem; font-size:1.8rem; color:var(--accent); font-weight:800; }

/* ==========================================================================
   MOBILE OVERRIDES
   ========================================================================== */
@media (max-width: 760px){

  .nav{
    grid-template-columns: 1fr;
    row-gap: .6rem;
  }
  .brand{
    justify-content: space-between;
  }
  .login-inline{
    justify-content: stretch;
    align-items: stretch;
    gap: .6rem;
  }
  .login-inline > div{
    flex: 1 1 100%;
    min-width: 0;
  }
  .login-inline input,
  .login-inline button{
    width: 100%;
    max-width: 100%;
  }

  .hero-inner{
    padding: .9rem 1rem 1.1rem;
  }
  .hero h1{
    font-size: 1.35rem;
  }

  .page{
    padding: 1rem;
  }
  .grid{
    grid-template-columns: 1fr;   /* untereinander */
  }
  .promo-card{ order: 1; }
  .page .card + .card{ order: 2; }

  .card{
    border-radius: 14px;
    padding: .9rem;
  }

  /* Formular: größere Touch-Ziele + sicherer Date-Fix */
  .user-form input,
  .user-form select,
  .user-form textarea{
    font-size: 16px;
    padding: .7rem .75rem;
    width: 100%;
    max-width: 100%;
    inline-size: 100%;
    max-inline-size: 100%;
    min-width: 0;
  }
  .user-form input[type="date"]{
    -webkit-appearance: none;
    appearance: none;
    padding-right: .9rem;   /* Platz für Picker-Icon */
  }

  .promo-card img{
    width: 100%;
    height: auto;
    max-height: 55vh;
    object-fit: cover;
    border-radius: 14px;
  }

  .toast-inline{
    top: 8px;
  }
}

/* iOS-Safari Only Hack: glättet Input-Breiten-Berechnung */
@supports (-webkit-touch-callout: none) {
  .user-form input[type="date"] { padding-right: 1rem; }
}


    .nav{ padding:.45rem .9rem; }
    .btn-login{
      display:inline-flex; align-items:center; gap:.4rem;
      height:34px; padding:0 .8rem; border-radius:10px; border:none; text-decoration:none;
      background: var(--brand); color:#fff; font-weight:600;
      box-shadow:0 6px 18px rgba(167,198,0,.35);
    }
    .btn-login:hover{ filter:brightness(.95); transform: translateY(-1px); }
    .nav-right{ display:flex; align-items:center; gap:.6rem; }
    .brand img{ height:26px; }
    @media (min-width:920px){ .brand img{ height:30px; } }