@import "https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&display=swap";:root{--primary:#ff7a00;--primary-hover:#e86e00;--primary-light:#fff3e8;--primary-pale:#ffedd5;--navy:#1e3a5f;--navy-hover:#2a4f7f;--navy-dark:#162d4a;--success:#34c759;--success-bg:#f0fdf4;--success-text:#166534;--danger:#ff3b30;--danger-bg:#fff1f0;--danger-text:#991b1b;--gold:#ffc107;--gold-bg:#fffbeb;--gold-text:#92400e;--white:#fff;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-900:#111827;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:999px;--shadow-xs:0 1px 2px #0000000f;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000f;--shadow:0 4px 6px -1px #00000014, 0 2px 4px -1px #0000000f;--shadow-md:0 10px 15px -3px #00000014, 0 4px 6px -2px #0000000d;--shadow-lg:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--warning:#f59e0b}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--gray-900);background:var(--gray-50);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;font-size:15px;line-height:1.55}.loading{height:100vh;color:var(--gray-500);justify-content:center;align-items:center;font-size:1.1rem;display:flex}.app-layout{flex-direction:column;height:100vh;display:flex}.app-header{background:var(--navy);z-index:20;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 1rem;display:flex;box-shadow:0 2px 12px #00000047}.app-header .logo{color:#fff;align-items:center;font-size:1.4rem;font-weight:800;text-decoration:none;display:flex}.app-header .logo:before{content:"P";background:var(--primary);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;margin-right:.45rem;font-size:.85rem;font-weight:900;display:inline-flex;box-shadow:0 2px 6px #ff7a0073}.app-header nav{align-items:center;gap:.75rem;display:flex}.app-header nav a{color:#fffc;border-radius:var(--radius-sm);padding:.4rem .75rem;font-size:.9rem;text-decoration:none;transition:background .15s,color .15s}.app-header nav a:hover{color:#fff;background:#ffffff1f}.app-main{flex:1;position:relative;overflow:hidden}.btn{border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:.9rem;font-weight:500;line-height:1;transition:background .15s,opacity .15s,box-shadow .15s;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 6px #ff7a0059}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 14px #ff7a0073}.btn-danger{background:var(--danger);color:#fff}.btn-outline{border:1px solid var(--gray-300);color:var(--gray-700);background:#fff}.btn-outline:hover:not(:disabled){background:var(--gray-100)}.btn-sm{padding:.35rem .7rem;font-size:.8rem}.btn-block{width:100%}.btn-google{border:1.5px solid var(--gray-200);color:var(--gray-700);background:#fff;font-weight:500}.btn-google:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300)}.form-group{margin-bottom:1rem}.form-group label{letter-spacing:.4px;text-transform:uppercase;color:var(--gray-500);margin-bottom:.3rem;font-size:.78rem;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--gray-200);border-radius:var(--radius);outline:none;width:100%;padding:.55rem .75rem;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ff7a0024}.card{border-radius:var(--radius-lg);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm);background:#fff;padding:1.25rem}.auth-page{background:linear-gradient(145deg, var(--navy-dark) 0%, var(--navy) 55%, #243f6a 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-card{border-radius:var(--radius-xl);width:100%;max-width:400px;box-shadow:var(--shadow-lg);background:#fff;padding:2.25rem}.auth-card h1{text-align:center;margin-bottom:.5rem;font-size:1.5rem}.auth-card .subtitle{color:var(--gray-500);text-align:center;margin-bottom:1.5rem;font-size:.9rem}.auth-logo{justify-content:center;align-items:center;gap:.5rem;margin-bottom:1.75rem;display:flex}.auth-logo-badge{background:var(--primary);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.1rem;font-weight:900;display:flex;box-shadow:0 2px 8px #ff7a0066}.auth-logo-name{color:var(--navy);font-size:1.5rem;font-weight:800}.auth-card .divider{color:var(--gray-400);align-items:center;gap:.75rem;margin:1rem 0;font-size:.8rem;display:flex}.auth-card .divider:before,.auth-card .divider:after{content:"";background:var(--gray-200);flex:1;height:1px}.auth-card .footer-link{text-align:center;color:var(--gray-500);margin-top:1rem;font-size:.85rem}.auth-card .footer-link a{color:var(--primary);font-weight:500;text-decoration:none}.error-msg{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius);border:1px solid #ff3b302e;margin-bottom:1rem;padding:.5rem .75rem;font-size:.85rem}.map-container{width:100%;height:100%}.space-info-window{min-width:200px;padding:.5rem}.space-info-window h3{margin-bottom:.4rem;font-size:1rem}.space-info-window .price{color:var(--primary);letter-spacing:-.3px;margin-bottom:.3rem;font-size:1.3rem;font-weight:800}.space-info-window .meta{color:var(--gray-500);margin-bottom:.5rem;font-size:.8rem}.panel{z-index:10;background:#fff;width:380px;height:100%;padding:1.5rem;position:absolute;top:0;right:0;overflow-y:auto;box-shadow:-2px 0 8px #0000001a}.panel h2{margin-bottom:1rem;font-size:1.25rem}.dashboard{max-width:900px;height:100%;margin:0 auto;padding:1.5rem;overflow-y:auto}.dashboard h1{margin-bottom:1rem;font-size:1.5rem}.space-list{gap:1rem;display:grid}.space-card{justify-content:space-between;align-items:flex-start;display:flex}.space-card .space-info h3{margin-bottom:.25rem;font-size:1rem}.space-card .space-info .address{color:var(--gray-500);font-size:.85rem}.space-card .space-actions{gap:.5rem;display:flex}.booking-list{gap:.75rem;display:grid}.booking-card{cursor:pointer;justify-content:space-between;align-items:center;display:flex}.booking-card .booking-info{flex:1}.status-badge{text-transform:uppercase;border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.status-pending{background:var(--gold-bg);color:var(--gold-text)}.status-confirmed{background:var(--success-bg);color:var(--success-text)}.status-canceled{background:var(--danger-bg);color:var(--danger-text)}.status-expired{background:var(--gray-200);color:var(--gray-700)}.status-completed{color:#1e40af;background:#dbeafe}.role-select-page{background:linear-gradient(145deg, var(--navy-dark) 0%, var(--navy) 55%, #243f6a 100%);flex-direction:column;justify-content:center;align-items:center;gap:2rem;min-height:100vh;display:flex}.role-select-page h1{color:#fff}.role-cards{gap:1.5rem;display:flex}.role-card{border-radius:var(--radius-xl);text-align:center;width:260px;box-shadow:var(--shadow-md);cursor:pointer;background:#fff;border:2px solid #0000;padding:2rem;transition:transform .15s,box-shadow .15s}.role-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.role-card.selected{border-color:var(--primary);box-shadow:0 0 0 4px #ff7a002e, var(--shadow-md)}.role-card h2{margin-bottom:.5rem;font-size:1.2rem}.role-card p{color:var(--gray-500);font-size:.85rem}.role-switcher{background:#ffffff1f;border-radius:20px;gap:2px;padding:2px;display:flex}.role-tab{cursor:pointer;color:#ffffffa6;background:0 0;border:none;border-radius:18px;padding:.3rem .9rem;font-size:.82rem;font-weight:500;transition:all .15s}.role-tab.active{background:var(--primary);color:#fff;font-weight:600;box-shadow:0 1px 5px #ff7a0073}.role-tab:not(.active):hover{color:#fff}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(18px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-overlay{-webkit-backdrop-filter:blur(5px);z-index:100;background:#0f172a85;justify-content:center;align-items:center;padding:1rem;animation:.18s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal{border-radius:var(--radius-xl);background:#fff;width:100%;max-width:460px;max-height:90vh;padding:1.5rem;animation:.22s cubic-bezier(.17,.67,.25,1) slideUp;overflow-y:auto}.modal-header{justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;display:flex}.modal-header h2{margin-bottom:.2rem;font-size:1.2rem}.modal-subtitle{color:var(--gray-500);font-size:.82rem}.modal-close{background:var(--gray-100);cursor:pointer;color:var(--gray-500);border-radius:var(--radius-full);border:none;justify-content:center;align-items:center;width:28px;height:28px;font-size:1.1rem;transition:background .15s;display:flex}.modal-close:hover{background:var(--gray-200)}.map-skeleton{background:var(--gray-200);width:100%;height:100%;position:relative;overflow:hidden}.skeleton-shimmer{background:linear-gradient(90deg,#0000,#fff6,#0000);animation:1.5s infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skeleton-pin{background:var(--gray-400);border-radius:11px;width:44px;height:22px;position:absolute}.map-loading-bar{background:linear-gradient(90deg, var(--primary) 0%, #ffb347 100%);z-index:5;width:100%;height:3px;animation:1.2s ease-in-out infinite loadbar;position:absolute;top:0;left:0}@keyframes loadbar{0%{transform:translate(-100%)}to{transform:translate(100%)}}.price-estimate{background:var(--primary-light);border:1px solid var(--primary-pale);border-radius:var(--radius);color:var(--gray-700);margin-bottom:.75rem;padding:.5rem .75rem;font-size:.85rem}.price-estimate strong{color:var(--primary)}.total-line{background:var(--gray-50);border-radius:var(--radius);color:var(--gray-700);margin-bottom:1rem;padding:.75rem;font-size:.95rem}.booking-success{text-align:center;padding:1.5rem 0}.success-icon{background:var(--success);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 1rem;font-size:1.5rem;font-weight:700;display:flex;box-shadow:0 4px 16px #34c75961}.booking-success h3{margin-bottom:.5rem;font-size:1.2rem}.booking-success p{color:var(--gray-500);margin-bottom:1.5rem}.polling-state{text-align:center;padding:2rem 0}.polling-state p{color:var(--gray-500);margin-top:1rem}.spinner{border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;margin:0 auto;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.role-card-icon{margin-bottom:.5rem;font-size:2rem}.earnings-card{background:linear-gradient(135deg, var(--navy) 0%, var(--navy-hover) 100%);border-radius:var(--radius-lg);color:#fff;margin-bottom:1.5rem;padding:1.5rem;position:relative;overflow:hidden;box-shadow:0 4px 16px #1e3a5f59}.earnings-card h3{text-transform:uppercase;letter-spacing:.5px;color:#fff9;margin-bottom:.4rem;font-size:.72rem}.earnings-amount{color:var(--gold);font-size:2.5rem;font-weight:800}.earnings-meta{color:#ffffff80;margin-top:.2rem;font-size:.82rem}.stripe-banner{background:var(--gold-bg);border-radius:var(--radius-lg);border:1.5px solid #f0c040;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;padding:1rem 1.25rem;display:flex}.stripe-banner p{color:var(--gold-text);font-size:.9rem}.booking-dates{color:var(--gray-500);margin:.2rem 0;font-size:.8rem}.booking-price{color:var(--primary);font-size:.9rem;font-weight:700}.booking-card{transition:transform .15s,box-shadow .15s}.booking-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}@media (width<=640px){.app-header{height:52px}.role-tab{padding:.25rem .65rem}.modal{border-radius:var(--radius-lg);max-width:100%;padding:1.25rem}.role-cards{flex-direction:column;align-items:center}.role-card{width:100%;max-width:320px}.dashboard{padding:1rem}.auth-card{padding:1.75rem 1.25rem}.panel{border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-height:70vh;top:auto;bottom:0}.earnings-card{padding:1.25rem}.earnings-amount{font-size:2rem}}
