/* ═══════════════════════════════════════════════════════════════
   WETROO BILLS — Master Stylesheet v3.0
   Single source of truth for ALL pages
   Colors : Navy #1d2878 | Orange #f35c25
   Fonts  : Plus Jakarta Sans | Bricolage Grotesque
   Author : Wetroo Bills Design System
═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:wght@500;700;800&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap');

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Plus Jakarta Sans',sans-serif;background:#F6F8FF;color:#000;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.5;}

/* ══════════════════════════════════════
   §1  SHELL & LAYOUT
══════════════════════════════════════ */
.app-shell{max-width:420px;margin:0 auto;background:#fff;min-height:100vh;display:flex;flex-direction:column;position:relative;box-shadow:0 0 40px rgba(29,40,120,.10);}
.auth-shell{max-width:420px;margin:0 auto;background:#fff;min-height:100vh;display:flex;flex-direction:column;position:relative;box-shadow:0 0 40px rgba(29,40,120,.10);overflow:hidden;}
.page-content{flex:1;overflow-y:auto;padding-bottom:80px;}
.page-content::-webkit-scrollbar{display:none;}

/* padding-bottom variants */
.pb-20{padding-bottom:20px;}
.pb-24{padding-bottom:24px;}
.pb-70{padding-bottom:70px;}
.pb-88{padding-bottom:88px;}
.pb-90{padding-bottom:90px;}
.pb-100{padding-bottom:100px;}

/* ══════════════════════════════════════
   §2  TOPBAR
══════════════════════════════════════ */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#fff;border-bottom:1px solid #e2e6f0;position:sticky;top:0;z-index:100;min-height:56px;}
.topbar-left{display:flex;align-items:center;gap:10px;}
.topbar-right{display:flex;align-items:center;gap:10px;}
.topbar-title{font-family:'Plus Jakarta Sans',sans-serif;font-size:17px;font-weight:700;color:#1d2878;letter-spacing:-.01em;}

.back-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#1d2878;font-size:20px;border-radius:8px;transition:background .15s;border:none;background:none;text-decoration:none;}
.back-btn:hover{background:#e8eaf8;}
.topbar-icon-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#1d2878;font-size:18px;border-radius:8px;transition:background .15s;border:none;background:none;text-decoration:none;}
.topbar-icon-btn:hover{background:#e8eaf8;}

/* Navy topbar (Daybook) */
.topbar-navy{background:#3d3db5;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;min-height:58px;}
.topbar-navy-left{display:flex;align-items:flex-start;gap:10px;}
.topbar-navy-title{font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1.1;}
.topbar-navy-sub{font-size:11.5px;color:rgba(255,255,255,.65);font-weight:500;margin-top:2px;}
.topbar-navy-back{color:#fff;font-size:22px;background:none;border:none;cursor:pointer;padding:0 4px;margin-top:2px;text-decoration:none;display:flex;align-items:center;}
.topbar-navy-pdf{width:36px;height:36px;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.25);border-radius:9px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:15px;text-decoration:none;}
.topbar-navy-pdf:hover{background:rgba(255,255,255,.25);}

/* ══════════════════════════════════════
   §3  BOTTOM NAV
══════════════════════════════════════ */
.bottom-nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:420px;background:#fff;border-top:1.5px solid #e2e6f0;display:flex;z-index:200;box-shadow:0 -4px 20px rgba(29,40,120,.08);}
.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:9px 4px 7px;cursor:pointer;text-decoration:none;gap:3px;transition:all .15s;border:none;background:none;}
.nav-icon{font-size:22px;line-height:1;color:#7880a4;transition:color .15s;}
.nav-label{font-size:10.5px;font-weight:600;color:#7880a4;transition:color .15s;}
.nav-item.active .nav-icon,.nav-item.active .nav-label{color:#1d2878;}
.nav-item:hover .nav-icon,.nav-item:hover .nav-label{color:#1d2878;}

/* ══════════════════════════════════════
   §4  BUTTONS
══════════════════════════════════════ */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:7px;background:#1d2878;color:#fff;border:none;border-radius:12px;font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;padding:14px 24px;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px rgba(29,40,120,.25);text-decoration:none;width:100%;}
.btn-primary:hover{background:#141f60;transform:translateY(-1px);box-shadow:0 6px 22px rgba(29,40,120,.32);}
.btn-primary:active{transform:scale(.98);}
.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none;}

.btn-orange{background:#f35c25;box-shadow:0 4px 16px rgba(243,92,37,.28);}
.btn-orange:hover{background:#d94c18;}

.btn-ghost{background:transparent;color:#1d2878;border:1.5px solid #cdd2eb;box-shadow:none;}
.btn-ghost:hover{background:#e8eaf8;border-color:#c5caf0;}

.btn-outline-navy{display:inline-flex;align-items:center;gap:6px;background:transparent;color:#1d2878;border:1.5px solid #1d2878;border-radius:20px;font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:700;padding:6px 14px;cursor:pointer;transition:all .15s;}
.btn-outline-navy:hover{background:#e8eaf8;}

/* Pill outline (EDIT buttons) */
.btn-outline-pill{background:#fff;border:1.5px solid #cdd2eb;border-radius:20px;padding:6px 16px;font-size:12.5px;font-weight:700;color:#3a3f5c;cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;}
.btn-outline-pill:hover{background:#F6F8FF;}

/* Topbar add-new text button */
.btn-topbar-text{background:none;border:none;font-family:'Plus Jakarta Sans',sans-serif;font-size:13.5px;font-weight:700;color:#1d2878;cursor:pointer;display:flex;align-items:center;gap:4px;}

/* ══════════════════════════════════════
   §5  FORM FIELDS
══════════════════════════════════════ */
.field-group{margin-bottom:16px;}
.field-label{font-size:12.5px;font-weight:600;color:#3a3f5c;margin-bottom:6px;display:block;}
.field-label .req,.req{color:#dc2626;margin-left:2px;}
.field-input{width:100%;background:#fff;border:1.5px solid #e2e6f0;border-radius:10px;padding:12px 14px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:#000;outline:none;transition:border-color .18s,box-shadow .18s;appearance:none;}
.field-input:focus{border-color:#1d2878;box-shadow:0 0 0 3px rgba(29,40,120,.08);}
.field-input::placeholder{color:#bbbfce;}
.field-input.has-value{color:#000;}
select.field-input{cursor:pointer;}

.field-hint{font-size:11.5px;color:#7880a4;font-weight:500;margin-top:4px;padding-left:2px;}

/* Price input wrapper */
.price-input-wrap{display:flex;align-items:center;border:1.5px solid #e2e6f0;border-radius:10px;overflow:hidden;background:#fff;transition:border-color .18s;}
.price-input-wrap:focus-within{border-color:#1d2878;}
.price-prefix{padding:12px 12px;font-size:15px;font-weight:600;color:#7880a4;background:#F6F8FF;border-right:1px solid #e2e6f0;flex-shrink:0;}
.price-field{flex:1;border:none;outline:none;padding:12px 12px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:#000;background:transparent;}
.price-field::placeholder{color:#bbbfce;}
.price-suffix{display:flex;align-items:center;gap:5px;padding:0 12px;font-size:13px;font-weight:600;color:#3a3f5c;border-left:1px solid #e2e6f0;cursor:pointer;flex-shrink:0;height:100%;white-space:nowrap;}

/* Two-column field row */
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}

/* ══════════════════════════════════════
   §6  TYPOGRAPHY UTILITIES
══════════════════════════════════════ */
.text-navy{color:#1d2878;}
.text-orange{color:#f35c25;}
.text-green{color:#16a34a;}
.text-red{color:#dc2626;}
.text-muted{color:#7880a4;}
.text-text2{color:#3a3f5c;}
.text-xs{font-size:11px;}
.text-sm{font-size:12.5px;}
.text-base{font-size:14px;}
.text-lg{font-size:18px;}
.text-xl{font-size:20px;}
.text-2xl{font-size:22px;}
.text-right{text-align:right;}
.text-center{text-align:center;}
.font-bold{font-weight:700;}
.font-black{font-weight:800;}
.font-semibold{font-weight:600;}
.font-normal{font-weight:400;}
.font-headline{font-family:'Bricolage Grotesque',sans-serif;}
.uppercase{text-transform:uppercase;}
.no-appearance{appearance:none;}
.cursor-pointer{cursor:pointer;}
.opacity-70{opacity:.7;}
.u-line{text-decoration:underline;}

/* ══════════════════════════════════════
   §7  LAYOUT UTILITIES
══════════════════════════════════════ */
.flex-between{display:flex;align-items:center;justify-content:space-between;}
.flex-items-center{display:flex;align-items:center;}
.flex-col{display:flex;flex-direction:column;}
.gap-4{gap:4px;}
.gap-8{gap:8px;}
.gap-10{gap:10px;}
.gap-12{gap:12px;}
.gap-16{gap:16px;}
.grid-cols-2{display:grid;grid-template-columns:1fr 1fr;}
.relative{position:relative;}
.hidden{display:none!important;}
.mb-3{margin-bottom:3px;}
.mb-6{margin-bottom:6px;}
.mb-8{margin-bottom:8px;}
.mb-12{margin-bottom:12px;}
.mt-12{margin-top:12px;}

/* Backgrounds */
.bg-white{background:#fff;}
.bg-soft{background:#F6F8FF;}
.bg-soft-navy{background:#e8eaf8;}
.bg-soft-orange{background:#fff1ec;}
.bg-soft-green{background:#dcfce7;}

/* Borders */
.border-b-e2{border-bottom:1px solid #e2e6f0;}
.border-b-8{border-bottom:8px solid #F6F8FF;}

/* Padding shortcuts */
.p-12-16{padding:12px 16px;}
.p-14-16{padding:14px 16px;}
.p-16-20{padding:16px 16px 20px;}
.p-18-16{padding:18px 16px 0;}

/* Border radius */
.rounded-8{border-radius:8px;}
.rounded-10{border-radius:10px;}
.rounded-12{border-radius:12px;}
.rounded-14{border-radius:14px;}

/* ══════════════════════════════════════
   §8  SECTION LABELS & DIVIDERS
══════════════════════════════════════ */
.section-label{font-size:12px;font-weight:600;color:#7880a4;background:#F6F8FF;padding:8px 16px;letter-spacing:.02em;}
.divider{height:1px;background:#e2e6f0;margin:0;}
.divider-thick{height:8px;background:#F6F8FF;}

/* ══════════════════════════════════════
   §9  LIST ROWS (More, Reports, etc.)
══════════════════════════════════════ */
.list-row{display:flex;align-items:center;justify-content:space-between;padding:15px 16px;border-bottom:1px solid #e2e6f0;cursor:pointer;background:#fff;transition:background .13s;text-decoration:none;color:inherit;}
.list-row:last-child{border-bottom:none;}
.list-row:hover{background:#F6F8FF;}
.list-row:active{background:#e8eaf8;}
.list-row-left{display:flex;align-items:center;gap:14px;}
.list-row-icon{width:40px;height:40px;border-radius:10px;background:#e8eaf8;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;color:#1d2878;}
.list-row-icon svg{width:20px;height:20px;fill:#1d2878;}
.list-row-title{font-size:14.5px;font-weight:500;color:#000;}
.list-row-sub{font-size:12px;color:#7880a4;margin-top:2px;}
.list-row-chevron{color:#7880a4;font-size:16px;flex-shrink:0;}
.list-row-value{font-size:14.5px;font-weight:600;color:#3a3f5c;}

/* Settings rows (Business GST) */
.settings-group{background:#fff;border-bottom:8px solid #F6F8FF;}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:15px 16px;border-bottom:1px solid #e2e6f0;cursor:pointer;background:#fff;transition:background .13s;text-decoration:none;color:inherit;gap:12px;}
.settings-row:hover{background:#F6F8FF;}
.settings-row:last-child{border-bottom:none;}
.sr-left{display:flex;align-items:center;gap:14px;flex:1;}
.sr-icon{width:38px;height:38px;border-radius:10px;background:#e8eaf8;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#1d2878;font-size:18px;font-weight:800;}
.sr-icon svg{width:20px;height:20px;fill:#1d2878;}
.sr-title{font-size:14.5px;font-weight:500;color:#000;}
.sr-value{font-size:12.5px;color:#7880a4;margin-top:2px;line-height:1.4;text-align:right;}
.sr-chevron{font-size:16px;color:#7880a4;flex-shrink:0;}

/* ══════════════════════════════════════
   §10 REPORT ITEMS
══════════════════════════════════════ */
.report-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #e2e6f0;cursor:pointer;background:#fff;transition:background .13s;text-decoration:none;color:inherit;}
.report-item:hover{background:#F6F8FF;}
.report-item:active{background:#e8eaf8;}
.report-item-left{display:flex;align-items:center;gap:14px;}
.report-icon{width:40px;height:40px;border-radius:10px;background:#e8eaf8;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.report-icon svg{width:20px;height:20px;fill:#1d2878;}
.report-title{font-size:14.5px;font-weight:500;color:#000;}
.report-sub{font-size:12px;color:#7880a4;margin-top:2px;}
.report-chevron{color:#7880a4;font-size:16px;}

/* ══════════════════════════════════════
   §11 BADGES & CHIPS
══════════════════════════════════════ */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:700;}
.badge-navy{background:#e8eaf8;color:#1d2878;}
.badge-orange{background:#fff1ec;color:#f35c25;border:1px solid #fdddd3;}
.badge-green{background:#dcfce7;color:#16a34a;}
.badge-red{background:#fee2e2;color:#dc2626;}
.badge-grey{background:#F6F8FF;color:#7880a4;border:1px solid #e2e6f0;}

/* Type selector (Product / Service) */
.type-selector{display:flex;gap:10px;}
.type-opt{padding:8px 20px;border-radius:100px;border:1.5px solid #e2e6f0;font-size:13.5px;font-weight:600;color:#7880a4;cursor:pointer;background:#fff;transition:all .15s;font-family:'Plus Jakarta Sans',sans-serif;}
.type-opt:hover{border-color:#1d2878;color:#1d2878;}
.type-opt.active{border-color:#1d2878;color:#1d2878;background:#e8eaf8;}

/* Business type chips (Register) */
.btype-chips{display:flex;gap:8px;flex-wrap:wrap;}
.btype-chip{padding:7px 14px;border-radius:100px;border:1.5px solid #e2e6f0;font-size:12.5px;font-weight:600;color:#7880a4;background:#fff;cursor:pointer;transition:all .15s;font-family:'Plus Jakarta Sans',sans-serif;}
.btype-chip:hover{border-color:#1d2878;color:#1d2878;}
.btype-chip.active{background:#1d2878;border-color:#1d2878;color:#fff;}

/* ══════════════════════════════════════
   §12 TAB BAR
══════════════════════════════════════ */
.tab-bar{display:flex;border-bottom:1.5px solid #e2e6f0;background:#fff;overflow-x:auto;}
.tab-bar::-webkit-scrollbar{display:none;}
.tab-item{flex-shrink:0;padding:12px 18px;font-size:13.5px;font-weight:600;color:#7880a4;cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-1.5px;transition:all .18s;white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none;font-family:'Plus Jakarta Sans',sans-serif;}
.tab-item.active{color:#1d2878;border-bottom-color:#1d2878;font-weight:700;}
.tab-content{display:none;}
.tab-content.active{display:block;}

/* ══════════════════════════════════════
   §13 SEARCH BAR
══════════════════════════════════════ */
.search-wrap{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fff;border-bottom:1px solid #e2e6f0;}
.search-box{flex:1;display:flex;align-items:center;gap:8px;background:#F6F8FF;border:1.5px solid #e2e6f0;border-radius:20px;padding:9px 14px;transition:border-color .18s;}
.search-box:focus-within{border-color:#1d2878;}
.search-icon{color:#7880a4;font-size:16px;flex-shrink:0;}
.search-input{flex:1;border:none;outline:none;background:transparent;font-family:'Plus Jakarta Sans',sans-serif;font-size:13.5px;color:#000;}
.search-input::placeholder{color:#7880a4;}
.search-action-btn{width:36px;height:36px;border-radius:50%;background:#e8eaf8;display:flex;align-items:center;justify-content:center;font-size:16px;color:#1d2878;cursor:pointer;border:none;flex-shrink:0;transition:background .13s;}
.search-action-btn:hover{background:#c5caf0;}

/* ══════════════════════════════════════
   §14 QUANTITY STEPPER
══════════════════════════════════════ */
.qty-stepper{display:flex;align-items:center;border:1.5px solid #cdd2eb;border-radius:10px;overflow:hidden;}
.qty-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:20px;color:#1d2878;cursor:pointer;background:#fff;border:none;transition:background .13s;font-weight:400;line-height:1;}
.qty-btn:hover{background:#e8eaf8;}
.qty-btn:active{background:#c5caf0;}
.qty-val{min-width:36px;text-align:center;font-size:15px;font-weight:700;color:#000;padding:0 4px;border-left:1px solid #e2e6f0;border-right:1px solid #e2e6f0;height:36px;display:flex;align-items:center;justify-content:center;}

/* ══════════════════════════════════════
   §15 CREATE NEW PILL BUTTON
══════════════════════════════════════ */
.create-new-btn{display:flex;align-items:center;justify-content:flex-end;gap:6px;margin:10px 14px;}
.create-new-pill{display:inline-flex;align-items:center;gap:6px;background:#F6F8FF;border:1.5px solid #e2e6f0;border-radius:100px;padding:9px 18px;font-size:13.5px;font-weight:600;color:#3a3f5c;cursor:pointer;transition:all .15s;text-decoration:none;}
.create-new-pill:hover{border-color:#1d2878;color:#1d2878;background:#e8eaf8;}

/* ══════════════════════════════════════
   §16 BOTTOM ACTION BAR (Items, Bills)
══════════════════════════════════════ */
.bottom-action-bar{position:sticky;bottom:0;background:#fff;border-top:1px solid #e2e6f0;padding:12px 16px;z-index:50;}
.bottom-summary{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.bottom-summary-left{font-size:13px;font-weight:600;color:#3a3f5c;}
.bottom-summary-right{font-size:16px;font-weight:700;color:#000;}
.bottom-action-row{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.bottom-link-btn{font-size:13.5px;font-weight:700;color:#1d2878;cursor:pointer;background:none;border:none;font-family:'Plus Jakarta Sans',sans-serif;}
.bottom-link-sub{font-size:11px;color:#7880a4;font-weight:400;margin-top:1px;}

/* ══════════════════════════════════════
   §17 ITEM ROWS (items.php)
══════════════════════════════════════ */
.item-row{padding:14px 16px;border-bottom:1px solid #e2e6f0;display:flex;align-items:center;gap:13px;background:#fff;transition:background .13s;}
.item-row:hover{background:#F6F8FF;}
.item-name-text{font-size:15px;font-weight:700;color:#000;}
.item-desc-text{font-size:12.5px;color:#7880a4;margin-top:1px;}
.item-price-row{margin-top:6px;display:flex;align-items:center;gap:8px;}
.item-price-main{font-size:14px;font-weight:700;color:#000;}
.item-price-unit{color:#7880a4;font-weight:500;font-size:12px;}
.item-price-chevron{color:#7880a4;font-size:12px;}
.item-stock-row{font-size:12px;color:#7880a4;margin-top:2px;border-top:1.5px dashed #e2e6f0;padding-top:4px;}
.item-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px;}

/* Avatar / initial box */
.item-avatar{width:46px;height:46px;border-radius:12px;background:#e8eaf8;display:flex;align-items:center;justify-content:center;font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:800;color:#1d2878;flex-shrink:0;}
.item-avatar.orange{background:#fff1ec;color:#f35c25;}
.item-info-wrap{flex:1;min-width:0;}

/* ══════════════════════════════════════
   §18 INFO BANNER (Balance Sheet)
══════════════════════════════════════ */
.info-banner{background:#fefce8;border-left:3px solid #ca8a04;padding:12px 14px;margin:12px 16px;border-radius:8px;font-size:12.5px;color:#713f12;line-height:1.55;display:flex;gap:10px;align-items:flex-start;}
.info-icon{flex-shrink:0;font-size:14px;margin-top:1px;}
.info-banner strong{color:#1d2878;}

/* ══════════════════════════════════════
   §19 FINANCIAL ROWS (Balance Sheet)
══════════════════════════════════════ */
.fin-row{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid #e2e6f0;}
.fin-row.bold .fin-label,.fin-row.bold .fin-value{font-weight:700;color:#000;font-size:15px;}
.fin-row.sub{padding:9px 24px;}
.fin-row.sub .fin-label{font-size:13px;color:#7880a4;}
.fin-row.sub .fin-value{font-size:13px;color:#3a3f5c;}
.fin-row.header-row{background:#e8eaf8;}
.fin-row.section-gap{border-top:4px solid #F6F8FF;}
.fin-label{font-size:14.5px;font-weight:600;color:#000;}
.fin-value{font-size:14.5px;font-weight:700;color:#1d2878;}
.fin-value.neutral{color:#3a3f5c;}
.fin-value.green{color:#16a34a;}
.fin-value.red{color:#dc2626;}
.fin-value.large{font-size:17px;}

/* Info tooltip button (balance sheet) */
.info-tooltip-btn{background:none;border:1px solid #cdd2eb;border-radius:50%;width:18px;height:18px;font-size:10px;color:#7880a4;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;margin-left:4px;}

/* ══════════════════════════════════════
   §20 TOTAL STRIP & FAB
══════════════════════════════════════ */
.total-strip{background:#1d2878;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;}
.total-strip-label{font-size:15px;font-weight:700;color:#fff;}
.total-strip-value{font-size:16px;font-weight:800;color:#fff;font-family:'Bricolage Grotesque',sans-serif;}
.total-strip-fixed{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:420px;}

.fab{display:inline-flex;align-items:center;gap:8px;background:#1d2878;color:#fff;border:none;border-radius:100px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:700;padding:14px 28px;cursor:pointer;box-shadow:0 6px 24px rgba(29,40,120,.32);transition:all .2s;text-decoration:none;}
.fab:hover{background:#141f60;transform:translateY(-2px);}
.fab:active{transform:scale(.97);}
.fab-center{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:100;}

/* Daybook FABs */
.fab-group{position:fixed;bottom:24px;right:calc(50% - 200px);display:flex;gap:10px;z-index:100;}
.fab-sm{width:48px;height:48px;background:#fff;border:1.5px solid #cdd2eb;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 16px rgba(29,40,120,.14);transition:all .18s;font-size:18px;color:#1d2878;}
.fab-sm:hover{background:#e8eaf8;border-color:#1d2878;}
@media(max-width:480px){.fab-group{right:16px;}}

/* ══════════════════════════════════════
   §21 DATA TABLES
══════════════════════════════════════ */
.data-table{width:100%;border-collapse:collapse;font-size:12px;}
.data-table th{background:#F6F8FF;color:#3a3f5c;font-weight:700;padding:9px 8px;text-align:left;border:1px solid #e2e6f0;font-size:11px;white-space:nowrap;}
.data-table td{padding:9px 8px;border:1px solid #e2e6f0;color:#3a3f5c;vertical-align:top;font-size:11.5px;}
.data-table tr:hover td{background:#F6F8FF;}
.card-container{border:1px solid #e2e6f0;border-radius:12px;overflow:hidden;background:#fff;margin:14px 14px 0;}

/* ══════════════════════════════════════
   §22 EXPORT BUTTONS
══════════════════════════════════════ */
.export-btns{display:flex;gap:8px;}
.export-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;border:none;transition:opacity .15s;}
.export-btn:hover{opacity:.85;}
.export-btn.pdf{background:#fee2e2;color:#dc2626;}
.export-btn.xls{background:#dcfce7;color:#16a34a;}
.export-btn.json{background:#e8eaf8;color:#1d2878;}

/* ══════════════════════════════════════
   §23 DATE SELECTOR BAR
══════════════════════════════════════ */
.date-selector{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fff;border-bottom:1px solid #e2e6f0;cursor:pointer;}
.date-icon{font-size:18px;color:#1d2878;}
.date-period{font-size:13px;font-weight:700;color:#000;}
.date-range{font-size:12.5px;color:#7880a4;margin-top:1px;}
.date-change-btn{margin-left:auto;font-size:13px;font-weight:700;color:#1d2878;background:none;border:none;cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;}

/* CA Share banner (GSTR1) */
.ca-banner{background:#fffbeb;border-bottom:1px solid #fde68a;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.ca-banner-text{font-size:13px;color:#713f12;line-height:1.5;}
.ca-banner-try{background:#fff;border:1.5px solid #1d2878;border-radius:20px;padding:6px 14px;font-size:12.5px;font-weight:700;color:#1d2878;cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;white-space:nowrap;}
.ca-banner-close{background:none;border:none;font-size:18px;color:#7880a4;cursor:pointer;line-height:1;}

/* ══════════════════════════════════════
   §24 GSTR1 PAGE SPECIFIC
══════════════════════════════════════ */
.gstr-report-head{padding:16px 16px 10px;}
.gstr-label{font-size:14px;font-weight:700;color:#1d2878;margin-bottom:4px;}
.gstr-biz-name{font-size:14.5px;font-weight:700;color:#000;margin-bottom:2px;}
.gstr-meta{font-size:12.5px;color:#7880a4;}
.gstr-meta strong{color:#3a3f5c;}
.gstr-section-title{font-size:14px;font-weight:700;color:#000;margin-bottom:10px;}
.gstr-table-wrap{overflow-x:auto;border:1px solid #e2e6f0;border-radius:10px;margin-bottom:4px;}
.gstr-empty{text-align:center;padding:24px;color:#7880a4;font-size:13px;}
.gstr-empty-icon{font-size:28px;margin-bottom:8px;}
.gstr-tip{margin:0 16px 20px;background:#e8eaf8;border-radius:12px;padding:14px 16px;}
.gstr-tip-title{font-size:13px;font-weight:700;color:#1d2878;margin-bottom:5px;}
.gstr-tip-body{font-size:12px;color:#3a3f5c;line-height:1.6;}
.gstr-date-picker{display:none;background:#fff;border-bottom:1px solid #e2e6f0;padding:14px 16px;}
.gstr-date-picker-label{font-size:13px;font-weight:700;color:#3a3f5c;margin-bottom:10px;}
.gstr-period-opts{display:flex;gap:8px;flex-wrap:wrap;}
.gstr-section-pad{padding:12px 16px 8px;}

/* ══════════════════════════════════════
   §25 CREATE BILL PAGE
══════════════════════════════════════ */
.invoice-header-band{background:#F6F8FF;border-bottom:1px solid #e2e6f0;padding:12px 16px;}
.inv-num-text{font-size:14px;font-weight:700;color:#1d2878;}
.inv-date-text{font-size:12.5px;color:#7880a4;margin-top:2px;}
.inv-due-text{color:#3a3f5c;}
.party-section{padding:14px 16px;background:#fff;border-bottom:1px solid #e2e6f0;}
.party-label{font-size:13px;font-weight:700;color:#000;display:block;margin-bottom:8px;}
.party-select-wrap{position:relative;}
.party-select-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:16px;color:#7880a4;}
.party-padded{padding-left:40px;}
.items-section{background:#fff;margin-top:8px;}
.collapse-header{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;cursor:pointer;user-select:none;background:#fff;}
.collapse-title{font-size:14px;font-weight:700;color:#000;display:flex;align-items:center;gap:7px;}
.collapse-add-link{font-size:13px;font-weight:700;color:#1d2878;text-decoration:none;display:flex;align-items:center;gap:4px;}
.items-list-wrap{border-top:1px solid #e2e6f0;}
.subtotal-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1.5px solid #e2e6f0;}
.subtotal-label{font-size:14px;font-weight:700;color:#000;}
.subtotal-val{font-size:14.5px;font-weight:700;color:#000;}
.optional-section{background:#F6F8FF;padding:4px 0;border-top:1px solid #e2e6f0;border-bottom:1px solid #e2e6f0;}
.optional-row{display:flex;align-items:center;justify-content:flex-end;padding:11px 16px;gap:6px;cursor:pointer;}
.optional-plus{font-size:18px;color:#1d2878;font-weight:400;}
.optional-row-text{font-size:13.5px;font-weight:700;color:#1d2878;}
.optional-expand{display:none;padding:0 16px 12px;}
.optional-expand.soft{background:#F6F8FF;}
.total-section{background:#fff;padding:14px 16px;border-top:1px solid #e2e6f0;}
.total-row-inner{display:flex;align-items:center;justify-content:space-between;}
.total-label-text{font-size:15px;font-weight:700;color:#000;}
.total-amount-right{display:flex;align-items:center;gap:4px;}
.total-rupee-sym{font-size:18px;color:#7880a4;}
.total-amount-val{font-size:20px;font-weight:800;color:#000;font-family:'Bricolage Grotesque',sans-serif;}
.payment-mode-section{background:#fff;padding:14px 16px;margin-top:8px;border-top:1px solid #e2e6f0;border-bottom:1px solid #e2e6f0;}
.payment-mode-label-text{font-size:13px;font-weight:700;color:#000;display:block;margin-bottom:10px;}
.payment-modes-wrap{display:flex;gap:8px;flex-wrap:wrap;}

/* Bill item rows (rendered by JS) */
.bill-item-wrap{padding:12px 16px;border-bottom:1px solid #e2e6f0;}
.bill-item-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px;}
.bill-item-name{font-size:15px;font-weight:700;color:#000;}
.bill-item-price{font-size:15px;font-weight:700;color:#000;}
.bill-item-bottom{display:flex;justify-content:space-between;align-items:center;}
.inv-field-key{font-size:12.5px;color:#7880a4;font-weight:500;}
.inv-field-val{font-size:12.5px;color:#3a3f5c;font-weight:600;}

/* round-off apply button */
.btn-round-off{flex:1;background:#e8eaf8;border:none;border-radius:8px;padding:10px;font-size:13px;font-weight:700;color:#1d2878;cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;}

/* bottom fixed action bar (create-bill, create-item) */
.bottom-fixed-bar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:420px;background:#fff;border-top:1px solid #e2e6f0;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:100;}
.btn-save-new-text{background:none;border:none;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:700;color:#1d2878;cursor:pointer;display:block;}
.btn-save-new-sub{font-size:11px;color:#7880a4;margin-top:1px;}
.btn-primary-flex{flex:1;max-width:220px;padding:13px;}

/* ══════════════════════════════════════
   §26 CREATE ITEM PAGE
══════════════════════════════════════ */
.item-form-wrap{padding:18px 16px 0;}
.tax-panel{display:none;margin-top:8px;background:#F6F8FF;border-radius:8px;padding:10px 12px;}
.tax-panel-label{font-size:12px;font-weight:600;color:#3a3f5c;margin-bottom:6px;}
.tax-panel-opts{display:flex;gap:8px;flex-wrap:wrap;}
.tab-pad{padding:18px 16px;}
.partyprice-empty{text-align:center;padding:30px 20px;}
.partyprice-icon{font-size:36px;margin-bottom:12px;}
.partyprice-title{font-family:'Bricolage Grotesque',sans-serif;font-size:16px;font-weight:700;color:#1d2878;margin-bottom:8px;}
.partyprice-sub{font-size:13px;color:#7880a4;line-height:1.6;margin-bottom:20px;}

/* ══════════════════════════════════════
   §27 MORE PAGE
══════════════════════════════════════ */
.biz-header{padding:18px 16px 14px;background:#fff;border-bottom:1px solid #e2e6f0;}
.biz-header-inner{display:flex;align-items:center;justify-content:space-between;}
.biz-header-name{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:800;color:#000;letter-spacing:-.02em;}
.biz-settings-btn{margin-top:8px;display:inline-flex;align-items:center;gap:6px;background:#fff;border:1.5px solid #e2e6f0;border-radius:8px;padding:7px 13px;font-size:12px;font-weight:700;color:#3a3f5c;cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;letter-spacing:.04em;}
.biz-settings-btn:hover{background:#F6F8FF;}
.biz-avatar{width:52px;height:52px;border-radius:14px;background:#00bcd4;display:flex;align-items:center;justify-content:center;font-family:'Bricolage Grotesque',sans-serif;font-size:24px;font-weight:800;color:#fff;flex-shrink:0;}
.sub-banner{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;background:#fffbeb;border-bottom:1px solid #fde68a;cursor:pointer;text-decoration:none;}
.sub-banner-left{display:flex;align-items:center;gap:10px;}
.sub-banner-icon{font-size:20px;}
.sub-banner-text{font-size:14px;font-weight:700;color:#b45309;}
.sub-banner-chevron{color:#b45309;font-size:16px;}
.help-fab-wrap{position:fixed;bottom:76px;left:50%;transform:translateX(-50%);width:100%;max-width:420px;pointer-events:none;display:flex;justify-content:center;}
.help-fab-btn{pointer-events:all;display:inline-flex;align-items:center;gap:8px;background:#1d2878;color:#fff;border:none;border-radius:100px;padding:11px 22px;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 6px 22px rgba(29,40,120,.35);font-family:'Plus Jakarta Sans',sans-serif;}
.more-group{background:#fff;border-bottom:8px solid #F6F8FF;}
.app-version{text-align:center;padding:24px 16px;color:#bbbfce;}
.app-version-name{font-size:12px;font-weight:600;}
.app-version-made{font-size:11px;margin-top:3px;}

/* ══════════════════════════════════════
   §28 BUSINESS GST PAGE
══════════════════════════════════════ */
.biz-name-row{display:flex;align-items:flex-start;gap:14px;padding:18px 16px;background:#fff;border-bottom:8px solid #F6F8FF;}
.logo-upload-box{width:110px;height:110px;border:2px solid #e2e6f0;border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:all .18s;background:#F6F8FF;flex-shrink:0;position:relative;overflow:hidden;}
.logo-upload-box:hover{border-color:#1d2878;background:#e8eaf8;}
.logo-upload-icon{font-size:26px;color:#1d2878;}
.logo-upload-label{font-size:12.5px;font-weight:700;color:#1d2878;}
.logo-preview-img{width:100%;height:100%;object-fit:cover;position:absolute;top:0;left:0;display:none;border-radius:12px;}
.biz-name-field-wrap{flex:1;}
.biz-name-field-label{font-size:12.5px;font-weight:600;color:#7880a4;margin-bottom:7px;display:block;}
.biz-name-field{width:100%;border:1.5px solid #e2e6f0;border-radius:10px;padding:12px 14px;font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:500;color:#000;background:#fff;outline:none;transition:border-color .18s;}
.biz-name-field:focus{border-color:#1d2878;}

/* Edit panel (bottom sheet) */
.edit-panel{display:none;position:fixed;inset:0;background:rgba(29,40,120,.18);z-index:200;align-items:flex-end;}
.edit-panel.open{display:flex;}
.edit-panel-box{background:#fff;width:100%;max-width:420px;margin:0 auto;border-radius:22px 22px 0 0;padding:20px 20px 32px;box-shadow:0 -8px 32px rgba(29,40,120,.18);animation:slideUpPanel .25s ease;}
.max-h-80vh{max-height:80vh;overflow-y:auto;}
@keyframes slideUpPanel{from{transform:translateY(100%);}to{transform:translateY(0);}}
.ep-drag{width:40px;height:4px;border-radius:2px;background:#e2e6f0;margin:0 auto 16px;}
.ep-title{font-family:'Bricolage Grotesque',sans-serif;font-size:17px;font-weight:800;color:#000;margin-bottom:16px;}
.ep-close{position:absolute;right:20px;top:20px;width:30px;height:30px;border-radius:50%;background:#F6F8FF;border:1.5px solid #e2e6f0;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:#7880a4;}
.ep-close:hover{background:#e8eaf8;color:#1d2878;}
.resize-v{resize:vertical;}
.overflow-y-auto{overflow-y:auto;}

/* ══════════════════════════════════════
   §29 PAYMENT IN PAGE
══════════════════════════════════════ */
.section-block{background:#fff;border-bottom:8px solid #F6F8FF;padding:16px 16px;}
.field-label-bold{font-size:13px;font-weight:800;color:#000;letter-spacing:.04em;text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:4px;}
.party-input-wrap{position:relative;}
.party-search-input{width:100%;border:1.5px solid #e2e6f0;border-radius:10px;padding:13px 14px 13px 44px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;color:#7880a4;background:#fff;outline:none;transition:border-color .18s;cursor:pointer;}
.party-search-input:focus{border-color:#1d2878;color:#000;}
.party-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:17px;color:#7880a4;pointer-events:none;}
.party-chevron{position:absolute;right:13px;top:50%;transform:translateY(-50%);font-size:14px;color:#7880a4;pointer-events:none;}
.party-dropdown{display:none;background:#fff;border:1.5px solid #e2e6f0;border-radius:10px;margin-top:4px;overflow:hidden;box-shadow:0 6px 24px rgba(29,40,120,.12);z-index:50;position:relative;}
.party-dd-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid #e2e6f0;cursor:pointer;transition:background .13s;font-size:14px;color:#000;font-weight:500;}
.party-dd-item:last-child{border-bottom:none;}
.party-dd-item:hover{background:#F6F8FF;}
.dd-avatar{width:34px;height:34px;border-radius:9px;background:#e8eaf8;display:flex;align-items:center;justify-content:center;font-family:'Bricolage Grotesque',sans-serif;font-size:15px;font-weight:800;color:#1d2878;flex-shrink:0;}
.dd-avatar.orange-dd{background:#fff1ec;color:#f35c25;}
.dd-sub{font-size:11.5px;color:#7880a4;}
.dd-create{display:flex;align-items:center;gap:8px;padding:12px 14px;font-size:13.5px;font-weight:700;color:#1d2878;cursor:pointer;border-top:1px solid #e2e6f0;transition:background .13s;}
.dd-create:hover{background:#e8eaf8;}
.amount-row{display:flex;align-items:center;gap:14px;}
.amount-label{font-size:13px;font-weight:800;color:#000;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;display:flex;align-items:center;gap:4px;min-width:90px;}
.amount-input-wrap{flex:1;display:flex;align-items:center;border:1.5px solid #e2e6f0;border-radius:10px;padding:12px 14px;background:#fff;transition:border-color .18s;}
.amount-input-wrap:focus-within{border-color:#1d2878;}
.amount-rupee{font-size:16px;color:#7880a4;margin-right:8px;font-weight:500;}
.amount-field{border:none;outline:none;flex:1;font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:600;color:#000;background:transparent;width:100%;}
.amount-field::placeholder{color:#bbbfce;}
.opt-row{display:flex;align-items:center;justify-content:flex-end;padding:10px 16px;cursor:pointer;background:#F6F8FF;}
.opt-row-text{font-size:13.5px;font-weight:700;color:#1d2878;display:flex;align-items:center;gap:5px;}
.invoice-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#fff;border-bottom:1px solid #e2e6f0;}
.invoice-row-label{font-size:15px;font-weight:600;color:#000;}
.invoice-add-btn{font-size:13.5px;font-weight:700;color:#1d2878;display:flex;align-items:center;gap:4px;cursor:pointer;}
.invoice-panel{display:none;background:#F6F8FF;padding:14px 16px;border-top:1px solid #e2e6f0;}
.invoice-empty{text-align:center;padding:24px 16px;color:#7880a4;font-size:13px;}
.payment-mode-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#fff;}
.payment-mode-label{font-size:13px;font-weight:800;color:#000;letter-spacing:.04em;text-transform:uppercase;}
.payment-mode-select-wrap{display:flex;align-items:center;border:1.5px solid #e2e6f0;border-radius:10px;padding:11px 14px;min-width:160px;background:#fff;cursor:pointer;justify-content:space-between;gap:10px;position:relative;}
.payment-mode-select{border:none;outline:none;font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:500;color:#000;background:transparent;width:100%;appearance:none;cursor:pointer;}
.mode-chevron{font-size:14px;color:#7880a4;flex-shrink:0;}
.cheque-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.save-bar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:420px;background:#fff;border-top:1px solid #e2e6f0;padding:12px 16px;z-index:100;}

/* ══════════════════════════════════════
   §30 PROFIT & LOSS PAGE
══════════════════════════════════════ */
.date-picker-panel{display:none;background:#fff;border-bottom:1px solid #e2e6f0;padding:14px 16px;}
.period-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;}
.period-chip{padding:7px 16px;border-radius:100px;border:1.5px solid #e2e6f0;font-size:12.5px;font-weight:600;color:#7880a4;background:#fff;cursor:pointer;transition:all .15s;font-family:'Plus Jakarta Sans',sans-serif;}
.period-chip:hover{border-color:#1d2878;color:#1d2878;}
.period-chip.active{background:#1d2878;border-color:#1d2878;color:#fff;}
.report-header-block{padding:18px 16px 8px;background:#fff;}
.biz-name-lg{font-size:16px;font-weight:800;color:#000;}
.biz-phone{font-size:12.5px;color:#7880a4;margin-top:2px;}
.report-title-right{font-size:13.5px;font-weight:700;color:#000;text-decoration:underline;text-align:right;margin-top:8px;}
.duration-box{display:flex;justify-content:flex-end;margin:12px 16px;}
.duration-inner{border:1.5px solid #e2e6f0;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:600;color:#3a3f5c;}
.duration-inner strong{color:#1d2878;}
/* P&L Table */
.pl-table{width:100%;border-collapse:collapse;}
.pl-table thead th{background:#e8eaf8;color:#1d2878;font-size:13px;font-weight:700;padding:11px 14px;text-align:left;border-bottom:2px solid #cdd2eb;}
.pl-table thead th:last-child{text-align:right;}
.pl-table tbody tr{border-bottom:1px solid #e2e6f0;transition:background .12s;}
.pl-table tbody tr:hover{background:#F6F8FF;}
.pl-table tbody td{padding:10px 14px;font-size:13.5px;color:#3a3f5c;}
.pl-table tbody td:last-child{text-align:right;font-weight:600;color:#000;}
.pl-table tbody tr.summary-row td{font-weight:800;font-size:14px;color:#000;background:#e8eaf8;padding:12px 14px;}
.pl-table tbody tr.summary-row td:last-child{color:#1d2878;}
.pl-table tbody tr.profit-positive td:last-child{color:#16a34a;}
.pl-table tbody tr.profit-negative td:last-child{color:#dc2626;}
.amt-zero{color:#7880a4!important;}
.amt-positive{color:#16a34a!important;}
.amt-negative{color:#dc2626!important;}
.pl-summary-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 16px 20px;}
.pl-card{border-radius:12px;padding:16px;text-align:center;}
.pl-card-navy{background:#e8eaf8;}
.pl-card-green{background:#dcfce7;}
.pl-card-label{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;}
.pl-card-label.navy{color:#7880a4;}
.pl-card-label.green{color:#16a34a;}
.pl-card-val{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:800;}
.pl-card-val.navy{color:#1d2878;}
.pl-card-val.green{color:#16a34a;}

/* ══════════════════════════════════════
   §31 DAYBOOK PAGE
══════════════════════════════════════ */
.bg-soft{background:#F6F8FF;}
.period-select-wrap{background:#fff;border:1.5px solid #e2e6f0;border-radius:10px;padding:12px 14px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;margin:14px 14px 0;transition:border-color .18s;}
.period-select-wrap:hover{border-color:#1d2878;}
.period-select-val{font-size:15px;font-weight:600;color:#000;}
.period-select-chev{font-size:14px;color:#7880a4;}
.date-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px 14px 0;}
.date-pick-wrap{background:#fff;border:1.5px solid #e2e6f0;border-radius:10px;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:border-color .18s;}
.date-pick-wrap:focus-within{border-color:#1d2878;}
.date-pick-val{font-size:14px;font-weight:600;color:#000;border:none;outline:none;font-family:'Plus Jakarta Sans',sans-serif;background:transparent;width:100%;cursor:pointer;}
.date-pick-chev{font-size:13px;color:#7880a4;flex-shrink:0;}
.report-title-box{margin:14px 14px 0;border:2px solid #1d2878;border-radius:10px;padding:14px 16px;background:#fff;text-align:center;}
.rtb-title{font-size:16px;font-weight:800;color:#000;}
.rtb-range{font-size:15px;font-weight:600;color:#000;margin-top:3px;}
.period-dd-panel{display:none;background:#fff;border:1.5px solid #e2e6f0;border-radius:10px;margin:6px 14px 0;overflow:hidden;box-shadow:0 4px 16px rgba(29,40,120,.10);}
.period-dd-opt{padding:12px 16px;font-size:14px;font-weight:500;color:#000;border-bottom:1px solid #e2e6f0;cursor:pointer;transition:background .12s;}
.period-dd-opt:last-child{border-bottom:none;}
.period-dd-opt:hover{background:#F6F8FF;}
.period-dd-opt.active{color:#1d2878;font-weight:700;background:#e8eaf8;}
/* Daybook table */
.db-table{width:100%;border-collapse:collapse;}
.db-table thead tr{background:#3d3db5;}
.db-table thead th{color:#fff;font-size:13px;font-weight:700;padding:11px 12px;text-align:center;white-space:nowrap;}
.db-table thead th:last-child{text-align:right;}
.db-table thead th:nth-child(2){text-align:left;}
.db-table tbody tr{border-bottom:1px solid #e2e6f0;transition:background .12s;}
.db-table tbody tr:hover{background:#e8eaf8;}
.db-table tbody tr:nth-child(even){background:#F6F8FF;}
.db-table tbody tr:nth-child(even):hover{background:#e8eaf8;}
.db-table tbody td{padding:11px 12px;font-size:13.5px;color:#3a3f5c;text-align:center;vertical-align:middle;}
.db-table tbody td:nth-child(2){text-align:center;color:#000;font-weight:500;}
.db-table tbody td:last-child{text-align:right;font-weight:700;color:#000;}

/* ══════════════════════════════════════
   §32 AUTH PAGES (Login / Register / OTP)
══════════════════════════════════════ */
.auth-hero{background:linear-gradient(145deg,#1d2878 0%,#2d3ea0 60%,#3d4ec0 100%);padding:52px 28px 44px;position:relative;overflow:hidden;flex-shrink:0;}
.auth-hero.compact{padding:42px 28px 38px;}
.auth-hero.otp-hero{text-align:center;padding:48px 28px 50px;}
.auth-hero::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.06);pointer-events:none;}
.auth-hero::after{content:'';position:absolute;bottom:-40px;left:-40px;width:150px;height:150px;border-radius:50%;background:rgba(243,92,37,.12);pointer-events:none;}
.auth-logo-wrap{display:flex;align-items:center;gap:12px;margin-bottom:32px;position:relative;z-index:1;}
.auth-logo-wrap.compact{margin-bottom:24px;}
.auth-logo-icon{width:48px;height:48px;background:#fff;border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(0,0,0,.18);flex-shrink:0;}
.auth-logo-icon.sm{width:44px;height:44px;border-radius:13px;}
.auth-logo-icon svg{width:26px;height:26px;}
.auth-logo-name{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1;}
.auth-logo-name.sm{font-size:20px;}
.auth-logo-name span{color:#fb923c;}
.auth-logo-tagline{font-size:11.5px;font-weight:500;color:rgba(255,255,255,.6);margin-top:2px;}
.auth-logo-tagline.sm{font-size:11px;}
.auth-hero-title{font-family:'Bricolage Grotesque',sans-serif;font-size:28px;font-weight:800;color:#fff;line-height:1.15;letter-spacing:-.025em;position:relative;z-index:1;margin-bottom:8px;}
.auth-hero-title.sm{font-size:25px;}
.auth-hero-title span{color:#fb923c;}
.auth-hero-sub{font-size:13.5px;color:rgba(255,255,255,.62);position:relative;z-index:1;line-height:1.6;}
.auth-hero-sub.sm{font-size:13px;}
.auth-card{flex:1;background:#fff;border-radius:24px 24px 0 0;margin-top:-18px;padding:28px 24px 32px;position:relative;z-index:2;overflow-y:auto;}
.auth-card.compact{margin-top:-16px;padding:26px 24px 40px;}
.auth-card-title{font-family:'Bricolage Grotesque',sans-serif;font-size:20px;font-weight:800;color:#000;letter-spacing:-.02em;margin-bottom:4px;}
.auth-card-title.center{text-align:center;}
.auth-card-sub{font-size:13px;color:#7880a4;font-weight:400;margin-bottom:26px;}
.auth-card-sub.center{text-align:center;}

/* Auth fields */
.auth-field{margin-bottom:16px;}
.auth-field-label{font-size:12.5px;font-weight:700;color:#3a3f5c;margin-bottom:7px;display:block;letter-spacing:.01em;}
.auth-input-wrap{display:flex;align-items:center;border:1.5px solid #e2e6f0;border-radius:12px;overflow:hidden;background:#fff;transition:border-color .18s,box-shadow .18s;}
.auth-input-wrap:focus-within{border-color:#1d2878;box-shadow:0 0 0 3px rgba(29,40,120,.08);}
.auth-input-wrap.error{border-color:#dc2626;box-shadow:0 0 0 3px rgba(220,38,38,.08);}
.auth-input-icon{width:46px;display:flex;align-items:center;justify-content:center;font-size:17px;color:#7880a4;flex-shrink:0;background:#F6F8FF;align-self:stretch;border-right:1px solid #e2e6f0;}
.auth-input{flex:1;border:none;outline:none;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:500;color:#000;padding:13px 14px;background:transparent;width:100%;}
.auth-input::placeholder{color:#bbbfce;font-weight:400;}
.auth-eye-btn{width:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:17px;color:#7880a4;flex-shrink:0;background:none;border:none;align-self:stretch;transition:color .15s;}
.auth-eye-btn:hover{color:#1d2878;}
.phone-prefix{padding:0 12px;font-size:14px;font-weight:700;color:#1d2878;background:#F6F8FF;align-self:stretch;display:flex;align-items:center;border-right:1px solid #e2e6f0;white-space:nowrap;flex-shrink:0;}
.field-error{font-size:11.5px;color:#dc2626;font-weight:600;margin-top:5px;display:none;padding-left:2px;}

/* Password strength */
.pw-strength{margin-top:8px;}
.pw-strength-bar{height:4px;border-radius:4px;background:#e2e6f0;overflow:hidden;margin-bottom:4px;}
.pw-strength-fill{height:100%;border-radius:4px;width:0%;transition:all .3s;}
.pw-strength-label{font-size:11px;font-weight:700;}

/* Forgot / divider / switch */
.forgot-link{display:flex;justify-content:flex-end;margin:-4px 0 20px;}
.forgot-link a{font-size:12.5px;font-weight:700;color:#1d2878;text-decoration:none;cursor:pointer;}
.forgot-link a:hover{text-decoration:underline;}
.auth-divider{display:flex;align-items:center;gap:12px;margin:22px 0;}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:#e2e6f0;}
.auth-divider span{font-size:12px;color:#7880a4;font-weight:600;white-space:nowrap;}
.auth-switch{text-align:center;margin-top:24px;font-size:13px;color:#7880a4;font-weight:500;}
.auth-switch a{color:#1d2878;font-weight:700;text-decoration:none;cursor:pointer;}
.auth-switch a:hover{text-decoration:underline;}

/* Auth buttons */
.auth-btn{width:100%;background:#1d2878;color:#fff;border:none;border-radius:12px;padding:15px;font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 18px rgba(29,40,120,.28);display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.01em;}
.auth-btn:hover{background:#141f60;transform:translateY(-1px);box-shadow:0 6px 24px rgba(29,40,120,.38);}
.auth-btn:active{transform:scale(.98);}
.auth-btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none;}
.auth-btn.secondary{background:transparent;color:#1d2878;border:1.5px solid #cdd2eb;box-shadow:none;}
.auth-btn.secondary:hover{background:#e8eaf8;}
.max-w-280{max-width:280px;}
.btn-spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .75s linear infinite;display:none;}
@keyframes spin{to{transform:rotate(360deg);}}

/* Social login */
.social-btn{width:100%;background:#fff;border:1.5px solid #e2e6f0;border-radius:12px;padding:13px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:600;color:#3a3f5c;cursor:pointer;transition:all .18s;display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:12px;}
.social-btn:hover{border-color:#1d2878;color:#1d2878;background:#F6F8FF;}

/* Trust row */
.trust-row{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:24px;padding-top:20px;border-top:1px solid #e2e6f0;flex-wrap:wrap;}
.trust-item{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:#7880a4;}

/* Step bar (Register) */
.step-bar{display:flex;align-items:center;gap:0;margin-bottom:6px;}
.step-dot{width:28px;height:28px;border-radius:50%;background:#e2e6f0;border:2px solid #e2e6f0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#7880a4;flex-shrink:0;transition:all .25s;font-family:'Bricolage Grotesque',sans-serif;}
.step-dot.active{background:#1d2878;border-color:#1d2878;color:#fff;box-shadow:0 0 0 4px rgba(29,40,120,.12);}
.step-dot.done{background:#16a34a;border-color:#16a34a;color:#fff;}
.step-line{flex:1;height:2px;background:#e2e6f0;transition:background .25s;}
.step-line.done{background:#16a34a;}
.step-labels{display:flex;justify-content:space-between;margin-top:6px;margin-bottom:20px;}
.step-label-txt{font-size:10.5px;font-weight:600;color:#7880a4;text-align:center;transition:color .2s;}
.step-label-txt.active{color:#1d2878;}
.step-label-txt.done{color:#16a34a;}
.step-panel{display:none;}
.step-panel.active{display:block;}
.step-nav{display:flex;gap:10px;margin-top:6px;}
.step-nav .auth-btn{flex:1;}

/* Summary card (Register step 3) */
.summary-card{background:#F6F8FF;border:1.5px solid #e2e6f0;border-radius:14px;padding:16px;margin-bottom:18px;}
.summary-title{font-size:12px;font-weight:700;color:#7880a4;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;}
.summary-list{display:flex;flex-direction:column;gap:8px;}
.summary-item{display:flex;justify-content:space-between;}
.summary-key{font-size:13px;color:#7880a4;}
.summary-val{font-size:13px;font-weight:700;color:#000;}

/* Terms */
.terms-row{display:flex;align-items:flex-start;gap:10px;margin:16px 0;}
.terms-checkbox{width:20px;height:20px;border-radius:6px;border:2px solid #e2e6f0;appearance:none;cursor:pointer;transition:all .15s;flex-shrink:0;margin-top:1px;background:#fff;accent-color:#1d2878;}
.terms-checkbox:checked{background:#1d2878;border-color:#1d2878;}
.terms-text{font-size:12.5px;color:#7880a4;line-height:1.6;}
.terms-text a{color:#1d2878;font-weight:700;text-decoration:none;}

/* OTP */
.otp-shield{width:80px;height:80px;background:rgba(255,255,255,.14);border:2.5px solid rgba(255,255,255,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 20px;position:relative;z-index:1;backdrop-filter:blur(8px);animation:pulse-ring 2s ease infinite;}
@keyframes pulse-ring{0%{box-shadow:0 0 0 0 rgba(255,255,255,.25);}70%{box-shadow:0 0 0 14px rgba(255,255,255,0);}100%{box-shadow:0 0 0 0 rgba(255,255,255,0);}}
.otp-phone-tag{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:100px;padding:6px 16px;font-size:13px;font-weight:700;color:#fff;position:relative;z-index:1;margin-top:10px;}
.otp-boxes{display:flex;gap:12px;justify-content:center;margin-bottom:10px;}
.otp-box{width:52px;height:58px;border:2px solid #e2e6f0;border-radius:14px;background:#F6F8FF;text-align:center;font-family:'Bricolage Grotesque',sans-serif;font-size:26px;font-weight:800;color:#1d2878;outline:none;caret-color:#1d2878;transition:all .18s;-webkit-appearance:none;}
.otp-box:focus{border-color:#1d2878;background:#fff;box-shadow:0 0 0 4px rgba(29,40,120,.1);transform:scale(1.05);}
.otp-box.filled{border-color:#1d2878;background:#e8eaf8;}
.otp-box.error{border-color:#dc2626;background:#fee2e2;color:#dc2626;animation:shake .4s ease;}
@keyframes shake{0%,100%{transform:translateX(0);}20%{transform:translateX(-5px);}40%{transform:translateX(5px);}60%{transform:translateX(-4px);}80%{transform:translateX(4px);}}
.otp-box.success{border-color:#16a34a;background:#dcfce7;color:#16a34a;}
.otp-error{text-align:center;font-size:12.5px;font-weight:700;color:#dc2626;margin-top:8px;display:none;}
.otp-timer{text-align:center;font-size:13px;color:#7880a4;margin:18px 0 24px;line-height:1.6;}
.timer-value{font-weight:800;color:#1d2878;font-family:'Bricolage Grotesque',sans-serif;font-size:15px;}
.timer-expired{display:none;}
.resend-btn{background:none;border:none;font-family:'Plus Jakarta Sans',sans-serif;font-size:13.5px;font-weight:700;color:#1d2878;cursor:pointer;text-decoration:underline;padding:0;}
.change-link{display:flex;justify-content:center;margin-bottom:20px;}
.change-link a{font-size:13px;font-weight:700;color:#7880a4;text-decoration:none;display:flex;align-items:center;gap:5px;cursor:pointer;padding:7px 14px;border-radius:8px;transition:all .15s;}
.change-link a:hover{background:#F6F8FF;color:#1d2878;}
.security-note{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:#7880a4;margin-top:20px;padding:12px 16px;background:#F6F8FF;border-radius:10px;border:1px solid #e2e6f0;}
.demo-hint{background:#fffbeb;border:1.5px solid #fde68a;border-radius:10px;padding:10px 14px;font-size:12px;color:#92400e;text-align:center;margin-bottom:20px;font-weight:500;}
.success-overlay{display:none;position:fixed;inset:0;z-index:400;background:#fff;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px;}
.success-overlay.centered-fixed{left:50%;transform:translateX(-50%);max-width:420px;}
.success-overlay.show{display:flex;}
.success-icon-wrap{width:96px;height:96px;border-radius:50%;background:#dcfce7;border:3px solid #16a34a;display:flex;align-items:center;justify-content:center;font-size:44px;margin-bottom:24px;animation:popIn .4s cubic-bezier(.34,1.56,.64,1) both;}
@keyframes popIn{from{transform:scale(.5);opacity:0;}to{transform:scale(1);opacity:1;}}
.success-title{font-family:'Bricolage Grotesque',sans-serif;font-size:26px;font-weight:800;color:#000;margin-bottom:8px;letter-spacing:-.02em;}
.success-sub{font-size:14px;color:#7880a4;line-height:1.65;margin-bottom:32px;}

/* ══════════════════════════════════════
   §33 TOAST
══════════════════════════════════════ */
.toast-container{position:fixed;bottom:90px;left:50%;transform:translateX(-50%);z-index:9999;pointer-events:none;}
.toast{background:#1d2878;color:#fff;font-size:13px;font-weight:600;padding:11px 22px;border-radius:100px;box-shadow:0 6px 24px rgba(29,40,120,.35);opacity:0;transform:translateY(8px);transition:all .28s;white-space:nowrap;font-family:'Plus Jakarta Sans',sans-serif;}
.toast.show{opacity:1;transform:translateY(0);}

/* ══════════════════════════════════════
   §34 ANIMATIONS
══════════════════════════════════════ */
@keyframes slideUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
.slide-up{animation:slideUp .22s ease both;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.fade-in{animation:fadeIn .22s ease both;}

/* ══════════════════════════════════════
   §35 RESPONSIVE
══════════════════════════════════════ */
@media(max-width:480px){
  .auth-hero{padding:38px 22px 36px;}
  .auth-card{padding:22px 18px 32px;}
  .otp-boxes{gap:8px;}
  .otp-box{width:44px;height:52px;font-size:22px;}
}
