/* BauAuftragPortal — shared styles */
:root{
  --navy:#0f2957;
  --navy-2:#0a1f42;
  --navy-3:#1a3a6e;
  --amber:#f59e0b;
  --amber-2:#d97f06;
  --amber-soft:#fff7e6;
  --blue:#1a4a9c;
  --blue-light:#0e7ab5;
  --green:#22c55e;
  --green-2:#15cd72;
  --green-soft:#e8fbf0;
  --ink:#0f172a;
  --ink-2:#1a2235;
  --muted:#64748b;
  --muted-2:#94a3b8;
  --line:#e2e8f0;
  --bg:#f8fafc;
  --card:#ffffff;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace}

/* NAV */
.nav{position:sticky;top:0;z-index:50;background:rgba(248,250,252,.9);backdrop-filter:blur(14px);border-bottom:1px solid rgba(15,41,87,.1)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:70px}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:19px;letter-spacing:-.01em;color:var(--navy)}
.logo-mark{width:32px;height:32px;border-radius:8px;background:var(--navy);display:grid;place-items:center;color:var(--amber);font-weight:900;font-size:14px}
.logo small{display:block;font-size:10px;font-weight:500;color:var(--muted);margin-top:-2px;letter-spacing:.04em;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:14.5px;font-weight:500;color:#334155;transition:color .15s}
.nav-links a:hover,.nav-links a.active{color:var(--navy)}
.nav-links a.active{position:relative}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-22px;height:2px;background:var(--amber)}
.nav-cta{display:flex;align-items:center;gap:10px}

.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:8px;font-weight:600;font-size:14.5px;transition:transform .15s, background .2s, box-shadow .2s;white-space:nowrap}
.btn-ghost{color:var(--navy)}
.btn-ghost:hover{background:rgba(15,41,87,.06)}
.btn-primary{background:var(--amber);color:var(--navy);box-shadow:0 1px 0 rgba(0,0,0,.04),0 8px 22px -10px rgba(245,158,11,.55)}
.btn-primary:hover{background:var(--amber-2);color:#fff;transform:translateY(-1px)}
.btn-dark{background:var(--navy);color:#fff}
.btn-dark:hover{background:var(--navy-2)}
.btn-outline{border:1.5px solid var(--navy);color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-light{background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.25)}
.btn-light:hover{background:rgba(255,255,255,.18)}
.btn-lg{padding:14px 22px;font-size:15px;border-radius:10px}

/* HERO SHARED */
.hero{padding:56px 0 72px;position:relative;overflow:hidden;background:linear-gradient(135deg,#0f2957 0%,#1a4a9c 65%,#0e7ab5 100%);color:#fff}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.06) 1px,transparent 0);background-size:32px 32px;mask-image:radial-gradient(ellipse 60% 70% at 70% 50%,black 20%,transparent 70%)}
.hero .wrap{position:relative;z-index:1}
.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:6px 12px 6px 10px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);font-size:12.5px;color:#fff;font-weight:500;backdrop-filter:blur(6px)}
.eyebrow .dot-am{width:6px;height:6px;border-radius:50%;background:var(--amber)}
h1.hero-h{font-size:62px;line-height:1.05;letter-spacing:-0.01em;font-weight:800;margin:18px 0 20px;color:#fff}
h1.hero-h .accent{color:var(--amber)}
.hero-sub{font-size:17.5px;color:rgba(255,255,255,.82);max-width:560px;margin-bottom:26px;text-wrap:pretty}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-pills{margin-top:28px;display:flex;gap:10px;flex-wrap:wrap}
.hero-pill{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:8px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-size:13px;color:rgba(255,255,255,.9)}
.hero-pill .tick{color:var(--amber);font-weight:700}

/* SECTION */
section.sec{padding:84px 0;background:#fff}
section.sec.alt{background:var(--bg)}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:36px;gap:24px;flex-wrap:wrap}
.sec-h{font-size:40px;font-weight:800;letter-spacing:-.025em;color:var(--navy);line-height:1.08;margin:0}
.sec-kicker{font-size:12px;font-weight:700;color:var(--amber-2);text-transform:uppercase;letter-spacing:.14em;margin-bottom:12px}
.sec-lead{font-size:16px;color:var(--muted);max-width:440px;text-wrap:pretty}

/* CARD/BADGE helpers */
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:6px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.badge-amber{background:var(--amber-soft);color:var(--amber-2)}
.badge-navy{background:rgba(15,41,87,.08);color:var(--navy)}
.badge-green{background:var(--green-soft);color:#15803d}
.badge-red{background:#fef2f2;color:#b91c1c}

/* LISTING CARD */
.listing{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px;transition:all .18s;display:flex;flex-direction:column;gap:12px}
.listing:hover{border-color:var(--navy);transform:translateY(-2px);box-shadow:0 14px 30px -20px rgba(15,41,87,.3)}
.listing .top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.listing h3{margin:2px 0 4px;font-size:17px;font-weight:700;color:var(--navy);letter-spacing:-.01em;line-height:1.3}
.listing .meta{display:flex;gap:14px;font-size:12.5px;color:var(--muted);flex-wrap:wrap}
.listing .locked{padding:10px 12px;border-radius:8px;background:#f1f5f9;font-size:13px;color:#475569;display:flex;align-items:center;gap:8px}
.listing .cta{display:flex;justify-content:space-between;align-items:center;padding-top:10px;border-top:1px dashed var(--line)}
.listing .cta .mini{font-size:12px;color:var(--muted)}

/* CATEGORY */
.cats{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.cat{position:relative;background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 14px;cursor:pointer;transition:all .18s;display:flex;flex-direction:column;gap:8px;min-height:110px}
.cat:hover{transform:translateY(-2px);border-color:var(--navy);box-shadow:0 12px 26px -18px rgba(15,41,87,.3)}
.cat .glyph{width:36px;height:36px;border-radius:8px;background:var(--bg);display:grid;place-items:center;font-size:18px}
.cat.master .glyph{background:#fef2f2}
.cat h3{font-size:13.5px;font-weight:700;color:var(--navy);margin:0;letter-spacing:-.005em;line-height:1.3}
.cat .meister{position:absolute;top:10px;right:10px;font-size:9.5px;color:#b91c1c;font-weight:700;background:#fef2f2;padding:3px 7px;border-radius:5px;letter-spacing:.04em;text-transform:uppercase}

.basket-tabs{display:inline-flex;padding:4px;background:#fff;border:1px solid var(--line);border-radius:10px;gap:4px;margin-bottom:24px}
.basket-tabs button{padding:9px 14px;border-radius:7px;font-size:13px;font-weight:600;color:var(--muted);transition:all .2s}
.basket-tabs button.active{background:var(--navy);color:#fff}

/* FOOTER */
footer{background:var(--navy-2);color:rgba(255,255,255,.65);padding:56px 0 24px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:36px}
footer h5{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:#fff;margin:0 0 14px}
footer ul{list-style:none;padding:0;margin:0}
footer li{padding:5px 0;font-size:13.5px}
footer a:hover{color:var(--amber)}
.foot-logo{color:#fff;font-size:20px;font-weight:800;letter-spacing:-.015em;margin-bottom:12px;display:flex;align-items:center;gap:10px}
.foot-desc{font-size:13.5px;line-height:1.6;max-width:300px;margin-bottom:16px}
.foot-legal{font-size:12.5px;color:rgba(255,255,255,.55);line-height:1.7;margin-bottom:16px}
.foot-legal a{color:rgba(255,255,255,.75)}
.foot-cross{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:16px;margin-bottom:26px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.foot-cross .l{display:flex;align-items:center;gap:12px}
.foot-cross .mk{width:36px;height:36px;border-radius:8px;background:var(--navy);color:var(--amber);display:grid;place-items:center;font-weight:800;font-size:13px}
.foot-cross h4{margin:0 0 2px;font-size:14.5px;color:#fff;font-weight:700}
.foot-cross span{font-size:12.5px;color:rgba(255,255,255,.6)}
.foot-cross a{color:var(--amber);font-size:13px;font-weight:600}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:18px;display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,.45);flex-wrap:wrap;gap:10px}

/* Page hero (smaller than homepage hero) */
.page-hero{padding:48px 0 52px;background:linear-gradient(135deg,#0f2957 0%,#1a4a9c 100%);color:#fff;position:relative;overflow:hidden;scroll-margin-top:70px}
.page-hero::before{content:"";position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.05) 1px,transparent 0);background-size:32px 32px;mask-image:radial-gradient(ellipse 80% 100% at 50% 50%,black 20%,transparent 75%)}
.page-hero .wrap{position:relative;z-index:1}
.crumbs{font-size:12.5px;color:rgba(255,255,255,.6);margin-bottom:12px}
.crumbs a{color:rgba(255,255,255,.75)}
.crumbs a:hover{color:var(--amber)}
.page-hero h1{font-size:44px;font-weight:800;letter-spacing:-.025em;margin:0 0 10px;line-height:1.1}
.page-hero p{font-size:16.5px;color:rgba(255,255,255,.8);max-width:620px;margin:0}

/* Forms */
.field{display:block;margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:6px}
.field label .opt{color:var(--muted);font-weight:400}
.field input,.field select,.field textarea{width:100%;padding:11px 14px;border:1.5px solid var(--line);border-radius:8px;font-family:inherit;font-size:14.5px;color:var(--ink);background:#fff;transition:border-color .15s,box-shadow .15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(15,41,87,.08)}
.field textarea{min-height:120px;resize:vertical}
.field .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field .help{font-size:12px;color:var(--muted);margin-top:6px}
.check{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:#334155}
.check input{margin-top:3px}

/* Prose (legal pages) */
.prose{max-width:760px;margin:0 auto;padding:56px 0}
.prose h2{font-size:24px;color:var(--navy);margin-top:36px;letter-spacing:-.015em}
.prose h3{font-size:17px;color:var(--navy);margin-top:24px}
.prose p,.prose li{font-size:14.5px;color:#334155;line-height:1.7}
.prose a{color:var(--blue);text-decoration:underline}
.prose ul{padding-left:20px}

/* Responsive */
@media (max-width:1000px){
  .cats{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  .nav-links{display:none}
  h1.hero-h{font-size:44px}
  .sec-h{font-size:30px}
  .page-hero h1{font-size:32px}
  .page-hero{padding:72px 0 52px}
}
@media (max-width:560px){
  .cats{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  h1.hero-h{font-size:36px}
  .field .row{grid-template-columns:1fr}
  .page-hero{padding:80px 0 48px}
  .page-hero h1{font-size:28px}
}
