@font-face{font-family:Inter;src:url('/assets/fonts/inter/400-latin.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:Inter;src:url('/assets/fonts/inter/500-latin.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:Inter;src:url('/assets/fonts/inter/600-latin.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:Inter;src:url('/assets/fonts/inter/700-latin.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:Inter;src:url('/assets/fonts/inter/800-latin.woff2') format('woff2');font-weight:800;font-style:normal;font-display:swap}
:root{--green:#008a48;--green2:#0fbf82;--green3:#006b3c;--ink:#07111f;--muted:#697386;--line:#e2e8f0;--field:#f8faf9;--white:#fff;--radius:26px;--font:Inter,Arial,sans-serif}
*{box-sizing:border-box}html,body{margin:0;min-height:100%;font-family:var(--font);color:var(--ink)}body{background:#eef3f1}.fp-auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:34px 18px;background-image:linear-gradient(90deg,rgba(3,18,27,.38),rgba(3,18,27,.06)),url('/assets/img/bg.jpeg');background-size:cover;background-position:center;background-attachment:fixed;overflow:auto}.fp-auth-shell{width:100%;max-width:960px}.fp-auth-logo{height:58px;margin:0 0 18px;display:flex;align-items:center;justify-content:center}.fp-auth-logo img{height:58px;width:auto;display:block;max-width:290px;object-fit:contain}.fp-auth-card{display:grid;grid-template-columns:1.06fr .94fr;min-height:580px;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 28px 75px rgba(2,6,23,.25);border:1px solid rgba(255,255,255,.6)}.fp-auth-form-panel{display:flex;align-items:center;justify-content:center;padding:42px 54px;background:#fff}.fp-auth-form-inner{width:100%;max-width:395px}.fp-auth-title{margin:0;text-align:center;font-size:37px;line-height:.95;font-weight:800;letter-spacing:-1.3px}.fp-auth-subtitle{margin:13px 0 29px;text-align:center;color:var(--muted);font-size:14px;font-weight:500}.fp-field{margin-bottom:15px}.fp-label{display:block;margin-bottom:8px;font-size:13px;font-weight:800}.fp-input-wrap{height:52px;display:flex;align-items:center;gap:12px;padding:0 16px;border:1px solid #dbe3ea;background:var(--field);border-radius:14px}.fp-input-wrap:focus-within{background:#fff;border-color:rgba(0,138,72,.55);box-shadow:0 0 0 4px rgba(15,191,130,.12)}.fp-input-icon{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 16px;color:#9aa7b4}.fp-input-icon svg{display:block;width:16px;height:16px;stroke:currentColor}.fp-input{width:100%;min-width:0;border:0;outline:0;background:transparent;font:500 14px/1 var(--font);color:var(--ink)}.fp-input::placeholder{color:#8b96a5}.fp-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.fp-remember-box{height:54px;display:flex;align-items:center;gap:11px;padding:0 15px;border:1px solid #dbe3ea;border-radius:15px;background:#fff;font-size:13px;font-weight:800;flex:1}.fp-checkbox{width:18px;height:18px;margin:0;accent-color:var(--green)}.fp-select{height:54px;min-width:112px;padding:0 15px;border:1px solid #dbe3ea;border-radius:15px;background:#f8faf9;font:700 13px/1 var(--font);color:#64748b}.fp-select:disabled{opacity:.45;cursor:not-allowed;background:#f1f5f9}.fp-link-row{display:flex;justify-content:flex-end;margin:13px 0 16px}.fp-link{color:#006b3c;font-weight:800;font-size:13px;text-decoration:none}.fp-link:hover{text-decoration:underline}.fp-button{width:100%;height:55px;border:0;border-radius:14px;background:linear-gradient(135deg,#00904f,#006b3c);color:#fff;font:800 14px/1 var(--font);cursor:pointer;box-shadow:0 16px 34px rgba(0,138,72,.24)}.fp-button-secondary{width:100%;height:52px;border:1px solid #dbe3ea;border-radius:14px;background:#fff;color:var(--ink);font:800 14px/1 var(--font);cursor:pointer}.fp-divider{display:flex;align-items:center;gap:12px;margin:18px 0;color:#9aa7b4;font-size:12px}.fp-divider:before,.fp-divider:after{content:"";height:1px;background:#e5e7eb;flex:1}.fp-google{display:inline-flex;align-items:center;justify-content:center;margin-right:8px;width:18px;height:18px;border-radius:50%;font-weight:800;color:#4285f4}.fp-auth-foot{margin-top:18px;text-align:center;color:#6b7280;font-size:12px}.fp-auth-foot a{color:#006b3c;font-weight:800;text-decoration:none}.fp-auth-info-panel{position:relative;display:flex;align-items:center;padding:58px 50px;background:linear-gradient(145deg,#38cc95 0%,#008744 100%);color:#fff;overflow:hidden}.fp-auth-info-panel:after{content:"";position:absolute;right:-86px;bottom:-110px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.15)}.fp-auth-info-inner{position:relative;z-index:1;max-width:360px}.fp-info-title{margin:0 0 18px;font-size:38px;line-height:.98;font-weight:800;letter-spacing:-1.4px}.fp-info-text{margin:0 0 30px;color:rgba(255,255,255,.94);font-size:16px;line-height:1.55;font-weight:500}.fp-info-list{display:grid;gap:13px}.fp-info-item{display:flex;align-items:center;gap:14px;padding:16px;border:1px solid rgba(255,255,255,.22);border-radius:16px;background:rgba(255,255,255,.13)}.fp-info-icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;flex:0 0 42px;border-radius:13px;background:rgba(255,255,255,.18);color:#fff}.fp-info-icon svg{display:block;width:20px;height:20px;stroke:currentColor}.fp-info-item strong{display:block;font-size:14px;font-weight:800;margin-bottom:3px}.fp-info-item span{display:block;font-size:12px;line-height:1.35;color:rgba(255,255,255,.82);font-weight:500}.fp-alert{margin-bottom:16px;padding:12px 14px;border-radius:12px;background:#fef2f2;color:#991b1b;border:1px solid #fecaca;font-size:13px;font-weight:700}@media(max-width:900px){.fp-auth-card{grid-template-columns:1fr}.fp-auth-info-panel{display:none}.fp-auth-form-panel{padding:34px 24px}.fp-auth-shell{max-width:520px}}@media(max-width:520px){.fp-auth-page{padding:20px 12px;align-items:flex-start}.fp-auth-logo img{height:48px}.fp-auth-card{border-radius:22px}.fp-auth-form-panel{padding:30px 20px}.fp-auth-title{font-size:33px}.fp-row{display:grid}.fp-select{width:100%}}

/* =========================================================
   Firmenpilot Laravel Dashboard Bridge V3
   Nutzt die Original-Assets aus v5.zip und hält Login-CSS getrennt stabil.
   ========================================================= */
.fp-lv3-body {
    font-family: 'Inter', sans-serif;
    background: #ececec;
    color: #151515;
}
.fp-lv3-shell {
    width: 100%;
    min-height: 100vh;
}
.fp-lv3-icon-mask {
    display: inline-block;
    width: 1.08rem;
    height: 1.08rem;
    flex: 0 0 auto;
    background: currentColor;
    -webkit-mask: var(--fp-icon-url) center / contain no-repeat;
    mask: var(--fp-icon-url) center / contain no-repeat;
}
.fp-lv3-navbar-icon {
    display: inline-block;
    width: 1.2rem;
    height: 1.2rem;
    background: currentColor;
    -webkit-mask: var(--fp-icon-url) center / contain no-repeat;
    mask: var(--fp-icon-url) center / contain no-repeat;
}
.fp-lv3-account-panel,
.fp-lv3-mail-panel,
.fp-lv3-search-panel {
    display: none;
}
.fp-lv3-account-panel.is-open,
.fp-lv3-mail-panel.is-open,
.fp-lv3-search-panel.is-open {
    display: block;
}
.fp-lv3-search-panel {
    max-height: min(64vh, 640px);
    overflow-y: auto;
}
.fp-lv3-sidebar-card-bg {
    background-image: radial-gradient(circle at 78% 28%, rgba(0,255,150,.17), transparent 25%), radial-gradient(circle at 40% 70%, rgba(0,180,120,.2), transparent 35%), linear-gradient(145deg, #04170f, #0a2d1d 45%, #0e5131);
}
.fp-lv3-dashboard-card {
    min-height: 238px;
}
.fp-lv3-dashboard-card-tall {
    min-height: 238px;
}
.fp-lv3-page-title {
    letter-spacing: -0.075em;
}
.fp-lv3-menu-label {
    letter-spacing: -0.025em;
}
.fp-lv3-no-scrollbar::-webkit-scrollbar { width: 0; height: 0; }
.fp-lv3-no-scrollbar { scrollbar-width: none; }
@media (max-width: 1279px) {
    .fp-lv3-layout { grid-template-columns: 1fr !important; }
    .fp-lv3-sidebar { display: none; }
}

/* =========================================================
   Firmenpilot Dashboard Content Patch V5
   Dashboard-Inhalt naeher am Original: weniger fett, kleinere Buttons,
   kleinere Settings-Iconkarte, ruhigere Card-Typografie.
   ========================================================= */
.fp-dashboard-page .fp-lv3-page-title {
    margin: 0 !important;
    color: #151515 !important;
    font-size: clamp(3.25rem, 4.4vw, 4.45rem) !important;
    line-height: 0.94 !important;
    font-weight: 800 !important;
    letter-spacing: -0.075em !important;
}

.fp-dashboard-settings-button {
    display: inline-grid;
    width: 2.55rem;
    height: 2.55rem;
    flex: 0 0 auto;
    place-items: center;
    border: 1px solid rgba(15, 23, 42, .055);
    border-radius: 999px;
    background: rgba(255, 255, 255, .92);
    color: #0f6637;
    box-shadow: 0 12px 26px rgba(15, 23, 42, .075);
}

.fp-dashboard-settings-button .fp-lv3-navbar-icon {
    width: 1.05rem !important;
    height: 1.05rem !important;
}

.fp-dashboard-actions {
    align-items: center;
}

.fp-dashboard-action {
    display: inline-flex;
    min-height: 2.55rem;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0 .95rem;
    font-size: .9rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: -0.02em;
    white-space: nowrap;
    text-decoration: none;
    transition: transform .16s ease, box-shadow .16s ease, background-color .16s ease, border-color .16s ease;
}

.fp-dashboard-action-primary {
    border: 1px solid #127f44;
    background: #127f44;
    color: #fff;
    box-shadow: 0 12px 24px rgba(18, 127, 68, .16);
}

.fp-dashboard-action-secondary {
    border: 1px solid #2d5d46;
    background: #fff;
    color: #173b28;
    box-shadow: none;
}

.fp-dashboard-action:hover {
    transform: translateY(-1px);
}

.fp-dashboard-card,
.fp-card-welcome {
    border: 0 !important;
}

.fp-card-title {
    margin: 0;
    color: #111827;
    font-size: 1.06rem;
    font-weight: 750;
    line-height: 1.12;
    letter-spacing: -0.045em;
}

.fp-card-kicker {
    margin: 0;
    font-size: 1.2rem;
    font-weight: 750;
    line-height: 1.1;
    letter-spacing: -0.045em;
}

.fp-card-welcome-name {
    margin: .9rem 0 0;
    max-width: 13.5rem;
    color: #fff;
    font-size: 2.05rem;
    font-weight: 800;
    line-height: .98;
    letter-spacing: -0.075em;
}

.fp-card-open {
    position: absolute;
    right: 1.35rem;
    top: 1.35rem;
    display: grid;
    width: 2.35rem;
    height: 2.35rem;
    place-items: center;
    border: 2px solid #151515;
    border-radius: 999px;
    color: #111827;
    background: #fff;
    font-size: 1.2rem;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
}

.fp-card-number {
    color: #07111f;
    font-size: 3.55rem;
    font-weight: 800;
    line-height: .9;
    letter-spacing: -0.08em;
}

.fp-card-label {
    color: #64748b;
    font-size: .72rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: .22em;
    text-transform: uppercase;
}

.fp-card-time {
    color: #10182b;
    font-size: 3rem;
    font-weight: 800;
    line-height: .95;
    letter-spacing: -0.085em;
}

.fp-card-subtitle {
    margin: .18rem 0 0;
    color: #64748b;
    font-size: .86rem;
    font-weight: 500;
    line-height: 1.35;
}

.fp-card-footer {
    color: #6f8f78;
    font-size: .88rem;
    font-weight: 700;
    line-height: 1.35;
}

.fp-status-pill {
    display: inline-flex;
    width: max-content;
    align-items: center;
    border-radius: 999px;
    background: #f1f5f9;
    padding: .22rem .72rem;
    color: #475569;
    font-size: .78rem;
    font-weight: 700;
    line-height: 1.2;
}

.fp-small-action {
    display: inline-flex;
    min-width: 5.7rem;
    min-height: 2.25rem;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 0 .95rem;
    font-size: .82rem;
    font-weight: 750;
    line-height: 1;
}

.fp-small-action-primary {
    border: 1px solid #127f44;
    background: #127f44;
    color: #fff;
}

.fp-small-action-secondary {
    border: 1px solid #e2e8f0;
    background: #fff;
    color: #111827;
}

.fp-card-soft-icon {
    display: grid;
    width: 2.7rem;
    height: 2.7rem;
    place-items: center;
    border: 1px solid rgba(18, 127, 68, .12);
    border-radius: 999px;
    background: #e7f8ed;
    color: #127f44;
}

.fp-card-person {
    color: #111827;
    font-size: .94rem;
    font-weight: 700;
    line-height: 1.2;
}

.fp-presence-pill {
    display: inline-flex;
    align-items: center;
    gap: .32rem;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
    background: #f8fafc;
    padding: .25rem .62rem;
    color: #64748b;
    font-size: .74rem;
    font-weight: 700;
}

.fp-presence-pill span {
    color: #f43f5e;
}

.fp-money-negative,
.fp-money-neutral {
    font-size: 2.35rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.07em;
}

.fp-money-negative { color: #c81e3a; }
.fp-money-neutral { color: #102016; }

.fp-dashboard-unified-grid > [data-fp-dashboard-widget],
.fp-dashboard-unified-grid > .fp-dashboard-placeholder {
    height: 238px !important;
    min-height: 238px !important;
    max-height: 238px !important;
}

@media (max-width: 1279px) {
    .fp-dashboard-page .fp-lv3-page-title {
        font-size: clamp(2.8rem, 6vw, 4rem) !important;
    }
}

@media (max-width: 640px) {
    .fp-dashboard-actions {
        gap: .55rem !important;
    }
    .fp-dashboard-action {
        min-height: 2.35rem;
        padding: 0 .82rem;
        font-size: .84rem;
    }
    .fp-card-number {
        font-size: 3rem;
    }
}

/* =========================================================
   Firmenpilot Dashboard Restore Original Style V6
   Korrigiert nur Topbar + Dashboard-Header nach Originalstruktur.
   ========================================================= */
.fp-topbar {
    padding: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
}
.fp-topbar-inner {
    min-height: 54px !important;
    gap: 1rem !important;
}
.fp-topbar-search {
    height: 52px !important;
    min-height: 52px !important;
    gap: 0.9rem !important;
    padding-left: 1.35rem !important;
    padding-right: 1.35rem !important;
    border: 0 !important;
    background: #ffffff !important;
    box-shadow: 0 14px 34px rgba(15, 23, 42, 0.045) !important;
}
.fp-topbar-search-input {
    font-size: 0.98rem !important;
    font-weight: 400 !important;
    letter-spacing: -0.01em !important;
    color: #64748b !important;
}
.fp-topbar-search-input::placeholder {
    color: #8a94a6 !important;
    font-weight: 400 !important;
}
.fp-topbar-actions {
    gap: 0.65rem !important;
}
.fp-topbar-icon-button {
    width: 50px !important;
    height: 50px !important;
    min-width: 50px !important;
    min-height: 50px !important;
    background: #ffffff !important;
    box-shadow: 0 13px 30px rgba(15, 23, 42, 0.055) !important;
}
.fp-topbar-icon-button .fp-lv3-navbar-icon,
.fp-topbar-search .fp-lv3-navbar-icon {
    width: 1.05rem !important;
    height: 1.05rem !important;
}
.fp-topbar-icon-button .absolute {
    top: -0.25rem !important;
    right: -0.1rem !important;
    height: 1.25rem !important;
    min-width: 1.25rem !important;
    font-size: 0.66rem !important;
    line-height: 1 !important;
}
.fp-topbar-account-button {
    height: 50px !important;
    min-height: 50px !important;
    min-width: 236px !important;
    gap: 0.75rem !important;
    padding-left: 0.72rem !important;
    padding-right: 0.9rem !important;
    background: #ffffff !important;
    box-shadow: 0 13px 30px rgba(15, 23, 42, 0.055) !important;
}
.fp-topbar-avatar {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    font-size: 0.82rem !important;
    font-weight: 700 !important;
}
.fp-topbar-name {
    font-size: 0.94rem !important;
    font-weight: 600 !important;
    letter-spacing: -0.012em !important;
}
.fp-topbar-caret {
    font-size: 0.72rem !important;
    color: #0f5132 !important;
    opacity: 0.9 !important;
}

.fp-dashboard-page .fp-lv3-page-title,
.fp-dashboard-title {
    margin: 0 !important;
    color: #151515 !important;
    font-size: 3.4rem !important;
    line-height: 1 !important;
    font-weight: 700 !important;
    letter-spacing: -0.06em !important;
}
.fp-dashboard-header {
    align-items: flex-start !important;
}
.fp-dashboard-edit-gear,
.fp-dashboard-settings-button {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
    display: inline-grid !important;
    place-items: center !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 999px !important;
    background: #ffffff !important;
    color: #173b28 !important;
    box-shadow: 0 10px 24px rgba(15, 23, 42, .06) !important;
}
.fp-dashboard-edit-gear .fp-dashboard-gear-svg,
.fp-dashboard-settings-button .fp-lv3-navbar-icon {
    width: 1.05rem !important;
    height: 1.05rem !important;
}
.fp-dashboard-gear-svg svg {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    fill: none !important;
    stroke: currentColor !important;
    stroke-width: 1.85 !important;
    stroke-linecap: round !important;
    stroke-linejoin: round !important;
}
.fp-dashboard-header-btn,
.fp-dashboard-action {
    height: 40px !important;
    min-height: 40px !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
    border-radius: 999px !important;
    font-size: .875rem !important;
    font-weight: 600 !important;
    line-height: 1 !important;
    letter-spacing: -0.015em !important;
    white-space: nowrap !important;
    box-shadow: none !important;
}
.fp-dashboard-header-btn.bg-brand-600,
.fp-dashboard-action-primary {
    background: #127f44 !important;
    border-color: #127f44 !important;
    color: #ffffff !important;
    box-shadow: 0 10px 24px rgba(18, 127, 68, .13) !important;
}
.fp-dashboard-header-btn-secondary,
.fp-dashboard-action-secondary {
    border: 1px solid #2d5d46 !important;
    background: #ffffff !important;
    color: #173b28 !important;
}
.fp-card-title {
    font-size: 1.08rem !important;
    font-weight: 650 !important;
    letter-spacing: -0.035em !important;
}
.fp-card-kicker {
    font-size: 1.05rem !important;
    font-weight: 650 !important;
}
.fp-card-welcome-name {
    font-size: 1.9rem !important;
    font-weight: 700 !important;
    letter-spacing: -0.065em !important;
}
.fp-small-action {
    min-height: 2.05rem !important;
    min-width: 5rem !important;
    padding-left: .78rem !important;
    padding-right: .78rem !important;
    font-size: .78rem !important;
    font-weight: 650 !important;
}
@media (max-width: 1279px) {
    .fp-dashboard-page .fp-lv3-page-title,
    .fp-dashboard-title {
        font-size: clamp(2.4rem, 6vw, 3.4rem) !important;
    }
}
@media (max-width: 900px) {
    .fp-topbar-inner {
        align-items: flex-start !important;
    }
    .fp-topbar-search {
        height: 50px !important;
    }
    .fp-topbar-icon-button,
    .fp-topbar-account-button {
        height: 48px !important;
        min-height: 48px !important;
    }
    .fp-topbar-icon-button {
        width: 48px !important;
        min-width: 48px !important;
    }
    .fp-topbar-account-button {
        min-width: 210px !important;
    }
}
@media (max-width: 640px) {
    .fp-dashboard-header-btn,
    .fp-dashboard-action {
        width: 100% !important;
        justify-content: center !important;
    }
}

/* =========================================================
   Firmenpilot Dashboard Menu Patch V7
   Sidebar hover, animated dropdowns and persistent desktop collapse.
   ========================================================= */
.fp-sidebar {
    transition: width .28s ease, padding .28s ease, border-radius .28s ease, box-shadow .28s ease !important;
}
.fp-layout-grid {
    transition: grid-template-columns .28s ease !important;
}
.fp-sidebar-top {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: .65rem !important;
    margin-bottom: 1.15rem !important;
}
.fp-sidebar-brand {
    display: inline-flex !important;
    align-items: center !important;
    min-width: 0 !important;
    margin-bottom: 0 !important;
}
.fp-sidebar-brand-mini {
    display: none;
    width: 2.35rem;
    height: 2.35rem;
    place-items: center;
    border-radius: 16px;
    background: rgba(255, 255, 255, .86);
    box-shadow: 0 14px 30px rgba(15, 23, 42, .055);
}
.fp-sidebar-brand-mini img {
    display: block;
    width: 1.8rem;
    height: 1.8rem;
    object-fit: contain;
}
.fp-sidebar-collapse-button {
    display: grid !important;
    width: 2.25rem !important;
    height: 2.25rem !important;
    min-width: 2.25rem !important;
    place-items: center !important;
    border: 1px solid rgba(18, 127, 68, .10) !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: #127f44 !important;
    font-size: 1.35rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    box-shadow: 0 10px 24px rgba(15, 23, 42, .06) !important;
    transition: transform .18s ease, background-color .18s ease, color .18s ease, box-shadow .18s ease, border-color .18s ease !important;
}
.fp-sidebar-collapse-button:hover {
    transform: translateY(-1px) !important;
    background: #fff !important;
    color: #0f6637 !important;
    border-color: rgba(18, 127, 68, .18) !important;
    box-shadow: 0 14px 30px rgba(15, 23, 42, .10) !important;
}
.fp-sidebar-collapse-closed { display: none; }

.fp-sidebar-menu-single-framed,
.fp-sidebar-menu-group {
    border: 1px solid rgba(18, 127, 68, .08) !important;
    border-radius: 20px !important;
    background: rgba(255, 255, 255, .42) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .64) !important;
    overflow: hidden !important;
}
.fp-sidebar-menu-single-framed + .fp-sidebar-menu-group,
.fp-sidebar-menu-group + .fp-sidebar-menu-group {
    margin-top: .42rem !important;
}
.fp-sidebar-menu-summary {
    list-style: none !important;
}
.fp-sidebar-menu-summary::-webkit-details-marker { display: none !important; }
.fp-sidebar-menu-summary::marker { content: '' !important; }
.fp-sidebar-menu-summary,
.fp-sidebar-menu-link {
    min-height: 44px !important;
    border-radius: 18px !important;
    color: #4f4f4f !important;
    font-size: .94rem !important;
    font-weight: 650 !important;
    letter-spacing: -.015em !important;
    transition: background-color .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease !important;
}
.fp-sidebar-menu-single-framed .fp-sidebar-menu-link,
.fp-sidebar-menu-summary {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: .45rem !important;
    width: 100% !important;
    padding: .54rem .58rem !important;
    cursor: pointer !important;
}
.fp-sidebar-menu-link {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: .45rem !important;
    width: 100% !important;
    padding-left: .68rem !important;
    padding-right: .68rem !important;
}
.fp-sidebar-menu-link-nested {
    min-height: 38px !important;
    border-radius: 14px !important;
    padding-left: .42rem !important;
    padding-right: .58rem !important;
    font-size: .90rem !important;
    font-weight: 600 !important;
}
.fp-sidebar-menu-summary-main,
.fp-sidebar-menu-link-main {
    display: flex !important;
    align-items: center !important;
    min-width: 0 !important;
    gap: .42rem !important;
}
.fp-sidebar-menu-label {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}
.fp-sidebar-menu-icon,
.fp-sidebar-menu-summary-icon {
    display: grid !important;
    width: 1.45rem !important;
    height: 1.45rem !important;
    min-width: 1.45rem !important;
    flex-basis: 1.45rem !important;
    place-items: center !important;
    border-radius: 10px !important;
    color: #cbd5e1 !important;
    background: transparent !important;
    transition: color .18s ease, background-color .18s ease, transform .18s ease !important;
}
.fp-sidebar-icon-mask {
    display: block !important;
    width: 1.16rem !important;
    height: 1.16rem !important;
    background: currentColor !important;
    -webkit-mask: var(--fp-sidebar-icon-url) center / contain no-repeat !important;
    mask: var(--fp-sidebar-icon-url) center / contain no-repeat !important;
    transition: transform .18s ease, background-color .18s ease !important;
}
.fp-sidebar-menu-chevron {
    display: grid !important;
    width: 1.42rem !important;
    height: 1.42rem !important;
    min-width: 1.42rem !important;
    place-items: center !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, .64) !important;
    color: #cbd5e1 !important;
    font-size: 0 !important;
    transition: color .18s ease, background-color .18s ease, transform .22s cubic-bezier(.2,.8,.2,1) !important;
}
.fp-sidebar-menu-chevron-mark {
    display: block !important;
    width: .62rem !important;
    height: .62rem !important;
    border-right: 2.35px solid currentColor !important;
    border-bottom: 2.35px solid currentColor !important;
    border-radius: 1px !important;
    transform: rotate(-45deg) !important;
    transform-origin: 50% 50% !important;
    transition: transform .22s cubic-bezier(.2,.8,.2,1), color .18s ease, opacity .18s ease !important;
}
.fp-sidebar-menu-link:hover,
.fp-sidebar-menu-summary:hover {
    background: rgba(255, 255, 255, .72) !important;
    color: #151515 !important;
}
.fp-sidebar-menu-link:hover .fp-sidebar-menu-icon,
.fp-sidebar-menu-summary:hover .fp-sidebar-menu-summary-icon,
.fp-sidebar-menu-link:hover .fp-sidebar-menu-chevron,
.fp-sidebar-menu-summary:hover .fp-sidebar-menu-chevron,
.fp-sidebar-menu-link.is-active .fp-sidebar-menu-icon,
.fp-sidebar-menu-link.is-active .fp-sidebar-menu-chevron,
.fp-sidebar-menu-group[open] > .fp-sidebar-menu-summary .fp-sidebar-menu-summary-icon,
.fp-sidebar-menu-group[open] > .fp-sidebar-menu-summary .fp-sidebar-menu-chevron {
    color: #1f7a4d !important;
}
.fp-sidebar-menu-link:hover .fp-sidebar-icon-mask,
.fp-sidebar-menu-summary:hover .fp-sidebar-icon-mask {
    transform: translateY(-1px) scale(1.08) !important;
}
.fp-sidebar-menu-link.is-active {
    background: #fff !important;
    color: #151515 !important;
    box-shadow: 0 10px 30px rgba(0,0,0,.045) !important;
}
.fp-sidebar-menu-group[open] > .fp-sidebar-menu-summary .fp-sidebar-menu-chevron {
    background: rgba(31, 122, 77, .10) !important;
}
.fp-sidebar-menu-group[open] > .fp-sidebar-menu-summary .fp-sidebar-menu-chevron-mark {
    transform: rotate(45deg) !important;
}
.fp-sidebar-active-bar {
    position: absolute !important;
    left: -.15rem !important;
    top: 50% !important;
    width: 5px !important;
    height: 28px !important;
    transform: translateY(-50%) !important;
    border-radius: 999px !important;
    background: #179d54 !important;
}
.fp-sidebar-menu-subnav {
    display: grid !important;
    gap: .24rem !important;
    padding: 0 .25rem .48rem !important;
    animation: fpSidebarSubnavOpen .18s ease both !important;
}
.fp-sidebar-menu-link.is-disabled {
    opacity: .62 !important;
    color: #9b9b9b !important;
    cursor: default !important;
}
.fp-sidebar-menu-link.is-disabled:hover {
    background: transparent !important;
    color: #9b9b9b !important;
    box-shadow: none !important;
}
.fp-sidebar-menu-link.is-disabled .fp-sidebar-menu-icon {
    color: #d1d5db !important;
}
@keyframes fpSidebarSubnavOpen {
    0% { opacity: 0; transform: translateY(-4px); }
    100% { opacity: 1; transform: translateY(0); }
}

@media (min-width: 1280px) {
    .fp-sidebar-is-collapsed .fp-layout-grid {
        grid-template-columns: 88px minmax(0, 1fr) !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar {
        width: 88px !important;
        overflow: visible !important;
        padding-left: .5rem !important;
        padding-right: .5rem !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar-scroll {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        margin-right: 0 !important;
        padding-right: 0 !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar-top,
    .fp-sidebar-is-collapsed .fp-sidebar-menu-single-framed,
    .fp-sidebar-is-collapsed .fp-sidebar-menu-group {
        width: 3.55rem !important;
        min-width: 3.55rem !important;
        max-width: 3.55rem !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar-top {
        flex-direction: column !important;
        justify-content: flex-start !important;
        align-items: center !important;
        gap: .55rem !important;
        margin-bottom: .72rem !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar-logo {
        display: none !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar-brand-mini {
        display: grid !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar-brand,
    .fp-sidebar-is-collapsed .fp-sidebar-collapse-button,
    .fp-sidebar-is-collapsed .fp-sidebar-menu-summary,
    .fp-sidebar-is-collapsed .fp-sidebar-menu-link {
        width: 3.55rem !important;
        min-width: 3.55rem !important;
        max-width: 3.55rem !important;
        height: 3.1rem !important;
        min-height: 3.1rem !important;
        justify-content: center !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        border-radius: 18px !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar-brand,
    .fp-sidebar-is-collapsed .fp-sidebar-collapse-button {
        border: 1px solid rgba(15, 23, 42, .055) !important;
        background: rgba(255,255,255,.86) !important;
        box-shadow: 0 14px 30px rgba(15, 23, 42, .055) !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar-collapse-open { display: none !important; }
    .fp-sidebar-is-collapsed .fp-sidebar-collapse-closed { display: inline !important; }
    .fp-sidebar-is-collapsed .fp-sidebar-menu-summary-main,
    .fp-sidebar-is-collapsed .fp-sidebar-menu-link-main {
        justify-content: center !important;
        gap: 0 !important;
        flex: 0 0 auto !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar-menu-label,
    .fp-sidebar-is-collapsed .fp-sidebar-menu-chevron,
    .fp-sidebar-is-collapsed .fp-sidebar-active-bar {
        display: none !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar-menu-subnav {
        display: none !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar-menu-icon,
    .fp-sidebar-is-collapsed .fp-sidebar-menu-summary-icon {
        width: 2.25rem !important;
        height: 2.25rem !important;
        min-width: 2.25rem !important;
        flex-basis: 2.25rem !important;
        border-radius: 14px !important;
    }
    .fp-sidebar-is-collapsed .fp-sidebar-smart-slider {
        display: none !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    .fp-sidebar,
    .fp-layout-grid,
    .fp-sidebar-menu-chevron,
    .fp-sidebar-menu-chevron-mark,
    .fp-sidebar-icon-mask,
    .fp-sidebar-menu-link,
    .fp-sidebar-menu-summary {
        transition: none !important;
        animation: none !important;
    }
}

/* =========================================================
   Firmenpilot Laravel - gemeinsame Seiten-Styles V8
   Abgeleitet vom vorhandenen Firmenbereich: Hero, Actions,
   Statuskarten, Filterleisten und leere Zustände.
   ========================================================= */
.fp-page-hero {
    position: relative;
    overflow: hidden;
    border-radius: 28px;
    border: 1px solid rgba(255, 255, 255, .12);
    background:
        radial-gradient(circle at 88% 20%, rgba(87, 208, 146, .22), transparent 25%),
        radial-gradient(circle at 55% 100%, rgba(26, 148, 91, .18), transparent 32%),
        linear-gradient(135deg, #06231d 0%, #063a2b 48%, #0b7a4d 100%);
    color: #ffffff;
    padding: 1.45rem;
    box-shadow: 0 22px 54px rgba(15, 23, 42, .08);
}

.fp-page-hero-glow {
    position: absolute;
    pointer-events: none;
    border-radius: 999px;
    filter: blur(48px);
}

.fp-page-hero-glow-a {
    right: -5rem;
    top: -5rem;
    width: 18rem;
    height: 18rem;
    background: rgba(255, 255, 255, .10);
}

.fp-page-hero-glow-b {
    left: 34%;
    bottom: -7rem;
    width: 18rem;
    height: 18rem;
    background: rgba(110, 226, 160, .10);
}

.fp-page-hero-main,
.fp-page-stat-grid {
    position: relative;
    z-index: 1;
}

.fp-page-hero-main {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1.25rem;
}

.fp-page-hero-copy {
    max-width: 56rem;
}

.fp-page-hero-copy h1 {
    margin: 0;
    color: #ffffff;
    font-size: clamp(1.85rem, 2.3vw, 2.35rem);
    font-weight: 760;
    line-height: 1.08;
    letter-spacing: -0.045em;
}

.fp-page-hero-copy p {
    max-width: 47rem;
    margin: .85rem 0 0;
    color: rgba(255, 255, 255, .92);
    font-size: 1rem;
    font-weight: 430;
    line-height: 1.55;
}

.fp-page-hero-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .65rem;
    min-width: min(100%, 23rem);
}

.fp-page-hero-action {
    display: inline-flex;
    min-height: 2.65rem;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 255, 255, .20);
    border-radius: 999px;
    background: rgba(255, 255, 255, .10);
    padding: 0 .95rem;
    color: #ffffff;
    font-size: .88rem;
    font-weight: 650;
    line-height: 1;
    text-decoration: none;
    transition: transform .16s ease, background .16s ease, border-color .16s ease;
}

.fp-page-hero-action:hover {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, .16);
    border-color: rgba(255, 255, 255, .28);
}

.fp-page-hero-action.is-primary {
    background: #ffffff;
    border-color: #ffffff;
    color: #064e3b;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .10);
}

.fp-page-hero-action.is-primary:hover {
    background: #f8fafc;
}

.fp-page-stat-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: .8rem;
    margin-top: 1.55rem;
}

.fp-page-stat-card {
    min-height: 5.9rem;
    border: 1px solid rgba(255, 255, 255, .15);
    border-radius: 18px;
    background: rgba(255, 255, 255, .10);
    padding: 1rem 1.15rem;
    text-align: left;
    color: #ffffff;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08);
    backdrop-filter: blur(8px);
    transition: background .16s ease, color .16s ease, border-color .16s ease, transform .16s ease, box-shadow .16s ease;
}

.fp-page-stat-card:hover {
    transform: translateY(-1px);
    border-color: rgba(255, 255, 255, .26);
    background: rgba(255, 255, 255, .14);
}

.fp-page-stat-card span {
    display: block;
    color: rgba(255, 255, 255, .72);
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: .045em;
    line-height: 1.15;
    text-transform: uppercase;
}

.fp-page-stat-card strong {
    display: block;
    margin-top: .55rem;
    color: currentColor;
    font-size: 2.05rem;
    font-weight: 760;
    line-height: 1;
    letter-spacing: -0.055em;
}

.fp-page-stat-card.is-active {
    background: #ffffff;
    border-color: rgba(255, 255, 255, .82);
    color: #053c2d;
    box-shadow: inset 0 0 0 2px rgba(6, 78, 59, .10), 0 16px 34px rgba(15, 23, 42, .10);
}

.fp-page-stat-card.is-active span {
    color: rgba(6, 95, 70, .70);
}

.fp-page-panel,
.fp-page-filterbar {
    border: 1px solid rgba(226, 232, 240, .9);
    border-radius: 26px;
    background: #ffffff;
    box-shadow: 0 16px 38px rgba(15, 23, 42, .055);
}

.fp-page-panel {
    padding: 1.35rem;
}

.fp-page-panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.fp-page-panel-head h2 {
    margin: 0;
    color: #0f172a;
    font-size: 1.05rem;
    font-weight: 720;
    letter-spacing: -.025em;
}

.fp-page-panel-head p {
    margin: .25rem 0 0;
    color: #64748b;
    font-size: .86rem;
    line-height: 1.45;
}

.fp-page-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.fp-page-searchbox {
    display: flex;
    min-height: 3.15rem;
    width: min(100%, 34rem);
    align-items: center;
    gap: .7rem;
    border: 1px solid #dbe4f0;
    border-radius: 18px;
    background: #f8fafc;
    padding: 0 1rem;
    color: #94a3b8;
}

.fp-page-searchbox input {
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    color: #0f172a;
    font-size: .92rem;
    font-weight: 430;
}

.fp-page-searchbox input::placeholder {
    color: #94a3b8;
}

.fp-page-perpage {
    display: flex;
    align-items: center;
    gap: .65rem;
    color: #64748b;
    font-size: .88rem;
    font-weight: 500;
}

.fp-page-perpage select {
    min-height: 2.9rem;
    border: 1px solid #dbe4f0;
    border-radius: 999px;
    background: #f8fafc;
    padding: 0 .9rem;
    color: #0f172a;
    font-weight: 500;
}

.fp-page-filterbar {
    display: grid;
    grid-template-columns: minmax(0, 16rem) minmax(0, 1fr) auto;
    gap: 1rem;
    align-items: end;
    padding: 1.15rem 1.35rem;
}

.fp-page-filterbar .fp-page-filter-field:only-of-type,
.fp-page-filterbar .fp-page-filter-field.is-search:first-child {
    grid-column: span 2;
}

.fp-page-filter-field {
    display: grid;
    gap: .45rem;
    min-width: 0;
}

.fp-page-filter-field span {
    color: #0f172a;
    font-size: .88rem;
    font-weight: 650;
}

.fp-page-filter-field input,
.fp-page-filter-field select {
    width: 100%;
    min-height: 3.15rem;
    border: 1px solid #dbe4f0;
    border-radius: 18px;
    background: #f8fafc;
    padding: 0 1rem;
    color: #334155;
    font-size: .92rem;
    outline: 0;
    transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.fp-page-filter-field input:focus,
.fp-page-filter-field select:focus {
    border-color: rgba(18, 127, 68, .45);
    background: #ffffff;
    box-shadow: 0 0 0 4px rgba(18, 127, 68, .10);
}

.fp-page-filter-actions {
    display: flex;
    gap: .65rem;
    align-items: center;
    justify-content: flex-end;
}

.fp-page-filter-button {
    min-height: 3.15rem;
    border: 1px solid #e2e8f0;
    border-radius: 999px;
    background: #ffffff;
    padding: 0 1.35rem;
    color: #0f172a;
    font-size: .90rem;
    font-weight: 650;
    transition: transform .16s ease, border-color .16s ease, background .16s ease;
}

.fp-page-filter-button:hover {
    transform: translateY(-1px);
    border-color: rgba(18, 127, 68, .22);
    background: #f8fffb;
}

.fp-page-filter-button.is-primary {
    border-color: #127f44;
    background: #127f44;
    color: #ffffff;
}

.fp-page-empty {
    display: grid;
    min-height: 15rem;
    place-items: center;
    border: 1px solid #e2e8f0;
    border-radius: 24px;
    background: #f8fafc;
    padding: 2.4rem 1rem;
    text-align: center;
}

.fp-page-empty-icon {
    display: grid;
    width: 3rem;
    height: 3rem;
    place-items: center;
    border-radius: 18px;
    background: #ecfdf5;
    color: #127f44;
    font-size: 1.25rem;
    font-weight: 760;
}

.fp-page-empty h3 {
    margin: .8rem 0 0;
    color: #0f172a;
    font-size: 1.15rem;
    font-weight: 720;
    letter-spacing: -.02em;
}

.fp-page-empty p {
    margin: .45rem 0 0;
    color: #64748b;
    font-size: .92rem;
}

.fp-page-empty-button {
    display: inline-flex;
    min-height: 2.7rem;
    align-items: center;
    justify-content: center;
    margin-top: 1rem;
    border: 1px solid #a7f3d0;
    border-radius: 999px;
    background: #ffffff;
    padding: 0 1rem;
    color: #065f46;
    font-size: .88rem;
    font-weight: 650;
}

.fp-page-tabs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.fp-page-tabs button {
    position: relative;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: .85rem;
    align-items: center;
    min-height: 5rem;
    border: 1px solid #dbe4f0;
    border-radius: 22px;
    background: #f8fafc;
    padding: .85rem 1rem;
    text-align: left;
    color: #334155;
}

.fp-page-tabs button.is-active {
    background: #ffffff;
    box-shadow: inset 0 0 0 2px rgba(18, 127, 68, .08), 0 10px 24px rgba(15, 23, 42, .04);
}

.fp-page-tabs button > span {
    display: grid;
    width: 2.45rem;
    height: 2.45rem;
    place-items: center;
    border-radius: 16px;
    background: #ecfdf5;
    color: #127f44;
}

.fp-page-tabs strong {
    display: block;
    color: #064e3b;
    font-size: .98rem;
    font-weight: 700;
    letter-spacing: -.015em;
}

.fp-page-tabs small {
    display: block;
    margin-top: .18rem;
    color: #64748b;
    font-size: .82rem;
    font-weight: 430;
    line-height: 1.25;
}

.fp-page-tabs em {
    display: grid;
    width: 2rem;
    height: 2rem;
    place-items: center;
    border: 1px solid #dbe4f0;
    border-radius: 999px;
    color: #127f44;
    font-size: .80rem;
    font-style: normal;
    font-weight: 650;
}

@media (max-width: 1280px) {
    .fp-page-stat-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
    .fp-page-filterbar { grid-template-columns: 1fr; }
    .fp-page-filterbar .fp-page-filter-field:only-of-type,
    .fp-page-filterbar .fp-page-filter-field.is-search:first-child { grid-column: auto; }
    .fp-page-filter-actions { justify-content: flex-start; }
}

@media (max-width: 900px) {
    .fp-page-hero-main { display: grid; }
    .fp-page-hero-actions { justify-content: flex-start; min-width: 0; }
    .fp-page-stat-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .fp-page-tabs { grid-template-columns: 1fr; }
    .fp-page-toolbar { display: grid; }
    .fp-page-searchbox { width: 100%; }
}

@media (max-width: 640px) {
    .fp-page-hero { padding: 1.1rem; border-radius: 24px; }
    .fp-page-hero-copy h1 { font-size: 1.65rem; }
    .fp-page-hero-copy p { font-size: .92rem; }
    .fp-page-hero-action { width: 100%; }
    .fp-page-stat-grid { grid-template-columns: 1fr; }
    .fp-page-stat-card { min-height: 5.1rem; }
    .fp-page-panel,
    .fp-page-filterbar { border-radius: 22px; padding: 1rem; }
    .fp-page-filter-actions { display: grid; grid-template-columns: 1fr 1fr; }
}

/* =========================================================
   Firmenpilot Laravel - Kundenformular Styles
   Nutzt die bestehende Seitenbasis und die Firmenpilot-Grünwerte.
   ========================================================= */
.fp-customer-create .fp-page-hero {
    margin-bottom: 0;
}

.fp-customer-form {
    margin-top: 0;
}

.fp-customer-type-tabs button {
    grid-template-columns: auto minmax(0, 1fr);
    min-height: 4.9rem;
    align-items: center;
}

.fp-customer-type-tabs button > span {
    width: 2.8rem;
    height: 2.8rem;
}

.fp-customer-type-tabs button > span svg {
    width: 1.25rem;
    height: 1.25rem;
}

.fp-customer-type-tabs strong {
    color: #0f172a;
    font-size: .98rem;
    font-weight: 700;
}

.fp-customer-type-tabs small {
    font-size: .84rem;
    line-height: 1.35;
}

.fp-form-grid {
    display: grid;
    grid-template-columns: repeat(12, minmax(0, 1fr));
    gap: .85rem;
}

.fp-col-12 { grid-column: span 12; }
.fp-col-10 { grid-column: span 10; }
.fp-col-8 { grid-column: span 8; }
.fp-col-6 { grid-column: span 6; }
.fp-col-4 { grid-column: span 4; }
.fp-col-3 { grid-column: span 3; }
.fp-col-2 { grid-column: span 2; }

.fp-form-field {
    display: grid;
    gap: .42rem;
    min-width: 0;
}

.fp-form-field > span,
.fp-nested-title {
    color: #0f172a;
    font-size: .84rem;
    font-weight: 650;
    line-height: 1.25;
}

.fp-form-field input,
.fp-form-field select,
.fp-form-field textarea,
.fp-autocomplete-box > input {
    width: 100%;
    min-height: 3.05rem;
    border: 1px solid #dbe4f0;
    border-radius: 17px;
    background: #f8fafc;
    padding: 0 .95rem;
    color: #0f172a;
    font-size: .92rem;
    font-weight: 430;
    outline: 0;
    transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}

.fp-form-field textarea {
    min-height: 7.2rem;
    padding-top: .85rem;
    resize: vertical;
}

.fp-form-field input:focus,
.fp-form-field select:focus,
.fp-form-field textarea:focus,
.fp-autocomplete-box > input:focus {
    border-color: rgba(18, 127, 68, .45);
    background: #ffffff;
    box-shadow: 0 0 0 4px rgba(18, 127, 68, .10);
}

.fp-form-field input::placeholder,
.fp-autocomplete-box > input::placeholder {
    color: #94a3b8;
}

.fp-hidden {
    display: none !important;
}

.fp-nested-panel {
    border: 1px solid #e2e8f0;
    border-radius: 22px;
    background: #fbfcfd;
    padding: .95rem;
}

.fp-nested-title {
    margin-bottom: .75rem;
}

.fp-small-icon-button {
    display: inline-flex;
    width: 2.15rem;
    height: 2.15rem;
    align-items: center;
    justify-content: center;
    border: 1px solid #127f44;
    border-radius: 999px;
    background: #127f44;
    color: #ffffff;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1;
}

.fp-options-stack {
    display: grid;
    gap: .85rem;
}

.fp-option-box {
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    background: #fbfcfd;
    padding: .75rem;
}

.fp-option-head {
    display: flex;
    min-height: 2.65rem;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border: 1px solid #e5eaf0;
    border-radius: 17px;
    background: #ffffff;
    padding: 0 .9rem;
    color: #0f172a;
    font-size: .92rem;
    font-weight: 520;
}

.fp-checkbox-ui {
    position: relative;
    display: inline-flex;
    width: 1.15rem;
    height: 1.15rem;
    flex: 0 0 auto;
}

.fp-checkbox-ui input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
}

.fp-checkbox-ui i {
    display: inline-flex;
    width: 1.15rem;
    height: 1.15rem;
    align-items: center;
    justify-content: center;
    border: 1px solid #cbd5e1;
    border-radius: .22rem;
    background: #ffffff;
    color: #ffffff;
    font-size: .75rem;
    font-style: normal;
    font-weight: 800;
}

.fp-checkbox-ui input:checked + i {
    border-color: #127f44;
    background: #127f44;
}

.fp-checkbox-ui input:checked + i::before {
    content: '✓';
}

.fp-option-content {
    margin-top: .8rem;
}

.fp-option-content[hidden] {
    display: none !important;
}

.fp-inline-check {
    display: inline-flex;
    min-height: 3.05rem;
    align-items: center;
    gap: .55rem;
    align-self: end;
    border: 1px solid #e2e8f0;
    border-radius: 17px;
    background: #ffffff;
    padding: 0 .85rem;
    color: #0f172a;
    font-size: .88rem;
    font-weight: 520;
}

.fp-inline-check input[type="checkbox"] {
    width: 1rem;
    height: 1rem;
    accent-color: #127f44;
}

.fp-field-action {
    display: flex;
    align-items: end;
}

.fp-field-action .fp-page-filter-button,
.fp-button-small {
    min-height: 2.7rem;
    padding: 0 .95rem;
    font-size: .84rem;
}

.fp-autocomplete-box {
    position: relative;
    border: 1px solid #e2e8f0;
    border-radius: 20px;
    background: #fbfcfd;
    padding: .75rem;
}

.fp-autocomplete-results {
    position: absolute;
    z-index: 40;
    left: .75rem;
    right: .75rem;
    top: calc(3.05rem + 1.1rem);
    overflow: hidden;
    border: 1px solid #dbe4f0;
    border-radius: 17px;
    background: #ffffff;
    box-shadow: 0 18px 30px rgba(15, 23, 42, .10);
}

.fp-autocomplete-results[hidden] {
    display: none !important;
}

.fp-autocomplete-result {
    display: block;
    width: 100%;
    border: 0;
    border-bottom: 1px solid #eef2f5;
    background: transparent;
    padding: .75rem .95rem;
    text-align: left;
}

.fp-autocomplete-result:last-child {
    border-bottom: 0;
}

.fp-autocomplete-result:hover {
    background: #f8fffb;
}

.fp-autocomplete-result strong {
    display: block;
    color: #0f172a;
    font-size: .9rem;
    font-weight: 650;
}

.fp-autocomplete-result span {
    display: block;
    margin-top: .2rem;
    color: #64748b;
    font-size: .8rem;
    font-weight: 430;
}

.fp-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    margin-top: .65rem;
}

.fp-chip {
    display: inline-flex;
    align-items: center;
    gap: .45rem;
    border: 1px solid #a7f3d0;
    border-radius: 999px;
    background: #ecfdf5;
    padding: .35rem .65rem;
    color: #065f46;
    font-size: .84rem;
    font-weight: 520;
    line-height: 1.2;
}

.fp-chip button {
    border: 0;
    background: transparent;
    color: #065f46;
    font-size: .95rem;
    line-height: 1;
    padding: 0;
}

.fp-empty-line {
    border: 1px solid #e2e8f0;
    border-radius: 17px;
    background: #f8fafc;
    padding: .8rem .95rem;
    color: #64748b;
    font-size: .86rem;
}

.fp-field-create-line {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: .85rem;
    border: 1px solid #a7f3d0;
    border-radius: 18px;
    background: #ecfdf5;
    padding: .85rem .95rem;
}

.fp-field-create-line strong {
    display: block;
    color: #064e3b;
    font-size: .88rem;
    font-weight: 700;
}

.fp-field-create-line span {
    display: block;
    margin-top: .22rem;
    color: #047857;
    font-size: .8rem;
    font-weight: 430;
}

.fp-form-actions {
    display: flex;
    justify-content: flex-end;
    gap: .65rem;
    margin-top: 1rem;
}

.fp-form-actions .fp-page-filter-button {
    min-height: 2.65rem;
    padding: 0 1.05rem;
    font-size: .86rem;
}

.fp-form-alert {
    border: 1px solid #fecaca;
    border-radius: 22px;
    background: #fef2f2;
    padding: .95rem 1.1rem;
    color: #991b1b;
    font-size: .88rem;
}

.fp-form-alert div {
    font-weight: 700;
}

.fp-form-alert ul {
    margin: .35rem 0 0;
    padding-left: 1.1rem;
}

@media (max-width: 920px) {
    .fp-col-10,
    .fp-col-8,
    .fp-col-6,
    .fp-col-4,
    .fp-col-3,
    .fp-col-2 {
        grid-column: span 12;
    }

    .fp-field-create-line,
    .fp-form-actions {
        display: grid;
        grid-template-columns: 1fr;
    }
}

.fp-customer-type-tabs button > span {
    grid-row: 1 / span 2;
}

.fp-customer-type-tabs button strong,
.fp-customer-type-tabs button small {
    grid-column: 2;
}
