/* ============================================================
   InvoicePro — SaaS Invoice UI
   Plain CSS + Bootstrap 5 (no Tailwind, no frameworks)
   Brand: #1377bc (blue) + #f69322 (orange)
   ============================================================ */

:root{
  --ip-primary:#1377bc;
  --ip-primary-600:#0f5f97;
  --ip-primary-700:#0c4d7a;
  --ip-primary-50:#e7f2fa;
  --ip-primary-100:#cfe4f4;
  --ip-accent:#f69322;
  --ip-accent-600:#dc7d10;
  --ip-accent-50:#fdf1de;
  --ip-success:#16a34a;
  --ip-warning:#f59e0b;
  --ip-danger:#dc2626;
  --ip-info:#0ea5e9;
  --ip-dark:#0f172a;
  --ip-body:#475569;
  --ip-muted:#94a3b8;
  --ip-bg:#f5f7fb;
  --ip-surface:#ffffff;
  --ip-border:#e5e7eb;
  --ip-radius:14px;
  --ip-radius-sm:10px;
  --ip-shadow:0 1px 2px rgba(15,23,42,.04), 0 8px 24px rgba(15,23,42,.06);
  --ip-shadow-lg:0 10px 40px rgba(19,119,188,.18);
  --ip-sidebar-w:260px;
  --ip-header-h:64px;
  --ip-gradient:linear-gradient(135deg,#1377bc 0%,#0f5f97 55%,#f69322 130%);
  --ip-gradient-soft:linear-gradient(135deg,#1377bc 0%,#2a92db 100%);
  --ip-gradient-orange:linear-gradient(135deg,#f69322 0%,#e26f0a 100%);
  --ip-font:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  font-family:var(--ip-font);
  color:var(--ip-body);
  background:var(--ip-bg);
  font-size:14.5px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{color:var(--ip-dark);font-weight:700;letter-spacing:-.01em}
a{color:var(--ip-primary);text-decoration:none}
a:hover{color:var(--ip-primary-600)}

/* ============ BUTTONS ============ */
.btn{border-radius:10px;font-weight:600;padding:.55rem 1.1rem;transition:all .2s ease;border:1px solid transparent}
.btn-primary{background:var(--ip-primary);border-color:var(--ip-primary);color:#fff}
.btn-primary:hover,.btn-primary:focus{background:var(--ip-primary-600);border-color:var(--ip-primary-600);color:#fff;transform:translateY(-1px);box-shadow:0 6px 18px rgba(19,119,188,.35)}
.btn-accent{background:var(--ip-accent);border-color:var(--ip-accent);color:#fff}
.btn-accent:hover,.btn-accent:focus{background:var(--ip-accent-600);border-color:var(--ip-accent-600);color:#fff;transform:translateY(-1px);box-shadow:0 6px 18px rgba(246,147,34,.35)}
.btn-gradient{background:var(--ip-gradient);color:#fff;border:0}
.btn-gradient:hover,.btn-gradient:focus{color:#fff;transform:translateY(-1px);box-shadow:var(--ip-shadow-lg)}
.btn-outline-primary{color:var(--ip-primary);border-color:var(--ip-primary);background:#fff}
.btn-outline-primary:hover,.btn-outline-primary:focus{background:var(--ip-primary);border-color:var(--ip-primary);color:#fff}
.btn-outline-accent{color:var(--ip-accent);border-color:var(--ip-accent);background:#fff}
.btn-outline-accent:hover{background:var(--ip-accent);color:#fff}
.btn-light-soft{background:#f1f5f9;color:var(--ip-dark);border:1px solid #e2e8f0}
.btn-light-soft:hover{background:#e2e8f0;color:var(--ip-dark)}
.btn-danger-soft{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.btn-danger-soft:hover{background:#fecaca;color:#991b1b}
.btn-sm{padding:.35rem .75rem;font-size:.825rem}
.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;padding:0;border-radius:10px}

/* ============ CARDS ============ */
.card{
  border:1px solid var(--ip-border);
  border-radius:var(--ip-radius);
  box-shadow:var(--ip-shadow);
  background:var(--ip-surface);
}
.card-header{
  background:transparent;
  border-bottom:1px solid var(--ip-border);
  padding:1rem 1.25rem;
  font-weight:600;
  color:var(--ip-dark);
}
.card-body{padding:1.25rem}

.stat-card{padding:1.25rem;border-radius:var(--ip-radius);background:#fff;border:1px solid var(--ip-border);box-shadow:var(--ip-shadow);position:relative;overflow:hidden}
.stat-card .stat-icon{width:46px;height:46px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;font-size:20px;color:#fff}
.stat-card .stat-value{font-size:1.65rem;font-weight:700;color:var(--ip-dark);margin:.4rem 0 .15rem}
.stat-card .stat-label{font-size:.85rem;color:var(--ip-muted);margin:0}
.stat-card .stat-trend{font-size:.78rem;font-weight:600}
.stat-trend.up{color:var(--ip-success)}
.stat-trend.down{color:var(--ip-danger)}

.bg-grad-1{background:linear-gradient(135deg,#1377bc,#0f5f97)}
.bg-grad-2{background:linear-gradient(135deg,#f69322,#dc7d10)}
.bg-grad-3{background:linear-gradient(135deg,#16a34a,#22c55e)}
.bg-grad-4{background:linear-gradient(135deg,#0ea5e9,#1377bc)}
.bg-grad-5{background:linear-gradient(135deg,#f59e0b,#dc2626)}

/* ============ FORMS ============ */
.form-control,.form-select{
  border-radius:10px;
  border:1px solid var(--ip-border);
  padding:.6rem .85rem;
  font-size:.92rem;
  background:#fff;
  color:var(--ip-dark);
  transition:border-color .15s, box-shadow .15s;
}
.form-control:focus,.form-select:focus{
  border-color:var(--ip-primary);
  box-shadow:0 0 0 4px rgba(19,119,188,.12);
}
.form-label{font-weight:600;color:var(--ip-dark);font-size:.85rem;margin-bottom:.4rem}
.form-text{color:var(--ip-muted);font-size:.8rem}
.input-group-text{background:#f8fafc;border-color:var(--ip-border);color:var(--ip-muted);border-radius:10px}
.form-check-input:checked{background-color:var(--ip-primary);border-color:var(--ip-primary)}

/* ============ TABLES ============ */
.table{margin-bottom:0;color:var(--ip-body)}
.table thead th{
  background:#f8fafc;
  color:var(--ip-muted);
  font-size:.75rem;
  text-transform:uppercase;
  letter-spacing:.05em;
  font-weight:600;
  border-bottom:1px solid var(--ip-border);
  padding:.85rem 1rem;
  white-space:nowrap;
}
.table tbody td{padding:.95rem 1rem;vertical-align:middle;border-color:#f1f5f9;color:var(--ip-dark)}
.table tbody tr:hover{background:#fafbff}
.table-responsive{border-radius:var(--ip-radius)}

/* ============ BADGES ============ */
.badge{font-weight:600;padding:.4em .7em;border-radius:999px;font-size:.72rem;letter-spacing:.02em}
.badge-soft-success{background:#d1fae5;color:#065f46}
.badge-soft-warning{background:#fef3c7;color:#92400e}
.badge-soft-danger{background:#fee2e2;color:#991b1b}
.badge-soft-info{background:#dbeafe;color:#1e40af}
.badge-soft-primary{background:var(--ip-primary-50);color:var(--ip-primary-700)}
.badge-soft-accent{background:var(--ip-accent-50);color:#9a5b0a}
.badge-soft-muted{background:#f1f5f9;color:#475569}
.badge-solid-primary{background:var(--ip-primary);color:#fff}
.badge-solid-accent{background:var(--ip-accent);color:#fff}

/* ============ ALERTS ============ */
.alert{border:0;border-radius:12px;padding:.95rem 1.1rem;font-size:.9rem}
.alert-success{background:#ecfdf5;color:#065f46}
.alert-warning{background:#fffbeb;color:#92400e}
.alert-danger{background:#fef2f2;color:#991b1b}
.alert-info{background:#eff6ff;color:#0c4d7a}
.alert-primary{background:var(--ip-primary-50);color:var(--ip-primary-700)}

/* ============ MODAL ============ */
.modal-content{border:0;border-radius:var(--ip-radius);box-shadow:0 25px 60px rgba(15,23,42,.25)}
.modal-header{border-bottom:1px solid var(--ip-border);padding:1rem 1.25rem}
.modal-footer{border-top:1px solid var(--ip-border);padding:.85rem 1.25rem}

/* ============ APP LAYOUT (Sidebar/Header) ============ */
.app{display:flex;min-height:100vh}
.sidebar{
  width:var(--ip-sidebar-w);
  background:#ffffff;
  border-right:1px solid var(--ip-border);
  position:fixed;top:0;left:0;bottom:0;
  z-index:1030;
  display:flex;flex-direction:column;
  transition:transform .25s ease;
  overflow-y:auto;
}
.sidebar .brand{
  display:flex;align-items:center;gap:.6rem;
  padding:1rem 1.25rem;
  border-bottom:1px solid var(--ip-border);
  font-weight:700;color:var(--ip-dark);font-size:1.05rem;
  text-decoration:none;
}
.brand-mark{
  width:34px;height:34px;border-radius:9px;
  background:var(--ip-gradient);
  display:inline-flex;align-items:center;justify-content:center;color:#fff;
  font-weight:700;
}
.sidebar .nav-section{padding:.6rem 1.4rem .3rem;font-size:.68rem;color:var(--ip-muted);text-transform:uppercase;letter-spacing:.09em;margin-top:.5rem;font-weight:700}
.sidebar .nav-link{
  display:flex;align-items:center;gap:.75rem;
  padding:.6rem .9rem;margin:.15rem .6rem;
  border-radius:10px;color:#475569;font-weight:500;font-size:.9rem;
}
.sidebar .nav-link i{width:18px;text-align:center;font-size:1rem;color:#94a3b8}
.sidebar .nav-link:hover{background:#f5f7fb;color:var(--ip-dark)}
.sidebar .nav-link.active{background:var(--ip-primary-50);color:var(--ip-primary-700)}
.sidebar .nav-link.active i{color:var(--ip-primary)}
.sidebar-footer{margin-top:auto;padding:1rem;border-top:1px solid var(--ip-border)}
.upgrade-card{background:var(--ip-gradient);color:#fff;padding:1rem;border-radius:12px;font-size:.85rem}
.upgrade-card .btn{background:#fff;color:var(--ip-primary-700);font-weight:600}

.main{flex:1;margin-left:var(--ip-sidebar-w);display:flex;flex-direction:column;min-width:0}
.topbar{
  height:var(--ip-header-h);
  background:#fff;border-bottom:1px solid var(--ip-border);
  display:flex;align-items:center;gap:1rem;
  padding:0 1.5rem;position:sticky;top:0;z-index:1020;
}
.topbar .search{flex:1;max-width:420px;position:relative}
.topbar .search input{padding-left:2.4rem;background:#f5f7fb;border:1px solid transparent}
.topbar .search i{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);color:var(--ip-muted)}
.topbar .icon-btn{width:40px;height:40px;border-radius:10px;border:1px solid var(--ip-border);background:#fff;display:inline-flex;align-items:center;justify-content:center;color:var(--ip-body);position:relative}
.topbar .icon-btn .dot{position:absolute;top:8px;right:9px;width:8px;height:8px;border-radius:50%;background:var(--ip-accent);border:2px solid #fff}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--ip-gradient);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}
.avatar-sm{width:30px;height:30px;font-size:.78rem}
.avatar-lg{width:72px;height:72px;font-size:1.5rem}

.content{padding:1.75rem;flex:1}
.page-title{font-size:1.5rem;font-weight:700;color:var(--ip-dark);margin:0}
.page-subtitle{color:var(--ip-muted);font-size:.92rem;margin:.25rem 0 0}
.breadcrumb{font-size:.82rem;margin-bottom:.5rem}
.breadcrumb a{color:var(--ip-muted)}
.breadcrumb-item+.breadcrumb-item::before{color:var(--ip-muted)}
.breadcrumb .active{color:var(--ip-dark);font-weight:600}

/* Admin variant */
.sidebar.admin .brand-mark{background:var(--ip-gradient-orange)}
.sidebar.admin .nav-link.active{background:var(--ip-accent-50);color:#9a5b0a}
.sidebar.admin .nav-link.active i{color:var(--ip-accent)}

/* Mobile sidebar */
.sidebar-toggle{display:none}
@media (max-width: 991.98px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.show{transform:translateX(0)}
  .main{margin-left:0}
  .sidebar-toggle{display:inline-flex}
  .topbar .search{max-width:none}
}

/* ============ LANDING (Marketing) ============ */
.marketing{background:#fff}
.nav-marketing{padding:.85rem 0;background:rgba(255,255,255,.92);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--ip-border);position:sticky;top:0;z-index:50}
.nav-marketing .navbar-brand{font-weight:700;color:var(--ip-dark);display:flex;align-items:center;gap:.6rem}
.nav-marketing .nav-link{color:#475569;font-weight:500;padding:.5rem 1rem!important}
.nav-marketing .nav-link:hover{color:var(--ip-primary)}

.hero{
  background:
    radial-gradient(circle at 15% 10%, rgba(19,119,188,.16), transparent 45%),
    radial-gradient(circle at 88% 18%, rgba(246,147,34,.16), transparent 45%),
    #fff;
  padding:5rem 0 4rem;
  position:relative;
  overflow:hidden;
}
.hero h1{font-size:3.2rem;line-height:1.1;font-weight:800;letter-spacing:-.02em}
.hero .lead{font-size:1.15rem;color:#475569;max-width:560px}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .85rem;border-radius:999px;background:var(--ip-primary-50);color:var(--ip-primary-700);font-size:.82rem;font-weight:600;margin-bottom:1rem}
.gradient-text{background:var(--ip-gradient);-webkit-background-clip:text;background-clip:text;color:transparent}
.accent-text{color:var(--ip-accent)}

.hero-visual{
  background:#fff;border:1px solid var(--ip-border);
  border-radius:18px;box-shadow:0 20px 50px rgba(15,23,42,.12);
  padding:1rem;
}

.section{padding:5rem 0}
.section-eyebrow{color:var(--ip-accent);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem}
.section-title{font-size:2.25rem;font-weight:800;margin:.5rem 0 .75rem;color:var(--ip-dark);letter-spacing:-.02em}
.section-lead{color:#64748b;font-size:1.05rem;max-width:640px;margin:0 auto}

.feature{padding:1.6rem;border-radius:14px;background:#fff;border:1px solid var(--ip-border);height:100%;transition:transform .2s, box-shadow .2s}
.feature:hover{transform:translateY(-4px);box-shadow:var(--ip-shadow-lg)}
.feature .icon-wrap{width:48px;height:48px;border-radius:12px;background:var(--ip-primary-50);color:var(--ip-primary);display:inline-flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:1rem}
.feature.alt .icon-wrap{background:var(--ip-accent-50);color:var(--ip-accent)}
.feature h5{font-weight:700}

.logo-row{display:flex;flex-wrap:wrap;gap:2.5rem;justify-content:center;align-items:center;opacity:.7}
.logo-row span{font-weight:700;color:#64748b;font-size:1.1rem;letter-spacing:.04em}

.cta-band{background:var(--ip-gradient);border-radius:20px;padding:3rem;color:#fff;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.08);top:-100px;right:-80px}
.cta-band::before{pointer-events:none}
.cta-band > *{position:relative;z-index:1}
.cta-band .btn-light{background:#fff;color:var(--ip-primary-700);font-weight:700}

.footer{background:#0f172a;color:#cbd5e1;padding:3.5rem 0 2rem}
.footer h6{color:#fff;font-weight:700;margin-bottom:1rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em}
.footer a:not(.footer-social-btn){color:#cbd5e1;display:block;padding:.25rem 0;font-size:.9rem}
.footer a:not(.footer-social-btn):hover{color:var(--ip-accent)}
.footer .footer-bottom{border-top:1px solid #1e293b;margin-top:2.5rem;padding-top:1.5rem;font-size:.85rem;color:#94a3b8}
.footer a.footer-social-btn{
  display:inline-flex;
  flex:0 0 auto;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border-radius:50%;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  color:#fff;
  font-size:1rem;
  line-height:1;
  padding:0;
  transition:background .2s,border-color .2s,color .2s;
}
.footer a.footer-social-btn i{line-height:1}
.footer a.footer-social-btn:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.3);color:var(--ip-accent)}

/* ============ PRICING ============ */
.price-card{padding:2rem;border-radius:18px;background:#fff;border:1px solid var(--ip-border);height:100%;position:relative;transition:transform .2s, box-shadow .2s;display:flex;flex-direction:column}
.price-card.popular{border-color:var(--ip-primary);box-shadow:0 20px 50px rgba(19,119,188,.18);transform:scale(1.02)}
.price-card .price-name{font-weight:700;color:var(--ip-dark);font-size:1.1rem}
.price-card .price{font-size:2.75rem;font-weight:800;color:var(--ip-dark);letter-spacing:-.02em}
.price-card .price small{font-size:.95rem;color:var(--ip-muted);font-weight:500}
.price-card ul{list-style:none;padding:0;margin:1.25rem 0 1.5rem;flex:1}
.price-card ul li{padding:.4rem 0;color:#475569;font-size:.92rem;display:flex;gap:.6rem;align-items:flex-start}
.price-card ul li i{color:var(--ip-success);margin-top:.18rem}
.popular-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--ip-gradient-orange);color:#fff;padding:.3rem .9rem;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}

/* ============ AUTH ============ */
.auth-wrap{min-height:100vh;display:flex;background:#fff}
.auth-side{
  flex:1;background:var(--ip-gradient);color:#fff;
  padding:3rem;display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;
}
.auth-side::before,.auth-side::after{
  content:"";position:absolute;border-radius:50%;
  background:rgba(255,255,255,.08);
}
.auth-side::before{width:320px;height:320px;top:-80px;right:-80px}
.auth-side::after{width:220px;height:220px;bottom:-60px;left:-60px}
.auth-side .brand{color:#fff;position:relative;z-index:2;font-weight:700;font-size:1.1rem;display:flex;align-items:center;gap:.6rem;text-decoration:none}
.auth-side .brand .brand-mark{background:rgba(255,255,255,.18)}
.auth-side h2{color:#fff;font-size:2rem;line-height:1.25;position:relative;z-index:2}
.auth-side .quote{background:rgba(255,255,255,.12);border-radius:14px;padding:1.25rem;backdrop-filter:blur(6px);position:relative;z-index:2}
.auth-form{flex:1;display:flex;align-items:center;justify-content:center;padding:2.5rem}
.auth-form .auth-box{width:100%;max-width:440px}
.auth-form h3{font-weight:800}
.auth-form .form-control{padding:.7rem .9rem}
.divider{display:flex;align-items:center;gap:.75rem;color:var(--ip-muted);font-size:.82rem;margin:1.2rem 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--ip-border)}
.social-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.6rem;border:1px solid var(--ip-border);background:#fff;border-radius:10px;color:var(--ip-dark);font-weight:500}
.social-btn:hover{background:#f8fafc}

@media(max-width:768px){
  .auth-side{display:none}
  .hero h1{font-size:2.25rem}
  .section{padding:3rem 0}
  .cta-band{padding:2rem}
}

/* ============ INVOICE ============ */
.invoice-paper{background:#fff;border-radius:var(--ip-radius);box-shadow:var(--ip-shadow);padding:2.25rem;border:1px solid var(--ip-border)}
.invoice-paper .doc-title{font-size:2rem;font-weight:800;color:var(--ip-primary);letter-spacing:.08em}
.invoice-line-table th{background:#f8fafc;font-size:.78rem}
.totals-row{display:flex;justify-content:space-between;padding:.45rem 0;color:#475569}
.totals-row.grand{border-top:1px dashed var(--ip-border);margin-top:.5rem;padding-top:.85rem;font-size:1.15rem;font-weight:700;color:var(--ip-dark)}

/* ============ CHECKOUT ============ */
.checkout-side{background:#fff;border:1px solid var(--ip-border);border-radius:var(--ip-radius);padding:1.5rem;position:sticky;top:1.5rem}
.plan-toggle{display:inline-flex;background:#f1f5f9;border-radius:999px;padding:.25rem}
.plan-toggle .btn{border-radius:999px;padding:.4rem 1rem;font-size:.85rem;border:0;background:transparent;color:var(--ip-body)}
.plan-toggle .btn.active{background:#fff;color:var(--ip-primary);box-shadow:0 1px 3px rgba(0,0,0,.08)}

/* ============ FAQ ============ */
.accordion-item{border:1px solid var(--ip-border);border-radius:12px!important;margin-bottom:.75rem;overflow:hidden}
.accordion-button{font-weight:600;color:var(--ip-dark);padding:1rem 1.25rem}
.accordion-button:not(.collapsed){background:var(--ip-primary-50);color:var(--ip-primary-700);box-shadow:none}
.accordion-button:focus{box-shadow:none;border-color:var(--ip-primary)}

/* ============ HELPERS ============ */
.text-muted-2{color:var(--ip-muted)!important}
.text-primary-brand{color:var(--ip-primary)!important}
.text-accent{color:var(--ip-accent)!important}
.bg-primary-brand{background:var(--ip-primary)!important;color:#fff}
.bg-accent{background:var(--ip-accent)!important;color:#fff}
.bg-primary-soft{background:var(--ip-primary-50)!important}
.bg-accent-soft{background:var(--ip-accent-50)!important}
.divider-y{height:1px;background:var(--ip-border);margin:1.5rem 0}
.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .65rem;border-radius:999px;background:#f1f5f9;color:#475569;font-size:.78rem;font-weight:500}
.rounded-xl{border-radius:14px!important}
.shadow-sm-soft{box-shadow:var(--ip-shadow)!important}
.kbd{font-family:ui-monospace,monospace;background:#f1f5f9;border:1px solid var(--ip-border);border-bottom-width:2px;padding:.05rem .4rem;border-radius:6px;font-size:.78rem;color:var(--ip-dark)}

/* Scrollbar */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:#94a3b8}

/* CodeIgniter integration compatibility: keep template visuals while mapping legacy app classes. */
.ip-wrap{max-width:1140px;margin:0 auto;padding:0 12px}
.ip-section{padding:5rem 0}
.ip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}
.ip-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem}
.ip-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.ip-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.ip-form-grid .full{grid-column:1/-1}
.ip-page-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem}
.ip-filter-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;align-items:end}
.ip-duration-list{display:grid;gap:.75rem;margin:1.25rem 0 1.5rem}
.ip-duration-row{display:flex;justify-content:space-between;gap:1rem;align-items:center;padding:.9rem;border:1px solid var(--ip-border);border-radius:12px;background:#fbfdff}
.ip-duration-row strong{font-size:1.35rem;color:var(--ip-dark)}
.ip-empty,.empty-state{background:#f8fafc;border:1px dashed #c9d4e3;border-radius:12px;color:#64748b;padding:1.25rem}
.ip-muted{color:var(--ip-muted)!important}
.ip-public{background:#fff}
.ip-public .nav-marketing .container{max-width:1140px}
.ip-public .navbar-collapse{display:flex!important;align-items:center;flex-basis:auto}
.ip-public .navbar-nav{display:flex;flex-direction:row;padding-left:0;margin-bottom:0;list-style:none}
.ip-public .nav-marketing .collapse:not(.show){display:flex}
.ip-footer{background:#0f172a;color:#cbd5e1;padding:3.5rem 0 2rem}
.ip-footer-grid{display:grid;grid-template-columns:2fr repeat(3,1fr);gap:1.5rem}
.ip-footer h6{color:#fff;font-weight:700;margin-bottom:1rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em}
.ip-footer a{color:#cbd5e1;display:block;padding:.25rem 0;font-size:.9rem}
.ip-footer a:hover{color:var(--ip-accent)}
.ip-footer-bottom{border-top:1px solid #1e293b;margin-top:2.5rem;padding-top:1.5rem;font-size:.85rem;color:#94a3b8;display:flex;flex-wrap:wrap;justify-content:space-between;gap:.5rem}
.brand-lockup{display:flex;align-items:center;gap:.6rem;font-weight:700;color:inherit}

body.header-dark.sidebar-light{background:var(--ip-bg);font-family:var(--ip-font);font-size:14.5px;color:var(--ip-body)}
body.header-dark.sidebar-light .header{height:var(--ip-header-h);background:#fff!important;border-bottom:1px solid var(--ip-border);box-shadow:none!important;display:flex;align-items:center;gap:1rem;padding:0 1.5rem;position:fixed;top:0;z-index:1020}
body.header-dark.sidebar-light .left-side-bar{width:var(--ip-sidebar-w)!important;background:#fff!important;border-right:1px solid var(--ip-border);box-shadow:none!important;position:fixed!important;top:0!important;left:0!important;bottom:0!important;z-index:1030;overflow-y:auto}
body.header-dark.sidebar-light .main-container{background:var(--ip-bg);min-height:100vh}
body.header-dark.sidebar-light .brand-logo a{display:flex;align-items:center;gap:.6rem;padding:1rem 1.25rem;border-bottom:1px solid var(--ip-border);font-weight:700;color:var(--ip-dark);font-size:1.05rem;text-decoration:none}
.sidebar-menu .nav-section{padding:.6rem 1.4rem .3rem;font-size:.68rem;color:var(--ip-muted);text-transform:uppercase;letter-spacing:.09em;margin-top:.5rem;font-weight:700}
.sidebar-menu>ul>li{margin:0;padding:0!important}
.sidebar-menu>ul>li>a,.sidebar-menu .customer-account-link,.sidebar-menu .dropdown-toggle{display:flex!important;align-items:center!important;gap:.75rem;padding:.6rem .9rem!important;margin:.15rem .6rem!important;border-radius:10px!important;color:#475569!important;font-weight:500!important;font-size:.9rem!important;line-height:1.55;border:0!important;text-decoration:none!important}
.sidebar-menu>ul>li>a i,.sidebar-menu .customer-account-link i,.sidebar-menu .dropdown-toggle i{width:18px;text-align:center;font-size:1rem;color:#94a3b8}
.sidebar-menu>ul>li>a:hover,.sidebar-menu>ul>li>a.active,.sidebar-menu .customer-account-link:hover,.sidebar-menu .customer-account-link.active,.sidebar-menu .dropdown-toggle:hover,.sidebar-menu .dropdown-toggle.active{background:var(--ip-primary-50)!important;color:var(--ip-primary-700)!important;box-shadow:none!important}
body.ip-admin .sidebar-menu>ul>li>a:hover,body.ip-admin .sidebar-menu>ul>li>a.active,body.ip-admin .sidebar-menu .dropdown-toggle:hover,body.ip-admin .sidebar-menu .dropdown-toggle.active{background:var(--ip-accent-50)!important;color:#9a5b0a!important}
.ip-topbar{height:var(--ip-header-h);background:#fff!important;border-bottom:1px solid var(--ip-border);display:flex;align-items:center;gap:1rem;padding:0 1.5rem}
.ip-topbar .ip-search,.topbar .search{flex:1;max-width:420px;position:relative}
.ip-topbar .ip-search input{padding-left:2.4rem;background:#f5f7fb;border:1px solid transparent}
.ip-topbar .ip-search i{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);color:var(--ip-muted)}
.ip-icon-btn{width:40px;height:40px;border-radius:10px;border:1px solid var(--ip-border);background:#fff;display:inline-flex;align-items:center;justify-content:center;color:var(--ip-body)}
.page-header{background:transparent!important;border:0!important;box-shadow:none!important;margin-bottom:1.5rem!important;padding:0!important}
.page-header .title h4{font-size:1.5rem;font-weight:700;color:var(--ip-dark);margin:0}
.content,.ip-content{padding:1.75rem}
.card-box{border:1px solid var(--ip-border)!important;border-radius:var(--ip-radius)!important;box-shadow:var(--ip-shadow)!important;background:#fff!important}
.pd-20{padding:1.25rem!important}.pd-30{padding:1.5rem!important}.height-100-p{height:auto!important}
.btn-border{color:var(--ip-primary);border-color:var(--ip-primary);background:#fff}
.btn-border:hover{background:var(--ip-primary);border-color:var(--ip-primary);color:#fff}
.btn-warning{background:var(--ip-accent)!important;border-color:var(--ip-accent)!important;color:#fff!important}
.btn-secondary{background:#f1f5f9!important;color:var(--ip-dark)!important;border:1px solid #e2e8f0!important}
.filter{margin-bottom:1rem}.filter .card-header{padding:0}.btn-header-link{display:flex;align-items:center;width:100%;padding:1rem 1.25rem!important;color:var(--ip-dark)!important;font-weight:600;background:transparent!important}
.dataTables_wrapper{background:#f8fafc!important;border:1px dashed #c9d4e3!important;border-radius:12px!important;color:#64748b}
.pagination{gap:.25rem}.page-link{border-radius:8px!important;color:var(--ip-primary);border-color:var(--ip-border)}.page-item.active .page-link{background:var(--ip-primary);border-color:var(--ip-primary)}
/* Legacy solid badges -> soft brand badges (keeps invoice detail/review + Saas lists on-brand without markup changes) */
.badge.badge-success{background:#d1fae5!important;color:#065f46!important}
.badge.badge-warning{background:#fef3c7!important;color:#92400e!important}
.badge.badge-danger{background:#fee2e2!important;color:#991b1b!important}
.badge.badge-info{background:#dbeafe!important;color:#1e40af!important}
.badge.badge-primary{background:var(--ip-primary-50)!important;color:var(--ip-primary-700)!important}
.badge.badge-secondary{background:#f1f5f9!important;color:#475569!important}

.addInvoice .card-box,.addInvoice.card-box,.reviewInvoiceCon,.invoiceDetails{max-width:1180px!important}
.addInvoice .title{color:var(--ip-primary);letter-spacing:.08em}
.addInvoice .card,.displayBox,.reviewInvoiceCon,.reviewInvoiceBody,.invoiceDetails{border-color:var(--ip-border)!important;border-radius:var(--ip-radius)!important}
.displayBox{background:#fff!important;box-shadow:none!important}.displayBox .topHedaer{border-color:var(--ip-border)!important}
.sectionFour .invoiceTable{min-width:860px}.sectionFour .invoiceTable thead tr,.invoice-line-table thead tr{background:var(--ip-primary)!important}.sectionFour .invoiceTable thead th,.invoice-line-table thead th{background:var(--ip-primary)!important;color:#fff!important}
.sectionFour .table-responsive,.invoiceDetails .table-responsive{overflow-x:auto!important;overflow-y:hidden!important}
.reviewInvoiceCon .navheader .cols{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end}.reviewInvoiceCon .navheader a{margin:0!important}
.invoiceSummary,.invoiceDetails{background:#fff!important;border-color:var(--ip-border)!important;box-shadow:var(--ip-shadow)}
.invoiceDetails .section3 .cols.right{background:var(--ip-primary-50)!important;border:1px solid var(--ip-primary-100)}
.addInvoice .displayBody .rows .cols.right p,.invoiceSummary .flexWrap .value,.invoiceDetails p{overflow-wrap:anywhere}

@media(min-width:992px){
  body.header-dark.sidebar-light:not(.sidebar-shrink) .header{left:var(--ip-sidebar-w)!important;width:calc(100% - var(--ip-sidebar-w))!important}
  body.header-dark.sidebar-light:not(.sidebar-shrink) .main-container{padding-left:calc(var(--ip-sidebar-w) + 1.75rem)!important;padding-right:1.75rem!important;padding-top:calc(var(--ip-header-h) + 1.75rem)!important}
}
@media(max-width:991.98px){
  .ip-public .navbar-collapse{display:none!important;width:100%;padding-top:1rem}.ip-public .navbar-collapse.show{display:block!important}.ip-public .navbar-nav{flex-direction:column}
  .ip-grid-2,.ip-footer-grid{grid-template-columns:1fr}.ip-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  body.header-dark.sidebar-light .header{left:0!important;width:100%!important}
  body.header-dark.sidebar-light .main-container{padding:calc(var(--ip-header-h) + 1.25rem) 1.25rem 1.25rem!important}
  body.header-dark.sidebar-light .left-side-bar{transform:translateX(-100%);transition:transform .25s ease}
  body.header-dark.sidebar-light .left-side-bar.show{transform:translateX(0)}
  .ip-topbar .ip-search{display:none}
}
@media(max-width:640px){
  .ip-section{padding:3rem 0}.ip-form-grid,.ip-filter-grid{grid-template-columns:1fr}.ip-page-head{align-items:stretch}.ip-page-head .btn{justify-content:center}
  .auth-form{padding:1.5rem}.reviewInvoiceCon .navheader .btn,.ip-actions .btn{justify-content:center}
}
