*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{font-family:var(--font-ui);color:var(--charcoal-800);background:linear-gradient(135deg,var(--ivory-50),var(--ivory-100));letter-spacing:0}.hidden{display:none!important}button,select,input{font:inherit}button{cursor:pointer}
.login-page{position:relative;min-height:100vh;display:grid;grid-template-columns:minmax(0,1fr) minmax(480px,35vw);overflow:hidden;background:var(--ivory-100);padding-top:0}.login-hero{position:absolute;inset:0;min-height:100vh;background:var(--ivory-100);display:flex}.login-hero>img{width:100%;height:100%;object-fit:cover;object-position:center}.login-hero:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,253,248,.02),rgba(255,253,248,.14) 54%,rgba(255,253,248,.1))}
.splash-brand{position:absolute;left:34px;bottom:34px;max-width:1500px;display:flex;flex-direction:column;gap:18px;z-index:2;text-transform:none}.splash-brand strong,.splash-brand span{display:block;font-family:"Cormorant Garamond","Playfair Display","Bodoni 72",Didot,Georgia,serif;font-size:230px;font-weight:500;line-height:.84;letter-spacing:.02em;color:#053436;white-space:nowrap;text-shadow:3px 4px 0 rgba(177,132,48,.55),0 6px 12px rgba(70,48,18,.22)}
.login-panel-area{position:relative;z-index:1;grid-column:2;width:auto;min-height:100vh;display:flex;align-items:end;justify-content:end;padding:0 38px 42px;background:transparent;border:0;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}.login-card{width:min(100%,440px);padding:28px 28px 30px;border:2px solid rgba(183,131,24,.82);border-radius:28px;background:transparent;box-shadow:none;text-align:center;backdrop-filter:none;-webkit-backdrop-filter:none}.login-badge-row{display:flex;align-items:center;justify-content:center;gap:28px;margin-bottom:10px}.login-badge-row span{width:88px;height:2px;background:linear-gradient(90deg,transparent,var(--gold-700),transparent)}.login-badge{width:84px;height:84px;filter:drop-shadow(0 14px 28px rgba(17,22,18,.2))}.login-card h1{font-family:var(--font-display);font-size:42px;line-height:1;margin:8px 0 8px;color:var(--charcoal-800);text-shadow:0 2px 24px rgba(255,253,248,.78)}.login-card p{color:var(--teal-700);font-size:18px;margin:0 0 22px;font-weight:900;text-shadow:0 1px 18px rgba(255,253,248,.78)}.field{height:60px;display:flex;align-items:center;gap:17px;border:1px solid rgba(255,253,248,.48);border-radius:16px;background:rgba(255,255,255,.14);margin:12px 0;padding:0 20px;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}.field img{width:24px;height:24px}.field-right{margin-left:auto}.field input,.field select{min-width:0;border:0;outline:0;flex:1;font-size:18px;color:var(--charcoal-800);background:transparent;font-weight:900}.login-options{display:flex;justify-content:space-between;align-items:center;gap:14px;margin:18px 4px}.login-options span{display:flex;align-items:center;gap:9px;color:var(--charcoal-700);font-weight:900;font-size:15px;text-shadow:0 1px 16px rgba(255,253,248,.82)}.login-options img{width:22px;height:22px}.sign-in-button{height:60px;width:100%;border:1px solid rgba(255,253,248,.5);border-radius:16px;background:rgba(255,255,255,.08);color:var(--teal-700);font-family:var(--font-display);font-size:30px;font-weight:900;box-shadow:none;display:flex;align-items:center;justify-content:center;gap:54px;backdrop-filter:none;-webkit-backdrop-filter:none;text-shadow:0 1px 16px rgba(255,253,248,.88)}.sign-in-button img{width:30px}
.app{min-height:100vh;display:grid;grid-template-columns:278px minmax(0,1fr)}.sidebar{background:#111612;color:white;padding:26px 18px;display:flex;flex-direction:column;gap:6px}.brand{display:flex;align-items:center;gap:12px;padding:0 8px 20px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:14px}.brand img{width:48px}.brand strong{display:block;color:var(--gold-300);font-family:var(--font-display);font-size:24px}.brand span{font-size:12px;color:#c8bea7}.nav{display:flex;align-items:center;gap:12px;background:transparent;border:0;color:#d8d1c1;text-align:left;padding:12px;border-radius:8px;font-weight:700}.nav img{width:32px;height:32px}.nav.active,.nav:hover{background:rgba(183,131,24,.18);color:white}.side-user{margin-top:auto;background:rgba(255,255,255,.06);border-radius:8px;padding:16px}.side-user span{display:block;color:#c8bea7;font-size:12px}
.main{position:relative;min-width:0;padding:34px;background:radial-gradient(circle at 85% 0,rgba(215,170,66,.12),transparent 30%),var(--ivory-100);overflow:hidden}.corner-art{position:absolute;top:0;right:0;width:min(430px,34vw);height:250px;background:url("assets/images/visista-ruby-corner.png") top right/contain no-repeat;opacity:.96;overflow:hidden;pointer-events:none;-webkit-mask-image:linear-gradient(to left,#000 0 84%,transparent 100%),linear-gradient(to top,#000 0 78%,transparent 100%);-webkit-mask-composite:source-in;mask-image:linear-gradient(to left,#000 0 84%,transparent 100%),linear-gradient(to top,#000 0 78%,transparent 100%);mask-composite:intersect}.topbar{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:flex-start;gap:22px;margin-bottom:24px;padding-right:0}.topbar h1{font-family:var(--font-display);font-size:42px;color:var(--charcoal-800);margin:0}.topbar p{color:var(--teal-700);margin:6px 0}.top-actions{position:relative;top:auto;right:auto;display:flex;align-items:center;margin-top:4px}.icon-button,.logout,.gold-btn,.ghost-btn{display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(183,131,24,.18);background:rgba(255,253,248,.78);color:var(--teal-700);padding:10px 14px;border-radius:8px;font-weight:800;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.icon-button,.logout{width:40px;height:40px;padding:0}.icon-button img,.logout img{width:21px;height:21px}.gold-btn{background:linear-gradient(135deg,var(--gold-500),var(--gold-700));color:white;border:0}.ghost-btn{background:transparent}.full{width:100%;margin-top:14px}.page{display:none;position:relative;z-index:1}.page.active{display:block}
.control-strip{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:rgba(255,253,248,.9);border:1px solid rgba(183,131,24,.22);border-radius:8px;padding:12px;margin-bottom:18px;box-shadow:var(--shadow-card)}.control-strip label{display:flex;align-items:center;gap:8px;color:var(--muted-700);font-weight:800}.control-strip select{border:1px solid var(--line-gold);border-radius:8px;background:white;color:var(--charcoal-800);padding:8px 10px}
.kpis{display:grid;gap:16px;margin-bottom:18px}.kpis.five{grid-template-columns:repeat(5,minmax(0,1fr))}.kpis.four{grid-template-columns:repeat(4,minmax(0,1fr))}.kpi,.card{background:rgba(255,253,248,.92);border:1px solid rgba(183,131,24,.22);border-radius:8px;box-shadow:var(--shadow-card)}.kpi{padding:18px;min-width:0}.kpi span{display:block;color:var(--muted-700);font-size:13px}.kpi b{display:block;color:var(--teal-700);font:700 30px var(--font-display);margin:8px 0;white-space:nowrap}.kpi em{font-style:normal;color:var(--ruby-700);font-weight:800;font-size:12px}.kpi.warn b,.kpi.warn em{color:var(--red-700)}
.grid{display:grid;gap:18px;margin-top:18px}.grid.two{grid-template-columns:minmax(0,1.25fr) minmax(0,1fr)}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.pos-grid{grid-template-columns:minmax(0,1.6fr) minmax(280px,.7fr)}.card{padding:22px;min-width:0;overflow:auto}.card h3{margin:0 0 14px;color:var(--teal-700);font-size:21px}.section-title{display:flex;justify-content:space-between;align-items:center;gap:12px}.section-title span{color:var(--muted-700);font-weight:800}canvas{width:100%;height:240px}.list p{display:flex;justify-content:space-between;gap:16px;border-bottom:1px solid var(--line-soft);padding:11px 0;margin:0}.donut{width:170px;height:170px;border-radius:50%;margin:8px auto 16px;background:conic-gradient(var(--teal-700) 0 56%,var(--gold-700) 56% 78%,#5e8b83 78% 88%,#d8c299 88%);display:grid;place-items:center}.donut span{width:92px;height:92px;border-radius:50%;background:var(--ivory-50);display:grid;place-items:center;color:var(--teal-700);font-weight:900}.muted{color:var(--muted-700)}.chip{padding:12px 14px;background:#f6efd9;border-left:3px solid var(--gold-700);border-radius:8px;margin:9px 0;color:var(--teal-700);font-weight:800}
.bill-header{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;background:#f6efd9;border-radius:8px;padding:14px;margin-bottom:14px}table{width:100%;border-collapse:collapse;min-width:620px}th{background:var(--teal-700);color:white;text-align:left;padding:11px}td{padding:12px;border-bottom:1px solid var(--line-soft)}.bill-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.bill-total{margin:18px 0 0 auto;max-width:330px;background:#f6efd9;border-radius:8px;padding:15px;display:flex;justify-content:space-between;gap:16px}.bill-total b{font-size:24px;color:var(--gold-800)}.profile{text-align:center}.avatar{width:80px;height:80px;border-radius:50%;background:var(--teal-700);color:var(--gold-300);display:grid;place-items:center;font:700 30px var(--font-display);margin:auto}.stat{display:flex;justify-content:space-between;gap:16px;border-top:1px solid var(--line-soft);padding:13px}.bar{height:12px;background:#eee4c8;border-radius:999px;overflow:hidden}.bar i{display:block;height:100%;background:var(--teal-700)}.tabs{display:flex;gap:10px;margin-bottom:18px;overflow:auto}.tabs button,.report-grid button{background:white;border:1px solid var(--line-gold);border-radius:8px;padding:10px 16px;color:var(--teal-700);font-weight:800;white-space:nowrap}.tabs button.active{background:var(--teal-700);color:white}.report-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.report-grid button{padding:18px}.pill{display:inline-flex;align-items:center;min-height:26px;padding:4px 9px;border-radius:999px;font-weight:900;font-size:12px}.pill.ok{background:#e6f4ea;color:var(--ruby-700)}.pill.warn{background:#fff0cf;color:var(--gold-900)}.pill.danger{background:#f6dfdc;color:var(--red-700)}
.pos-shell{display:grid;grid-template-columns:minmax(0,2fr) minmax(330px,.72fr);gap:18px}.pos-workspace,.customer-panel{background:rgba(255,253,248,.92);border:1px solid rgba(183,131,24,.22);border-radius:8px;box-shadow:var(--shadow-card);overflow:hidden}.pos-controlbar{display:grid;grid-template-columns:1.05fr 1.25fr 1.45fr;border-bottom:1px solid var(--line-soft)}.pos-control{min-height:116px;display:flex;align-items:center;gap:14px;padding:22px 24px;border-right:1px solid var(--line-soft)}.pos-control:last-child{border-right:0}.pos-icon,.rate-icon{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;border:1px solid rgba(183,131,24,.25);background:rgba(255,253,248,.78);box-shadow:0 10px 22px rgba(55,37,8,.08)}.pos-icon img{width:30px}.rate-icon{background:linear-gradient(135deg,var(--gold-500),var(--gold-900));color:white;font:700 24px var(--font-display)}.pos-control label{display:grid;gap:8px;flex:1;color:#2f4050;font-weight:900}.pos-control select,.barcode-control input{height:50px;border:1px solid rgba(29,27,22,.14);border-radius:8px;background:white;color:var(--charcoal-800);padding:0 14px;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}.rate-control b{font-size:24px;color:var(--charcoal-800)}.rate-control small{font-size:12px;color:var(--muted-700)}.rate-control em{font-style:normal;color:var(--ruby-700);font-size:16px;margin-left:10px}.barcode-control span{display:flex;align-items:center;gap:10px}.barcode-control input{min-width:0;flex:1}.barcode-control img{width:26px;height:26px}.pos-bill-card{display:grid;grid-template-columns:300px minmax(0,1fr);min-height:430px}.product-panel{padding:24px;border-right:1px solid var(--line-soft)}.product-photo{height:220px;border-radius:8px;overflow:hidden;background:#4A0614;margin-bottom:18px}.product-photo img{width:100%;height:100%;object-fit:cover;object-position:right top}.product-panel h3{margin:0 0 18px;font-size:20px;color:var(--charcoal-800)}.product-panel dl{display:grid;grid-template-columns:1fr;gap:5px;margin:0}.product-panel dt{color:#56616c;font-size:14px;font-weight:900}.product-panel dd{margin:0 0 7px;color:#2f4050;font-weight:800}.hallmark{display:inline-flex;margin-top:12px;padding:10px 12px;border-radius:6px;background:#e9f3e7;color:var(--ruby-700);font-weight:900}.bill-panel{min-width:0}.bill-panel-title{height:64px;display:flex;align-items:center;padding:0 24px;border-bottom:1px solid var(--line-soft)}.bill-panel-title h3{margin:0;font-size:18px;color:var(--charcoal-800)}.pos-table{min-width:720px}.pos-table th{background:#fafafa;color:#4d5965;font-size:13px;text-align:right;border-bottom:1px solid var(--line-soft)}.pos-table th:nth-child(1),.pos-table th:nth-child(2){text-align:left}.pos-table td{text-align:right;color:#2f4050}.pos-table td:nth-child(1),.pos-table td:nth-child(2){text-align:left}.bill-summary-row{display:grid;grid-template-columns:1fr 1.05fr;border-top:1px solid var(--line-soft)}.weight-summary,.amount-summary{padding:24px 28px}.weight-summary{border-right:1px solid var(--line-soft)}.weight-summary p,.amount-summary p{display:flex;justify-content:space-between;gap:16px;margin:0 0 16px;color:#3c4856}.weight-summary b,.amount-summary b{font-weight:900}.final-total{display:flex;justify-content:space-between;align-items:end;gap:16px;border-top:1px solid rgba(183,131,24,.28);padding-top:18px;margin-top:10px}.final-total span{font:700 22px var(--font-display)}.final-total b{font:700 34px var(--font-display);color:var(--gold-900)}.pos-actions{display:grid;grid-template-columns:150px 150px 160px minmax(220px,1fr);gap:14px;padding:14px 24px 20px}.pos-actions button{height:50px}.generate-btn{justify-self:end;min-width:300px}.generate-btn img{width:24px}.customer-panel{padding:26px}.customer-hero{display:flex;align-items:center;gap:18px;padding-bottom:18px}.customer-hero .avatar{margin:0;width:74px;height:74px;border:2px solid var(--gold-700)}.customer-hero h3{font:700 30px var(--font-display);margin:0 0 8px}.member-pill{display:inline-flex;border:1px solid rgba(183,131,24,.32);border-radius:8px;padding:7px 12px;color:var(--gold-900);background:#fff8e8;font-weight:900}.contact-list{border-bottom:1px solid var(--line-soft);padding:8px 0 18px}.contact-list p{margin:12px 0;color:#3c4856;font-weight:800}.profile-section-title{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:20px 0 12px}.profile-section-title h3{margin:0;color:#2f4050}.profile-section-title button{border:0;background:transparent;color:var(--teal-700);font-weight:900}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.summary-grid div{border:1px solid rgba(183,131,24,.22);border-radius:8px;padding:18px 10px;text-align:center;background:rgba(255,253,248,.72)}.summary-grid span{display:block;color:#5b6470;font-weight:800;font-size:13px}.summary-grid b{display:block;margin-top:8px;font:700 22px var(--font-display);color:var(--charcoal-800)}.scheme-box{border:1px solid rgba(183,131,24,.25);border-radius:8px;background:#fff8e8;padding:18px 22px}.scheme-box span{display:block;color:#5b6470;font-weight:900}.scheme-box b{display:block;margin-top:6px;font-size:26px;color:var(--charcoal-800)}.scheme-box small{font-size:13px;color:#5b6470}
/* POS workstation alignment pass */
#pos .pos-shell{align-items:start;gap:14px;margin-top:8px}
#pos .pos-workspace,#pos .customer-panel{border-color:rgba(183,131,24,.2)}
#pos .pos-controlbar{grid-template-columns:minmax(0,.95fr) minmax(0,1.1fr) minmax(0,1.35fr)}
#pos .pos-control{min-width:0;min-height:92px;padding:16px 18px}
#pos .pos-control label{min-width:0}
#pos .pos-icon,#pos .rate-icon{width:46px;height:46px;flex:0 0 46px}
#pos .pos-icon img{width:26px}
#pos .rate-control b{font-size:19px}
#pos .pos-control select,#pos .barcode-control input{height:44px}
#pos .pos-bill-card{grid-template-columns:250px minmax(0,1fr);min-height:0}
#pos .product-panel{padding:18px;background:rgba(255,253,248,.72);color:var(--teal-700)}
#pos .product-photo{height:156px;margin-bottom:13px}
#pos .product-panel h3{font-size:17px;margin-bottom:11px;color:var(--teal-700)}
#pos .product-panel dt{font-size:12px;color:var(--teal-800)}
#pos .product-panel dd{font-size:13px;margin-bottom:4px;color:var(--teal-700)}
#pos .hallmark{padding:8px 10px;font-size:13px}
#pos .bill-panel-title{height:52px;padding:0 18px}
#pos .bill-panel-title h3{font-size:16px}
#pos .pos-table{min-width:620px}
#pos .pos-table th,#pos .pos-table td{padding:8px 9px;font-size:12px}
#pos .bill-summary-row{grid-template-columns:.9fr 1.1fr}
#pos .weight-summary,#pos .amount-summary{padding:14px 16px}
#pos .weight-summary p,#pos .amount-summary p{margin-bottom:9px;font-size:13px}
#pos .final-total{padding-top:14px}
#pos .final-total span{font-size:17px}
#pos .final-total b{font-size:27px}
#pos .pos-actions{grid-template-columns:130px 130px 150px minmax(190px,1fr);gap:10px;padding:12px 18px 16px}
#pos .pos-actions button{height:44px;font-size:13px}
#pos .generate-btn{min-width:240px}
#pos .customer-panel{padding:20px}
#pos .customer-hero{padding-bottom:14px}
#pos .customer-hero .avatar{width:62px;height:62px;font-size:25px}
#pos .customer-hero h3{font-size:23px}
#pos .contact-list{padding-bottom:12px}
#pos .contact-list p{margin:9px 0}
#pos .profile-section-title{margin:16px 0 10px}
#pos .summary-grid{gap:10px}
#pos .summary-grid div{padding:14px 8px}
#pos .summary-grid b{font-size:18px}
#pos .scheme-box{padding:15px 18px}
#pos .scheme-box b{font-size:20px}

/* 100% zoom density pass */
.app{grid-template-columns:236px minmax(0,1fr)}
.sidebar{padding:22px 14px}
.brand img{width:42px}.brand strong{font-size:21px}.nav{padding:10px;font-size:14px}.nav img{width:28px;height:28px}
.main{padding:24px}
.topbar{margin-bottom:18px}
.topbar h1{font-size:34px}.topbar p{font-size:14px}
#pos .pos-shell{grid-template-columns:minmax(0,1fr) 300px;gap:12px}
#pos .pos-controlbar{grid-template-columns:minmax(0,1fr) minmax(0,1.05fr) minmax(0,1.4fr)}
#pos .pos-control{min-height:78px;padding:12px 14px;gap:10px}
#pos .pos-icon,#pos .rate-icon{width:38px;height:38px;flex-basis:38px}
#pos .pos-icon img{width:22px}.rate-icon{font-size:20px}
#pos .pos-control label{font-size:13px;gap:5px}
#pos .pos-control select,#pos .barcode-control input{height:38px;font-size:13px}
#pos .rate-control b{font-size:17px}.rate-control em{font-size:13px}.rate-control small{font-size:11px}
#pos .pos-bill-card{grid-template-columns:210px minmax(0,1fr)}
#pos .product-panel{padding:14px}
#pos .product-photo{height:128px;margin-bottom:10px}
#pos .product-panel h3{font-size:15px;margin-bottom:8px}
#pos .product-panel dt{font-size:11px}.product-panel dd{font-size:12px}
#pos .hallmark{font-size:11px;padding:7px 9px}
#pos .bill-panel-title{height:42px;padding:0 14px}
#pos .bill-panel-title h3{font-size:14px}
#pos .pos-table{min-width:560px}
#pos .pos-table th,#pos .pos-table td{padding:7px 8px;font-size:11px}
#pos .weight-summary,#pos .amount-summary{padding:12px 14px}
#pos .weight-summary p,#pos .amount-summary p{font-size:12px;margin-bottom:7px}
#pos .final-total{padding-top:10px}
#pos .final-total span{font-size:15px}.final-total b{font-size:24px}
#pos .pos-actions{grid-template-columns:116px 116px 128px minmax(180px,1fr);padding:10px 14px 14px}
#pos .pos-actions button{height:40px;font-size:12px}
#pos .generate-btn{min-width:210px}
#pos .customer-panel{padding:16px}
#pos .customer-hero .avatar{width:54px;height:54px;font-size:22px}
#pos .customer-hero h3{font-size:21px}.member-pill{font-size:12px;padding:6px 10px}
#pos .contact-list p{font-size:13px;margin:7px 0}
#pos .profile-section-title h3{font-size:16px}.profile-section-title button{font-size:12px}
#pos .summary-grid{gap:8px}
#pos .summary-grid div{padding:12px 6px}
#pos .summary-grid span{font-size:11px}.summary-grid b{font-size:16px}
#pos .scheme-box{padding:12px 14px}.scheme-box b{font-size:18px}

/* Unified app shell: ivory workspace with ruby navigation */
.app{background:var(--ivory-100)}
.sidebar{background:linear-gradient(180deg,rgba(255,253,248,.96),rgba(250,247,237,.96));color:var(--teal-700);border-right:1px solid rgba(183,131,24,.22);box-shadow:8px 0 30px rgba(55,37,8,.06)}
.brand{border-bottom:1px solid rgba(183,131,24,.2);padding-bottom:18px}
.brand strong{color:var(--teal-700)}
.brand span{color:var(--gold-900);font-weight:800}
.nav{color:var(--teal-700);background:transparent;border:1px solid transparent}
.nav.active,.nav:hover{background:rgba(183,131,24,.12);border-color:rgba(183,131,24,.32);color:var(--teal-800);box-shadow:0 8px 18px rgba(55,37,8,.07)}
.side-user{background:rgba(255,253,248,.78);border:1px solid rgba(183,131,24,.22);color:var(--teal-700)}
.side-user span{color:var(--gold-900);font-weight:800}
.main{background:radial-gradient(circle at 88% 0,rgba(215,170,66,.1),transparent 26%),var(--ivory-100)}
.page{padding-top:0}
.control-strip,.kpi,.card,.pos-workspace,.customer-panel{background:rgba(255,253,248,.88)}
.sidebar{overflow-y:auto}
.module-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px}
.module-card{background:rgba(255,253,248,.88);border:1px solid rgba(183,131,24,.22);border-radius:8px;box-shadow:var(--shadow-card);padding:16px}
.module-card span{display:block;color:var(--muted-700);font-size:12px;font-weight:900}
.module-card b{display:block;color:var(--teal-700);font:700 26px var(--font-display);margin:7px 0}
.module-card em{font-style:normal;color:var(--ruby-700);font-size:12px;font-weight:900}
.module-list p{display:flex;justify-content:space-between;gap:16px;border-bottom:1px solid var(--line-soft);padding:10px 0;margin:0;color:var(--charcoal-700);font-weight:800}
.module-list p b{color:var(--teal-700)}

/* Desktop-only application contract */
html,body{min-width:1280px;overflow-x:auto}
.app{min-width:1280px;grid-template-columns:236px minmax(1044px,1fr)}
.sidebar{position:relative!important;display:flex!important;flex-direction:column!important;grid-template-columns:none!important;min-height:100vh;border-right:1px solid rgba(183,131,24,.22)!important;border-bottom:0!important;box-shadow:8px 0 30px rgba(55,37,8,.06)!important}
.brand,.side-user{grid-column:auto!important}
.main{min-width:0}
#pos .pos-shell{grid-template-columns:minmax(0,1fr) 300px!important}
#pos .pos-controlbar{grid-template-columns:minmax(0,1fr) minmax(0,1.05fr) minmax(0,1.4fr)!important}
#pos .pos-bill-card{grid-template-columns:210px minmax(0,1fr)!important}
#pos .bill-summary-row{grid-template-columns:.9fr 1.1fr!important}
#pos .pos-actions{grid-template-columns:116px 116px 128px minmax(180px,1fr)!important}
.login-page{grid-template-columns:minmax(0,1fr) 500px!important}

/* PDF reference pass for authenticated ERP pages */
.app{
  font-family:var(--font-ui);
  color:#273331;
  background:var(--ivory-100);
}
.app .main{
  padding:24px 28px 30px;
  background:
    radial-gradient(circle at 90% -4%,rgba(215,170,66,.10),transparent 27%),
    repeating-linear-gradient(135deg,rgba(183,131,24,.026) 0 1px,transparent 1px 18px),
    var(--ivory-100)!important;
}
.app .topbar{
  align-items:center;
  margin-bottom:20px;
}
.app .topbar h1{
  font-family:var(--font-display);
  font-size:38px!important;
  line-height:1.02;
  font-weight:700;
  color:var(--charcoal-800);
}
.app .topbar p{
  margin-top:7px;
  color:var(--teal-700);
  font-size:14px;
  font-weight:700;
}
.app .topbar:after{
  content:"";
  position:absolute;
  left:0;
  bottom:-10px;
  width:56px;
  height:2px;
  background:var(--gold-700);
}
.app .corner-art{
  width:min(390px,30vw);
  height:224px;
  opacity:.95;
}
.app .sidebar{
  background:
    linear-gradient(180deg,rgba(255,253,248,.96),rgba(250,247,237,.97)),
    repeating-linear-gradient(135deg,rgba(183,131,24,.035) 0 1px,transparent 1px 18px)!important;
}
.app .brand{
  gap:10px;
  margin-bottom:12px;
}
.app .brand img{
  width:42px;
  height:42px;
}
.app .brand strong{
  font-family:var(--font-display);
  font-size:23px;
  line-height:1;
  color:var(--teal-800);
}
.app .brand span{
  color:var(--gold-900);
  font-size:11px;
  font-weight:700;
}
.app .nav{
  min-height:40px;
  padding:8px 10px;
  gap:10px;
  border-radius:8px;
  color:var(--teal-800);
  font-size:13px;
  font-weight:700;
}
.app .nav img{
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--teal-800);
  border:1px solid var(--gold-700);
  padding:5px;
}
.app .nav.active,.app .nav:hover{
  background:rgba(255,253,248,.78);
  border-color:rgba(183,131,24,.36);
  box-shadow:0 8px 18px rgba(55,37,8,.07);
}
.app .side-user{
  border-color:rgba(183,131,24,.26);
  background:rgba(255,253,248,.76);
  border-radius:8px;
  padding:13px 14px;
}
.app .control-strip,.app .kpi,.app .card,.app .module-card,.app .pos-workspace,.app .customer-panel{
  background:rgba(255,253,248,.91)!important;
  border:1px solid rgba(183,131,24,.28)!important;
  border-radius:8px!important;
  box-shadow:0 10px 26px rgba(55,37,8,.075)!important;
}
.app .control-strip{
  padding:10px 12px;
  margin-bottom:16px;
}
.app .control-strip label,.app .control-strip select,.app .control-strip button{
  font-size:13px;
}
.app .kpis{
  gap:14px;
  margin-bottom:16px;
}
.app .kpi{
  padding:15px 16px;
}
.app .kpi span,.app .module-card span{
  color:var(--muted-700);
  font-size:11px;
  font-weight:700;
  letter-spacing:0;
  text-transform:none;
}
.app .kpi b,.app .module-card b{
  color:var(--teal-700);
  font-family:var(--font-display);
  font-weight:700;
}
.app .kpi b{
  font-size:28px;
  margin:6px 0;
}
.app .kpi em,.app .module-card em{
  font-size:11px;
  font-weight:700;
}
.app .grid{
  gap:16px;
  margin-top:16px;
}
.app .card{
  padding:18px 20px;
}
.app .card h3,.app .profile-section-title h3,.app .bill-panel-title h3{
  font-family:var(--font-display);
  color:var(--charcoal-800);
  font-weight:700;
  letter-spacing:0;
}
.app .card h3{
  font-size:20px;
  margin-bottom:13px;
}
.app .card h3:after,.app .profile-section-title h3:after,.app .bill-panel-title h3:after{
  content:"";
  display:block;
  width:42px;
  height:2px;
  margin-top:7px;
  background:var(--gold-700);
}
.app table{
  font-size:13px;
}
.app th{
  background:rgba(255,253,248,.88);
  color:#43515d;
  border-bottom:1px solid rgba(183,131,24,.22);
  font-size:12px;
  font-weight:700;
}
.app td{
  color:#34403d;
}
.app .gold-btn,.app .generate-btn,.app .tabs button.active{
  background:linear-gradient(135deg,var(--teal-700),var(--teal-900))!important;
  color:var(--ivory-50)!important;
  border:1px solid rgba(183,131,24,.52)!important;
  box-shadow:0 11px 22px rgba(0,81,76,.16)!important;
}
.app .gold-btn img,.app .generate-btn img{
  filter:brightness(0) invert(1);
}
.app .ghost-btn,.app .logout,.app .tabs button,.app .report-grid button{
  border-color:rgba(183,131,24,.30);
  color:var(--teal-700);
  background:rgba(255,253,248,.72);
}
.app .chip{
  background:rgba(255,248,232,.84);
  border-left-color:var(--gold-700);
  color:var(--teal-700);
  font-size:13px;
}
.app .module-grid{
  gap:14px;
}
.app .module-card{
  padding:15px 16px;
}
.app .module-card b{
  font-size:25px;
}
.app .module-list p{
  font-size:13px;
  font-weight:700;
}
#pos .pos-control{
  background:rgba(255,253,248,.64);
}
#pos .pos-icon,#pos .rate-icon,.app .avatar{
  border-radius:50%;
  border:2px solid var(--gold-700)!important;
}
#pos .rate-icon,.app .avatar{
  background:var(--teal-800)!important;
  color:var(--gold-300)!important;
}
#pos .pos-icon{
  background:rgba(255,253,248,.85)!important;
}
#pos .pos-control label,#pos .product-panel dt,#pos .summary-grid span,#pos .scheme-box span{
  color:#4f5b62;
  font-weight:700;
}
#pos .pos-control select,#pos .barcode-control input{
  border-color:rgba(183,131,24,.25);
}
#pos .product-panel{
  background:rgba(255,253,248,.86)!important;
}
#pos .product-panel h3{
  font-family:var(--font-display);
  color:var(--charcoal-800)!important;
  font-size:16px;
}
#pos .product-panel dd{
  color:var(--teal-800)!important;
  font-weight:700;
}
#pos .bill-panel-title h3{
  font-size:16px;
}
#pos .pos-table th,#pos .pos-table td{
  font-size:11px;
}
#pos .final-total span,#pos .final-total b,.app .summary-grid b,.app .scheme-box b{
  font-family:var(--font-display);
}
#pos .final-total b{
  color:var(--gold-900);
}
#pos .member-pill,#pos .scheme-box,#pos .summary-grid div{
  background:rgba(255,248,232,.72);
  border-color:rgba(183,131,24,.28);
}

/* PDF-style interior icon medallions and weight tuning */
.app .control-strip label,
.app .nav,
.app .side-user,
.app .module-list p,
.app .list p,
.app .chip,
.app .ghost-btn,
.app .gold-btn,
.app .generate-btn,
.app .tabs button,
.app .report-grid button,
.app .profile-section-title button,
#pos .contact-list p,
#pos .product-panel dd,
#pos .weight-summary b,
#pos .amount-summary b,
#pos .pos-control label{
  font-weight:700!important;
}
.app .kpi em,
.app .module-card em,
.app .pill,
#pos .hallmark,
#pos .member-pill{
  font-weight:700!important;
}
.app .kpi,
.app .module-card,
.app .summary-grid div,
.app .scheme-box{
  position:relative;
}
.app .kpi{
  min-height:118px;
  padding:15px 58px 15px 16px;
}
.app .kpi:before,
.app .module-card:before,
.app .summary-grid div:before,
.app .scheme-box:before,
.app .card h3:before,
.app .profile-section-title h3:before,
.app .bill-panel-title h3:before{
  content:"";
  width:34px;
  height:34px;
  border-radius:50%;
  border:2px solid var(--gold-700);
  background-color:var(--teal-800);
  background-image:url("assets/icons/svg/diamond.svg");
  background-position:center;
  background-repeat:no-repeat;
  background-size:20px 20px;
  box-shadow:0 8px 18px rgba(55,37,8,.10);
}
.app .kpi:before{
  position:absolute;
  top:14px;
  right:14px;
}
.app .kpis .kpi:nth-child(1):before{background-image:url("assets/icons/svg/pos.svg")}
.app .kpis .kpi:nth-child(2):before{background-image:url("assets/icons/svg/reports.svg")}
.app .kpis .kpi:nth-child(3):before{background-image:url("assets/icons/svg/dashboard.svg")}
.app .kpis .kpi:nth-child(4):before{background-image:url("assets/icons/svg/inventory.svg")}
.app .kpis .kpi:nth-child(5):before{background-image:url("assets/icons/svg/check.svg")}
.app .module-card{
  min-height:112px;
  padding:15px 14px 15px 62px;
}
.app .module-card:before{
  position:absolute;
  left:15px;
  top:18px;
}
.app .module-grid .module-card:nth-child(1):before{background-image:url("assets/icons/svg/dashboard.svg")}
.app .module-grid .module-card:nth-child(2):before{background-image:url("assets/icons/svg/check.svg")}
.app .module-grid .module-card:nth-child(3):before{background-image:url("assets/icons/svg/inventory.svg")}
.app .module-grid .module-card:nth-child(4):before{background-image:url("assets/icons/svg/reports.svg")}
.app .card h3,
.app .profile-section-title h3,
.app .bill-panel-title h3{
  display:block;
  position:relative;
  padding:2px 0 8px 40px;
}
.app .card h3:before,
.app .profile-section-title h3:before,
.app .bill-panel-title h3:before{
  position:absolute;
  left:0;
  top:50%;
  transform:translateY(-58%);
  width:30px;
  height:30px;
  background-size:17px 17px;
}
.app .grid .card:nth-child(1) h3:before{background-image:url("assets/icons/svg/reports.svg")}
.app .grid .card:nth-child(2) h3:before{background-image:url("assets/icons/svg/dashboard.svg")}
.app .grid .card:nth-child(3) h3:before{background-image:url("assets/icons/svg/check.svg")}
.app .card h3:after,
.app .profile-section-title h3:after,
.app .bill-panel-title h3:after{
  position:absolute;
  left:40px;
  bottom:0;
  margin:0;
}
.app .profile-section-title h3{
  white-space:nowrap;
  font-size:15px!important;
}
.app .profile-section-title button{
  white-space:nowrap;
}
.app .profile-section-title h3:before{
  width:28px;
  height:28px;
  background-size:16px 16px;
}
.app .summary-grid div{
  padding-top:46px!important;
}
.app .summary-grid div:before{
  position:absolute;
  top:10px;
  left:50%;
  transform:translateX(-50%);
  width:28px;
  height:28px;
  background-size:16px 16px;
}
.app .summary-grid div:nth-child(1):before{background-image:url("assets/icons/svg/pos.svg")}
.app .summary-grid div:nth-child(2):before{background-image:url("assets/icons/svg/dashboard.svg")}
.app .summary-grid div:nth-child(3):before{background-image:url("assets/icons/svg/diamond.svg")}
.app .scheme-box{
  padding-left:62px!important;
}
.app .scheme-box:before{
  position:absolute;
  top:16px;
  left:16px;
  background-image:url("assets/icons/svg/inventory.svg");
}
#pos .product-panel dt,
#pos .summary-grid span,
#pos .scheme-box span,
.app .kpi span,
.app .module-card span{
  font-weight:700!important;
}
#pos .final-total b{
  font-weight:700!important;
}

/* PDF luminosity: warmer canvas, brighter cards, soft serif glow */
.app .main{
  background:
    radial-gradient(circle at 82% 6%,rgba(255,255,255,.72) 0 17%,rgba(255,253,248,.28) 34%,transparent 56%),
    radial-gradient(circle at 18% 16%,rgba(255,255,255,.64) 0 14%,rgba(255,253,248,.18) 34%,transparent 58%),
    linear-gradient(135deg,#fffdf8 0%,#fbf7ec 48%,#fffaf0 100%),
    repeating-linear-gradient(135deg,rgba(183,131,24,.022) 0 1px,transparent 1px 18px)!important;
}
.app .topbar h1,
.app .card h3,
.app .profile-section-title h3,
.app .bill-panel-title h3,
#pos .product-panel h3,
#pos .customer-hero h3,
#pos .final-total span,
#pos .final-total b,
.app .kpi b,
.app .module-card b,
.app .summary-grid b,
.app .scheme-box b{
  text-shadow:
    0 1px 0 rgba(255,255,255,.98),
    0 8px 18px rgba(125,86,14,.16),
    0 0 18px rgba(255,253,248,.75);
}
.app .topbar h1{
  color:#191914;
  text-shadow:
    0 1px 0 rgba(255,255,255,.95),
    0 10px 24px rgba(125,86,14,.20),
    0 0 22px rgba(255,255,255,.86);
}
.app .topbar p{
  color:var(--teal-700);
  text-shadow:0 1px 0 rgba(255,255,255,.86),0 0 16px rgba(255,255,255,.72);
}
.app .control-strip,
.app .kpi,
.app .card,
.app .module-card,
.app .pos-workspace,
.app .customer-panel{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 50% 8%,rgba(255,255,255,.92),rgba(255,253,248,.78) 55%,rgba(255,248,232,.70) 100%)!important;
  border-color:rgba(183,131,24,.24)!important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.94),
    inset 0 0 38px rgba(255,255,255,.36),
    0 10px 28px rgba(125,86,14,.10)!important;
}
.app .sidebar{
  background:
    radial-gradient(circle at 46% 0,rgba(255,255,255,.86),transparent 34%),
    linear-gradient(180deg,rgba(255,253,248,.98),rgba(251,247,237,.97)),
    repeating-linear-gradient(135deg,rgba(183,131,24,.028) 0 1px,transparent 1px 18px)!important;
}
.app .nav.active,
.app .nav:hover,
.app .side-user{
  background:
    radial-gradient(circle at 50% 0,rgba(255,255,255,.88),rgba(255,253,248,.76) 70%)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 8px 20px rgba(125,86,14,.08)!important;
}
.app .kpi:before,
.app .module-card:before,
.app .summary-grid div:before,
.app .scheme-box:before,
.app .card h3:before,
.app .profile-section-title h3:before,
.app .bill-panel-title h3:before,
#pos .rate-icon,
.app .avatar{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.24),
    0 0 0 3px rgba(215,170,66,.16),
    0 10px 20px rgba(0,61,57,.18)!important;
}
.app .gold-btn,
.app .generate-btn,
.app .tabs button.active{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.22),
    0 12px 24px rgba(143,18,48,.18),
    0 0 18px rgba(215,170,66,.10)!important;
}
#pos .product-photo,
.app .corner-art{
  filter:saturate(1.12) brightness(1.05) contrast(1.03);
}
#pos .product-panel,
#pos .bill-panel,
#pos .customer-panel,
.app .summary-grid div,
.app .scheme-box{
  background:
    radial-gradient(circle at 50% 0,rgba(255,255,255,.86),rgba(255,253,248,.74) 70%,rgba(255,248,232,.66))!important;
}

/* Alignment pass: consistent rows, baselines, and card geometry */
.app .page.active{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.app .control-strip,
.app .kpis,
.app .module-grid,
.app .grid,
.app .tabs,
#pos .pos-shell{
  margin-top:0!important;
  margin-bottom:0!important;
}
.app .control-strip{
  min-height:58px;
  align-items:center;
}
.app .control-strip label{
  min-height:38px;
}
.app .kpis,
.app .module-grid{
  align-items:stretch;
}
.app .kpis{
  grid-auto-rows:118px;
}
.app .module-grid{
  grid-auto-rows:112px;
}
.app .kpi,
.app .module-card{
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}
.app .kpi span,
.app .module-card span{
  min-height:15px;
  line-height:1.2;
}
.app .kpi b,
.app .module-card b{
  line-height:1.05;
}
.app .kpi em,
.app .module-card em{
  margin-top:auto;
  line-height:1.25;
}
.app .control-strip::after,
.app .kpi::after,
.app .card::after,
.app .module-card::after,
.app .pos-workspace::after,
.app .customer-panel::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(118deg,
      rgba(255,255,255,.58) 0%,
      rgba(255,255,255,.22) 12%,
      rgba(255,255,255,0) 32%,
      rgba(255,255,255,.16) 54%,
      rgba(255,255,255,0) 74%,
      rgba(255,255,255,.20) 88%,
      rgba(255,255,255,0) 100%);
  opacity:.45;
  mix-blend-mode:screen;
}
.app .kpi::after,
.app .module-card::after{
  background:
    linear-gradient(128deg,
      rgba(255,255,255,.50) 0%,
      rgba(255,255,255,.16) 18%,
      rgba(255,255,255,0) 42%,
      rgba(255,255,255,.12) 62%,
      rgba(255,255,255,0) 86%);
  opacity:.35;
}
.app .control-strip > *,
.app .kpi > *,
.app .card > *,
.app .module-card > *,
.app .pos-workspace > *,
.app .customer-panel > *{
  position:relative;
  z-index:1;
}
.app .grid{
  align-items:stretch;
}
.app .grid.two{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
}
.app .grid.three{
  grid-auto-rows:minmax(230px,auto);
}
.app .grid > .card{
  height:100%;
}
.app .card{
  display:flex;
  flex-direction:column;
}
.app .card h3,
.app .profile-section-title h3,
.app .bill-panel-title h3{
  min-height:40px;
  margin-bottom:12px!important;
  line-height:1.08;
}
.app .card h3:before,
.app .profile-section-title h3:before,
.app .bill-panel-title h3:before{
  top:17px;
  transform:none;
}
.app .card h3:after,
.app .profile-section-title h3:after,
.app .bill-panel-title h3:after{
  bottom:0;
}
.app .card canvas{
  flex:1;
  min-height:220px;
}
.app .list,
.app .module-list{
  display:flex;
  flex-direction:column;
  gap:0;
}
.app .list p,
.app .module-list p{
  min-height:38px;
  align-items:center;
}
.app .report-grid{
  align-items:stretch;
}
.app .report-grid button{
  min-height:58px;
}
.app .report-panel{
  display:none;
  flex-direction:column;
  gap:16px;
}
.app .report-panel.active{
  display:flex;
}
#pos .pos-shell{
  align-items:start;
}
#pos .pos-workspace,
#pos .customer-panel{
  align-self:start;
}
#pos .pos-controlbar{
  min-height:82px;
  align-items:stretch;
}
#pos .pos-control{
  min-height:82px!important;
  align-items:center;
}
#pos .pos-control label{
  align-content:center;
}
#pos .pos-bill-card{
  align-items:stretch;
}
#pos .product-panel,
#pos .bill-panel{
  min-height:452px;
}
#pos .product-panel{
  display:flex;
  flex-direction:column;
}
#pos .product-panel h3{
  min-height:38px;
}
#pos .product-panel dl{
  flex:1;
}
#pos .bill-panel-title{
  height:50px!important;
  align-items:center;
}
#pos .bill-panel-title h3{
  margin:0!important;
}
#pos .bill-summary-row{
  min-height:128px;
}
#pos .pos-actions{
  align-items:center;
}
#pos .pos-actions button{
  align-self:center;
}
#pos .customer-panel{
  display:flex;
  flex-direction:column;
  min-height:500px;
}
#pos .customer-hero{
  min-height:74px;
  align-items:center;
}
#pos .profile-section-title{
  min-height:36px;
  margin:16px 0 10px!important;
  align-items:center;
}
#pos .profile-section-title h3{
  margin:0!important;
}
#pos .summary-grid{
  grid-auto-rows:132px;
  align-items:stretch;
}
#pos .summary-grid div{
  height:100%;
}
#pos .scheme-box{
  min-height:74px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

/* Visista client demo: ruby identity, no legacy color carry-over */
.splash-brand strong,
.splash-brand span{
  color:#5b0718;
  text-shadow:
    3px 4px 0 rgba(177,132,48,.55),
    0 6px 12px rgba(70,18,28,.24);
}
.login-card{
  border-color:rgba(143,18,48,.72)!important;
}
.login-card p,
.sign-in-button,
.topbar p,
.icon-button,
.logout,
.ghost-btn{
  color:var(--teal-700)!important;
}
.brand img,
.nav img,
.login-badge,
.field img,
.login-options img,
.sign-in-button img,
.icon-button img,
.logout img,
.barcode-control img{
  filter:drop-shadow(0 8px 14px rgba(143,18,48,.12));
}
.gold-btn,
.tabs button.active{
  background:linear-gradient(135deg,var(--teal-700),var(--teal-900))!important;
}
.app th,
#pos .pos-table th{
  background:rgba(255,253,248,.92)!important;
  color:var(--teal-800)!important;
  border-bottom:1px solid rgba(183,131,24,.26)!important;
}
.donut{
  background:conic-gradient(var(--teal-700) 0 56%,var(--gold-700) 56% 78%,#B44A5B 78% 88%,#d8c299 88%)!important;
}
.pill.ok{
  background:#f8e6eb!important;
  color:var(--teal-700)!important;
}
.hallmark{
  background:#f8e6eb!important;
  color:var(--teal-700)!important;
}

/* Desktop preview scale: gives the ERP screens more breathing room at browser 100%. */
#appView.app:not(.hidden){
  zoom:.9;
  width:111.111%;
  min-height:111.111vh;
}
