/* =========================================================
   FischerHaus BauPartner — Anfragen-Atelier (CRM)
   Dark-Luxus Design-System · eigens gestaltet
   ========================================================= */
:root{
  --bg:#0a0d13; --bg-2:#0f131c; --ink:#f5f2ea;
  --muted:#aab2c0; --muted-2:#7e8696;
  --gold:#c8a86a; --gold-lite:#e7d6ad; --navy:#29456b;
  --line:rgba(255,255,255,.12); --line-soft:rgba(255,255,255,.06);
  --gold-grad:linear-gradient(110deg,#b8915a 0%,#e9d6a8 45%,#c8a86a 100%);
  --glass:rgba(15,19,28,.66);
  --ease:cubic-bezier(.16,.84,.34,1);
  --shadow:0 24px 60px -28px rgba(0,0,0,.7);
  --shadow-soft:0 10px 40px -24px rgba(0,0,0,.6);
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  background:var(--bg); color:var(--ink);
  font-family:'Inter',system-ui,sans-serif; font-weight:300;
  line-height:1.65; -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
/* Subtiler, edler Hintergrund-Glow */
body::before{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(80% 55% at 80% -5%, rgba(40,69,107,.22), transparent 60%),
    radial-gradient(60% 50% at 0% 0%, rgba(200,168,106,.07), transparent 55%),
    radial-gradient(90% 60% at 50% 110%, rgba(40,69,107,.10), transparent 60%);
}
h1,h2,h3,.serif{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;letter-spacing:.005em}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:rgba(200,168,106,.3);color:#fff}
.eyebrow{font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;font-weight:500;color:var(--gold)}
.gold-text{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.hr-gold{height:1px;width:64px;background:var(--gold-grad);border:0;margin:14px 0}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  border:none;cursor:pointer;font-family:'Inter',sans-serif;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;font-size:.72rem;
  padding:13px 24px;border-radius:3px;background:var(--gold-grad);color:#14110a;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),filter .3s var(--ease);
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 34px -16px rgba(200,168,106,.55);filter:brightness(1.04)}
.btn:active{transform:translateY(0)}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold-lite);box-shadow:none}
.btn.tiny{padding:9px 16px;font-size:.66rem}

/* =========================================================
   LOGIN
   ========================================================= */
.login-stage{
  min-height:100vh;display:grid;place-items:center;padding:40px 20px;position:relative;
}
.login{
  width:100%;max-width:420px;position:relative;
  border:1px solid var(--line);border-radius:10px;
  background:var(--glass);backdrop-filter:blur(18px) saturate(120%);
  box-shadow:var(--shadow);
  padding:46px 42px 40px;
  animation:rise .9s var(--ease) both;
}
.login::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:var(--gold-grad);opacity:.9;border-radius:10px 10px 0 0;
}
.login-logo{height:46px;width:auto;margin:0 auto 26px;opacity:.96;filter:drop-shadow(0 6px 24px rgba(0,0,0,.5))}
.login .eyebrow{display:block;text-align:center;margin-bottom:12px}
.login h1{text-align:center;font-size:2rem;line-height:1.15;margin-bottom:8px}
.login .lede{text-align:center;color:var(--muted);font-size:.92rem;margin-bottom:30px}
.login label{display:block;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-2);margin:18px 0 8px}
.login .infield{position:relative}
.login input{
  width:100%;padding:14px 16px;background:rgba(255,255,255,.035);
  border:1px solid var(--line);border-radius:5px;color:var(--ink);
  font-family:inherit;font-size:.95rem;font-weight:300;
  transition:border-color .35s var(--ease),background .35s var(--ease),box-shadow .35s var(--ease);
}
.login input::placeholder{color:var(--muted-2)}
.login input:focus{outline:none;border-color:var(--gold);background:rgba(200,168,106,.05);box-shadow:0 0 0 3px rgba(200,168,106,.10)}
.login .submit{margin-top:28px}
.login .submit .btn{width:100%}
.err{
  color:#e8a187;font-size:.85rem;margin-top:18px;text-align:center;
  padding:11px 14px;border:1px solid rgba(224,134,107,.28);border-radius:5px;
  background:rgba(224,134,107,.07);
}
.login-foot{margin-top:26px;text-align:center;color:var(--muted-2);font-size:.74rem;letter-spacing:.04em;line-height:1.7}
.login-foot .sig{color:var(--gold-lite);font-family:'Cormorant Garamond',serif;font-size:.95rem;letter-spacing:.02em}

/* =========================================================
   APP SHELL
   ========================================================= */
.top{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:18px clamp(20px,4vw,46px);
  border-bottom:1px solid var(--line);
  background:rgba(8,10,15,.7);backdrop-filter:blur(16px) saturate(120%);
}
.top .brand{display:flex;align-items:center;gap:14px}
.top .brand img{height:34px;width:auto}
.top .brand .bt{display:flex;flex-direction:column;line-height:1.1}
.top .brand .bt b{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.12rem}
.top .brand .bt span{font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold)}
.top .right{display:flex;align-items:center;gap:18px}
.top .who{display:flex;flex-direction:column;text-align:right;line-height:1.25}
.top .who b{font-weight:500;font-size:.86rem;color:var(--ink)}
.top .who span{font-size:.68rem;color:var(--muted-2);letter-spacing:.04em}
.top .logout{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);transition:color .3s var(--ease);display:inline-flex;align-items:center;gap:6px}
.top .logout:hover{color:var(--gold-lite)}

.wrap{max-width:1320px;margin:0 auto;padding:clamp(28px,5vw,56px) clamp(18px,4vw,46px) 60px}

/* ---------- Greeting ---------- */
.greeting{margin-bottom:38px;animation:rise .8s var(--ease) both}
.greeting .eyebrow{margin-bottom:14px}
.greeting h1{font-size:clamp(2.1rem,4.4vw,3.4rem);line-height:1.05;font-weight:600}
.greeting h1 .gold-text{font-style:italic;font-weight:500}
.greeting .sub{color:var(--muted);font-size:1rem;margin-top:12px;max-width:60ch}

/* ---------- Stat cards ---------- */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:42px;
}
.stat{
  position:relative;border:1px solid var(--line);border-radius:10px;
  padding:24px 26px 22px;background:var(--bg-2);overflow:hidden;
  transition:transform .5s var(--ease),border-color .5s var(--ease),box-shadow .5s var(--ease);
  animation:rise .7s var(--ease) both;
}
.stat:nth-child(2){animation-delay:.07s}
.stat:nth-child(3){animation-delay:.14s}
.stat:nth-child(4){animation-delay:.21s}
.stat:hover{transform:translateY(-4px);border-color:rgba(200,168,106,.4);box-shadow:var(--shadow-soft)}
.stat::after{
  content:"";position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--gold-grad);opacity:0;transition:opacity .5s var(--ease);
}
.stat:hover::after{opacity:1}
.stat .ico{
  width:40px;height:40px;border-radius:8px;display:grid;place-items:center;
  border:1px solid var(--line);color:var(--gold-lite);margin-bottom:18px;
  background:rgba(200,168,106,.05);
}
.stat .ico svg{width:20px;height:20px}
.stat .n{font-family:'Cormorant Garamond',serif;font-size:2.7rem;font-weight:600;line-height:1;
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .l{color:var(--muted-2);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;margin-top:10px}

/* ---------- Toolbar ---------- */
.toolbar{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:22px;
}
.toolbar .section-label{margin-right:auto}
.toolbar .section-label .eyebrow{display:block;margin-bottom:4px}
.toolbar .section-label .t{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600}
.search{position:relative;min-width:240px;flex:1 1 240px;max-width:360px}
.search svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--muted-2);pointer-events:none}
.search input{
  width:100%;padding:12px 14px 12px 40px;background:rgba(255,255,255,.035);
  border:1px solid var(--line);border-radius:6px;color:var(--ink);font-family:inherit;font-size:.9rem;font-weight:300;
  transition:border-color .35s var(--ease),box-shadow .35s var(--ease);
}
.search input::placeholder{color:var(--muted-2)}
.search input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(200,168,106,.10)}
.filter-pills{display:flex;gap:8px;flex-wrap:wrap}
.pill{
  font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);
  padding:9px 15px;border:1px solid var(--line);border-radius:30px;cursor:pointer;background:transparent;
  font-family:inherit;transition:all .3s var(--ease);display:inline-flex;align-items:center;gap:7px;
}
.pill:hover{color:var(--ink);border-color:rgba(255,255,255,.25)}
.pill.active{color:#14110a;background:var(--gold-grad);border-color:transparent;font-weight:500}
.pill .cnt{opacity:.7;font-variant-numeric:tabular-nums}

/* ---------- Table / card ---------- */
.tablewrap{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--bg-2);box-shadow:var(--shadow-soft)}
table{width:100%;border-collapse:collapse;font-size:.92rem}
thead th{
  text-align:left;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);
  font-weight:600;padding:16px 20px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.015);
  white-space:nowrap;user-select:none;
}
thead th.sortable{cursor:pointer;transition:color .3s var(--ease)}
thead th.sortable:hover{color:var(--gold-lite)}
thead th .arr{display:inline-block;width:0;opacity:0;transition:opacity .25s;font-size:.8em;margin-left:4px}
thead th.sorted .arr{width:auto;opacity:.9}
.lead-row{cursor:pointer;transition:background .3s var(--ease)}
.lead-row>td{padding:17px 20px;border-bottom:1px solid var(--line-soft);vertical-align:middle;color:var(--ink)}
.lead-row:hover>td{background:rgba(255,255,255,.022)}
.lead-row.open>td{background:rgba(200,168,106,.04)}
.lead-row:last-child>td{border-bottom:none}
.cell-name{font-weight:400}
.cell-name b{font-weight:500}
.cell-name .mail{display:block;color:var(--muted-2);font-size:.8rem;margin-top:2px}
.cell-date{color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums}
.cell-date .rel{display:block;color:var(--muted-2);font-size:.72rem;margin-top:2px}
.cell-tel a{color:var(--gold-lite)}
.chev{width:16px;height:16px;color:var(--muted-2);transition:transform .4s var(--ease)}
.lead-row.open .chev{transform:rotate(90deg);color:var(--gold-lite)}

/* status badge + select */
.badge{
  display:inline-flex;align-items:center;gap:7px;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;
  padding:6px 12px;border-radius:30px;border:1px solid var(--line);font-weight:500;white-space:nowrap;
}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.badge.neu{color:var(--gold-lite);border-color:rgba(200,168,106,.4);background:rgba(200,168,106,.08)}
.badge.kontaktiert{color:#9fc0e8;border-color:rgba(41,69,107,.6);background:rgba(41,69,107,.18)}
.badge.erledigt{color:#9bd1a9;border-color:rgba(96,167,118,.35);background:rgba(96,167,118,.10)}
.device-tag{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:.78rem}
.device-tag svg{width:14px;height:14px;color:var(--muted-2)}

/* detail panel */
.detail-row>td{padding:0;border-bottom:1px solid var(--line-soft);background:rgba(0,0,0,.18)}
.detail-inner{
  display:grid;grid-template-columns:1.4fr 1fr;gap:30px;padding:26px 24px 30px;
}
.detail-block .eyebrow{margin-bottom:12px}
.detail-msg{
  color:var(--ink);font-weight:300;line-height:1.75;font-size:.98rem;
  border-left:2px solid;border-image:var(--gold-grad) 1;padding:4px 0 4px 18px;
}
.meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 20px}
.meta-grid .mi{min-width:0}
.meta-grid .mi .k{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-bottom:4px}
.meta-grid .mi .v{font-size:.9rem;color:var(--ink);word-break:break-word}
.meta-grid .mi .v a{color:var(--gold-lite)}
.meta-grid .mi.wide{grid-column:1 / -1}
.detail-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:22px;grid-column:1 / -1}
.detail-actions .lbl{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-right:4px}
.status-set{display:inline-flex;border:1px solid var(--line);border-radius:30px;overflow:hidden;background:rgba(255,255,255,.02)}
.status-set button{
  border:none;background:transparent;color:var(--muted);font-family:inherit;cursor:pointer;
  font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;padding:9px 16px;transition:all .3s var(--ease);
}
.status-set button:hover{color:var(--ink)}
.status-set button.on{color:#14110a;background:var(--gold-grad);font-weight:500}
.detail-actions .quick{margin-left:auto;display:flex;gap:8px}

.empty{text-align:center;color:var(--muted);padding:72px 24px}
.empty .serif{font-size:1.5rem;color:var(--ink);margin-bottom:8px}
.no-results{display:none;text-align:center;color:var(--muted);padding:54px 24px}

/* ---------- Footer signature ---------- */
.app-foot{
  max-width:1320px;margin:46px auto 0;padding:30px clamp(18px,4vw,46px) 50px;
  border-top:1px solid var(--line-soft);
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.app-foot .made{display:flex;align-items:center;gap:12px;color:var(--muted-2);font-size:.78rem;letter-spacing:.04em}
.app-foot .made .seal{
  width:30px;height:30px;border-radius:50%;border:1px solid rgba(200,168,106,.5);
  display:grid;place-items:center;color:var(--gold-lite);font-family:'Cormorant Garamond',serif;font-size:.9rem;
  flex:none;background:rgba(200,168,106,.06);
}
.app-foot .made b{color:var(--gold-lite);font-weight:400;font-family:'Cormorant Garamond',serif;font-size:1rem;letter-spacing:.02em}
.app-foot .ver{color:var(--muted-2);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase}

/* ---------- Animations ---------- */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ---------- Responsive ---------- */
@media(max-width:1080px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .detail-inner{grid-template-columns:1fr;gap:24px}
}
@media(max-width:760px){
  .top .who{display:none}
  .greeting h1{font-size:clamp(1.9rem,8vw,2.4rem)}
  .toolbar{align-items:stretch}
  .search{max-width:none}
  /* Tabelle -> Karten */
  thead{display:none}
  table,tbody,tr,td{display:block;width:100%}
  .lead-row{position:relative;border:1px solid var(--line);border-radius:10px;margin:0 12px 12px;padding:6px 0;background:var(--bg-2)}
  .lead-row:first-child{margin-top:12px}
  .lead-row>td{border:none;padding:8px 18px}
  .lead-row>td.cell-chev{position:absolute;top:14px;right:14px;width:auto;padding:0}
  .lead-row>td.cell-name{padding-top:16px}
  .lead-row>td[data-mlabel]::before{
    content:attr(data-mlabel);display:block;font-size:.6rem;letter-spacing:.14em;
    text-transform:uppercase;color:var(--muted-2);margin-bottom:3px;
  }
  .detail-row>td{padding:0 12px 12px;background:transparent}
  .detail-inner{margin:0 6px;border:1px solid var(--line);border-radius:10px;background:rgba(0,0,0,.2)}
  .meta-grid{grid-template-columns:1fr}
  .app-foot{flex-direction:column;text-align:center}
}
@media(max-width:430px){
  .stats{grid-template-columns:1fr}
  .login{padding:38px 26px 32px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}

/* ===== FrontPage media — Credit, Wordmark & Kontaktkarte ===== */
.fp-wordmark{font-family:'Inter',sans-serif;letter-spacing:.06em;color:var(--ink,#f5f2ea);white-space:nowrap}
.fp-wordmark .fp-front{font-weight:300}
.fp-wordmark .fp-page{font-weight:700}
.fp-wordmark .fp-media{font-weight:300;opacity:.7;font-size:.82em;margin-left:.12em}
.fp-wordmark.big{font-size:1.55rem}
.fp-credit{margin-top:6px;color:var(--muted-2,#7e8696);font-size:.78rem;line-height:1.55;font-weight:300}
.fp-credit b{color:var(--muted,#aab2c0);font-weight:500}
.fp-contact-btn{margin-top:12px;display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  background:transparent;border:1px solid var(--line,rgba(255,255,255,.12));color:var(--gold-lite,#e7d6ad);
  font-family:'Inter',sans-serif;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  padding:9px 16px;border-radius:4px;transition:all .25s ease}
.fp-contact-btn:hover{border-color:var(--gold,#c8a86a);background:rgba(200,168,106,.08)}
.app-foot .made{display:flex;gap:14px;align-items:flex-start}
.app-foot .made-txt{display:flex;flex-direction:column;gap:5px}
.app-foot .foot-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.login-foot{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}
@media(max-width:640px){.app-foot .foot-right{align-items:flex-start}}
/* Kopfzeile auf kleinen Bildschirmen entzerren (Logo + Links statt Überlappung) */
@media(max-width:620px){
  .top{padding:14px 16px;gap:10px}
  .top .brand{gap:10px;min-width:0}
  .top .brand img{height:28px;max-width:42vw;width:auto}
  .top .brand .bt{display:none}
  .top .right{gap:12px;flex-shrink:0}
  .top .logout{font-size:.62rem;letter-spacing:.09em}
}

/* Kontakt-Modal */
.fp-modal{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;
  background:rgba(4,6,10,.78);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  opacity:0;pointer-events:none;transition:opacity .3s ease;padding:20px}
.fp-modal.open{opacity:1;pointer-events:auto}
.fp-card{position:relative;width:100%;max-width:420px;background:linear-gradient(180deg,#10141d,#0b0e15);
  border:1px solid var(--line,rgba(255,255,255,.12));border-radius:12px;padding:34px 30px 28px;
  box-shadow:0 40px 110px rgba(0,0,0,.6);transform:translateY(14px) scale(.98);
  transition:transform .35s cubic-bezier(.16,.84,.34,1)}
.fp-modal.open .fp-card{transform:none}
.fp-close{position:absolute;top:12px;right:16px;background:none;border:none;color:var(--muted,#aab2c0);
  font-size:1.6rem;line-height:1;cursor:pointer}
.fp-close:hover{color:var(--ink,#f5f2ea)}
.fp-card .fp-wordmark.big{display:block;text-align:center;margin-bottom:18px}
.fp-person{text-align:center;margin-bottom:22px}
.fp-person .eyebrow{display:block;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold,#c8a86a);margin-bottom:6px}
.fp-person b{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:600;color:var(--ink,#f5f2ea)}
.fp-rows{display:flex;flex-direction:column;gap:10px}
.fp-row{display:flex;align-items:center;gap:14px;padding:12px 14px;border:1px solid var(--line,rgba(255,255,255,.12));
  border-radius:8px;text-decoration:none;transition:all .25s ease}
.fp-row:hover{border-color:var(--gold,#c8a86a);background:rgba(200,168,106,.06)}
.fp-ic{flex:none;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  background:rgba(200,168,106,.12);color:var(--gold-lite,#e7d6ad)}
.fp-ic svg{width:18px;height:18px}
.fp-txt{display:flex;flex-direction:column}
.fp-txt .t{color:var(--muted-2,#7e8696);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}
.fp-txt .s{color:var(--ink,#f5f2ea);font-size:.98rem}

.fp-credit.small{font-size:.7rem;line-height:1.5}
