*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #020617;--surface: #0f172a;--surface2: #1e293b;--border: rgba(255,255,255,.08);--border-hover: rgba(16,185,129,.3);--text: #f1f5f9;--text2: #94a3b8;--text3: #475569;--emerald: #10b981;--amber: #f59e0b;--red: #ef4444;--purple: #8b5cf6;--blue: #3b82f6}html{background:var(--bg);color:var(--text);font-family:Sarabun,sans-serif}body{min-height:100vh;background:var(--bg)}nav{position:sticky;top:0;z-index:50;background:#020617e6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}.nav-inner{max-width:800px;margin:0 auto;padding:0 16px;height:60px;display:flex;align-items:center;justify-content:space-between}.nav-brand{display:flex;align-items:center;gap:8px;text-decoration:none}.nav-logo{width:34px;height:34px;background:linear-gradient(135deg,#059669,#10b981);border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.1rem;color:#fff}.nav-brand span{font-weight:700;font-size:1rem;color:var(--text)}.nav-actions{display:flex;align-items:center;gap:10px}.btn-ghost{background:none;border:1px solid var(--border);color:var(--text2);padding:6px 14px;border-radius:8px;font-size:.82rem;cursor:pointer;transition:all .2s;font-family:inherit}.btn-ghost:hover{border-color:var(--border-hover);color:var(--text)}main{max-width:800px;margin:0 auto;padding:24px 16px 80px}h1{font-size:1.6rem;font-weight:700;margin-bottom:6px}.subtitle{color:var(--text2);font-size:.88rem;margin-bottom:24px}.filter-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;margin-bottom:24px}.filter-tabs::-webkit-scrollbar{display:none}.filter-tab{padding:8px 18px;border-radius:9999px;font-size:.82rem;font-weight:600;cursor:pointer;border:1px solid var(--border);background:#ffffff0d;color:var(--text2);white-space:nowrap;transition:all .2s;font-family:inherit}.filter-tab.active{background:var(--emerald);color:#fff;border-color:transparent;box-shadow:0 4px 15px #10b9814d}.filter-tab:hover:not(.active){background:#ffffff1a;border-color:#ffffff26;color:var(--text)}.booking-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px;margin-bottom:16px;transition:border-color .2s,box-shadow .2s}.booking-card:hover{border-color:var(--border-hover);box-shadow:0 8px 30px #0000004d}.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}.shop-name{font-size:1.05rem;font-weight:700;color:var(--text)}.service-name{font-size:.83rem;color:var(--text2);margin-top:3px}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:9999px;font-size:.75rem;font-weight:700}.badge-pending{background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.2)}.badge-confirmed{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.2)}.badge-completed{background:#3b82f626;color:#60a5fa;border:1px solid rgba(59,130,246,.2)}.badge-cancelled,.badge-declined{background:#ef44441f;color:#f87171;border:1px solid rgba(239,68,68,.2)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.detail-item label{display:block;font-size:.72rem;color:var(--text3);margin-bottom:2px}.detail-item span{font-size:.88rem;font-weight:600;color:var(--text)}.detail-item .price{color:var(--emerald);font-size:1rem}.late-warn{background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:10px;padding:10px 14px;font-size:.78rem;color:#fbbf24;margin-bottom:12px;display:flex;gap:8px;align-items:flex-start}.card-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-sm{padding:8px 16px;border-radius:10px;font-size:.8rem;font-weight:600;cursor:pointer;border:none;font-family:inherit;transition:all .2s;text-decoration:none;display:inline-flex;align-items:center;gap:5px}.btn-cancel{background:#ef44441f;color:#fca5a5}.btn-cancel:hover{background:#ef444440}.btn-review{background:#f59e0b26;color:#fbbf24}.btn-review:hover{background:#f59e0b4d}.btn-bookagain{background:#10b98126;color:#10b981}.btn-bookagain:hover{background:#10b9814d}.btn-view{background:#ffffff12;color:var(--text2)}.btn-view:hover{background:#ffffff24}.loading{text-align:center;padding:60px 20px}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--emerald);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;padding:60px 20px}.empty-icon{font-size:3rem;margin-bottom:12px}.empty h3{font-size:1.1rem;font-weight:700;color:var(--text2);margin-bottom:6px}.empty p{color:var(--text3);font-size:.88rem;margin-bottom:20px}.btn-primary{background:var(--emerald);color:#fff;padding:10px 24px;border-radius:12px;font-weight:700;text-decoration:none;font-size:.88rem;display:inline-block;transition:opacity .2s}.btn-primary:hover{opacity:.85}.modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s}.modal-backdrop.open{opacity:1;pointer-events:auto}.modal{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:28px;max-width:420px;width:100%}.modal h3{font-size:1.1rem;font-weight:700;margin-bottom:8px}.modal p{color:var(--text2);font-size:.85rem;margin-bottom:16px}.modal textarea{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:10px 14px;color:var(--text);font-family:inherit;font-size:.85rem;resize:vertical;min-height:80px;outline:none}.modal textarea:focus{border-color:var(--border-hover)}.modal-actions{display:flex;gap:10px;margin-top:16px}.modal-actions button{flex:1;padding:10px;border-radius:10px;font-weight:600;cursor:pointer;font-family:inherit;border:none;font-size:.85rem}.btn-modal-cancel-dismiss{background:var(--surface2);color:var(--text2)}.btn-modal-cancel-confirm{background:var(--red);color:#fff}.policy-box{background:#ef444414;border:1px solid rgba(239,68,68,.15);border-radius:10px;padding:10px 14px;font-size:.77rem;color:#fca5a5;margin-bottom:12px}
