/* WriteBiz UI — navy/blue enterprise chrome, matching the reference screens. */
:root {
    --wb-navy: #14315e;
    --wb-navy-dark: #0f2748;
    --wb-blue: #1f4d8f;
    --wb-accent: #f2c200;     /* yellow tab/button accent */
    --wb-bg: #d9dde3;         /* page gray */
    --wb-panel: #ffffff;
    --wb-line: #c3ccd6;
    --wb-red: #9b1c2e;        /* section headings */
    --wb-text: #1c2733;
    --wb-link: #1f4d8f;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    font-family: "Segoe UI", Tahoma, Arial, sans-serif;
    font-size: 13px;
    color: var(--wb-text);
    background: var(--wb-bg);
}

a { color: var(--wb-link); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---------- Top bar ---------- */
.wb-topbar {
    background: var(--wb-navy);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 22px;
    height: 64px;
}
.wb-brand { display: flex; align-items: center; gap: 12px; color: #fff; }
.wb-brand:hover { text-decoration: none; }
.wb-logo {
    background: #fff;
    color: var(--wb-navy);
    font-weight: 800;
    font-size: 20px;
    border-radius: 6px;
    padding: 6px 9px;
    letter-spacing: -1px;
}
.wb-brandtext { font-size: 26px; letter-spacing: -0.5px; }
.wb-brandtext strong { font-weight: 800; }
.wb-topbar-right { display: flex; align-items: center; gap: 16px; }
.wb-loggedin { font-size: 12px; font-weight: 600; letter-spacing: .3px; }
.wb-loginlink { color: #fff; font-weight: 600; }
.wb-btn-dark {
    background: var(--wb-blue);
    color: #fff !important;
    padding: 7px 14px;
    border-radius: 4px;
    font-weight: 600;
    border: 1px solid #2b5ea0;
}
.wb-btn-dark:hover { text-decoration: none; background: #2b5ea0; }

/* ---------- Main / footer ---------- */
.wb-main { min-height: calc(100vh - 64px - 70px); }
.wb-footer {
    background: var(--wb-navy);
    color: #cfd9e6;
    padding: 12px 22px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    font-size: 11px;
}
.wb-footer-brand { font-weight: 800; font-size: 18px; color: #fff; }
.wb-footer-brand span { font-weight: 400; font-size: 9px; display: block; letter-spacing: 2px; }
.wb-footer-meta a { color: #ffd24d; }

/* ---------- Home landing ---------- */
.home-nav {
    background: var(--wb-navy-dark);
    display: flex;
    gap: 4px;
    padding: 0 22px;
}
.home-nav a {
    color: #fff;
    padding: 14px 18px;
    font-weight: 600;
    font-size: 14px;
}
.home-nav a:hover { background: var(--wb-blue); text-decoration: none; }
.home-hero {
    position: relative;
    height: 460px;
    background: linear-gradient(120deg, #0f2748 0%, #1f4d8f 60%, #2f6fb0 100%);
    color: #fff;
    display: flex;
    align-items: center;
    padding: 0 60px;
}
.home-hero h1 { font-size: 44px; margin: 0 0 14px; max-width: 640px; line-height: 1.1; }
.home-hero p { font-size: 18px; max-width: 560px; opacity: .92; }
.home-hero .hero-cta {
    display: inline-block; margin-top: 24px; background: var(--wb-accent);
    color: var(--wb-navy-dark); font-weight: 700; padding: 12px 26px; border-radius: 5px;
}
.home-hero .hero-cta:hover { text-decoration: none; filter: brightness(1.05); }

/* ---------- Login ---------- */
.login-wrap { max-width: 420px; margin: 60px auto; background: #fff; border: 1px solid var(--wb-line); }
.login-head { background: var(--wb-navy); color: #fff; padding: 14px 20px; font-size: 16px; font-weight: 600; }
.login-body { padding: 26px 28px; }
.login-body label { display: block; font-weight: 600; margin: 14px 0 5px; }
.login-body input[type=text], .login-body input[type=password], .login-body select {
    width: 100%; padding: 8px 10px; border: 1px solid var(--wb-line); border-radius: 3px;
}
.login-actions { margin-top: 22px; }
.wb-btn {
    background: var(--wb-blue); color: #fff; border: none; padding: 9px 22px;
    border-radius: 4px; font-weight: 600; cursor: pointer;
}
.wb-btn:hover { background: #2b5ea0; }
.login-error { color: var(--wb-red); margin-top: 12px; font-weight: 600; }

/* ---------- Dashboard layout ---------- */
.wb-shell { display: flex; gap: 0; align-items: stretch; }
.wb-left {
    width: 230px; background: #eef1f5; border-right: 1px solid var(--wb-line);
    flex: 0 0 230px; padding: 12px;
}
.wb-left .search-box { background: #fff; border: 1px solid var(--wb-line); padding: 10px; margin-bottom: 14px; }
.wb-left .search-box input { width: 100%; padding: 6px 8px; margin-bottom: 6px; border: 1px solid var(--wb-line); }
.wb-left h4 { color: var(--wb-navy); font-size: 12px; text-transform: uppercase; letter-spacing: .5px; margin: 16px 0 8px; }
.wb-left a.tool { display: block; padding: 7px 10px; color: var(--wb-text); border-bottom: 1px solid #e1e6ec; }
.wb-left a.tool:hover { background: #dfe6ef; text-decoration: none; }
.wb-left a.tool.writebiz { font-weight: 700; color: var(--wb-navy); }

.wb-center { flex: 1 1 auto; padding: 16px 20px; }
.wb-tabs { display: flex; gap: 2px; border-bottom: 2px solid var(--wb-navy); margin-bottom: 16px; }
.wb-tabs a {
    background: #cdd5df; color: var(--wb-navy); padding: 9px 16px; font-weight: 600;
    border-radius: 4px 4px 0 0;
}
.wb-tabs a.active, .wb-tabs a:hover { background: var(--wb-navy); color: #fff; text-decoration: none; }

/* ---------- Panels / grids ---------- */
.wb-panel { background: var(--wb-panel); border: 1px solid var(--wb-line); margin-bottom: 18px; }
.wb-panel > h2, .section-head {
    color: var(--wb-red); font-size: 15px; margin: 0; padding: 12px 14px 6px;
    border-bottom: 1px solid #eee;
}
.wb-panel .panel-body { padding: 14px; }
table.wb-grid { width: 100%; border-collapse: collapse; }
table.wb-grid th {
    background: var(--wb-navy); color: #fff; text-align: left; padding: 8px 10px; font-size: 12px;
}
table.wb-grid td { padding: 8px 10px; border-bottom: 1px solid #e3e8ee; }
table.wb-grid tr:nth-child(even) td { background: #f6f8fb; }
.lob-check { color: #2e8b3d; font-weight: 800; }
.lob-empty { color: #cfd6de; }

/* ---------- LOB detail form ---------- */
.lob-form { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 22px; padding: 14px; }
.lob-form .full { grid-column: 1 / -1; }
.lob-form label { display: block; font-weight: 600; margin-bottom: 4px; }
.lob-form input, .lob-form select, .lob-form textarea {
    width: 100%; padding: 7px 9px; border: 1px solid var(--wb-line); border-radius: 3px;
}
.lob-actions { padding: 0 14px 16px; }
.rate-result { padding: 10px 14px; background: #eef6ee; border: 1px solid #cfe3cf; color: #1f5a2a; font-weight: 700; margin: 0 14px 14px; }
.validation { padding: 10px 14px; background: #fbeced; border: 1px solid #e6c3c8; color: var(--wb-red); margin: 0 14px 14px; }
.validation ul { margin: 6px 0 0 18px; }

.crumbs { color: #5a6675; margin-bottom: 10px; font-size: 12px; }
.client-banner { background: var(--wb-navy); color: #fff; padding: 10px 16px; display:flex; justify-content: space-between; align-items:center; }
.client-banner .addr { font-size: 12px; line-height: 1.3; text-align: right; }
