@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--font-sans: "Inter", system-ui, -apple-system, sans-serif;--sidebar-width: 260px;--header-height: 60px;--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--transition: .2s ease}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-card: #ffffff;--bg-hover: #f1f5f9;--bg-elevated: #ffffff;--accent: #0ea5e9;--accent-dim: #0284c7;--accent-glow: rgba(14, 165, 233, .2);--accent-secondary: #6366f1;--text-primary: #0f172a;--text-secondary: #64748b;--text-muted: #94a3b8;--border: #e2e8f0;--border-subtle: #f1f5f9;--border-focus: var(--accent);--success: #22c55e;--warning: #eab308;--error: #ef4444;--info: #3b82f6;--danger: #ef4444;--shadow: 0 1px 3px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1);--chart-bg: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);--chart-grid: rgba(148, 163, 184, .2);--chart-axis: #64748b;--chart-tooltip-bg: #ffffff;--chart-tooltip-border: #e2e8f0;--chart-bar: #0ea5e9;--chart-bar-soft: rgba(14, 165, 233, .3);--chart-bar-alt: #6366f1;--chart-pie-muted: #e2e8f0;--chart-glow: 0 0 0 1px rgba(14, 165, 233, .1);--btn-primary-text: #ffffff;--accent-bg: rgba(14, 165, 233, .12)}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: #1e293b;--bg-hover: #334155;--bg-elevated: #334155;--accent: #38bdf8;--accent-dim: #0ea5e9;--accent-glow: rgba(56, 189, 248, .2);--accent-secondary: #818cf8;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--border: #334155;--border-subtle: #1e293b;--border-focus: var(--accent);--success: #22c55e;--warning: #eab308;--error: #f87171;--info: #60a5fa;--danger: #f87171;--shadow: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--chart-bg: linear-gradient(180deg, #1e293b 0%, #0f172a 100%);--chart-grid: rgba(148, 163, 184, .15);--chart-axis: #64748b;--chart-tooltip-bg: #1e293b;--chart-tooltip-border: #334155;--chart-bar: #38bdf8;--chart-bar-soft: rgba(56, 189, 248, .3);--chart-bar-alt: #818cf8;--chart-pie-muted: #334155;--chart-glow: 0 0 24px rgba(56, 189, 248, .15);--btn-primary-text: #0f172a;--accent-bg: rgba(56, 189, 248, .12)}html:not([data-theme]){color-scheme:light}html[data-theme=light]{color-scheme:light}html[data-theme=dark]{color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}a{color:var(--accent-secondary);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent)}button{font-family:inherit;cursor:pointer;border:none;border-radius:var(--radius);transition:all var(--transition)}input,select,textarea{font-family:inherit;font-size:1rem}.page-wrapper{animation:pageFadeIn .3s ease}@keyframes pageFadeIn{0%{opacity:0}to{opacity:1}}.page-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.page-header h2{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.page-header.dashboard-header{flex-direction:column;align-items:flex-start}.page-header.dashboard-header .dashboard-period-filter{width:100%;margin-top:1rem}.section-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.plan-card{padding:1.5rem}.plan-name{margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.plan-price{margin-bottom:1rem}.plan-features{margin:0 0 1rem;padding-left:1.25rem;color:var(--text-secondary);font-size:.9rem;line-height:1.6}.plan-max-units{font-size:.85rem;color:var(--text-muted)}.page-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-secondary)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);transition:all var(--transition)}.theme-toggle:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent)}.app-layout{display:flex;min-height:100vh}.app-sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column}.app-main{flex:1;display:flex;flex-direction:column;min-width:0}.app-content{flex:1;padding:1.75rem;overflow:auto}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:all var(--transition)}.kpi-card:hover{border-color:var(--accent-dim);box-shadow:var(--shadow)}.kpi-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem;font-weight:500}.kpi-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.chart-card{background:var(--chart-bg);box-shadow:var(--chart-glow);position:relative;overflow:hidden;border-radius:var(--radius-lg);border:1px solid var(--border)}.chart-card:before{content:"";position:absolute;inset:-40%;background:radial-gradient(circle at top left,var(--accent-glow),transparent 60%),radial-gradient(circle at bottom right,var(--chart-bar-soft),transparent 65%);opacity:.6;pointer-events:none}.chart-inner{position:relative;z-index:1}.chart-card--glass{backdrop-filter:blur(18px) saturate(120%);-webkit-backdrop-filter:blur(18px) saturate(120%);background:var(--chart-bg);box-shadow:var(--chart-glow),var(--shadow-lg)}.chart-title{margin:0 0 1rem;font-size:.9rem;font-weight:600;letter-spacing:.02em;color:var(--text-secondary)}.chart-card-header{display:flex;align-items:center;justify-content:space-between}.chart-card-body{height:100%;display:flex}.chart-card-body-inner{flex:1}.chart-skeleton{width:100%;height:100%;border-radius:var(--radius);background:linear-gradient(90deg,var(--chart-bar-soft) 0%,var(--chart-bar) 50%,var(--chart-bar-soft) 100%);background-size:200% 100%;animation:chartSkeleton 1.2s ease-in-out infinite;opacity:.4}.chart-empty-state{width:100%;text-align:center;color:var(--text-muted);font-size:.9rem;padding:2rem .5rem}.chart-tooltip{font-size:.875rem}.dashboard-charts-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem}.dashboard-period-filter{margin-bottom:0;padding:.75rem 1rem}.period-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.period-btn{padding:.5rem 1rem;font-size:.875rem;font-weight:500}.period-btn--active{background:var(--accent);color:var(--btn-primary-text);border:1px solid var(--accent)}.period-btn--active:hover{background:var(--accent-dim);border-color:var(--accent-dim)}.period-date-range{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.period-date-range .filter-date{min-width:140px}.period-date-sep{font-size:.875rem;color:var(--text-secondary)}@keyframes chartSkeleton{0%{background-position:200% 0}to{background-position:-200% 0}}.btn{padding:.5rem 1rem;font-weight:500;border-radius:var(--radius);font-size:.9rem}.btn-primary{background:var(--accent);color:var(--btn-primary-text)}.btn-primary:hover:not(:disabled){background:var(--accent-dim);filter:brightness(1.05);box-shadow:0 0 0 2px var(--accent-glow)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-muted)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.375rem}.form-input{width:100%;padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);transition:border-color var(--transition),box-shadow var(--transition)}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.form-input::placeholder{color:var(--text-muted)}.modal-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);max-width:480px;width:100%;max-height:90vh;overflow:auto;animation:slideUp .25s ease;box-shadow:var(--shadow-lg)}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:1.125rem;font-weight:600}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.filter-bar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;margin-bottom:1.25rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg)}.filter-search{flex:1;min-width:200px;max-width:280px}.filter-select,.filter-date{width:auto;min-width:140px}.pagination-bar{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;margin-top:1.25rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg)}.pagination-info{font-size:.875rem;color:var(--text-secondary)}.pagination-controls{display:flex;align-items:center;gap:.75rem}.pagination-per-page{width:auto;min-width:120px}.pagination-page{font-size:.875rem;color:var(--text-secondary)}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.875rem 1.25rem;text-align:left;border-bottom:1px solid var(--border)}.table th{background:var(--bg-tertiary);font-weight:600;font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--bg-hover)}.table .link{color:var(--accent);font-weight:500}.table .link:hover{color:var(--accent-dim);text-decoration:underline}.toast-error{background:var(--error);color:#fff;padding:.75rem 1rem;border-radius:var(--radius);font-size:.9rem}.toast-success{background:var(--success);color:#fff;padding:.75rem 1rem;border-radius:var(--radius);font-size:.9rem}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.app-sidebar{width:72px}.app-content{padding:1rem}.kpi-grid{grid-template-columns:repeat(2,1fr)}.dashboard-charts-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}}.sidebar-brand{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.875rem}.brand-icon{font-size:1.75rem;filter:grayscale(.2)}.brand-text{font-weight:700;font-size:1.15rem;color:var(--text-primary);letter-spacing:-.02em}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.nav-item{display:block;padding:.75rem 1.5rem;color:var(--text-secondary);font-size:.95rem;font-weight:500;transition:all var(--transition);margin:0 .75rem;border-radius:var(--radius)}.nav-item:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-item.active{color:var(--accent);background:var(--accent-bg);border-left:3px solid var(--accent);margin-left:.75rem;padding-left:calc(1.5rem - 3px)}.sidebar-footer{padding:1.25rem 1.5rem;border-top:1px solid var(--border)}.user-info{display:flex;flex-direction:column;margin-bottom:.75rem}.user-name{font-weight:600;font-size:.9rem}.user-role{font-size:.75rem;color:var(--text-muted);text-transform:capitalize}.profile-link{display:inline-block;margin-top:.5rem;font-size:.85rem;color:var(--accent-secondary);text-decoration:none;transition:color var(--transition)}.profile-link:hover{color:var(--accent)}.profile-link.active{color:var(--accent);font-weight:600}.logout-btn{width:100%;justify-content:center;padding:.625rem;color:var(--text-secondary);font-size:.875rem}.logout-btn:hover{background:#ef444426;color:var(--error)}.app-header{height:var(--header-height);padding:0 1.75rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--bg-secondary)}.page-title{margin:0;font-size:1.25rem;font-weight:600;letter-spacing:-.02em}@media(max-width:768px){.brand-text,.user-info,.nav-item span{display:none}.sidebar-brand{justify-content:center;padding:1rem}.nav-item{padding:.875rem;text-align:center;margin:0 .5rem}.nav-item.active{margin-left:.5rem;padding-left:.875rem;border-left:none;border-bottom:3px solid var(--accent)}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:1.5rem;position:relative;overflow:hidden}.auth-page:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 50% 0%,var(--accent-glow),transparent 60%);pointer-events:none;opacity:.5}.auth-theme-toggle{position:absolute;top:1rem;right:1rem;z-index:10}.auth-card{width:100%;max-width:420px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-lg);position:relative;z-index:1}.auth-brand{text-align:center;margin-bottom:2rem}.auth-brand-icon{font-size:3rem;display:block;margin-bottom:.75rem}.auth-brand h1{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;letter-spacing:-.02em}.auth-brand p{margin:0;color:var(--text-secondary);font-size:.9rem}.auth-form .form-group:last-of-type{margin-bottom:1.25rem}.auth-link{display:block;text-align:center;margin-top:1.25rem;font-size:.9rem;color:var(--accent-secondary)}.auth-link:hover{color:var(--accent);text-decoration:underline}.password-input-wrapper{position:relative}.password-input-wrapper .form-input{padding-right:3rem}.password-toggle{position:absolute;top:50%;right:.75rem;transform:translateY(-50%);border:none;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:.8rem;font-weight:500}.password-toggle:hover{color:var(--accent)}.table-floor-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.table-floor-header h2{margin:0}.table-floor-filters{display:flex;flex-wrap:wrap;gap:.5rem}.table-floor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem}.table-card{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:.75rem;cursor:pointer;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition)}.table-card:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 8px 24px var(--accent-glow)}.table-card--occupied{border-color:#eab30880}.table-card--paused{border-color:#3b82f680}.table-card-eye{position:absolute;top:.65rem;right:.65rem;z-index:2;width:34px;height:34px;border-radius:50%;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition),color var(--transition)}.table-card-eye:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.table-visual{position:relative;width:100%;aspect-ratio:2 / 1;border-radius:12px;background:linear-gradient(145deg,#1a5f3f,#0f4a30,#1a6b47);border:6px solid #8b5a2b;box-shadow:inset 0 0 20px #00000059,0 4px 12px #00000040;margin-bottom:.75rem}.table-visual:before,.table-visual:after{content:"";position:absolute;width:14px;height:14px;background:#111;border-radius:50%;box-shadow:inset 0 1px 2px #ffffff26}.table-visual:before{top:6px;left:6px;box-shadow:calc(100% + 0px) 0 0 0 #111,0 calc(100% + 0px) 0 0 #111,calc(100% + 0px) calc(100% + 0px) 0 0 #111}.table-visual-center{position:absolute;inset:18% 22%;border:1px solid rgba(255,255,255,.12);border-radius:4px;pointer-events:none}.table-visual-spot{position:absolute;top:25%;left:25%;width:8px;height:8px;background:#fff;border-radius:50%;opacity:.9}.table-card-meta{display:flex;flex-direction:column;gap:.25rem}.table-card-name{font-weight:600;font-size:1rem;color:var(--text-primary)}.table-card-type{font-size:.8rem;color:var(--text-secondary)}.table-status-badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.75rem;font-weight:600;padding:.2rem .55rem;border-radius:999px;width:fit-content;margin-top:.25rem}.table-status-badge--available{background:#22c55e26;color:var(--success)}.table-status-badge--occupied{background:#eab30826;color:var(--warning)}.table-status-badge--paused{background:#3b82f626;color:var(--info)}.table-status-badge--maintenance{background:#ef44441f;color:var(--error)}.table-modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.table-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:1.5rem;width:min(100%,420px);box-shadow:0 20px 50px #00000040}.table-modal h3{margin:0 0 .35rem}.table-modal-sub{color:var(--text-secondary);font-size:.9rem;margin:0 0 1.25rem}.table-modal-actions{display:flex;flex-direction:column;gap:.65rem}.table-detail-list{margin:0 0 1rem;padding:0;list-style:none;display:flex;flex-direction:column;gap:.5rem}.table-detail-list li{display:flex;justify-content:space-between;gap:1rem;font-size:.9rem;padding-bottom:.35rem;border-bottom:1px solid var(--border-subtle)}.table-detail-list span:first-child{color:var(--text-secondary)}.table-floor-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.customer-pay-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:linear-gradient(145deg,#0f172a,#1e293b,#0f172a)}.customer-pay-card{width:100%;max-width:440px;background:var(--card-bg, #fff);border-radius:16px;padding:1.75rem;box-shadow:0 20px 50px #00000059}.customer-pay-brand{display:flex;gap:1rem;align-items:center;margin-bottom:1.5rem}.customer-pay-brand span{font-size:2.5rem}.customer-pay-brand h1{margin:0;font-size:1.35rem}.customer-pay-brand p{margin:.25rem 0 0;color:var(--text-secondary, #64748b);font-size:.9rem}.customer-pay-error{background:#fef2f2;color:#b91c1c;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.customer-pay-btn{width:100%;margin-top:.5rem}.customer-pay-summary{margin-top:1.25rem;padding:1rem;background:var(--bg-secondary, #f8fafc);border-radius:10px}.customer-pay-due{font-size:1.35rem;font-weight:700;color:#b91c1c;margin:.5rem 0 0}.moyasar-form-wrap{margin-top:1.25rem;min-height:120px}.customer-layout{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.customer-header{display:flex;align-items:center;gap:1.5rem;padding:.75rem 1.5rem;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-wrap:wrap}.customer-header-brand{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.05rem}.customer-header-nav a{color:var(--text-secondary);text-decoration:none;padding:.35rem .75rem;border-radius:var(--radius-md)}.customer-header-nav a.active{color:var(--accent);background:var(--accent-glow)}.customer-header-actions{margin-left:auto;display:flex;align-items:center;gap:.75rem}.customer-user-name{color:var(--text-secondary);font-size:.9rem}.customer-main{flex:1;padding:1.5rem}@media(max-width:640px){.customer-header{gap:.75rem}.customer-header-actions{width:100%;justify-content:flex-end}}
