/* ============================================================
   Gutachten-Portal · Webdesign nach Design-Tokens (hellblau)
   Rebranding: --primary unten anpassen.
============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root{
  --bg:#FBFAF6; --fg:#161D17; --card:#FFFFFF; --muted:#F3F2EE; --muted-fg:#5F6560;
  --line:#DDDFD8;
  --primary:#2f7dc4; --primary-dk:#235e95; --primary-li:#E4F0FB;
  --ok:#2faf56; --warn:#e0a316; --hard:#d8503f;
  --radius:12px; --radius-sm:8px; --radius-md:10px; --radius-xl:16px;
  --shadow:0 1px 2px rgba(22,29,23,.04),0 4px 12px rgba(22,29,23,.06);
  --shadow-hover:0 2px 4px rgba(22,29,23,.06),0 12px 24px rgba(22,29,23,.10);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font:15px/1.55 Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--fg);background:var(--bg);font-feature-settings:"cv02","cv03","cv04","cv11"}
h1,h2,h3{letter-spacing:-0.015em}
a{color:var(--primary-dk);text-decoration:none}
a:hover{text-decoration:underline}
.hidden{display:none!important}

/* ---- Top-Navigation ---- */
.nav{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50;box-shadow:var(--shadow)}
.nav .inner{max-width:1120px;margin:0 auto;padding:12px 22px;display:flex;align-items:center;gap:14px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--fg);font-size:18px}
.brand .logo{width:32px;height:32px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--primary),#5aa0e0);display:grid;place-items:center;color:#fff;font-size:17px}
.nav .spacer{flex:1}
.nav .user{font-size:13px;color:var(--muted-fg)}
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:#fff;color:var(--fg);
  padding:0 16px;height:40px;border-radius:var(--radius-md);font:inherit;font-size:14px;font-weight:500;cursor:pointer;transition:.15s}
.btn:hover{border-color:var(--primary);color:var(--primary-dk)}
.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}
.btn.primary:hover{background:var(--primary-dk);color:#fff}
.btn.ghost{background:transparent}

/* ---- Login ---- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(1200px 520px at 50% -10%, var(--primary-li), var(--bg))}
.login-card{width:100%;max-width:410px;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius-xl);box-shadow:var(--shadow-hover);padding:34px 30px}
.login-card .brand{justify-content:center;font-size:21px;margin-bottom:6px}
.login-card .logo{width:40px;height:40px;font-size:21px}
.login-sub{text-align:center;color:var(--muted-fg);font-size:14px;margin:0 0 22px}
label{display:block;font-size:13px;font-weight:600;color:var(--fg);margin:14px 0 5px}
input[type=email],input[type=password],input[type=text]{width:100%;padding:11px 13px;border:1px solid var(--line);
  border-radius:var(--radius-sm);font:inherit;background:#fff;height:42px}
input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-li)}
.login-card .btn.primary{width:100%;justify-content:center;margin-top:22px;height:44px}
.msg{margin-top:14px;font-size:14px;padding:10px 12px;border-radius:var(--radius-sm);display:none}
.msg.err{display:block;background:#fdecea;color:#a32417;border:1px solid #f5c4bd}
.msg.ok{display:block;background:#e9f7ee;color:#1c6b37;border:1px solid #bfe6cc}
.login-foot{text-align:center;margin-top:18px;font-size:12px;color:var(--muted-fg)}

/* ---- Portal ---- */
.page{max-width:1120px;margin:0 auto;padding:34px 22px 70px}
.hero{background:linear-gradient(135deg,var(--primary),#5aa0e0);color:#fff;border-radius:var(--radius-xl);
  padding:38px 38px;box-shadow:var(--shadow);margin-bottom:14px}
.hero h1{margin:0 0 10px;font-size:30px;line-height:1.2}
.hero p{margin:0;max-width:760px;color:#eaf3fb;font-size:16px}
.usps{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.usp{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);padding:8px 14px;border-radius:9999px;font-size:13.5px;font-weight:600}
.lead{color:var(--muted-fg);font-size:16px;max-width:840px;margin:26px 2px 4px}

.section-title{display:flex;align-items:baseline;gap:12px;margin:30px 2px 8px}
.section-title h2{font-size:18px;margin:0}
.section-title .hint{font-size:13px;color:var(--muted-fg)}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:14px}
.tile{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 20px 18px;box-shadow:var(--shadow);transition:.15s;display:flex;flex-direction:column;gap:6px}
.tile h3{margin:0;font-size:16px}
.tile .law{font-size:12.5px;color:var(--muted-fg)}
.tile .desc{font-size:13.5px;color:#46565d;margin-top:4px}
.tile .foot{margin-top:auto;padding-top:14px;display:flex;align-items:center;gap:8px}
.tag{font-size:11px;font-weight:700;padding:3px 10px;border-radius:9999px}
.tag.live{background:var(--primary-li);color:var(--primary-dk)}
.tag.soon{background:var(--muted);color:#8a938c}
.tile.available{cursor:pointer;border-color:#bcd9f1}
.tile.available:hover{border-color:var(--primary);box-shadow:var(--shadow-hover);transform:translateY(-2px)}
.tile.available .go{margin-left:auto;color:var(--primary-dk);font-weight:700;font-size:14px}
.tile.locked{opacity:.62;background:#f8f8f5}
.tile.locked .lockicon{position:absolute;top:16px;right:16px;color:#aab3ab}
.tile .corner{position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 40px 40px 0;border-color:transparent var(--primary) transparent transparent}
.tile .corner::after{content:"✓";position:absolute;top:2px;right:-35px;color:#fff;font-size:13px;font-weight:700}

.foot-note{margin-top:34px;font-size:12.5px;color:var(--muted-fg);border-top:1px solid var(--line);padding-top:16px}
.demobar{background:#fff4d6;color:#7a5a00;border-bottom:1px solid #ecd58c;font-size:13.5px;padding:9px 22px;text-align:center}
.demobar b{color:#6a4e00}

/* ---- App-Seite Einbettung ---- */
.appframe{width:100%;height:calc(100vh - 58px);border:0;display:block;background:#FBFAF6}
.app-subbar{background:#fff;border-bottom:1px solid var(--line)}
.app-subbar .inner{max-width:1120px;margin:0 auto;padding:9px 22px;display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--muted-fg)}
.breadcrumb a{color:var(--muted-fg)}
.breadcrumb b{color:var(--fg)}

/* ---- Tab-Navigation ---- */
.nav .tabs{display:flex;gap:4px;flex-wrap:wrap}
.nav .tabs a{padding:8px 12px;border-radius:var(--radius-sm);font-size:14px;color:var(--muted-fg);font-weight:500}
.nav .tabs a:hover{background:var(--muted);text-decoration:none;color:var(--fg)}
.nav .tabs a.active{background:var(--primary-li);color:var(--primary-dk)}

/* ---- Pfad-Karten (zwei Nutzertypen) ---- */
.paths{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}
.path{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px}
.path:hover{box-shadow:var(--shadow-hover)}
.path .ic{width:48px;height:48px;border-radius:var(--radius-md);background:var(--primary-li);display:grid;place-items:center;font-size:23px}
.path h3{margin:6px 0 0;font-size:19px}
.path p{margin:0;color:var(--muted-fg);font-size:14px}
.path ul{margin:6px 0 0;padding-left:18px;color:#46565d;font-size:13.5px}.path li{margin:4px 0}
.path .btn{margin-top:14px;align-self:flex-start}

/* ---- Plattform-Seite ---- */
.sec{margin-top:36px}
.sec h2{font-size:22px;margin:0 0 4px}
.sec .sub{color:var(--muted-fg);margin:0 0 14px;max-width:760px}
.flowwrap{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);overflow-x:auto}
.flowwrap svg{display:block;width:100%;height:auto;min-width:560px}
.feature-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-top:8px}
.feature{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.feature .fi{font-size:22px}.feature h4{margin:8px 0 4px;font-size:15px}.feature p{margin:0;color:var(--muted-fg);font-size:13.5px}
.pricing{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:10px}
.price{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);display:flex;flex-direction:column}
.price.feat{border-color:var(--primary);box-shadow:var(--shadow-hover)}
.badge-role{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:9999px;background:var(--primary-li);color:var(--primary-dk);align-self:flex-start}
.price h3{margin:10px 0 2px;font-size:18px}
.price .amt{font-size:24px;font-weight:700;color:var(--primary-dk);margin:8px 0}
.price .amt small{font-size:13px;color:var(--muted-fg);font-weight:500}
.price ul{margin:8px 0 16px;padding-left:18px;color:#46565d;font-size:14px}.price li{margin:5px 0}
.price .btn{margin-top:auto}
.dsgvo{background:var(--primary-li);border:1px solid #bcd9f1;border-radius:var(--radius);padding:22px;margin-top:14px}
.dsgvo h3{margin:0 0 8px}.dsgvo ul{margin:0;padding-left:18px;font-size:14px;color:#28455c}.dsgvo li{margin:5px 0}
.beauftragen{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin-top:14px;box-shadow:var(--shadow)}
.frame-intro{color:var(--muted-fg);font-size:14px;margin:14px 0}

@media(max-width:680px){.paths{grid-template-columns:1fr}}
@media(max-width:600px){
  .hero{padding:26px 22px}.hero h1{font-size:24px}
  .page{padding:22px 16px 50px}
}
