:root{--ink:#17332c;--muted:#60736e;--line:#dbe4e1;--bg:#f6f3ed;--card:#fff;--primary:#175b4d;--primary-2:#0e4036;--gold:#c6994b;--available:#e8f4ef;--available-border:#79aa9c;--selected:#175b4d;--pending:#f6e3a7;--pending-border:#d1a845;--confirmed:#d8dcdb;--confirmed-border:#a2acab;--danger:#b54141;--shadow:0 18px 45px rgba(23,51,44,.10)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--ink);font-family:"Tahoma","Arial",sans-serif;line-height:1.65}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{cursor:pointer}.shell{width:min(1240px,calc(100% - 32px));margin:auto}.topbar{background:var(--ink);color:#fff;font-size:13px}.topbar .shell{display:flex;justify-content:space-between;align-items:center;padding:8px 0;gap:16px}.nav{background:rgba(255,255,255,.96);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20;backdrop-filter:blur(12px)}.nav .shell{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:18px}.brand{display:flex;align-items:center;gap:12px;font-weight:700}.brand-mark{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:var(--primary);color:#fff;border:3px solid #e6d4ae;font-size:27px;line-height:1}.brand small{display:block;color:var(--muted);font-weight:400;font-size:12px}.nav-actions{display:flex;gap:10px;align-items:center}.btn{border:0;border-radius:11px;padding:11px 16px;font-weight:700;transition:.2s;display:inline-flex;align-items:center;justify-content:center;gap:7px}.btn:hover{transform:translateY(-1px)}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 8px 18px rgba(23,91,77,.20)}.btn-dark{background:var(--ink);color:#fff}.btn-light{background:#fff;color:var(--ink);border:1px solid var(--line)}.btn-danger{background:#fff1f1;color:var(--danger);border:1px solid #f1c6c6}.btn-sm{padding:7px 10px;font-size:12px;border-radius:8px}.hero{padding:40px 0 26px;background:radial-gradient(circle at 15% 20%,rgba(198,153,75,.15),transparent 34%),linear-gradient(180deg,#fff,#f6f3ed)}.hero-grid{display:grid;grid-template-columns:1.4fr .65fr;gap:22px;align-items:stretch}.kicker{display:inline-flex;align-items:center;gap:8px;color:var(--primary);font-weight:700;font-size:13px;background:#eaf4f0;padding:7px 10px;border-radius:999px}h1{font-size:clamp(30px,5vw,55px);line-height:1.18;margin:16px 0 12px;letter-spacing:-1px}.lead{color:var(--muted);font-size:17px;max-width:720px;margin:0 0 18px}.hero-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.meta-chip{background:#fff;border:1px solid var(--line);border-radius:12px;padding:10px 12px;font-size:13px;box-shadow:0 5px 16px rgba(23,51,44,.04)}.price-chip{border-color:#dfc996;background:#fffaf0}.hero-card{background:var(--ink);color:#fff;padding:23px;border-radius:20px;box-shadow:var(--shadow);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center}.hero-card:before{content:"✦";position:absolute;left:-15px;top:-25px;font-size:120px;color:rgba(255,255,255,.06)}.hero-card h3{margin:0 0 8px;font-size:20px}.hero-card p{color:#cedbd7;font-size:14px;margin:0}.steps{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}.step{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px}.step b{width:27px;height:27px;border-radius:50%;display:grid;place-items:center;background:#fff;border:1px solid var(--line);color:var(--primary)}.main{padding:24px 0 52px}.grid{display:grid;grid-template-columns:minmax(0,1fr) 345px;gap:20px;align-items:start}.card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:0 10px 28px rgba(23,51,44,.05)}.card-head{padding:18px 20px 12px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;justify-content:space-between;gap:15px}.card-head h2,.card-head h3{margin:0;font-size:19px}.card-head p{margin:5px 0 0;color:var(--muted);font-size:13px}.card-body{padding:18px 20px}.legend{display:flex;gap:12px;flex-wrap:wrap;margin:0 0 12px;font-size:12px;color:var(--muted)}.legend span{display:flex;align-items:center;gap:6px}.legend i{width:13px;height:13px;border-radius:50%;display:inline-block;border:1px solid}.legend .av{background:var(--available);border-color:var(--available-border)}.legend .sl{background:var(--selected);border-color:var(--selected)}.legend .pn{background:var(--pending);border-color:var(--pending-border)}.legend .cn{background:var(--confirmed);border-color:var(--confirmed-border)}.seat-rule{font-size:12px;background:#fffbf2;border:1px dashed #ddc38a;color:#755a24;padding:10px 12px;border-radius:11px;margin:0 0 12px}.map-wrap{overflow:auto;padding:4px;border-radius:14px;background:#f8faf9;border:1px solid #e8efed}.seat-map{position:relative;width:1060px;height:790px;margin:auto;background:linear-gradient(180deg,#fbfdfc,#f4f8f6);border-radius:16px;overflow:hidden}.open-center{position:absolute;left:28%;top:12%;width:44%;height:62%;border:1px dashed rgba(198,153,75,.55);border-radius:32px;background:linear-gradient(135deg,rgba(198,153,75,.05),rgba(255,255,255,.35))}.table-node{position:absolute;transform:translate(-50%,-50%);z-index:2}.table-node.horizontal{width:150px;height:82px}.table-node.vertical{width:82px;height:150px}.table-body{position:absolute;background:#fff;border:2px solid #d8e3df;display:grid;place-items:center;text-align:center;font-weight:700;font-size:10px;color:var(--primary);box-shadow:0 4px 10px rgba(23,51,44,.08);z-index:2}.table-body small{display:block;color:var(--muted);font-size:9px}.horizontal .table-body{left:9px;top:27px;width:132px;height:28px;border-radius:8px}.vertical .table-body{left:27px;top:9px;width:28px;height:132px;border-radius:8px;writing-mode:vertical-rl}.seat{position:absolute;width:23px;height:23px;border-radius:50%;border:1px solid var(--available-border);background:var(--available);font-size:9px;display:grid;place-items:center;color:var(--primary-2);transition:.15s;padding:0;z-index:3}.seat:hover{transform:scale(1.15)}.seat.selected{background:var(--selected);border-color:var(--selected);color:#fff;box-shadow:0 0 0 3px rgba(23,91,77,.16)}.seat.pending{background:var(--pending);border-color:var(--pending-border);color:#8b6b1c;cursor:not-allowed}.seat.confirmed{background:var(--confirmed);border-color:var(--confirmed-border);color:#65706f;cursor:not-allowed}.seat.other-table{opacity:.32;cursor:not-allowed}.horizontal .seat{left:calc(4px + (var(--pos) - 1) * 30px)}.horizontal .side-a{top:0}.horizontal .side-b{bottom:0}.vertical .seat{top:calc(4px + (var(--pos) - 1) * 30px)}.vertical .side-a{left:0}.vertical .side-b{right:0}.sticky{position:sticky;top:88px}.summary{display:grid;gap:12px}.summary-stats{display:grid;grid-template-columns:1fr 1fr;gap:9px}.summary-box{border:1px solid var(--line);border-radius:13px;padding:11px;background:#fbfcfc}.summary-box b{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}.summary-box strong{font-size:22px;color:var(--primary)}.selected-tags{display:flex;flex-wrap:wrap;gap:6px;min-height:26px}.tag{font-size:11px;background:#e9f3f0;border:1px solid #c7ded7;padding:4px 7px;border-radius:999px;color:var(--primary-2)}.pattern-message{font-size:12px;border-radius:9px;padding:0}.pattern-message.good{padding:8px 9px;color:#17614f;background:#edf8f4;border:1px solid #b8ded1}.pattern-message.warn{padding:8px 9px;color:#835f18;background:#fff8df;border:1px solid #ead69c}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}.field{display:grid;gap:5px}.field.full{grid-column:1/-1}label{font-size:12px;color:var(--muted);font-weight:700}input,textarea,select{width:100%;border:1px solid var(--line);border-radius:10px;padding:11px;background:#fff;color:var(--ink);outline:none;transition:.2s}input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(23,91,77,.10)}.notice{font-size:12px;color:var(--muted);background:#f8faf9;border:1px dashed #ccd9d5;padding:10px;border-radius:10px}.error{background:#fff1f1;border:1px solid #f0c1c1;color:#943838;padding:10px;border-radius:10px;font-size:13px;display:none}.success{background:#edf8f4;border:1px solid #b8ded1;color:#185e4f;padding:10px;border-radius:10px;font-size:13px;display:none}.lookup{margin-top:20px}.lookup-result{margin-top:12px;font-size:13px}.footer{background:var(--ink);color:#d5e0dd;padding:24px 0;font-size:13px}.modal{position:fixed;inset:0;background:rgba(10,29,25,.66);display:none;align-items:center;justify-content:center;z-index:90;padding:18px}.modal.open{display:flex}.modal-card{width:min(520px,100%);background:#fff;border-radius:19px;padding:24px;box-shadow:var(--shadow);text-align:center}.check{width:62px;height:62px;border-radius:50%;display:grid;place-items:center;background:#eaf6f2;color:var(--primary);font-size:34px;margin:0 auto 12px}.code{font-size:26px;font-weight:800;color:var(--primary);letter-spacing:1px;background:#eef6f3;border:1px dashed #b4d2c9;padding:10px;border-radius:12px;margin:12px 0}.admin-bg{min-height:100vh;background:#f4f6f5}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(440px,100%);background:#fff;border-radius:20px;border:1px solid var(--line);padding:24px;box-shadow:var(--shadow)}.admin-top{background:var(--ink);color:#fff;padding:12px 0}.admin-top .shell{display:flex;align-items:center;justify-content:space-between;gap:15px}.admin-main{padding:24px 0 50px}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}.stat{background:#fff;border:1px solid var(--line);border-radius:15px;padding:15px}.stat b{display:block;color:var(--muted);font-size:12px}.stat strong{display:block;font-size:31px;color:var(--primary)}.toolbar{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:12px}.toolbar input{flex:1;min-width:230px}.table-scroll{overflow:auto}table{width:100%;border-collapse:collapse;font-size:13px;min-width:920px}th,td{text-align:right;padding:11px 9px;border-bottom:1px solid var(--line);vertical-align:top}th{font-size:12px;color:var(--muted);background:#fafcfc}.status{display:inline-flex;padding:4px 8px;border-radius:999px;font-size:11px;font-weight:700}.status.pending_cash{background:#fff3cc;color:#82631b}.status.confirmed{background:#e5f5ef;color:#17614f}.status.cancelled,.status.expired{background:#f1f1f1;color:#6e7472}.actions{display:flex;gap:6px;flex-wrap:wrap}.admin-grid{display:grid;grid-template-columns:1fr;gap:18px}.compact-map .seat-map{transform-origin:top right;transform:scale(.72);margin-bottom:-220px;margin-left:-240px}.hidden{display:none!important}@media(max-width:930px){.hero-grid,.grid{grid-template-columns:1fr}.sticky{position:static}.hero{padding-top:26px}.stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.shell{width:min(100% - 20px,1240px)}.nav-actions .admin-link{display:none}.hero-meta{display:grid}.card-body,.card-head{padding-left:14px;padding-right:14px}.form-grid{grid-template-columns:1fr}.field.full{grid-column:auto}h1{font-size:34px}.lead{font-size:15px}.stats{gap:8px}.stat strong{font-size:24px}}

/* V3 additions */
.admin-mode{display:flex;gap:9px;align-items:center;flex-wrap:wrap;background:#e7f6f1;border:1px solid #a8d5c7;border-radius:12px;padding:10px 12px;margin-bottom:12px;color:#175b4d;font-size:13px}.admin-tip{margin-bottom:14px}.btn-whatsapp{background:#1f9d5a;color:#fff;border-color:#1f9d5a}.btn-whatsapp:hover{filter:brightness(.95)}
.ticket-bg{background:linear-gradient(135deg,#f5f2eb,#e8f0ed);min-height:100vh;padding:28px 14px}.ticket-shell{max-width:760px;margin:auto}.ticket-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow)}.ticket-brand{margin-bottom:20px}.ticket-title{padding:18px 0;border-top:1px dashed var(--line);border-bottom:1px dashed var(--line);margin-bottom:18px}.ticket-title h1{font-size:28px;margin:5px 0}.ticket-grid{display:grid;grid-template-columns:1fr auto;gap:22px;align-items:center}.qr-wrap{background:#fff;border:1px solid var(--line);padding:12px;border-radius:16px;text-align:center}.qr-wrap small{display:block;margin-top:8px;color:var(--muted)}
.scanner-shell{max-width:760px;margin:26px auto;padding:0 14px}.scanner-box{max-width:560px;margin:auto}.manual-check{border-top:1px solid var(--line);margin-top:18px;padding-top:16px}.manual-check label{display:block;margin-bottom:8px;font-weight:700}.manual-row{display:flex;gap:8px}.manual-row input{flex:1}.scan-result{display:none;border-radius:14px;padding:16px;margin-top:16px}.scan-result.good{display:block;background:#e5f5ef;border:1px solid #a7d5c7;color:#175b4d}.scan-result.warn{display:block;background:#fff3cc;border:1px solid #e0c46d;color:#705619}.scan-result.bad{display:block;background:#fce8e8;border:1px solid #e2aaaa;color:#8f3030}.scan-result h3{margin:0 0 8px}.scan-result p{margin:4px 0}
@media(max-width:620px){.ticket-grid{grid-template-columns:1fr}.qr-wrap{width:max-content;max-width:100%;margin:auto}.manual-row{display:grid}.ticket-title h1{font-size:23px}}

/* V3.2 clarity improvements */
.lookup-card{overflow:hidden}.lookup-guide{display:flex;align-items:flex-start;gap:14px;padding:18px 20px;background:linear-gradient(135deg,#eef7f4,#fbfcfb);border-bottom:1px solid var(--line)}.lookup-guide h3{margin:0 0 7px;font-size:19px;color:var(--primary)}.lookup-guide p{margin:0;color:var(--muted);font-size:13px;line-height:1.9}.lookup-icon{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:#fff;border:1px solid var(--line);font-size:20px;flex:0 0 auto}.save-code{background:#fff8df;border:1px solid #ead69c;color:#705619;border-radius:10px;padding:9px 11px;font-size:13px;line-height:1.7}

/* V3.3 - wider non-overlapping U layout and individual PDF ticket controls */
.seat-map{width:1350px;height:1650px;overflow:hidden}.open-center{left:25%;top:9%;width:50%;height:70%;border-radius:42px}.table-node.horizontal{width:220px;height:112px}.table-node.vertical{width:112px;height:220px}.horizontal .table-body{left:12px;top:39px;width:196px;height:34px}.vertical .table-body{left:39px;top:12px;width:34px;height:196px}.seat{width:31px;height:31px;font-size:12px}.horizontal .seat{left:calc(6px + (var(--pos) - 1) * 46px)}.horizontal .side-a{top:0}.horizontal .side-b{bottom:0}.vertical .seat{top:calc(6px + (var(--pos) - 1) * 46px)}.vertical .side-a{left:0}.vertical .side-b{right:0}.compact-map .seat-map{transform-origin:top right;transform:scale(.46);margin-bottom:-870px;margin-left:-720px}.ticket-panel-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.ticket-items{display:grid;gap:10px}.ticket-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:13px;padding:12px;background:#fbfcfc}.ticket-item b,.ticket-item small{display:block}.ticket-item small{color:var(--muted);margin-top:3px}.ticket-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}.ticket-seat-preview{position:relative;width:240px;height:315px;margin:18px auto 0;background:#f7faf9;border:1px solid var(--line);border-radius:16px}.ticket-mini-table{position:absolute;left:88px;top:28px;width:64px;height:260px;border:2px solid #cbdad6;border-radius:14px;background:#fff;display:grid;place-items:center;color:var(--primary);font-weight:700;writing-mode:vertical-rl}.ticket-mini-seat{position:absolute;width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:700;top:calc(35px + (var(--p) - 1) * 54px)}.ticket-mini-seat.left{left:34px}.ticket-mini-seat.right{right:34px}.ticket-mini-seat.muted{background:#e2e7e5;border:1px solid #c2ccca;color:#94a09e}.ticket-mini-seat.active{background:#175b4d;border:2px solid #0e4036;color:#fff;box-shadow:0 0 0 4px rgba(23,91,77,.14)}
@media(max-width:620px){.ticket-item{display:grid}.compact-map .seat-map{transform:scale(.36);margin-bottom:-1050px;margin-left:-850px}}

/* V3.4 - phone-only lookup and clearer payment confirmation */
.phone-lookup-form{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:end}.phone-lookup-form .btn{min-height:43px}.lookup-list{display:grid;gap:10px}.lookup-item{border:1px solid var(--line);border-radius:13px;padding:12px;background:#fbfcfc}.lookup-item-head{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:8px}.lookup-item p{margin:5px 0;color:var(--muted)}.modal-lead{font-size:16px}.payment-callout{display:grid;gap:5px;background:#edf8f4;border:1px solid #b8ded1;border-radius:14px;padding:13px;margin:14px 0;color:#175b4d}.payment-callout strong{font-size:34px}.whatsapp-help{background:#eef7f4;border:1px solid #b8ded1;color:#175b4d;border-radius:12px;padding:10px 12px;font-size:13px;line-height:1.8;margin-bottom:12px}.ticket-item .btn-whatsapp{white-space:nowrap}
@media(max-width:620px){.phone-lookup-form{grid-template-columns:1fr}.lookup-item-head{align-items:flex-start;flex-direction:column}}

/* V3.8 - left/right/top seating layout with empty lower area */
.seat-map{width:min(1120px,100%);height:980px;min-width:820px;overflow:hidden}
.open-center{left:33%;top:26%;width:34%;height:60%;border-radius:34px}
.table-node.table-horizontal{width:208px;height:96px}
.table-node.table-vertical{width:96px;height:208px}
.table-node.table-horizontal .table-body{left:12px;top:34px;width:184px;height:28px;border-radius:8px;writing-mode:horizontal-tb}
.table-node.table-vertical .table-body{left:34px;top:12px;width:28px;height:184px;border-radius:8px;writing-mode:vertical-rl}
.table-node.table-horizontal .seat{width:28px;height:28px;left:calc(6px + (var(--pos) - 1) * 43px);top:auto;right:auto}
.table-node.table-horizontal .side-a{top:0;bottom:auto}
.table-node.table-horizontal .side-b{bottom:0;top:auto}
.table-node.table-vertical .seat{width:28px;height:28px;top:calc(6px + (var(--pos) - 1) * 43px);left:auto;bottom:auto}
.table-node.table-vertical .side-a{left:0;right:auto}
.table-node.table-vertical .side-b{right:0;left:auto}
.seat-name{position:absolute;right:50%;top:100%;transform:translate(50%,5px);max-width:92px;padding:3px 6px;border-radius:7px;background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:0 6px 14px rgba(23,51,44,.12);font-size:10px;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:0;pointer-events:none;z-index:8}
.seat.pending .seat-name,.seat.confirmed .seat-name{opacity:.92}
.seat:hover .seat-name,.seat:focus .seat-name{opacity:1;white-space:normal}
.brand-mark{overflow:hidden;background:#fff;padding:0}
.brand-mark img{width:100%;height:100%;display:block;object-fit:cover;border-radius:50%}
.locked-table{opacity:.56}
.locked-table .table-body{border-style:dashed;background:#f2f4f3;color:#7a8582}
.locked-table .seat{background:#eef0ef;border-color:#cbd3d0;color:#9aa4a1;cursor:not-allowed}
.seat.locked{background:#eef0ef;border-color:#cbd3d0;color:#9aa4a1;cursor:not-allowed}
.active-table .table-body{border-color:var(--primary);box-shadow:0 0 0 4px rgba(23,91,77,.12),0 4px 10px rgba(23,51,44,.08)}
.seat.other-table{opacity:.55;cursor:pointer}
.table-lock{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:6;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:#fff;border:1px solid var(--line);box-shadow:0 6px 14px rgba(23,51,44,.14);font-size:14px}
.compact-map .seat-map{transform-origin:top right;transform:scale(.7);margin-bottom:-300px;margin-left:-240px}
@media(max-width:620px){
  .seat-map{min-width:720px;height:920px}
  .table-node.horizontal,.table-node.vertical{transform:translate(-50%,-50%) scale(.84)}
  .compact-map .seat-map{transform:scale(.5);margin-bottom:-460px;margin-left:-430px}
}


.seat.admin-locked{background:#f1f1f1;border-color:#777;color:#4d4d4d;cursor:pointer}
.legend .lk{background:#f1f1f1;border:1px solid #777}
.seat-admin-tools{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:0 0 12px}
.seat-admin-tools select{min-width:160px;border:1px solid var(--line);border-radius:9px;padding:7px 10px;background:#fff;color:var(--ink)}
.compact-map .seat{cursor:pointer}


/* === v3.12 responsive seat map (fit-to-width, no horizontal scroll) === */
.map-wrap{overflow:hidden;padding:0;background:transparent;border:0;display:flex;justify-content:center}
.seat-map{flex:0 0 auto;position:relative;left:auto;right:auto;margin:0;width:1100px;height:940px;min-width:0;max-width:none;transform-origin:top center;will-change:transform}
@media(max-width:620px){
  .seat-map{min-width:0;height:940px}
  /* the whole canvas now scales as one unit, so per-table scaling is no longer needed */
  .table-node.horizontal,.table-node.vertical{transform:translate(-50%,-50%)}
}

/* V3.13 requested edits: stronger unavailable colors and table public-lock state */
.seat.pending{background:#f59e0b!important;border-color:#b45309!important;color:#fff!important}
.seat.confirmed{background:#b91c1c!important;border-color:#7f1d1d!important;color:#fff!important}
.legend .pn{background:#f59e0b!important;border-color:#b45309!important}
.legend .cn{background:#b91c1c!important;border-color:#7f1d1d!important}
.public-locked-table .table-body{border-style:dashed;background:#fff8df;color:#835f18}
.public-locked-table:after{content:'مقفلة للزوار';position:absolute;left:50%;bottom:-20px;transform:translateX(-50%);font-size:10px;color:#835f18;background:#fff8df;border:1px solid #ead69c;border-radius:999px;padding:2px 7px;white-space:nowrap;z-index:9}
.seat-name{font-weight:700}
.seat.confirmed .seat-name,.seat.pending .seat-name{background:#fff;color:#17332c;border-color:#dbe4e1}


/* === V3.14: clean visible names + standby side tables + mobile auto-fit === */
.table-node{overflow:visible}
.seat-name{display:none!important}
.reservation-label{position:absolute;z-index:9;pointer-events:none;background:rgba(255,255,255,.96);color:#17332c;border:1px solid #dbe4e1;box-shadow:0 5px 14px rgba(23,51,44,.12);font-size:10.5px;font-weight:800;line-height:1.25;text-align:center;padding:4px 7px;border-radius:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}
.table-horizontal .reservation-label{left:calc(6px + (var(--start) - 1) * 43px);width:calc(28px + (var(--span) - 1) * 43px);min-width:58px;max-width:210px}
.table-horizontal .reservation-label.side-a{top:-29px}
.table-horizontal .reservation-label.side-b{bottom:-29px}
.table-vertical .reservation-label{top:calc(6px + (var(--start) - 1) * 43px);height:28px;display:flex;align-items:center;justify-content:center;width:116px;max-width:116px}
.table-vertical .reservation-label.side-a{right:calc(100% + 8px)}
.table-vertical .reservation-label.side-b{left:calc(100% + 8px)}
.inactive-table{opacity:.72;filter:saturate(.65)}
.inactive-table .table-body{border-style:dashed;background:#f3f5f4;color:#6b7471}
.inactive-table .seat,.seat.inactive-seat{background:#edf0ef!important;border-color:#b8c1be!important;color:#7b8582!important;cursor:pointer}
.public-locked-table .table-body,.locked-table .table-body{background:#fbf7ec;border-color:#e6c977}
.seat.pending{background:#f59e0b!important;border-color:#b45309!important;color:#fff!important}
.seat.confirmed{background:#b91c1c!important;border-color:#7f1d1d!important;color:#fff!important}
@media(max-width:760px){
  .shell{width:min(100% - 14px,1240px)}
  .map-wrap{margin-inline:-6px;border-radius:10px}
  .reservation-label{font-size:9.5px;padding:3px 5px}
  .table-horizontal .reservation-label.side-a{top:-25px}
  .table-horizontal .reservation-label.side-b{bottom:-25px}
  .table-vertical .reservation-label{width:92px;max-width:92px;font-size:9px}
  .table-vertical .reservation-label.side-a{right:calc(100% + 4px)}
  .table-vertical .reservation-label.side-b{left:calc(100% + 4px)}
}


/* === V3.15 - reserve side tables and safer responsive layout === */
.seat-map{width:1320px!important;height:940px!important;}
.open-center{left:36%!important;top:21%!important;width:28%!important;height:56%!important;border-radius:38px!important;}
@media(max-width:620px){
  .reservation-label{font-size:8.8px!important;max-width:130px!important;}
  .table-horizontal .reservation-label{min-width:52px!important;}
}


/* === V3.16 — professional side-table layout + small non-overlapping names === */
.seat-map{width:1320px!important;height:1100px!important;}
.open-center{left:37%!important;top:20%!important;width:26%!important;height:66%!important;border-radius:38px!important;}
.table-node{overflow:visible!important;}
.table-node.table-horizontal{width:220px!important;height:112px!important;}
.table-node.table-horizontal .table-body{left:12px!important;top:45px!important;width:196px!important;height:22px!important;border-radius:9px!important;display:flex!important;align-items:center!important;justify-content:center!important;overflow:hidden!important;}
.table-node.table-horizontal .table-body b{font-size:12px!important;line-height:1!important;white-space:nowrap!important;}
.table-node.table-horizontal .table-body small{display:none!important;}
.table-node.table-horizontal .seat{width:28px!important;height:28px!important;left:calc(6px + (var(--pos) - 1) * 43px)!important;font-size:12px!important;z-index:3!important;}
.table-node.table-horizontal .side-a{top:0!important;bottom:auto!important;}
.table-node.table-horizontal .side-b{bottom:0!important;top:auto!important;}
/* For the upper row, names appear below the seat numbers. For the lower row, names appear above the numbers. */
.reservation-label{font-size:7px!important;font-weight:700!important;line-height:1.05!important;padding:1px 3px!important;border-radius:5px!important;box-shadow:0 2px 6px rgba(23,51,44,.10)!important;max-width:112px!important;height:12px!important;display:flex!important;align-items:center!important;justify-content:center!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important;z-index:8!important;}
.table-horizontal .reservation-label{left:calc(6px + (var(--start) - 1) * 43px)!important;width:calc(28px + (var(--span) - 1) * 43px)!important;min-width:28px!important;max-width:200px!important;}
.table-horizontal .reservation-label.side-a{top:31px!important;bottom:auto!important;}
.table-horizontal .reservation-label.side-b{bottom:31px!important;top:auto!important;}
.table-vertical .reservation-label{font-size:6.5px!important;width:44px!important;max-width:44px!important;height:14px!important;padding:1px 2px!important;}
.table-vertical .reservation-label.side-a{right:calc(100% + 3px)!important;left:auto!important;}
.table-vertical .reservation-label.side-b{left:calc(100% + 3px)!important;right:auto!important;}
.table-node.table-vertical .table-body small{display:none!important;}
@media(max-width:760px){
  .reservation-label{font-size:6.2px!important;height:11px!important;padding:0 2px!important;}
  .table-horizontal .reservation-label.side-a{top:30px!important;}
  .table-horizontal .reservation-label.side-b{bottom:30px!important;}
  .table-vertical .reservation-label{font-size:5.8px!important;width:38px!important;max-width:38px!important;}
}


/* === V3.17 — reserve tables shifted between existing tables + cleaner labels === */
.table-body small{display:none!important;}
/* Keep the printed names very small; full name appears when pressing a booked seat. */
.reservation-label{font-size:6.3px!important;height:11px!important;max-width:96px!important;}
.table-horizontal .reservation-label.side-a{top:31px!important;}
.table-horizontal .reservation-label.side-b{bottom:31px!important;}
.seat.pending,.seat.confirmed{cursor:pointer!important;}


/* === V3.18 — full responsive layout for all mobile screen sizes === */
html,body{max-width:100%;overflow-x:hidden}
img,svg,video,canvas{max-width:100%;height:auto}
.nav .shell,.admin-top .shell{flex-wrap:wrap}
.nav-actions{flex-wrap:wrap;justify-content:flex-end}.nav-actions .btn{white-space:nowrap}
.map-wrap{overflow-x:auto!important;overflow-y:hidden!important;justify-content:flex-start!important;-webkit-overflow-scrolling:touch;touch-action:pan-x pan-y;overscroll-behavior-x:contain;padding:8px!important;border:1px solid #e8efed!important;background:#f8faf9!important;scrollbar-width:thin}
.map-wrap:before{content:'اسحب يميناً ويساراً لرؤية كل الطاولات';position:sticky;right:10px;top:8px;z-index:30;display:inline-block;background:rgba(255,255,255,.92);border:1px solid #dbe4e1;color:#60736e;border-radius:999px;padding:3px 9px;font-size:11px;box-shadow:0 4px 10px rgba(23,51,44,.08)}
.map-wrap:not(.map-needs-scroll):before{display:none}.seat-map{transform-origin:top center!important;margin:0 auto!important}.compact-map .seat-map{margin:0 auto!important;transform-origin:top center!important}.seat,.btn,input,select,textarea{touch-action:manipulation}.reservation-label{pointer-events:none!important}.seat{min-width:28px;min-height:28px}
@media(max-width:930px){.hero-grid,.grid{grid-template-columns:1fr!important}.sticky{position:static!important;top:auto}.main{padding-top:14px}.card{border-radius:15px}.map-wrap{margin-inline:-4px}.summary{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2,1fr)!important}.toolbar{display:grid;grid-template-columns:1fr;gap:8px}.toolbar input{min-width:0}.seat-admin-tools{display:grid!important;grid-template-columns:1fr 1fr;gap:8px}.seat-admin-tools select{grid-column:1/-1;width:100%}}
@media(max-width:640px){.shell{width:min(100% - 12px,1240px)!important}.topbar{font-size:11px}.topbar .shell{gap:8px}.nav .shell{padding:9px 0}.brand{gap:8px;font-size:14px}.brand-mark{width:38px;height:38px}.brand small{font-size:10px}.nav-actions{gap:6px}.btn{width:100%;padding:10px 12px}.nav-actions .btn{width:auto;font-size:12px;padding:8px 9px}.hero{padding:20px 0 14px}.hero-card{padding:16px}.hero-meta{display:grid;grid-template-columns:1fr;gap:7px}.steps{display:grid;gap:7px}h1{font-size:clamp(25px,8vw,34px)!important}.lead{font-size:14px!important}.card-head{display:grid;gap:7px;padding:13px 12px}.card-body{padding:12px!important}.legend{gap:7px;font-size:10px}.seat-rule{font-size:11px;padding:8px}.form-grid{grid-template-columns:1fr!important}.field.full{grid-column:auto!important}.summary-stats{grid-template-columns:1fr 1fr}.summary-box{padding:9px}.summary-box strong{font-size:19px}.selected-tags{max-height:90px;overflow:auto}.modal-card{padding:16px}.code{font-size:19px;word-break:break-all}.phone-lookup-form{grid-template-columns:1fr!important}.lookup-item-head{flex-direction:column;align-items:flex-start}.table-scroll{overflow-x:auto}.table-scroll table{min-width:760px}.stats{grid-template-columns:1fr 1fr!important}.stat{padding:10px}.stat strong{font-size:22px}.actions .btn{width:auto}.seat-admin-tools{grid-template-columns:1fr!important}.reservation-label{font-size:5.8px!important;height:10px!important;max-width:88px!important}.table-horizontal .reservation-label.side-a{top:31px!important}.table-horizontal .reservation-label.side-b{bottom:31px!important}.table-vertical .reservation-label{font-size:5.4px!important;width:34px!important;max-width:34px!important}}
@media(max-width:380px){.shell{width:min(100% - 8px,1240px)!important}.btn{font-size:12px}.card-head h2,.card-head h3{font-size:16px}.summary-stats{grid-template-columns:1fr}.seat-rule,.notice{font-size:10.5px}.map-wrap{padding:6px!important}.map-wrap:before{font-size:10px;right:6px}.reservation-label{font-size:5.2px!important;max-width:78px!important}.table-node.table-horizontal .table-body b{font-size:10px!important}.table-node.table-horizontal .seat{font-size:11px!important}}

/* === V3.19 — fixed sideways map scroll + mobile summary fit === */
.grid,.grid > *, .sticky, .card, .card-body{min-width:0!important;}
.map-wrap{
  display:block!important;
  width:100%!important;
  max-width:100%!important;
  overflow:auto!important;
  overflow-x:scroll!important;
  overflow-y:auto!important;
  direction:ltr!important;
  -webkit-overflow-scrolling:touch!important;
  touch-action:auto!important;
  overscroll-behavior:contain!important;
  padding:8px!important;
  border:1px solid #e8efed!important;
  background:#f8faf9!important;
  border-radius:14px!important;
  scrollbar-width:auto!important;
}
.map-wrap::-webkit-scrollbar{height:12px;width:12px;}
.map-wrap::-webkit-scrollbar-thumb{background:#b7c7c2;border-radius:999px;border:2px solid #f8faf9;}
.map-wrap::-webkit-scrollbar-track{background:#edf3f1;border-radius:999px;}
.map-wrap:before{display:block!important;content:'اسحب يميناً ويساراً وللأعلى والأسفل لرؤية كل الطاولات'!important;position:sticky!important;right:auto!important;left:10px!important;top:8px!important;z-index:40!important;width:max-content!important;max-width:calc(100vw - 40px)!important;margin-bottom:6px!important;direction:rtl!important;}
.seat-map{
  direction:rtl!important;
  width:1320px!important;
  height:1100px!important;
  min-width:1320px!important;
  max-width:none!important;
  flex:0 0 1320px!important;
  transform:none!important;
  margin:0!important;
  position:relative!important;
}
.compact-map .seat-map{transform:none!important;margin:0!important;}
.summary{width:100%!important;max-width:100%!important;overflow:hidden!important;}
.summary-box,.summary-stats,.form-grid,.selected-tags,.pattern-message,.notice,.error,.success{max-width:100%!important;min-width:0!important;}
.selected-tags{overflow-x:auto!important;white-space:normal!important;}
.tag{max-width:100%;overflow:hidden;text-overflow:ellipsis;}
#bookingForm input,#bookingForm button{max-width:100%!important;}
@media(max-width:930px){
  .grid{grid-template-columns:minmax(0,1fr)!important;}
  .sticky{width:100%!important;max-width:100%!important;}
  .sticky .card{width:100%!important;max-width:100%!important;}
  .map-wrap{height:64vh!important;min-height:360px!important;max-height:680px!important;}
}
@media(max-width:640px){
  .shell{width:calc(100% - 10px)!important;}
  .main{padding-bottom:22px!important;}
  .card{width:100%!important;max-width:100%!important;}
  .map-wrap{height:62vh!important;min-height:340px!important;margin-inline:0!important;padding:6px!important;}
  .card-body.summary{padding:10px!important;gap:9px!important;}
  .summary-stats{grid-template-columns:1fr 1fr!important;gap:7px!important;}
  .summary-box{padding:8px!important;border-radius:11px!important;}
  .summary-box b{font-size:10.5px!important;}
  .summary-box strong{font-size:18px!important;}
  .selected-tags{max-height:74px!important;}
  .form-grid{gap:8px!important;}
  input,textarea,select{padding:9px!important;border-radius:9px!important;}
  .notice{font-size:10.5px!important;padding:8px!important;}
  #submitBooking{width:100%!important;}
}
@media(max-width:380px){
  .map-wrap{height:60vh!important;min-height:320px!important;}
  .summary-stats{grid-template-columns:1fr!important;}
  .selected-tags{max-height:64px!important;}
}


/* === V3.20 — zoomable map only, rest of site unchanged === */
.map-zoom-controls{
  display:flex!important;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  justify-content:flex-start;
  direction:rtl;
  margin:0 0 10px;
}
.map-zoom-controls .btn{padding:7px 10px;font-size:12px;border-radius:9px;}
.zoom-readout{font-size:12px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:999px;padding:5px 10px;}
.map-wrap{
  overflow:auto!important;
  overflow-x:auto!important;
  overflow-y:auto!important;
  touch-action:pan-x pan-y!important;
  -webkit-overflow-scrolling:touch!important;
}
.map-wrap:before{content:'الخريطة تبدأ مصغّرة. استخدم الأزرار للتكبير، ثم اسحب يميناً ويساراً.'!important;}
.seat-map{
  width:1320px!important;
  height:1100px!important;
  min-width:1320px!important;
  transform:none!important;
  transform-origin:top left!important;
}
.compact-map .seat-map{transform:none!important;}
@media(max-width:640px){
  .map-zoom-controls{position:sticky;top:64px;z-index:45;background:rgba(255,255,255,.94);padding:6px;border:1px solid var(--line);border-radius:12px;box-shadow:0 6px 16px rgba(23,51,44,.08)}
  .map-zoom-controls .btn{flex:1 1 28%;min-width:84px;padding:8px 6px;font-size:11px;}
  .zoom-readout{flex:1 1 100%;text-align:center;font-size:11px;}
  .map-wrap{height:62vh!important;min-height:330px!important;}
}

/* === V3.21 — mobile gesture-only map zoom === */
.map-wrap{
  overscroll-behavior:contain!important;
}
@media(max-width:768px){
  .map-zoom-controls{
    display:none!important;
  }
  .map-wrap{
    touch-action:none!important;
    cursor:grab;
    height:62vh!important;
    min-height:340px!important;
  }
  .map-wrap:before{
    content:'استخدم إصبعين للتكبير والتصغير، واسحب بإصبع واحد لتحريك الخريطة.'!important;
  }
}

/* V3.22 — half/full table quick booking (5 or 10 persons) */
.call-note{background:#fff7e8;border:1px solid #e6c98a;color:#6b521c;border-style:solid}
.call-note b{color:#9a6b12}
.quick-book{border:1px solid var(--line);border-radius:14px;padding:14px;background:#fbfcfc}
.quick-book-label{margin:0 0 10px;font-size:13px;color:var(--muted);font-weight:700}
.quick-book-label b{color:var(--primary);font-weight:800}
.quick-book-buttons{display:flex;gap:10px}
.qb-btn{flex:1;flex-direction:column;gap:2px;padding:13px 8px;font-size:19px;line-height:1.1}
.qb-btn small{font-weight:500;font-size:11px;opacity:.85}
.qb-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.qb-btn:disabled:hover{transform:none}

/* V3.22 admin — single primary WhatsApp send button + collapsed extras */
.btn-send-main{width:100%;font-size:18px;padding:15px 16px}
.advanced-send{margin:0 0 14px;font-size:13px}
.advanced-send>summary{cursor:pointer;color:var(--muted);padding:6px 2px;user-select:none;list-style:none}
.advanced-send>summary::-webkit-details-marker{display:none}
.advanced-send>summary:before{content:"▾ ";opacity:.7}
.advanced-send>summary:hover{color:var(--ink)}
.advanced-send .ticket-panel-actions{margin-top:8px;margin-bottom:4px}

/* V3.23 — committee contact list inside the call note */
.call-note .contact-list{list-style:none;margin:8px 0 0;padding:0;display:grid;gap:6px}
.call-note .contact-list li{display:flex;justify-content:space-between;align-items:center;gap:10px;background:#fff;border:1px solid #ecd9ab;border-radius:9px;padding:7px 11px}
.call-note .contact-name{font-weight:700;color:#6b521c}
.call-note .contact-phone{font-weight:800;color:var(--primary);white-space:nowrap}
