*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #f5f5f5;--card: #ffffff;--primary: #2563eb;--primary-light: #dbeafe;--text: #1a1a1a;--text-sub: #6b7280;--border: #e5e7eb;--danger: #ef4444;--success: #10b981;--warning: #f59e0b;--radius: 12px;--shadow: 0 1px 3px rgba(0,0,0,.08)}html{font-size:16px;overflow-y:scroll}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;min-height:100dvh}.layout{display:flex;flex-direction:column;min-height:100dvh}.main-content{flex:1}.nav-brand,.nav-logout{display:none}.nav{display:flex;background:var(--card);border-top:1px solid var(--border);position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:1200px;z-index:100;box-shadow:0 -1px 4px #0000000f}.nav a{flex:1;display:flex;flex-direction:column;align-items:center;padding:8px 0 calc(8px + env(safe-area-inset-bottom));text-decoration:none;color:var(--text-sub);font-size:11px;gap:2px;transition:color .15s}.nav a.active{color:var(--primary);font-weight:600}.nav a svg{width:22px;height:22px}.page{padding:16px;padding-bottom:calc(80px + env(safe-area-inset-bottom))}.page-title{font-size:22px;font-weight:700;margin-bottom:16px;display:flex;align-items:center}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:12px}.card-title{font-size:15px;font-weight:600;margin-bottom:8px}.card-sub{font-size:13px;color:var(--text-sub)}.tag{display:inline-block;padding:3px 8px;border-radius:6px;font-size:12px;font-weight:500}.tag-flight{background:#dbeafe;color:#1d4ed8}.tag-hotel{background:#fef3c7;color:#92400e}.tag-package{background:#d1fae5;color:#065f46}.list-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border)}.list-item:last-child{border-bottom:none}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .15s;white-space:nowrap}.btn:active{opacity:.7}.btn-primary{background:var(--primary);color:#fff}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:6px 12px;font-size:13px}.btn-block{width:100%}.btn-icon{width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-sub);cursor:pointer;font-size:16px;flex-shrink:0}.btn-icon:active{background:var(--border)}input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:16px!important;font-family:inherit;background:var(--card);color:var(--text)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary)}label{display:block;font-size:13px;font-weight:500;color:var(--text-sub);margin-bottom:4px}.form-group{margin-bottom:14px}.grid-2col-form{display:grid;grid-template-columns:1fr 1fr;gap:8px}.amount{font-weight:600;font-variant-numeric:tabular-nums}.amount-total{font-size:20px;color:var(--primary)}.section{margin-bottom:20px}.section-title{font-size:14px;font-weight:600;color:var(--text-sub);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.tab-bar{display:flex;background:var(--card);border-bottom:2px solid var(--border);position:sticky;top:0;z-index:10;margin:12px -16px 0;padding:0 16px;border-radius:var(--radius) var(--radius) 0 0}.tab-bar button{flex:1;padding:12px 0;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:14px;font-weight:500;color:var(--text-sub);cursor:pointer;transition:color .15s,border-color .15s}.tab-bar button.active{color:var(--primary);border-bottom-color:var(--primary)}.timeline{position:relative;padding-left:20px}.timeline:before{content:"";position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--border)}.timeline-item{position:relative;padding:4px 0 6px;cursor:pointer;border-radius:6px;transition:background .15s}.timeline-item:hover{background:#2563eb08}.timeline-item.timeline-active{background:var(--primary-light);margin:0 -6px;padding:4px 6px 6px;border-radius:6px}.timeline-item:before{display:none}.timeline-dot{position:absolute;left:-24px;top:4px;width:20px;height:20px;cursor:pointer;z-index:1}.timeline-dot:after{content:"";position:absolute;left:7px;top:7px;width:6px;height:6px;border-radius:50%;background:var(--primary)}.timeline-item.timeline-active .timeline-dot{left:-18px}.timeline-time{font-size:12px;font-weight:600;color:var(--primary);margin-right:6px}.timeline-text{font-size:13px;font-weight:500;line-height:1.3}.schedule-layout{display:flex;flex-direction:column;overflow:hidden}.schedule-list{order:2;overflow:hidden}.map-container{order:1;height:40vh;margin:12px -16px 0;border-radius:0;overflow:hidden}.schedule-list .flex::-webkit-scrollbar{display:none}.restaurant-card.selected{border-left:3px solid var(--success)}.restaurant-panel{margin-top:8px;padding:12px;background:var(--bg);border-radius:8px}.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-wrap{flex-wrap:wrap}.gap-8{gap:8px}.gap-12{gap:12px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.text-center{text-align:center}.text-sub{color:var(--text-sub)}.text-sm{font-size:13px}@media(min-width:768px){.layout{flex-direction:row}.nav{position:fixed;top:0;left:0;bottom:0;width:200px;flex-direction:column;transform:none;border-top:none;border-right:1px solid var(--border);box-shadow:1px 0 4px #0000000a;padding:0;z-index:100;max-width:none}.nav-brand{display:block;padding:20px 20px 16px;font-size:18px;font-weight:800;color:var(--primary);letter-spacing:-.5px;border-bottom:1px solid var(--border)}.nav a{flex:none;flex-direction:row;align-items:center;gap:10px;padding:12px 20px;font-size:14px;border-radius:0;border-left:3px solid transparent}.nav a.active{color:var(--primary);font-weight:600;background:var(--primary-light);border-left-color:var(--primary)}.nav a svg{width:20px;height:20px}.nav-logout{display:flex;align-items:center;gap:8px;margin-top:auto;padding:12px 20px;border:none;background:none;cursor:pointer;font-size:13px;color:var(--text-sub);border-top:1px solid var(--border);width:100%;text-align:left}.nav-logout:hover{color:var(--danger);background:#fef2f2}.nav-user{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main-content{margin-left:200px;max-width:none}.page{padding:24px 32px 40px}.card{padding:20px}.tab-bar{margin:12px 0 0;padding:0}.schedule-layout{display:grid;grid-template-columns:2fr 3fr;gap:20px}.schedule-list{order:1}.map-container{order:2;height:auto;min-height:500px;margin:12px 0 0;border-radius:var(--radius);position:sticky;top:20px}.page-title{font-size:26px}}@media(min-width:1024px){.page{padding:32px 48px}.map-container{min-height:600px}.schedule-layout{grid-template-columns:1fr 2fr}}@media(min-width:1440px){.page{padding:32px 64px}.map-container{min-height:700px}}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eff6ff,#dbeafe,#bfdbfe);padding:16px}.login-card{background:#fff;border-radius:16px;box-shadow:0 4px 24px #00000014;padding:40px 32px;width:100%;max-width:380px;text-align:center}.login-logo{margin-bottom:12px}.login-card h1{font-size:24px;font-weight:800;color:var(--text);margin-bottom:4px}.login-sub{font-size:14px;color:var(--text-sub);margin-bottom:28px}.login-card .form-group{text-align:left;margin-bottom:16px}.login-card .form-group label{font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px;display:block}.login-card input{width:100%;padding:12px;border:1px solid var(--border);border-radius:8px;font-size:15px;outline:none;transition:border-color .2s}.login-card input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.login-code-input{font-size:24px!important;text-align:center;letter-spacing:8px;font-weight:700}.login-sent{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:10px 14px;font-size:13px;color:#15803d;margin-bottom:16px;text-align:left}.login-sent span{font-weight:700}.login-error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:10px 14px;font-size:13px;color:var(--danger);margin-bottom:12px}.login-card .btn-block{width:100%;padding:12px;font-size:15px}.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px;font-size:15px;font-weight:600;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--text);cursor:pointer;text-decoration:none;transition:background .2s}.btn-google:hover{background:#f8fafc}.login-divider{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--text-sub);font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}
