:root{
  --bg:#FBF8F4; --panel:#ffffff; --ink:#211C18; --ink-soft:#766B62;
  --blush:#F1D7C9; --blush-soft:#FAEEE7; --gold:#BE9444; --gold-d:#9C7833;
  --line:#ECE2D8; --radius:18px; --shadow:0 18px 50px -22px rgba(60,40,25,.28);
  --ok:#2f9e6f; --okb:#e4f5ec; --warn:#b9852a; --warnb:#fbf0db;
  --bad:#c0533f; --badb:#fbe7e2; --info:#3f6fb0; --infob:#e8f0fa;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
button,input,select,textarea{font-family:inherit}
body{font-family:'Manrope',system-ui,-apple-system,'Segoe UI',sans-serif;background:var(--bg);
  color:var(--ink);line-height:1.65;font-size:16px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4{font-family:'Cormorant Garamond',Georgia,serif;font-weight:700;line-height:1.1;letter-spacing:.2px}
.serif{font-family:'Cormorant Garamond',Georgia,serif}
.container{max-width:1160px;margin:0 auto;padding:0 24px}
section{padding:78px 0}
.kicker{font-family:'Manrope',sans-serif;text-transform:uppercase;letter-spacing:3.5px;font-size:12px;
  font-weight:700;color:var(--gold);margin-bottom:14px}
.sec-head{text-align:center;max-width:680px;margin:0 auto 50px}
.sec-head h2{font-size:clamp(32px,4.5vw,46px)}
.sec-head p{color:var(--ink-soft);margin-top:12px;font-size:17px}
.muted{color:var(--ink-soft)}
.gold{color:var(--gold)}
.mt{margin-top:18px}.mb{margin-bottom:18px}.text-c{text-align:center}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:0;
  font-family:'Manrope',sans-serif;font-weight:700;font-size:15px;padding:14px 30px;border-radius:50px;
  transition:.25s;background:var(--ink);color:#fff}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-d));color:#fff}
.btn-light{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}
.btn-block{width:100%}
.btn-sm{padding:9px 18px;font-size:13px}
.btn-ghost{background:var(--blush-soft);color:var(--ink)}

/* header */
header.site{position:sticky;top:0;z-index:50;background:rgba(251,248,244,.88);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:18px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:50px;width:50px;border-radius:50%;object-fit:cover;background:var(--blush)}
.brand b{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;white-space:nowrap}
.brand span{display:block;font-size:10px;letter-spacing:2.5px;color:var(--ink-soft);font-weight:600;font-family:'Manrope',sans-serif}
.menu{display:flex;align-items:center;gap:4px}
.menu a{padding:10px 15px;border-radius:50px;font-size:14.5px;font-weight:600;color:var(--ink-soft);white-space:nowrap;transition:.2s}
.menu a:hover,.menu a.active{color:var(--ink);background:var(--blush-soft)}
.menu .btn{margin-left:8px}
.burger{display:none;background:none;border:0;font-size:26px;cursor:pointer;color:var(--ink)}
@media(max-width:980px){
  .burger{display:block}
  .menu{position:fixed;inset:78px 0 auto 0;flex-direction:column;align-items:stretch;background:var(--bg);
    padding:16px 24px 24px;gap:4px;border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    transform:translateY(-150%);transition:.35s}
  .menu.open{transform:translateY(0)}
  .menu .btn{margin:6px 0 0}
}

/* hero */
.hero{position:relative;text-align:center;padding:96px 0 84px;
  background:radial-gradient(1100px 460px at 50% -8%,var(--blush-soft),transparent 70%)}
.hero .badge{width:104px;height:104px;border-radius:50%;margin:0 auto 26px;background:#fff;
  display:grid;place-items:center;box-shadow:var(--shadow);border:1px solid var(--line)}
.hero .badge img{width:74px;height:74px;border-radius:50%}
.hero h1{font-size:clamp(40px,7vw,76px);letter-spacing:-.5px}
.hero p.lead{max-width:600px;margin:20px auto 0;font-size:18px;color:var(--ink-soft)}
.hero .cta{margin-top:34px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* grids & cards */
.grid{display:grid;gap:22px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g3,.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.g2,.g3,.g4{grid-template-columns:1fr}}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:.25s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--blush)}
.card .ic{width:58px;height:58px;border-radius:14px;background:var(--blush-soft);display:grid;place-items:center;font-size:26px;margin-bottom:16px}
.card h3{font-size:24px}
.card p{color:var(--ink-soft);margin-top:6px;font-size:15px}
.feature{text-align:center}
.feature .ic{margin:0 auto 16px}

/* offers */
.offer{position:relative;background:linear-gradient(160deg,#fff,var(--blush-soft));
  border:1px solid var(--line);border-radius:var(--radius);padding:30px;overflow:hidden}
.offer .disc{position:absolute;top:0;right:0;background:var(--gold);color:#fff;font-weight:700;
  font-size:13px;padding:7px 16px;border-bottom-left-radius:14px}
.offer h3{font-size:26px;margin-bottom:6px}
.offer p{color:var(--ink-soft)}

/* reviews */
.stars{color:var(--gold);font-size:20px;letter-spacing:2px}
.star-pick{cursor:pointer;color:#d9cdc2;font-size:32px;transition:.15s}
.star-pick.on{color:var(--gold)}

/* price list */
.cat-block{border:1px solid var(--line);border-radius:var(--radius);margin-bottom:14px;overflow:hidden;background:#fff}
.cat-head{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;cursor:pointer;font-weight:700;font-size:18px}
.cat-head .count{font-size:13px;color:var(--ink-soft);font-weight:600}
.cat-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.cat-block.open .cat-body{max-height:4000px}
.svc-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:13px 24px;border-top:1px solid var(--line)}
.svc-row label{display:flex;align-items:center;gap:10px;cursor:pointer}
.svc-row .price{font-weight:700;color:var(--gold);white-space:nowrap}
input[type=checkbox]{width:18px;height:18px;accent-color:var(--gold);cursor:pointer}

/* forms */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;max-width:480px;margin:0 auto;box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1px solid var(--line);
  border-radius:12px;font-family:inherit;font-size:15px;background:#fff;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--gold)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.row2{grid-template-columns:1fr}}

/* alerts & badges */
.alert{padding:13px 17px;border-radius:12px;margin-bottom:16px;font-size:14.5px;font-weight:600}
.alert.ok{background:var(--okb);color:var(--ok)} .alert.bad{background:var(--badb);color:var(--bad)}
.alert.info{background:var(--infob);color:var(--info)} .alert.warn{background:var(--warnb);color:var(--warn)}
.badge{display:inline-block;padding:5px 12px;border-radius:50px;font-size:12px;font-weight:700}
.badge.ok{background:var(--okb);color:var(--ok)} .badge.warn{background:var(--warnb);color:var(--warn)}
.badge.bad{background:var(--badb);color:var(--bad)} .badge.info{background:var(--infob);color:var(--info)}

/* tables */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff}
table{width:100%;border-collapse:collapse;min-width:560px}
th,td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--line);font-size:14px}
th{background:var(--blush-soft);font-weight:700;white-space:nowrap}
tr:last-child td{border-bottom:0}

/* sticky booking bar */
.sticky-bar{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--line);
  padding:14px 24px;display:flex;justify-content:space-between;align-items:center;z-index:40;
  box-shadow:0 -10px 30px -12px rgba(0,0,0,.18)}
.sticky-bar .tot{font-weight:800;font-size:18px}

/* footer */
footer.site{background:var(--ink);color:#e7ddd4;padding:60px 0 26px;margin-top:30px}
footer.site h4{font-family:'Manrope',sans-serif;font-size:13px;text-transform:uppercase;letter-spacing:2px;color:#fff;margin-bottom:16px}
footer.site .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:36px}
@media(max-width:760px){footer.site .cols{grid-template-columns:1fr;gap:28px}}
footer.site a{display:block;color:#cbbfb4;padding:4px 0;font-size:14.5px}
footer.site a:hover{color:#fff}
footer.site .social{display:flex;gap:12px;margin-top:14px}
footer.site .social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;font-size:18px}
footer.site .copy{text-align:center;border-top:1px solid rgba(255,255,255,.12);margin-top:38px;padding-top:22px;font-size:13px;color:#9c9087}

/* admin */
.admin-wrap{display:flex;min-height:100vh}
.sidebar{width:256px;background:var(--ink);color:#e7ddd4;padding:26px 16px;flex-shrink:0;position:sticky;top:0;align-self:flex-start;height:100vh;overflow-y:auto;overscroll-behavior:contain;scrollbar-width:thin}
.sidebar .logo{display:flex;gap:11px;align-items:center;margin-bottom:28px;padding:0 8px}
.sidebar .logo img{width:42px;height:42px;border-radius:50%}
.sidebar .logo b{font-family:'Cormorant Garamond',serif;font-size:19px}
.sidebar a{display:flex;align-items:center;gap:11px;padding:12px 14px;border-radius:12px;margin-bottom:4px;
  font-weight:600;font-size:14px;color:#c7bbb0}
.sidebar a:hover{background:rgba(190,148,68,.15);color:#fff}
.sidebar a.active{background:rgba(190,148,68,.28);color:#fff;font-weight:800;box-shadow:inset 3px 0 0 var(--gold)}
[dir=rtl] .sidebar a.active{box-shadow:inset -3px 0 0 var(--gold)}
.admin-main{flex:1;padding:30px;min-width:0}
.admin-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:26px}
.admin-top h1{font-size:30px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:30px}
@media(max-width:900px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.stat .n{font-size:32px;font-weight:800;color:var(--gold);font-family:'Cormorant Garamond',serif}
.stat .l{color:var(--ink-soft);font-size:13px;font-weight:600;margin-top:4px}
.admin-mob{display:none;background:none;border:0;font-size:24px;cursor:pointer}
@media(max-width:880px){
  .sidebar{position:fixed;left:0;top:0;bottom:0;z-index:60;transform:translateX(-110%);transition:.3s}
  .sidebar.open{transform:translateX(0)}
  .admin-mob{display:inline-block}
}

/* ---- platform additions ---- */
.lang-pill{display:inline-flex;align-items:center;padding:7px 16px;border:1.5px solid var(--gold);border-radius:50px;color:var(--gold);font-weight:800;font-size:13px}
.lang-pill:hover{background:var(--gold);color:#fff}
.pl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:24px}
@media(max-width:900px){.pl-grid{grid-template-columns:1fr}}
.pl-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.pl-card .n{font-size:28px;font-weight:800;font-family:'Cormorant Garamond',serif}
.pl-card.up .n{color:#2f9e6f}.pl-card.down .n{color:#c0533f}.pl-card .l{color:var(--ink-soft);font-size:13px;font-weight:600}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin-bottom:22px}
.panel h3{font-size:22px;margin-bottom:16px}
.bar-row{display:flex;align-items:center;gap:12px;margin-bottom:10px;font-size:14px}
.bar-row .lbl{width:160px;flex-shrink:0;color:var(--ink-soft)}
.bar-row .track{flex:1;background:var(--blush-soft);border-radius:50px;height:14px;overflow:hidden}
.bar-row .fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-d));border-radius:50px}
.bar-row .val{width:90px;text-align:right;font-weight:700}
.theme-dot{width:46px;height:46px;border-radius:50%;cursor:pointer;border:3px solid transparent;display:inline-block}
.theme-dot.sel{border-color:var(--ink)}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:22px;border-bottom:1px solid var(--line);padding-bottom:14px}
.tabs a{padding:9px 18px;border-radius:50px;font-weight:600;font-size:14px;color:var(--ink-soft)}
.tabs a.active{background:var(--ink);color:#fff}
.perm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media(max-width:700px){.perm-grid{grid-template-columns:1fr 1fr}}
.perm-grid label{display:flex;gap:8px;align-items:center;background:var(--blush-soft);padding:10px 12px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer}
/* invoice */
.inv-box{max-width:820px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:16px;padding:40px}
.inv-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;border-bottom:2px solid var(--ink);padding-bottom:20px;margin-bottom:22px}
.inv-head .biz{display:flex;gap:14px;align-items:center}
.inv-head img{width:64px;height:64px;border-radius:50%}
.inv-title{text-align:right}
.inv-title h2{font-size:30px}
.inv-meta{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:22px;font-size:14px}
.inv-meta .bi{font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:1px}
.inv-table{width:100%;border-collapse:collapse;margin-bottom:18px}
.inv-table th{background:var(--blush-soft);padding:12px;text-align:left;font-size:13px}
.inv-table td{padding:12px;border-bottom:1px solid var(--line);font-size:14px}
.inv-tot{margin-left:auto;width:300px;font-size:14px}
.inv-tot .r{display:flex;justify-content:space-between;padding:7px 0}
.inv-tot .grand{border-top:2px solid var(--ink);font-weight:800;font-size:18px;padding-top:10px;margin-top:6px}
.inv-actions{max-width:820px;margin:18px auto 0;display:flex;gap:10px;flex-wrap:wrap}
@media print{.sidebar,.admin-top,.inv-actions,.no-print{display:none!important}.admin-main{padding:0}.inv-box{border:0}}
.bilingual{display:flex;justify-content:space-between;gap:6px}
.bilingual .ar{font-family:'Tajawal',sans-serif;direction:rtl}

/* ---- bilingual receipt / invoice ---- */
.receipt{margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:14px;padding:34px 30px;text-align:center;color:#1a1a1a}
.receipt .rc-logo img{width:88px;height:88px;border-radius:14px;margin:0 auto 12px;object-fit:cover}
.receipt .rc-name{font-family:'Cormorant Garamond',serif;font-size:1.7em;font-weight:700}
.receipt .rc-sub{color:#555;font-size:.95em;margin-top:2px}
.receipt .rc-rule{border-top:1.5px solid #1a1a1a;margin:16px 0}
.receipt .rc-meta{width:100%;border-collapse:collapse;margin:6px 0}
.receipt .rc-meta td{padding:5px 4px;vertical-align:top}
.receipt .rc-meta .en{text-align:left;color:#666;white-space:nowrap;font-size:.92em}
.receipt .rc-meta .ar{text-align:right;color:#666;white-space:nowrap;font-size:.95em;font-family:'Tajawal',sans-serif}
.receipt .rc-meta .v{text-align:center;font-weight:700}
.receipt .rc-meta .rc-grand td{border-top:1.5px solid #1a1a1a;padding-top:9px;font-size:1.15em;font-weight:800}
.receipt .rc-items{width:100%;border-collapse:collapse;margin:4px 0}
.receipt .rc-items th{padding:8px 4px;border-bottom:1.5px solid #1a1a1a;font-size:.9em;color:#333}
.receipt .rc-items th .ar{font-family:'Tajawal',sans-serif;color:#777;font-weight:600;font-size:.92em}
.receipt .rc-items td{padding:9px 4px;border-bottom:1px dashed #ddd}
.receipt .rc-foot{font-weight:600;margin:6px 0}
.receipt .rc-foot .ar{font-family:'Tajawal',sans-serif;color:#555}
.receipt .rc-served{color:#777;font-size:.9em;margin-top:8px}
.receipt .rc-qr{margin-top:14px}.receipt .rc-qr img{margin:0 auto}
@media print{.sidebar,.admin-top,.inv-actions,.no-print{display:none!important}.admin-main{padding:0}.receipt{border:0}}
.receipt .ar{font-family:"Tajawal",sans-serif}

/* ---- popup modal for add forms ---- */
.modal-overlay{position:fixed;inset:0;background:rgba(20,14,10,.55);backdrop-filter:blur(3px);z-index:1000;display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:18px;width:min(640px,100%);box-shadow:0 30px 80px -30px rgba(40,25,15,.5);animation:modalIn .22s ease}
@keyframes modalIn{from{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:none}}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--line)}
.modal-head h3{font-size:21px;margin:0}
.modal-x{background:var(--blush-soft);border:0;width:34px;height:34px;border-radius:50%;font-size:18px;cursor:pointer;color:var(--ink)}
.modal-body{padding:22px 24px}
.modal-foot{padding:16px 24px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:18px}

/* ---- receipt overflow safety (A5 / 80mm) ---- */
.receipt{box-sizing:border-box;overflow:hidden;word-wrap:break-word;overflow-wrap:anywhere}
.receipt *{box-sizing:border-box}
.receipt table{table-layout:fixed;width:100%}
.receipt .rc-name,.receipt .rc-meta .v,.receipt .rc-items td{overflow-wrap:anywhere}
.receipt .rc-items th:nth-child(1),.receipt .rc-items td:nth-child(1){width:26%}
.receipt .rc-items th:nth-child(2),.receipt .rc-items td:nth-child(2){width:16%}
.receipt .rc-items th:nth-child(3),.receipt .rc-items td:nth-child(3){width:58%}
.receipt .rc-meta .en,.receipt .rc-meta .ar{width:30%}
@media(max-width:380px){.receipt{padding:22px 16px}.receipt .rc-meta .en,.receipt .rc-meta .ar{white-space:normal}}

/* ---- receipt v2: fixed LTR direction + icons + robust layout ---- */
.receipt{direction:ltr}
.receipt .rc-meta{table-layout:auto}
.receipt .rc-meta .en{width:auto;white-space:normal;text-align:left;direction:ltr}
.receipt .rc-meta .ar{width:auto;white-space:normal;text-align:right;direction:rtl}
.receipt .rc-meta .v{white-space:normal;word-break:break-word}
.receipt .rc-ic{display:inline-block;width:1.25em}
.receipt .rc-en{display:inline-flex;align-items:center;gap:5px}
.receipt .rc-arlbl{display:inline-flex;align-items:center;gap:5px;flex-direction:row-reverse;font-family:'Tajawal',sans-serif}
.receipt .rc-items th:nth-child(1),.receipt .rc-items td:nth-child(1){width:24%}
.receipt .rc-items th:nth-child(2),.receipt .rc-items td:nth-child(2){width:14%}
.receipt .rc-items th:nth-child(3),.receipt .rc-items td:nth-child(3){width:62%}
.receipt .rc-svc-en{font-weight:600}
.receipt .rc-svc-ar{font-family:'Tajawal',sans-serif;color:#6a6a6a;font-size:.92em}
.receipt .rc-grand td{color:var(--gold-d)}

/* ===== receipt v3: flexbox, overflow-proof at any width ===== */
.receipt .rc-logo img{width:64px;height:64px;border-radius:12px}
.receipt .rc-name{font-size:1.45em;line-height:1.2}
.receipt .rc-sub{font-size:.9em}
.rc-line{display:flex;align-items:flex-start;gap:8px;padding:5px 0;font-size:.95em}
.rc-line .rc-en{flex:1 1 0;min-width:0;text-align:left;color:#666;display:flex;align-items:center;gap:5px;line-height:1.3}
.rc-line .rc-ar{flex:1 1 0;min-width:0;text-align:right;color:#666;font-family:'Tajawal',sans-serif;direction:rtl;line-height:1.5}
.rc-line .rc-v{flex:1 2 auto;min-width:0;text-align:center;font-weight:700;word-break:break-word;line-height:1.3}
.rc-grandline{border-top:2px solid #1a1a1a;margin-top:4px;padding-top:9px;font-size:1.15em}
.rc-grandline .rc-v{color:var(--gold-d);font-weight:800}
.rc-itemhead,.rc-itemrow{display:flex;gap:8px;align-items:flex-start;padding:8px 0}
.rc-itemhead{border-bottom:1.5px solid #1a1a1a;font-size:.82em;color:#444;font-weight:700}
.rc-itemrow{border-bottom:1px dashed #dcdcdc}
.rc-ip{flex:0 0 22%;min-width:0;text-align:left;word-break:break-word}
.rc-iq{flex:0 0 15%;min-width:0;text-align:center}
.rc-in{flex:1 1 0;min-width:0;text-align:right;word-break:break-word}
.rc-in .en{font-weight:600}
.rc-in .ar,.rc-itemhead .ar{display:block;font-family:'Tajawal',sans-serif;color:#777;font-size:.9em}

/* ---- discount checkbox tree ---- */
.disc-tree{max-height:300px;overflow-y:auto;border:1px solid var(--line);border-radius:12px;padding:10px;margin-bottom:14px}
.disc-cat{margin-bottom:8px}
.disc-cat-head{display:flex;align-items:center;gap:8px;background:var(--blush-soft);padding:9px 11px;border-radius:9px;cursor:pointer;font-size:14px}
.disc-svcs{padding:8px 14px;display:flex;flex-direction:column;gap:7px}
.disc-svcs label{display:flex;gap:8px;align-items:center;font-size:13px;cursor:pointer}
/* public discounted services */
.disc-sec{background:linear-gradient(135deg,var(--blush-soft),#fff)}
.disc-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;position:relative;overflow:hidden;text-align:center}
.disc-card .pct{position:absolute;top:0;inset-inline-end:0;background:linear-gradient(135deg,var(--gold),var(--gold-d));color:#fff;font-weight:800;padding:7px 13px;border-bottom-inline-start-radius:12px;font-size:15px}
.disc-card h3{font-size:18px;margin:6px 0 4px}
.disc-card .cat{color:var(--ink-soft);font-size:12px;margin-bottom:10px}
.disc-card .old{text-decoration:line-through;color:#b9a89c;font-size:14px}
.disc-card .new{color:var(--gold-d);font-weight:800;font-size:22px;font-family:'Cormorant Garamond',serif}

/* ---- compact booking service list ---- */
.cat-head{padding:14px 18px;font-size:16px}
.cat-body{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.svc-row{padding:9px 16px;font-size:14px;gap:10px}
.svc-row label{gap:8px}
@media(max-width:640px){.cat-body{grid-template-columns:1fr}}

/* ---- customer profile (screenshot-style) ---- */
.cust-wrap{display:grid;grid-template-columns:1fr 340px;gap:18px;align-items:start;margin-top:14px}
@media(max-width:900px){.cust-wrap{grid-template-columns:1fr}}
.cust-side{display:flex;flex-direction:column;gap:16px}
.cust-avatar{width:96px;height:96px;border-radius:50%;margin:14px auto 10px;display:flex;align-items:center;justify-content:center;font-size:42px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--gold),var(--gold-d))}
.cust-stat{flex:1;background:var(--blush-soft);border-radius:12px;padding:10px;text-align:center}
.cust-stat .v{font-size:18px;font-weight:800;color:var(--gold-d)}
.cust-stat .l{font-size:11px;color:var(--ink-soft)}
.cust-detail{display:flex;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);font-size:14px}
.cust-detail .k{color:var(--ink-soft)}
.cust-detail .v{font-weight:600;text-align:end;word-break:break-word}
.cust-tabs{display:flex;gap:6px}
.ct-btn{background:transparent;border:0;padding:6px 12px;border-radius:8px;cursor:pointer;font-weight:700;color:var(--ink-soft)}
.ct-btn.active{color:var(--gold-d);border-bottom:2px solid var(--gold-d)}

/* sidebar section separator */
.sidebar .nav-sep{font-size:11px;font-weight:800;letter-spacing:.5px;color:var(--ink-soft);opacity:.7;padding:14px 16px 4px;text-transform:uppercase}

/* ===== Cashier POS ===== */
.pos{display:grid;grid-template-columns:420px 1fr;gap:18px;align-items:start}
@media(max-width:980px){.pos{grid-template-columns:1fr}}
.pos-cart{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;position:sticky;top:14px}
.pos-cust{display:flex;gap:8px;padding:14px;border-bottom:1px solid var(--line)}
.pos-cust input{flex:1;padding:10px;border:1px solid var(--line);border-radius:10px}
.pos-items{max-height:46vh;overflow:auto}
.pos-items table{width:100%}.pos-items th{font-size:12px;color:var(--ink-soft);padding:8px 10px;text-align:start}
.pos-items td{padding:8px 10px;border-top:1px solid var(--line);vertical-align:middle}
.it-nm{font-weight:700;font-size:14px}
.it-wk{background:var(--blush-soft);border:0;border-radius:8px;padding:4px 8px;font-size:12px;cursor:pointer;margin-top:4px;color:var(--gold-d);font-weight:600}
.it-q,.it-p{width:64px;padding:6px;border:1px solid var(--line);border-radius:8px;text-align:center}
.it-x{background:transparent;border:0;cursor:pointer;font-size:16px}
.pos-tot{padding:14px;background:var(--blush-soft)}
.pos-tot .row{display:flex;justify-content:space-between;padding:5px 0;font-size:14px}
.pos-tot .row.grand{font-size:20px;font-weight:800;color:var(--gold-d);border-top:2px solid #1a1a1a;margin-top:6px;padding-top:10px}
.pos-tot textarea{width:100%;margin-top:10px;padding:9px;border:1px solid var(--line);border-radius:10px;box-sizing:border-box}
.pos-pay{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.pos-pay select{padding:10px;border:1px solid var(--line);border-radius:10px;flex:1}
.pos-pay .btn{flex:1}
.pos-cats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.pcat{background:#fff;border:1px solid var(--line);border-radius:50px;padding:9px 16px;cursor:pointer;font-weight:700;font-size:13px}
.pcat.active{background:linear-gradient(135deg,var(--gold),var(--gold-d));color:#fff;border-color:transparent}
.pos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.scard{background:linear-gradient(135deg,#c2568f,#a8437a);color:#fff;border:0;border-radius:14px;padding:14px 12px;cursor:pointer;text-align:center;display:flex;flex-direction:column;gap:6px;min-height:78px;justify-content:center;transition:.15s}
.scard:hover{transform:translateY(-2px);box-shadow:0 10px 20px -10px rgba(168,67,122,.6)}
.scard .nm{font-weight:700;font-size:14px;line-height:1.25}.scard .mt{font-size:12px;opacity:.92}
.wk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:14px}
.wk-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px}
.wk-card:hover{border-color:var(--gold);box-shadow:0 8px 18px -10px rgba(190,148,68,.6)}
.wk-card img{width:74px;height:74px;border-radius:50%;object-fit:cover}
.wk-ini{width:74px;height:74px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--gold),var(--gold-d))}
.wk-nm{font-weight:700;font-size:13px}

/* ===== Cashier POS v2 (themed) ===== */
.rc-worker{display:block;font-family:'Tajawal',sans-serif;color:var(--gold-d);font-weight:700;font-size:.9em;margin-top:2px}
/* entry gate */
.pos-gate{max-width:560px;margin:30px auto;background:#fff;border:1px solid var(--line);border-radius:24px;padding:34px;text-align:center;box-shadow:0 30px 70px -40px rgba(60,40,20,.45)}
.pos-gate img{height:96px;width:auto;margin-bottom:18px}
.pos-gate input{width:100%;box-sizing:border-box;padding:16px;border:2px solid var(--line);border-radius:14px;font-size:22px;text-align:center;letter-spacing:1px}
.pos-gate input:focus{border-color:var(--gold);outline:none}
.pos-gate .ghint{color:var(--ink-soft);font-size:14px;margin:10px 0 18px}
.pos-gate .btn{width:100%;padding:15px;font-size:17px;border-radius:14px;margin-top:10px}
/* themed service cards */
.scard{background:linear-gradient(135deg,var(--gold),var(--gold-d));color:#fff}
.pcat.active{background:linear-gradient(135deg,var(--gold),var(--gold-d));color:#fff;border-color:transparent}
/* stage header (worker pick in place) */
.stage-head{display:flex;justify-content:space-between;align-items:center;background:var(--blush-soft);border-radius:14px;padding:12px 16px;margin-bottom:14px}
.stage-head b{font-size:16px}
.pos-search{width:100%;box-sizing:border-box;padding:11px 14px;border:1px solid var(--line);border-radius:12px;margin-bottom:12px}
/* cart line worker chip */
.it-wk.set{background:var(--gold);color:#fff}
.pos-cart .line-tot{font-weight:700;color:var(--gold-d);white-space:nowrap}
.pos-change{background:#e7f6ec;color:#1c6b3a;border-radius:10px;padding:8px 10px;font-weight:700;margin-top:8px;display:none}

/* ===== Cashier cart — stacked line cards (no horizontal scroll) ===== */
.pos{grid-template-columns:460px 1fr}
@media(max-width:980px){.pos{grid-template-columns:1fr}}
.pos-items{max-height:50vh;overflow-y:auto;overflow-x:hidden;padding:8px;background:var(--blush-soft)}
.pos-line{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin-bottom:10px}
.pos-line .pl-top{display:flex;align-items:center;gap:10px}
.pl-x{background:transparent;border:0;cursor:pointer;font-size:19px;flex-shrink:0;line-height:1}
.pl-name{flex:1;font-weight:800;font-size:16px;line-height:1.35;word-break:break-word}
.pl-tot{font-weight:800;color:var(--gold-d);white-space:nowrap;font-size:16px}
.pos-line .it-wk{margin-top:10px;display:inline-block}
.pl-ctrls{display:flex;align-items:center;gap:14px;margin-top:12px;flex-wrap:wrap}
.qstep{display:flex;align-items:center;border:1px solid var(--line);border-radius:11px;overflow:hidden}
.qstep button{width:38px;height:38px;border:0;background:var(--blush-soft);font-size:20px;cursor:pointer;color:var(--ink)}
.qstep button:hover{background:var(--gold);color:#fff}
.qstep input{width:50px;height:38px;border:0;border-inline:1px solid var(--line);text-align:center;font-size:16px;font-weight:700}
.pl-price{display:flex;align-items:center;gap:7px;font-size:14px;color:var(--ink-soft);font-weight:600}
.pl-price input{width:88px;height:38px;border:1px solid var(--line);border-radius:11px;text-align:center;font-size:16px;font-weight:700}
.pos-tot{font-size:15px}
.pos-tot .row.grand{font-size:22px}

/* ===== Workers list + profile ===== */
.wk-table .wk-av{width:46px;height:46px;border-radius:50%;object-fit:cover;flex-shrink:0}
.wk-table .wk-av-i{display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;background:linear-gradient(135deg,var(--gold),var(--gold-d));font-size:18px}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 22px}
@media(max-width:640px){.info-grid{grid-template-columns:1fr}}

/* ===== Invoice / Cashier popup (in-platform) ===== */
.inv-pop{position:fixed;inset:0;background:rgba(30,20,12,.55);backdrop-filter:blur(3px);z-index:9999;display:none;align-items:center;justify-content:center;padding:20px}
.inv-pop.open{display:flex}
.inv-pop-box{background:#fff;border-radius:18px;width:min(1100px,100%);height:min(88vh,920px);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 40px 90px -30px rgba(0,0,0,.5)}
.inv-pop-head{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;border-bottom:1px solid var(--line);background:var(--blush-soft)}
.inv-pop-head b{font-size:17px}
.inv-pop iframe{flex:1;border:0;width:100%}
body.embed{background:transparent}
.embed-main{max-width:100%}

/* worker boolean flags */
.wk-flags{display:flex;flex-direction:column;gap:8px;background:var(--blush-soft);border-radius:12px;padding:12px;margin-top:6px}
.wk-flags label{display:flex;align-items:center;gap:8px;font-weight:600;cursor:pointer}

/* appointment per-service worker rows */
.ea-svc{display:flex;flex-direction:column;gap:8px}
.ea-svc-row{display:flex;align-items:center;gap:10px;justify-content:space-between;background:var(--blush-soft);border-radius:10px;padding:8px 12px}
.ea-svc-row .eas-n{font-weight:600;font-size:14px}
.ea-svc-row select{padding:7px;border:1px solid var(--line);border-radius:8px;min-width:140px}

/* expenses line items repeater */
.exp-line{display:flex;gap:8px;align-items:center;margin-bottom:8px;flex-wrap:wrap}
.exp-line select{min-width:150px;padding:8px;border:1px solid var(--line);border-radius:8px}
.exp-line input{padding:8px;border:1px solid var(--line);border-radius:8px}
.exp-line input:nth-of-type(1){flex:1;min-width:160px}

/* ===== Live dashboard ===== */
.dash-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.seg{display:inline-flex;background:var(--blush-soft,#f4ecef);border-radius:50px;padding:4px;gap:2px}
.seg button{border:0;background:none;padding:7px 15px;border-radius:50px;cursor:pointer;font:inherit;font-size:13px;color:var(--ink-soft);transition:.15s}
.seg button.on{background:#fff;color:var(--gold-d);font-weight:700;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:18px}
@media(max-width:1000px){.kpis{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.kpis{grid-template-columns:1fr}}
.kpi{background:#fff;border:1px solid var(--line);border-radius:16px;padding:15px 18px;position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;inset-inline-start:0;top:0;bottom:0;width:5px;background:var(--gold)}
.kpi.sales::before{background:#3aa76d}.kpi.exp::before{background:#d96b6b}.kpi.profit::before{background:var(--gold)}
.kpi.cust::before{background:#5b8def}.kpi.serv::before{background:#a06bd9}
.kpi .l{color:var(--ink-soft);font-size:13px;margin-bottom:6px}
.kpi .n{font-size:22px;font-weight:800;color:var(--ink)}
.panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}

/* dashboard nav + 3-col */
.navbtn{border:1px solid var(--line);background:#fff;width:32px;height:32px;border-radius:9px;cursor:pointer;font-size:18px;line-height:1;color:var(--ink-soft);transition:.15s}
.navbtn:hover{border-color:var(--gold);color:var(--gold-d)}
.period-title{font-size:13px;color:var(--ink-soft);font-weight:700;min-width:96px;text-align:center}
.grid.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:1000px){.grid.g3{grid-template-columns:1fr}}

/* ===== Live notifications ===== */
.notif-wrap{position:relative}
.notif-bell{position:relative;background:none;border:0;font-size:20px;cursor:pointer;line-height:1;padding:4px}
.notif-badge{position:absolute;top:-3px;inset-inline-end:-3px;background:#e0533f;color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.notif-panel{position:absolute;inset-inline-end:0;top:135%;width:330px;max-width:86vw;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 60px -20px rgba(0,0,0,.35);opacity:0;visibility:hidden;transform:translateY(-6px);transition:.15s;z-index:9000}
.notif-panel.open{opacity:1;visibility:visible;transform:none}
.notif-head{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--line)}
.notif-clear{background:none;border:0;color:var(--gold-d);cursor:pointer;font-size:12px}
.notif-list{max-height:380px;overflow:auto}
.notif-item{display:flex;gap:10px;padding:11px 14px;border-bottom:1px solid #f2ece4;text-decoration:none;color:inherit;transition:background .12s}
.notif-item:last-child{border-bottom:0}
.notif-item:hover{background:#faf5ef}
.notif-item.fresh{background:#fbf3e6}
.ni-ic{font-size:18px;flex:0 0 auto}
.ni-tx{font-size:13px;line-height:1.45}
.notif-toasts{position:fixed;bottom:18px;inset-inline-start:18px;display:flex;flex-direction:column;gap:10px;z-index:99998;max-width:320px}
.notif-toast{display:flex;gap:10px;background:#fff;border:1px solid var(--line);border-inline-start:4px solid var(--gold);border-radius:12px;padding:12px 14px;box-shadow:0 18px 44px -18px rgba(0,0,0,.4);cursor:pointer;opacity:0;transform:translateY(12px);transition:.35s}
.notif-toast.show{opacity:1;transform:none}
.notif-foot{display:block;text-align:center;padding:11px;font-size:13px;font-weight:700;color:var(--gold-d);text-decoration:none;border-top:1px solid var(--line)}
.notif-foot:hover{background:#faf5ef}

/* App Store badge + footer social */
.appstore-badge{display:inline-flex;align-items:center;gap:9px;background:#000;color:#fff!important;border:1px solid #2a2a2a;border-radius:11px;padding:8px 14px;text-decoration:none;margin-top:14px;width:max-content}
.appstore-badge:hover{background:#111}
.appstore-badge .asb-tx{display:flex;flex-direction:column;line-height:1.05;text-align:left}
.appstore-badge .asb-tx small{font-size:10px;opacity:.85}
.appstore-badge .asb-tx b{font-size:17px;font-weight:600;letter-spacing:.2px}
footer.site .social a{font-size:18px}
.svc-cat{font-weight:800;font-size:13px;color:var(--gold-d);margin:16px 0 9px;border-bottom:1px dashed var(--line);padding-bottom:5px}
.svc-cat:first-child{margin-top:2px}
