        @import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500&family=Inter:wght@300;400;500;600;700&display=swap');
        *{box-sizing:border-box;margin:0;padding:0}
        :root{
          --rose:#C4687A;--rose-light:#F5E6EA;--rose-mid:#E8B4BC;--rose-dark:#8B3A4A;
          --plum:#6B4C7A;--plum-light:#EDE6F2;--plum-mid:#C4A8D4;
          --ink:var(--color-text-primary,#111111);--ink-soft:var(--color-text-secondary,#555555);--ink-muted:var(--color-text-tertiary,#999999);
          --bg:var(--color-background-primary,#ffffff);--bg2:var(--color-background-secondary,#f7f7f8);--bg3:var(--color-background-tertiary,#f0f0f2);
          --bdr:var(--color-border-tertiary,#ebebeb);--bdr2:var(--color-border-secondary,#d9d9d9);
          --r-md:var(--border-radius-md,8px);--r-lg:var(--border-radius-lg,12px);
        }
        body{font-family:var(--font-serif,serif);background:var(--bg3);color:var(--ink);min-height:100vh}
        .app{display:flex;min-height:100vh}

        .sidebar{width:240px;background:var(--bg);border-right:0.5px solid var(--bdr2);position:sticky;top:0;height:100vh;overflow-y:auto;flex-shrink:0}
        .logo{padding:1.5rem;border-bottom:0.5px solid var(--bdr)}
        .logo-name{font-size:20px;font-weight:500;color:var(--rose-dark);font-family:var(--font-serif,serif)}
        .logo-heart{color:var(--rose);font-size:14px;margin-right:4px}
        .logo-sub{font-size:11px;color:var(--ink-muted);margin-top:3px;letter-spacing:1px}
        .nav{padding:1rem 0}
        .nav-label{font-size:10px;letter-spacing:2px;color:var(--ink-muted);padding:0.75rem 1.25rem 0.25rem;text-transform:uppercase}
        .nav-item{display:flex;align-items:center;gap:10px;padding:9px 1.25rem;cursor:pointer;color:var(--ink-soft);font-size:13px;border-left:2.5px solid transparent;transition:all 0.15s}
        .nav-item:hover{color:var(--ink);background:var(--bg2)}
        .nav-item.active{color:var(--rose-dark);background:var(--rose-light);border-left-color:var(--rose)}
        .nav-icon{font-size:15px;width:18px;text-align:center}

        .main{flex:1;min-width:0}
        .topbar{background:var(--bg);border-bottom:0.5px solid var(--bdr);box-shadow:0 2px 12px rgba(0,0,0,0.07);padding:1rem 1.75rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:20}
        .topbar-left h2{font-size:18px;font-weight:500;color:var(--ink)}
        .topbar-left p{font-size:12px;color:var(--ink-muted);margin-top:2px}
        .couple-pill{display:flex;align-items:center;gap:8px;background:var(--rose-light);border:0.5px solid var(--rose-mid);border-radius:20px;padding:6px 12px;cursor:pointer}
        .couple-avatars{display:flex}
        .avatar{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;border:1.5px solid var(--bg)}
        .avatar-a{background:#FBEAF0;color:#72243E;margin-right:-8px}
        .avatar-b{background:#EDE6F2;color:#3C3489}
        .couple-name{font-size:12px;font-weight:500;color:var(--rose-dark)}

        .content{padding:2rem 1.75rem 1.75rem;max-width:980px}
        .page{display:none}.page.active{display:block}

        .card{background:var(--bg);border:0.5px solid var(--bdr);border-radius:var(--r-lg);overflow:hidden;margin-bottom:1.25rem}
        .card-head{padding:1rem 1.25rem;border-bottom:0.5px solid var(--bdr);display:flex;align-items:center;justify-content:space-between}
        .card-title{font-size:15px;font-weight:500;color:var(--ink)}
        .card-sub{font-size:12px;color:var(--ink-muted);margin-top:2px}
        .card-body{padding:1.25rem}

        .g2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
        .g3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
        .g4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}

        .btn{padding:8px 16px;border-radius:var(--r-md);border:0.5px solid var(--bdr2);background:transparent;cursor:pointer;font-family:inherit;font-size:12px;font-weight:500;color:var(--ink);transition:all 0.15s;display:inline-flex;align-items:center;gap:6px}
        .btn:hover{background:var(--bg2)}
        .btn-rose{background:var(--rose);color:#fff;border-color:var(--rose)}
        .btn-rose:hover{background:var(--rose-dark)}
        .btn-sm{padding:6px 12px;font-size:11px}

        .badge{padding:3px 9px;border-radius:12px;font-size:11px;font-weight:500}
        .badge-rose{background:var(--rose-light);color:var(--rose-dark);border:0.5px solid var(--rose-mid)}
        .badge-plum{background:var(--plum-light);color:var(--plum);border:0.5px solid var(--plum-mid)}
        .badge-green{background:var(--color-background-success);color:var(--color-text-success)}
        .badge-muted{background:var(--bg2);color:var(--ink-muted);border:0.5px solid var(--bdr)}
        .badge-amber{background:#FAEEDA;color:#633806;border:0.5px solid #EF9F27}

        .form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
        .form-label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-muted)}
        .form-input{padding:9px 12px;border:0.5px solid var(--bdr2);border-radius:var(--r-md);background:var(--bg);font-family:inherit;font-size:13px;color:var(--ink);outline:none;transition:border 0.15s;width:100%}
        .form-input:focus{border-color:var(--rose)}
        select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 5 5-5' stroke='%23888' stroke-width='1.2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}

        .tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:11px;cursor:pointer;border:0.5px solid var(--bdr2);background:var(--bg2);color:var(--ink-soft);transition:all 0.15s;margin:3px 2px}
        .tag.on{background:var(--rose-light);color:var(--rose-dark);border-color:var(--rose-mid)}
        .tag-row{display:flex;flex-wrap:wrap;margin-top:6px}

        .idea-card{background:var(--bg);border:0.5px solid var(--bdr);border-radius:var(--r-lg);overflow:hidden;transition:all 0.15s;cursor:pointer}
        .idea-card:hover{border-color:var(--rose-mid)}
        .idea-card.top-pick{border:1.5px solid var(--rose);position:relative}
        .idea-top-label{position:absolute;top:10px;right:10px;background:var(--rose);color:#fff;font-size:10px;font-weight:500;padding:3px 8px;border-radius:10px;letter-spacing:0.3px}
        .idea-emoji{height:160px;display:flex;align-items:center;justify-content:center;font-size:44px;background:var(--bg2);overflow:hidden;position:relative}
        .idea-emoji img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.4s}
        .idea-card:hover .idea-emoji img{transform:scale(1.04)}
        .idea-body{padding:12px}
        .idea-name{font-size:14px;font-weight:500;color:var(--ink);margin-bottom:4px}
        .idea-loc{font-size:11px;color:var(--ink-muted)}
        .idea-tags{margin-top:8px;display:flex;flex-wrap:wrap;gap:4px}
        .idea-price{font-family:var(--font-serif,serif);font-size:16px;font-weight:500;color:var(--ink);margin-top:8px}
        .idea-price span{font-size:11px;color:var(--ink-muted);font-family:inherit;font-weight:400}
        .idea-match{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:11px;color:var(--color-text-success)}
        .match-bar-bg{flex:1;height:4px;background:var(--bdr2);border-radius:2px}
        .match-bar{height:4px;background:var(--color-background-success,#5DCAA5);border-radius:2px;transition:width 0.4s}

        .profile-pair{display:flex;align-items:stretch;gap:12px}
        .profile-half{flex:1;background:var(--bg2);border-radius:var(--r-md);padding:1rem}
        .profile-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;margin-bottom:10px}
        .pref-item{display:flex;align-items:center;gap:8px;font-size:12px;padding:5px 0;border-bottom:0.5px solid var(--bdr);color:var(--ink-soft)}
        .pref-item:last-child{border-bottom:none}
        .pref-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

        .reminder-item{display:flex;gap:10px;padding:10px 0;border-bottom:0.5px solid var(--bdr);align-items:flex-start}
        .reminder-item:last-child{border-bottom:none}
        .rem-dot{width:9px;height:9px;border-radius:50%;margin-top:4px;flex-shrink:0}
        .rem-title{font-size:13px;font-weight:500;color:var(--ink)}
        .rem-meta{font-size:11px;color:var(--ink-muted);margin-top:2px}

        .booking-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:0.5px solid var(--bdr)}
        .booking-row:last-child{border-bottom:none}
        .booking-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;background:var(--rose-light)}
        .booking-name{font-size:13px;font-weight:500;color:var(--ink)}
        .booking-meta{font-size:11px;color:var(--ink-muted);margin-top:2px}
        .booking-right{margin-left:auto;text-align:right}
        .booking-price{font-family:var(--font-serif,serif);font-size:16px;font-weight:500;color:var(--ink)}
        .booking-date{font-size:11px;color:var(--ink-muted);margin-top:2px}

        .cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
        .cal-daylabel{text-align:center;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--ink-muted);padding:4px 0}
        .cal-day{min-height:52px;background:var(--bg2);border:0.5px solid var(--bdr);border-radius:6px;padding:5px;cursor:pointer;transition:all 0.15s;position:relative}
        .cal-day:hover{border-color:var(--rose-mid);background:var(--rose-light)}
        .cal-day.today{border-color:var(--rose);background:var(--rose-light)}
        .cal-day.selected{border-color:var(--rose);background:var(--rose-light)}
        .cal-day.has-ev::after{content:'';width:5px;height:5px;border-radius:50%;background:var(--rose);position:absolute;top:5px;right:5px}
        .cal-day-n{font-size:12px;font-weight:500;color:var(--ink-soft)}
        .cal-ev{font-size:9px;color:var(--rose-dark);background:var(--rose-light);border-radius:3px;padding:1px 4px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-left:2px solid var(--rose)}
        .cal-day.other .cal-day-n{color:var(--ink-muted)}

        .stat{background:var(--bg2);border-radius:var(--r-md);padding:1rem}
        .stat-label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-muted)}
        .stat-val{font-family:var(--font-serif,serif);font-size:28px;font-weight:500;color:var(--ink);margin-top:4px}
        .stat-note{font-size:11px;color:var(--color-text-success);margin-top:3px}

        .occasion-chip{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1.5px solid var(--bdr2);border-radius:50px;cursor:pointer;font-size:12px;font-weight:500;color:var(--ink-soft);background:var(--bg2);transition:all 0.15s;-webkit-tap-highlight-color:transparent}
        .occasion-chip:hover{border-color:var(--rose-mid);background:var(--rose-light);color:var(--rose-dark)}
        .occasion-chip.active{border-color:var(--rose);background:var(--rose-light);color:var(--rose-dark)}
        .occasion-icon{font-size:14px;display:inline-flex;align-items:center;justify-content:center}

        .guided-step{margin-bottom:22px}
        .guided-step-label{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-muted);margin-bottom:10px;display:flex;align-items:center;gap:8px}
        .step-num{width:18px;height:18px;border-radius:50%;background:var(--rose);color:#fff;font-size:9px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}

        .vibe-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
        .vibe-card{border:1.5px solid var(--bdr2);border-radius:var(--r-lg);padding:14px 13px;cursor:pointer;transition:all 0.18s;background:var(--bg2);-webkit-tap-highlight-color:transparent;position:relative;user-select:none}
        .vibe-card:hover{border-color:var(--rose-mid);background:var(--rose-light)}
        .vibe-card.active{border-color:var(--rose);background:var(--rose-light);box-shadow:0 0 0 3px rgba(196,104,122,0.12)}
        .vibe-card.active::after{content:'✓';position:absolute;top:9px;right:11px;font-size:11px;color:var(--rose);font-weight:700}
        .vibe-icon{font-size:24px;display:block;margin-bottom:8px;line-height:1}
        .vibe-name{font-size:12px;font-weight:600;color:var(--ink);margin-bottom:3px}
        .vibe-desc{font-size:11px;color:var(--ink-muted);line-height:1.45}
        @media(max-width:640px){.vibe-grid{grid-template-columns:repeat(2,1fr);gap:8px}.vibe-card{padding:12px 10px}}

        .loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem;gap:12px}
        .spinner{width:28px;height:28px;border:2.5px solid var(--bdr2);border-top-color:var(--rose);border-radius:50%;animation:spin 0.8s linear infinite}
        @keyframes spin{to{transform:rotate(360deg)}}
        .loading-text{font-size:13px;color:var(--ink-muted)}

        .divider{height:0.5px;background:var(--bdr);margin:1rem 0}
        .section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:1rem}
        .section-title{font-size:16px;font-weight:500;color:var(--ink)}
        .section-link{font-size:12px;color:var(--rose);cursor:pointer}

        .tabs{display:flex;border-bottom:0.5px solid var(--bdr);margin-bottom:1.25rem}
        .tab{padding:8px 16px;font-size:13px;color:var(--ink-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-0.5px;transition:all 0.15s}
        .tab:hover{color:var(--ink)}
        .tab.active{color:var(--rose-dark);border-bottom-color:var(--rose);font-weight:500}

        .toast{position:fixed;bottom:20px;right:20px;background:var(--ink);color:var(--bg);padding:10px 18px;border-radius:var(--r-md);font-size:13px;z-index:999;opacity:0;transform:translateY(8px);transition:all 0.25s;pointer-events:none}
        .toast.show{opacity:1;transform:translateY(0)}

        /* ── Feature: Partner vote buttons ── */
        .vote-btn{padding:5px 11px;border-radius:20px;border:1px solid var(--bdr2);background:var(--bg);cursor:pointer;font-size:11px;font-weight:500;transition:all .15s;font-family:inherit;color:var(--ink-soft)}
        .vote-btn:hover{border-color:var(--rose-mid);background:var(--rose-light)}
        .vote-btn.yes.active{background:var(--rose-light);border-color:var(--rose);color:var(--rose-dark)}
        .vote-btn.no.active{background:#F3F4F6;border-color:#9CA3AF;color:#6B7280}
        .idea-card.both-love-card{border:1.5px solid var(--rose)!important;box-shadow:0 0 0 3px rgba(196,104,122,0.1)}

        /* ── Feature: Star ratings ── */
        .star-row{display:inline-flex;gap:2px}
        .star{font-size:17px;cursor:pointer;color:#E5E7EB;transition:color .1s;line-height:1;user-select:none}
        .star.lit{color:#F59E0B}

        /* ── Hinge-style swipe card stack ── */
        .swipe-section{display:flex;flex-direction:column;align-items:center;width:100%}
        .swipe-meta{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:420px;margin-bottom:10px}
        .swipe-meta-title{font-size:14px;font-weight:500;color:var(--ink)}
        .swipe-meta-link{font-size:12px;color:var(--rose);cursor:pointer}
        .swipe-stack{position:relative;width:100%;max-width:420px;height:580px;perspective:1200px}
        .swipe-card{position:absolute;inset:0;background:var(--bg);border-radius:18px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,0.13);transition:transform 0.35s cubic-bezier(.4,0,.2,1),opacity 0.35s;will-change:transform,opacity;display:flex;flex-direction:column;transform-style:preserve-3d}
        .swipe-card.card-active{z-index:10;transform:translateZ(0) rotateX(0) rotateY(0);opacity:1}
        .swipe-card.card-behind-1{z-index:9;transform:translateY(12px) translateZ(-40px) scale(0.96) rotateX(1.5deg);opacity:0.92;pointer-events:none}
        .swipe-card.card-behind-2{z-index:8;transform:translateY(24px) translateZ(-80px) scale(0.91) rotateX(2.5deg);opacity:0.6;pointer-events:none}
        .swipe-card.card-exit-left{transform:translate(-110%,0) rotate(-18deg);opacity:0;z-index:11}
        .swipe-card.card-exit-right{transform:translate(110%,0) rotate(18deg);opacity:0;z-index:11}
        .swipe-card-img{width:100%;height:290px;object-fit:cover;display:block;flex-shrink:0}
        .swipe-card-img-wrap{height:290px;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:60px;flex-shrink:0;position:relative}
        .swipe-card-top-badge{position:absolute;top:14px;left:14px;background:var(--rose);color:#fff;font-size:10px;font-weight:600;padding:4px 10px;border-radius:20px;letter-spacing:0.3px;z-index:2}
        .swipe-card-body{flex:1;padding:16px 18px 12px;display:flex;flex-direction:column;gap:0;overflow:hidden}
        .swipe-card-name-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:6px}
        .swipe-card-name{font-size:20px;font-weight:700;color:var(--ink);font-family:var(--font-serif,serif);line-height:1.15}
        .swipe-card-budget{font-size:15px;font-weight:500;color:var(--rose-dark);font-family:var(--font-serif,serif)}
        .swipe-card-loc{font-size:11px;color:var(--ink-muted);margin-bottom:8px}
        .swipe-card-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}
        .swipe-card-why{font-size:11px;color:var(--ink-soft);font-style:italic;line-height:1.45;margin-bottom:6px}
        .swipe-card-match{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--color-text-success)}
        .swipe-card-match-bar-bg{flex:1;height:3px;background:var(--bdr2);border-radius:2px}
        .swipe-card-match-bar{height:3px;background:var(--color-background-success,#5DCAA5);border-radius:2px}
        .swipe-actions{display:flex;align-items:center;justify-content:center;gap:20px;padding:12px 18px 16px;border-top:0.5px solid var(--bdr);background:var(--bg);flex-shrink:0}
        .swipe-btn{width:56px;height:56px;border-radius:50%;border:2px solid;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:22px;transition:all 0.18s;background:var(--bg);flex-shrink:0;-webkit-tap-highlight-color:transparent}
        .swipe-btn:active{transform:scale(0.9)}
        .swipe-btn-x{border-color:#E5E7EB;color:#9CA3AF}
        .swipe-btn-x:hover{border-color:#F87171;color:#EF4444;background:#FEF2F2}
        .swipe-btn-book{width:64px;height:64px;border-color:var(--rose);color:var(--rose)}
        .swipe-btn-book:hover{background:var(--rose);color:#fff;box-shadow:0 4px 14px rgba(196,104,122,0.35)}
        .swipe-btn-heart{border-color:#E5E7EB;color:#9CA3AF}
        .swipe-btn-heart:hover{border-color:var(--rose-mid);color:var(--rose);background:var(--rose-light)}
        .swipe-dots{display:flex;gap:6px;justify-content:center;margin-top:12px}
        .swipe-dot{width:7px;height:7px;border-radius:50%;background:var(--bdr2);transition:background 0.2s,transform 0.2s}
        .swipe-dot.active{background:var(--rose);transform:scale(1.25)}
        .swipe-counter{font-size:11px;color:var(--ink-muted);text-align:center;margin-top:6px}
        .swipe-done{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;text-align:center;padding:2rem}
        .swipe-done-icon{font-size:40px}
        .swipe-done-title{font-size:18px;font-weight:600;color:var(--ink);font-family:var(--font-serif,serif)}
        .swipe-done-sub{font-size:13px;color:var(--ink-muted);line-height:1.5}
        @media(max-width:480px){
          .swipe-stack{height:540px}
          .swipe-card-img,.swipe-card-img-wrap{height:240px}
          .swipe-card-name{font-size:17px}
        }

        /* Mobile header — hidden on desktop */
        .mobile-header{display:none;background:var(--bg,#fff);background-color:var(--bg,#fff);border-bottom:0.5px solid var(--bdr2,#e5e5e5);padding:12px 16px 10px;align-items:center;justify-content:space-between;flex-shrink:0;z-index:30}
        .mobile-logo{font-size:17px;font-weight:500;color:var(--rose-dark);font-family:var(--font-serif,serif)}
        .mobile-page-title{font-size:13px;color:var(--ink-muted);margin-top:1px}

        /* Mobile bottom nav bar — hidden on desktop */
        .mobile-nav-bar{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg,#fff);background-color:var(--bg,#fff);border-top:0.5px solid var(--bdr2,#e5e5e5);z-index:100;padding-bottom:env(safe-area-inset-bottom,0px)}
        .mnb-inner{display:flex;justify-content:space-around}
        .mnb-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 2px 10px;cursor:pointer;font-size:9.5px;letter-spacing:0.2px;color:var(--ink-muted);min-height:56px;transition:color 0.15s;border-top:2px solid transparent;-webkit-tap-highlight-color:transparent}
        .mnb-item.active{color:var(--rose-dark);border-top-color:var(--rose)}
        .mnb-icon{width:22px;height:22px;display:flex;align-items:center;justify-content:center;margin:0 auto}

        @media(max-width:820px){
          .sidebar{width:200px}
          .g3{grid-template-columns:repeat(2,minmax(0,1fr))}
          .g4{grid-template-columns:repeat(2,minmax(0,1fr))}
          .profile-pair{flex-direction:column}
        }

        /* ── Mobile layout (iPhone / Samsung) ── */
        @media(max-width:640px){
          .sidebar{display:none}
          .topbar{display:none}
          .mobile-header{display:flex}
          .mobile-nav-bar{display:block}
          .app{flex-direction:column;height:100vh;height:100dvh;overflow:hidden}
          .main{display:flex;flex-direction:column;flex:1;min-width:0;overflow:hidden}
          .content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0.9rem;max-width:100%;padding-bottom:calc(72px + env(safe-area-inset-bottom,20px))}

          /* Collapse all grids to single column */
          .g2,.g3{grid-template-columns:1fr}
          .g4{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
          .profile-pair{flex-direction:column}

          /* Cards */
          .card{margin-bottom:1rem}
          .card-head{flex-wrap:wrap;gap:8px}
          .card-body{padding:1rem}

          /* Stats */
          .stat{padding:0.75rem}
          .stat-val{font-size:22px}

          /* Idea cards — 1 column on narrow phones */
          .idea-card .idea-emoji{height:180px;font-size:38px}

          /* Calendar */
          .cal-day{min-height:38px}
          .cal-ev{font-size:8px;padding:1px 3px}

          /* Tabs scrollable */
          .tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;padding-bottom:1px}
          .tab{display:inline-block}

          /* Planner — always single column */
          #page-planner .g2{grid-template-columns:1fr !important}

          /* Booking filter buttons — wrap */
          #filter-btns{flex-wrap:wrap}

          /* Button groups */
          .btn{font-size:12px}
          .btn-sm{padding:5px 10px;font-size:11px}

          /* Toast — bottom of screen above nav */
          .toast{bottom:70px;right:12px;left:12px;text-align:center}
        }

        /* Very narrow (≤380px — SE / Galaxy A series) */
        @media(max-width:380px){
          .g4{grid-template-columns:1fr}
          .content{padding:0.7rem;padding-bottom:calc(72px + env(safe-area-inset-bottom,20px))}
          .card-body{padding:0.8rem}
          .idea-card .idea-emoji{height:150px;font-size:32px}
        }

        /* ── Landing page ── */
        .skip-lp #landing{display:none!important}
        #landing{
          position:fixed;inset:0;z-index:200;
          background:#080808;
          overflow-y:auto;-webkit-overflow-scrolling:touch;
          display:flex;flex-direction:column;
        }
        .lp-hero{
          background:linear-gradient(150deg,#8B3A4A 0%,#C4687A 55%,#E8B4BC 100%);
          padding:env(safe-area-inset-top,0px) 0 0;
          display:flex;flex-direction:column;align-items:center;
          text-align:center;position:relative;overflow:hidden;
        }
        .lp-hero::before{
          content:'';position:absolute;inset:0;
          background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
        }
        .lp-nav{width:100%;display:flex;align-items:center;justify-content:space-between;padding:18px 24px 0;position:relative}
        .lp-logo{font-size:18px;font-weight:600;color:#fff;font-family:var(--font-serif,serif);letter-spacing:-0.3px}
        .lp-logo-heart{margin-right:5px;opacity:0.9}
        .lp-skip{font-size:13px;font-weight:600;color:#8B3A4A;background:#fff;border:none;border-radius:20px;padding:8px 18px;cursor:pointer;font-family:inherit;letter-spacing:0.1px;box-shadow:0 2px 8px rgba(0,0,0,0.12)}
        .lp-skip:hover{background:#F5E6EA}
        .lp-skip:active{transform:scale(0.97)}
        .lp-hero-body{padding:40px 28px 52px;position:relative}
        .lp-tag{display:inline-block;background:rgba(255,255,255,0.18);color:#fff;font-size:12px;font-weight:500;letter-spacing:2px;text-transform:uppercase;padding:5px 14px;border-radius:20px;margin-bottom:22px;border:0.5px solid rgba(255,255,255,0.3)}
        .lp-headline{font-size:36px;font-weight:700;color:#fff;line-height:1.18;margin-bottom:14px;font-family:var(--font-serif,serif);letter-spacing:-0.5px}
        .lp-headline em{font-style:normal;color:#FBEAF0}
        .lp-sub{font-size:16px;color:rgba(255,255,255,0.88);line-height:1.6;max-width:340px;margin:0 auto 28px}
        .lp-cta-primary{display:inline-flex;align-items:center;gap:8px;background:#fff;color:#8B3A4A;font-size:16px;font-weight:600;padding:15px 30px;border-radius:50px;border:none;cursor:pointer;font-family:inherit;box-shadow:0 4px 20px rgba(0,0,0,0.15)}
        .lp-cta-primary:active{transform:scale(0.97)}
        .lp-phones{display:flex;gap:10px;justify-content:center;margin-top:32px;padding:0 20px}
        .lp-phone-mock{background:rgba(255,255,255,0.12);border:0.5px solid rgba(255,255,255,0.25);border-radius:16px;padding:14px;flex:1;max-width:130px;text-align:left;backdrop-filter:blur(6px)}
        .lp-mock-label{font-size:9px;color:rgba(255,255,255,0.6);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px}
        .lp-mock-item{font-size:11px;color:#fff;padding:5px 0;border-bottom:0.5px solid rgba(255,255,255,0.15);display:flex;align-items:center;gap:6px}
        .lp-mock-item:last-child{border-bottom:none}
        .lp-mock-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.6);flex-shrink:0}

        .lp-body{padding:0 24px 40px;background:#fff;flex:1}

        .lp-section{padding:36px 0 0}
        .lp-section-label{font-size:13px;letter-spacing:2px;text-transform:uppercase;color:#C4687A;font-weight:600;margin-bottom:10px}
        .lp-section-title{font-size:24px;font-weight:700;color:#1a1a1a;line-height:1.3;margin-bottom:10px;font-family:var(--font-serif,serif)}
        .lp-section-desc{font-size:16px;color:#555;line-height:1.65}

        .lp-features{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:28px}
        .lp-feat{background:#FDF8F9;border:0.5px solid #F5E6EA;border-radius:14px;padding:16px}
        .lp-feat-icon{font-size:22px;margin-bottom:8px}
        .lp-feat-title{font-size:15px;font-weight:600;color:#1a1a1a;margin-bottom:4px}
        .lp-feat-desc{font-size:13px;color:#777;line-height:1.6}

        .lp-divider{height:0.5px;background:#f0f0f0;margin:32px 0 0}

        .lp-woulduse{margin-top:32px}
        .lp-woulduse-q{font-size:18px;font-weight:600;color:#1a1a1a;margin-bottom:6px;line-height:1.4;font-family:var(--font-serif,serif)}
        .lp-woulduse-sub{font-size:15px;color:#777;margin-bottom:18px;line-height:1.5}
        .lp-vote-row{display:flex;gap:10px}
        .lp-vote{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:18px 10px;border:1.5px solid #eee;border-radius:14px;cursor:pointer;transition:all 0.18s;-webkit-tap-highlight-color:transparent;text-align:center}
        .lp-vote:active{transform:scale(0.97)}
        .lp-vote.yes.selected{border-color:#C4687A;background:#FDF8F9}
        .lp-vote.maybe.selected{border-color:#C4A87A;background:#FDF8F2}
        .lp-vote.no.selected{border-color:#7A8CC4;background:#F2F4FD}
        .lp-vote-emoji{font-size:28px}
        .lp-vote-label{font-size:14px;font-weight:600;color:#333}
        .lp-vote-desc{font-size:12px;color:#999;line-height:1.4}
        .lp-vote-result{margin-top:16px;padding:0 16px;border-radius:12px;background:#FDF8F9;border:0.5px solid #F5E6EA;font-size:15px;color:#8B3A4A;line-height:1.5;text-align:center;max-height:0;overflow:hidden;opacity:0;transition:max-height 0.35s ease,opacity 0.3s ease,padding 0.35s ease}
        .lp-vote-result.show{max-height:120px;opacity:1;padding:14px 16px}

        .lp-survey{margin-top:32px}
        .lp-survey-q{font-size:18px;font-weight:600;color:#1a1a1a;margin-bottom:14px;line-height:1.4;font-family:var(--font-serif,serif)}
        .lp-options{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
        .lp-option{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1.5px solid #eee;border-radius:12px;cursor:pointer;transition:all 0.15s;-webkit-tap-highlight-color:transparent}
        .lp-option.selected{border-color:#C4687A;background:#FDF8F9}
        .lp-option-radio{width:18px;height:18px;border-radius:50%;border:2px solid #ddd;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all 0.15s}
        .lp-option.selected .lp-option-radio{border-color:#C4687A;background:#C4687A}
        .lp-option.selected .lp-option-radio::after{content:'';width:6px;height:6px;border-radius:50%;background:#fff}
        .lp-option-text{font-size:15px;color:#333;line-height:1.4}

        .lp-form{margin-top:4px}
        .lp-form-title{font-size:18px;font-weight:600;color:#1a1a1a;margin-bottom:6px;font-family:var(--font-serif,serif)}
        .lp-form-sub{font-size:15px;color:#777;margin-bottom:18px;line-height:1.5}
        .lp-field{margin-bottom:12px}
        .lp-field label{display:block;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:#999;margin-bottom:6px;font-weight:500}
        .lp-field input{width:100%;padding:14px 14px;border:1.5px solid #eee;border-radius:10px;font-size:16px;color:#1a1a1a;font-family:inherit;outline:none;background:#fff;transition:border 0.15s;-webkit-appearance:none;appearance:none}
        .lp-field input:focus{border-color:#C4687A}
        .lp-field input::placeholder{color:#bbb}
        .lp-submit{width:100%;padding:16px;background:linear-gradient(135deg,#8B3A4A,#C4687A);color:#fff;font-size:17px;font-weight:600;border:none;border-radius:12px;cursor:pointer;font-family:inherit;margin-top:6px;letter-spacing:0.2px;-webkit-tap-highlight-color:transparent}
        .lp-submit:active{opacity:0.9}

        .lp-success{display:none;text-align:center;padding:32px 24px 8px}
        .lp-success-icon{font-size:44px;margin-bottom:12px}
        .lp-success-title{font-size:22px;font-weight:700;color:#1a1a1a;margin-bottom:8px;font-family:var(--font-serif,serif)}
        .lp-success-desc{font-size:16px;color:#777;line-height:1.6;margin-bottom:24px}
        .lp-try-btn{display:inline-flex;align-items:center;gap:8px;background:#C4687A;color:#fff;font-size:14px;font-weight:600;padding:14px 28px;border-radius:50px;border:none;cursor:pointer;font-family:inherit}
        .lp-try-btn:active{opacity:0.9}

        .lp-footer{text-align:center;padding:24px 0 calc(env(safe-area-inset-bottom,0px) + 24px);border-top:0.5px solid #f0f0f0;margin-top:32px}
        .lp-footer-logo{font-size:17px;font-weight:600;color:#8B3A4A;font-family:var(--font-serif,serif);margin-bottom:6px}
        .lp-footer-note{font-size:13px;color:#bbb}

        /* ── How it works ── */
        .lp-hiw{margin-top:28px;display:flex;flex-direction:column;gap:0}
        .lp-hiw-step{display:flex;gap:16px;align-items:flex-start;position:relative;padding-bottom:24px}
        .lp-hiw-step:last-child{padding-bottom:0}
        .lp-hiw-step:not(:last-child)::before{content:'';position:absolute;left:19px;top:40px;bottom:0;width:1.5px;background:linear-gradient(to bottom,#E8B4BC,#f0f0f0)}
        .lp-hiw-num{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#8B3A4A,#C4687A);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px rgba(196,104,122,0.3)}
        .lp-hiw-text{padding-top:8px}
        .lp-hiw-title{font-size:17px;font-weight:600;color:#1a1a1a;margin-bottom:4px}
        .lp-hiw-desc{font-size:15px;color:#666;line-height:1.55}

        /* ── Social proof ── */
        .lp-proof-count{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#FDF8F9;border:0.5px solid #F5E6EA;border-radius:50px;font-size:13px;color:#8B3A4A;font-weight:500;margin-bottom:20px}
        .lp-proof-avatars{display:flex}
        .lp-proof-av{width:22px;height:22px;border-radius:50%;border:1.5px solid #fff;font-size:9px;font-weight:600;display:flex;align-items:center;justify-content:center;margin-right:-6px;flex-shrink:0}
        .lp-testimonials{display:flex;flex-direction:column;gap:12px;margin-top:4px}
        .lp-testimonial{background:#FDF8F9;border:0.5px solid #F5E6EA;border-radius:14px;padding:16px}
        .lp-testimonial-text{font-size:15px;color:#333;line-height:1.6;font-style:italic;margin-bottom:10px}
        .lp-testimonial-author{display:flex;align-items:center;gap:8px}
        .lp-testimonial-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}
        .lp-testimonial-name{font-size:14px;font-weight:600;color:#555}
        .lp-testimonial-stars{display:flex;gap:2px;margin-left:auto}
        .lp-testimonial-star{font-size:11px;color:#F59E0B}

        /* ── Survey reactive ── */
        .lp-survey-reaction{margin-top:14px;padding:0 16px;border-radius:12px;background:linear-gradient(135deg,#FDF8F9,#F5E6EA);border:0.5px solid #E8B4BC;font-size:15px;color:#8B3A4A;line-height:1.55;max-height:0;overflow:hidden;opacity:0;transition:max-height 0.35s ease,opacity 0.3s ease,padding 0.35s ease}
        .lp-survey-reaction.show{max-height:150px;opacity:1;padding:14px 16px}
        .lp-reaction-headline{font-weight:700;margin-bottom:3px;font-size:16px}

        /* ── Trust badges ── */
        .lp-trust-badges{display:flex;justify-content:center;gap:16px;margin-top:14px;flex-wrap:wrap}
        .lp-trust-badge{display:flex;align-items:center;gap:5px;font-size:13px;color:#999}
        .lp-trust-badge-icon{font-size:13px}

        @media(min-width:641px){
          .lp-hero-body{padding:56px 48px 64px;max-width:600px;margin:0 auto}
          .lp-headline{font-size:48px}
          .lp-body{padding:0 48px 60px;max-width:640px;margin:0 auto}
          .lp-features{grid-template-columns:repeat(2,1fr)}
          .lp-testimonials{flex-direction:row}
          .lp-testimonial{flex:1}
        }

        /* ── Mood check-in ── */
        .mood-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:150;display:flex;align-items:flex-end;justify-content:center;animation:fadeInBg 0.2s}
        @keyframes fadeInBg{from{opacity:0}to{opacity:1}}
        .mood-sheet{background:var(--bg);border-radius:20px 20px 0 0;padding:26px 20px 40px;width:100%;max-width:480px;animation:slideUpSheet 0.28s cubic-bezier(.22,.68,0,1.2)}
        @keyframes slideUpSheet{from{transform:translateY(60px);opacity:0}to{transform:translateY(0);opacity:1}}
        .mood-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;border:1.5px solid var(--bdr2);border-radius:14px;cursor:pointer;transition:all 0.18s;background:var(--bg2);-webkit-tap-highlight-color:transparent;text-align:center;user-select:none}
        .mood-btn:hover{border-color:var(--rose-mid);background:var(--rose-light)}
        .mood-btn.selected{border-color:var(--rose);background:var(--rose-light);box-shadow:0 0 0 3px rgba(196,104,122,0.12)}
        .mood-btn-icon{font-size:28px;line-height:1}
        .mood-btn-label{font-size:12px;font-weight:600;color:var(--ink)}
        .mood-btn-desc{font-size:10px;color:var(--ink-muted);line-height:1.4}

        /* ── Roulette ── */
        @keyframes spinDie{0%{transform:rotate(0) scale(0.8);opacity:0.5}60%{transform:rotate(540deg) scale(1.3)}100%{transform:rotate(720deg) scale(1);opacity:1}}
        .roulette-die{display:inline-block;animation:spinDie 1.4s cubic-bezier(.22,.68,0,1.1) forwards}
        .roulette-reveal{animation:slideUpSheet 0.3s cubic-bezier(.22,.68,0,1.2)}

        /* ── Surprise mode ── */
        .surprise-toggle{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1.5px solid var(--plum-mid);border-radius:50px;cursor:pointer;font-size:12px;font-weight:600;color:var(--plum);background:var(--plum-light);transition:all 0.18s;user-select:none}
        .surprise-toggle:hover{background:var(--plum-mid);color:#fff}
        .surprise-toggle.active{background:var(--plum);color:#fff;border-color:var(--plum)}
        .sov-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:150;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeInBg 0.2s}
        .sov-card{background:var(--bg);border-radius:20px;width:100%;max-width:360px;overflow:hidden;animation:slideUpSheet 0.28s cubic-bezier(.22,.68,0,1.2)}
        .sov-hero{background:linear-gradient(145deg,#3C1654,#6B4C7A);padding:32px 24px;text-align:center;color:#fff}

        /* ── Wishlist ── */
        .wish-card{background:var(--bg);border:0.5px solid var(--bdr);border-radius:var(--r-lg);padding:14px;display:flex;align-items:flex-start;gap:12px;margin-bottom:8px;transition:all 0.15s}
        .wish-card:hover{border-color:var(--rose-mid)}
        .wish-card.done-item{opacity:0.55}
        .wish-check{width:22px;height:22px;border-radius:50%;border:2px solid var(--bdr2);flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:10px;margin-top:2px;transition:all 0.15s;user-select:none}
        .wish-check.checked{background:var(--rose);border-color:var(--rose);color:#fff}

        /* ── Journal ── */
        .journal-entry{background:var(--bg);border:0.5px solid var(--bdr);border-radius:var(--r-lg);padding:16px;margin-bottom:10px;transition:all 0.15s;cursor:default}
        .journal-entry:hover{border-color:var(--rose-mid)}
        .journal-stars{display:inline-flex;gap:2px;vertical-align:middle}
        .journal-star{font-size:13px;color:#FCD34D}

        /* ── Pre-date checklist overlay ── */
        .checklist-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:150;display:flex;align-items:flex-end;justify-content:center;animation:fadeInBg 0.2s}
        .checklist-sheet{background:var(--bg);border-radius:20px 20px 0 0;padding:24px 20px 36px;width:100%;max-width:480px;max-height:85vh;overflow-y:auto;animation:slideUpSheet 0.28s}
        .check-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:0.5px solid var(--bdr);cursor:pointer;user-select:none}
        .check-item:last-child{border-bottom:none}
        .check-circle{width:20px;height:20px;border-radius:50%;border:2px solid var(--bdr2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;transition:all 0.15s}
        .check-circle.done{background:var(--rose);border-color:var(--rose);color:#fff}

        /* ── Booking flow overlay ── */
        .bf-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:151;display:flex;align-items:flex-end;justify-content:center;animation:fadeInBg 0.2s}
        .bf-sheet{background:var(--bg);border-radius:20px 20px 0 0;padding:24px 20px 40px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:slideUpSheet 0.28s}
        .bf-step-dots{display:flex;gap:6px;margin-bottom:20px}
        .bf-dot{width:7px;height:7px;border-radius:50%;background:var(--bdr2);transition:all 0.25s}
        .bf-dot.active{background:var(--rose);width:22px;border-radius:4px}
        .bf-dot.done{background:var(--rose-mid)}
        .bf-venue-card{background:var(--bg2);border:0.5px solid var(--bdr);border-radius:14px;padding:16px;margin-bottom:18px}
        .bf-transport-opt{display:flex;align-items:center;gap:12px;padding:13px 14px;border:1.5px solid var(--bdr);border-radius:12px;margin-bottom:9px;cursor:pointer;transition:all 0.15s;background:var(--bg)}
        .bf-transport-opt:hover{border-color:var(--rose-mid);background:var(--rose-light)}
        .bf-transport-opt.highlight{border-color:var(--rose);background:var(--rose-light)}

        /* ── Booking execution layer ── */
        .bf-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 0;gap:12px;text-align:center}
        .bf-pulse-dots{display:flex;gap:7px;margin-top:4px}
        .bf-pulse-dot{width:8px;height:8px;border-radius:50%;background:var(--rose-mid);animation:bfPulse 1.2s ease-in-out infinite}
        .bf-pulse-dot:nth-child(2){animation-delay:0.2s}
        .bf-pulse-dot:nth-child(3){animation-delay:0.4s}
        @keyframes bfPulse{0%,100%{transform:scale(0.8);opacity:0.35}50%{transform:scale(1.2);opacity:1}}
        .bf-confirm-card{background:linear-gradient(150deg,#FDFAFA,#FDF8F9);border:1px solid var(--rose-mid);border-radius:14px;padding:16px;margin-bottom:14px}
        .bf-otable-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:500}
        .bf-driver-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0;color:#fff}
        .bf-notif-row{background:rgba(255,255,255,0.08);border-radius:12px;padding:10px 12px;margin-bottom:6px;display:flex;align-items:flex-start;gap:10px}
        .bf-notif-row:last-child{margin-bottom:0}
        .bf-notif-appicon{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#8B3A4A,#C4687A);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;color:#fff}
        .bf-concierge-banner{background:linear-gradient(135deg,#8B3A4A,#C4687A);border-radius:14px;padding:14px 16px;margin-bottom:14px;display:flex;align-items:center;gap:12px;color:#fff}
        @keyframes slideDownNotif{from{transform:translateX(-50%) translateY(-80px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}

        /* ── Couple quiz ── */
        .quiz-q{margin-bottom:18px}
        .quiz-q-label{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:9px}
        .quiz-options{display:flex;gap:7px;flex-wrap:wrap}
        .quiz-opt{padding:7px 14px;border:1.5px solid var(--bdr2);border-radius:20px;cursor:pointer;font-size:12px;color:var(--ink-soft);background:var(--bg2);transition:all 0.15s;user-select:none}
        .quiz-opt:hover{border-color:var(--rose-mid);background:var(--rose-light);color:var(--rose-dark)}
        .quiz-opt.active{border-color:var(--rose);background:var(--rose-light);color:var(--rose-dark);font-weight:500}

        /* ── Double-date mode ── */
        .dd-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:1.5px solid #93C5FD;border-radius:50px;cursor:pointer;font-size:12px;font-weight:600;color:#1D4ED8;background:#EFF6FF;transition:all 0.18s;user-select:none}
        .dd-pill:hover{background:#DBEAFE}
        .dd-pill.active{background:#1D4ED8;color:#fff;border-color:#1D4ED8}


        /* ════════════════════════════════════════════════════════════════
          TIDE THEME — Ambient · Frosted Glass · Soft · Time-Aware
          One unified dark theme inspired by Tide's calm aesthetic
        ════════════════════════════════════════════════════════════════ */

        /* ── Core palette ── */
        :root{
          --bg:#0A0A0A;--card:#161514;--bg2:#1A1918;--bg3:#131212;
          --primary:#C9A84C;--accent:#8B6914;
          --text:#FFFFFF;--subtle:#B8A880;
          --rose:var(--primary);--rose-light:rgba(201,168,76,0.1);
          --rose-mid:rgba(201,168,76,0.25);--rose-dark:#C0983A;
          --plum:var(--accent);--plum-light:rgba(139,105,20,0.1);--plum-mid:rgba(139,105,20,0.22);
          --color-text-primary:var(--text);--color-text-secondary:var(--subtle);
          --color-text-tertiary:rgba(184,168,128,0.7);
          --ink:var(--text);--ink-soft:var(--subtle);--ink-muted:rgba(184,168,128,0.7);
          --color-background-primary:var(--card);--color-background-secondary:#141210;
          --color-background-tertiary:var(--bg);
          --color-border-primary:rgba(255,255,255,0.04);--color-border-secondary:rgba(255,255,255,0.06);
          --color-border-tertiary:rgba(255,255,255,0.04);
          --bdr:rgba(255,255,255,0.1);--bdr2:rgba(255,255,255,0.15);
          --color-background-success:rgba(74,222,128,0.1);--color-text-success:#4ADE80;
          --border-radius-md:14px;--border-radius-lg:22px;
          --font-sans:'Cormorant Garamond',Georgia,serif;
          --font-serif:'Cormorant Garamond',Georgia,serif;
        }

        /* ── Global ── */
        *{-webkit-tap-highlight-color:transparent}
        html,body{background:var(--bg);height:100%;height:100dvh;overflow:hidden}
        body{font-family:var(--font-serif);-webkit-font-smoothing:antialiased}

        /* ── Ambient background (time-aware via JS) ── */
        .content{
          background:
            radial-gradient(ellipse at 25% 15%,var(--ambient-warm,rgba(180,140,80,0.06)) 0%,transparent 55%),
            radial-gradient(ellipse at 75% 85%,var(--ambient-cool,rgba(100,120,160,0.04)) 0%,transparent 50%),
            var(--bg)!important;
          scroll-behavior:smooth;scrollbar-width:none;overscroll-behavior-y:contain;
        }
        .content::-webkit-scrollbar{width:0;display:none}

        /* ── App shell ── */
        .app{background:var(--bg);flex-direction:column!important;height:100vh;height:100dvh;overflow:hidden;max-width:480px;margin:0 auto;box-shadow:none}
        .sidebar{display:none!important}.topbar{display:none!important}

        /* ── Header: frosted glass ── */
        .mobile-header{
          display:flex!important;flex-shrink:0;position:relative;z-index:30;
          padding:max(env(safe-area-inset-top,20px),20px) 16px 12px 16px!important;
          padding-top:calc(max(env(safe-area-inset-top,20px),20px) + 12px)!important;
          background:rgba(8,8,8,0.75)!important;
          backdrop-filter:blur(32px) saturate(160%);-webkit-backdrop-filter:blur(32px) saturate(160%);
          border-bottom:0.5px solid rgba(255,255,255,0.04)!important;
        }
        .mobile-logo{
          background:linear-gradient(125deg,rgba(255,255,255,0.7),rgba(201,168,76,0.8))!important;
          -webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;
          background-clip:text!important;font-weight:600!important;font-size:18px!important;letter-spacing:-0.3px!important;
        }
        .mobile-page-title{color:rgba(255,255,255,0.4)!important;font-size:11.5px!important}

        /* ── Bottom nav: frosted glass ── */
        .mobile-nav-bar{
          display:block!important;position:fixed!important;bottom:0!important;left:50%!important;
          transform:translateX(-50%)!important;width:100%!important;max-width:480px!important;z-index:100!important;
          background:rgba(8,8,8,0.7)!important;
          backdrop-filter:blur(32px) saturate(180%);-webkit-backdrop-filter:blur(32px) saturate(180%);
          border-top:0.5px solid rgba(255,255,255,0.04)!important;box-shadow:none!important;
        }
        .mnb-item{color:rgba(255,255,255,0.3)!important;border-top:none!important;position:relative;padding:10px 4px 12px!important}
        .mnb-item.active{color:rgba(255,255,255,0.85)!important}
        .mnb-item::before{content:'';position:absolute;bottom:6px;left:50%;transform:translateX(-50%) scale(0);width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,0.5);transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1),opacity 0.2s;opacity:0}
        .mnb-item.active::before{transform:translateX(-50%) scale(1);opacity:1}
        .mnb-icon{transition:transform 0.25s cubic-bezier(0.34,1.56,0.64,1)!important}
        .mnb-item.active .mnb-icon{transform:scale(1.18)!important}
        .mnb-item.active .mnb-icon svg{stroke:rgba(255,255,255,0.85)}

        /* ── Main layout ── */
        .main{display:flex!important;flex-direction:column!important;flex:1!important;min-width:0!important;overflow:hidden!important}
        .content{flex:1!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch!important;padding:0.9rem!important;max-width:100%!important;padding-bottom:calc(80px + env(safe-area-inset-bottom,20px))!important}
        .g2,.g3{grid-template-columns:1fr!important}
        .g4{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important}
        .profile-pair{flex-direction:column!important}
        .swipe-stack{max-width:100%!important;height:580px!important}
        @media(max-width:480px){.swipe-stack{height:540px!important}}
        @media(min-width:641px){.app{max-width:600px!important}.swipe-stack{height:620px!important}.swipe-card-img,.swipe-card-img-wrap{height:300px!important}.g2,.g3{grid-template-columns:repeat(2,minmax(0,1fr))!important}.profile-pair{flex-direction:row!important}}
        @media(min-width:900px){.app{max-width:700px!important}}

        /* ── Cards: frosted glass ── */
        .card{
          background:rgba(255,255,255,0.08)!important;
          backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
          border:0.5px solid rgba(255,255,255,0.12)!important;
          border-radius:22px!important;box-shadow:0 4px 20px rgba(0,0,0,0.3)!important;
          position:relative;overflow:hidden;
        }
        .card::after{content:'';position:absolute;inset:0 0 auto 0;height:0.5px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.06),transparent);pointer-events:none}
        .card-head{border-bottom:0.5px solid rgba(255,255,255,0.04)}
        .card-title{font-weight:600;color:rgba(255,255,255,0.85)}

        /* ── Buttons ── */
        .btn{background:rgba(255,255,255,0.09);border:0.5px solid rgba(255,255,255,0.15);color:rgba(255,255,255,0.8);border-radius:14px;font-weight:500;transition:all 0.18s;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
        .btn:hover{background:rgba(255,255,255,0.08)}
        .btn:active{transform:scale(0.95)!important;transition:transform 0.08s!important}
        .btn-rose{background:linear-gradient(135deg,#8B3A4A,#C4687A 50%,#D4887A)!important;color:#fff!important;border:none;font-weight:600;box-shadow:0 4px 16px rgba(196,104,122,0.3)}
        @media(hover:hover){.btn-rose:hover{box-shadow:0 6px 24px rgba(196,104,122,0.4);transform:translateY(-1px)}}

        /* ── Badges: muted frosted ── */
        .badge{background:rgba(255,255,255,0.09)!important;border:0.5px solid rgba(255,255,255,0.14)!important;color:rgba(255,255,255,0.7)!important;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);font-weight:500}
        .badge-rose{color:rgba(201,168,76,0.7)!important}
        .badge-green{background:rgba(74,222,128,0.08)!important;color:#4ADE80!important;border-color:rgba(74,222,128,0.15)!important}

        /* ── Form inputs ── */
        .form-input{background:rgba(255,255,255,0.08)!important;border:0.5px solid rgba(255,255,255,0.15)!important;color:#fff;border-radius:14px}
        .form-input:focus{border-color:rgba(255,255,255,0.15)!important;box-shadow:0 0 0 3px rgba(255,255,255,0.04)!important;outline:none}
        .form-input::placeholder{color:rgba(255,255,255,0.35)}
        select.form-input{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 5 5-5' stroke='%23555' stroke-width='1.2' fill='none'/%3E%3C/svg%3E")}
        select.form-input option{background:var(--card);color:#fff}

        /* ── Tags ── */
        .tag{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.14);color:rgba(255,255,255,0.6);border-radius:20px}
        .tag.on{background:rgba(255,255,255,0.14);border-color:rgba(255,255,255,0.22);color:rgba(255,255,255,0.85)}

        /* ── Swipe cards: the heart of the UI ── */
        .swipe-card{background:var(--card);border-radius:24px!important;box-shadow:0 8px 32px rgba(0,0,0,0.4);transition:transform 0.38s cubic-bezier(0.34,1.56,0.64,1),opacity 0.32s ease;border:0.5px solid rgba(255,255,255,0.05)!important}
        .swipe-card.card-active{z-index:10;transform:translateZ(0);opacity:1}
        .swipe-card.card-behind-1{z-index:9;transform:translateY(12px) scale(0.96);opacity:0.85;pointer-events:none;filter:brightness(0.85)}
        .swipe-card.card-behind-2{z-index:8;transform:translateY(24px) scale(0.91);opacity:0.5;pointer-events:none;filter:brightness(0.7) blur(0.5px)}
        .swipe-card-img-wrap{height:310px!important;position:relative}
        .swipe-card-img{height:310px!important;object-fit:cover;filter:contrast(1.05) saturate(1.1)}
        .swipe-card-img-wrap::after{content:'';position:absolute;bottom:0;left:0;right:0;height:180px;background:linear-gradient(0deg,rgba(6,6,6,0.98) 0%,rgba(6,6,6,0.6) 40%,transparent 100%)!important;pointer-events:none;z-index:1}
        .swipe-card-body{background:linear-gradient(180deg,#161514 0%,#121110 100%)!important;padding:20px 22px 16px!important;position:relative}
        .swipe-card-body::before{content:'';position:absolute;top:0;left:16px;right:16px;height:0.5px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.06),transparent);pointer-events:none}
        .swipe-card-name{color:rgba(255,255,255,0.95)!important;font-weight:700!important;font-size:21px!important;letter-spacing:-0.3px!important}
        .swipe-card-budget{color:rgba(201,168,76,0.7)!important;font-weight:600!important}
        .swipe-card-loc{color:rgba(255,255,255,0.45)!important;margin-bottom:10px!important}
        .swipe-card-tags .badge{background:rgba(255,255,255,0.04)!important;border:0.5px solid rgba(255,255,255,0.06)!important;color:rgba(255,255,255,0.5)!important}
        .swipe-card-why{background:rgba(255,255,255,0.04)!important;border-left:2px solid rgba(255,255,255,0.15)!important;color:rgba(255,255,255,0.55)!important;font-style:normal!important;padding:10px 12px!important;border-radius:10px;font-size:12px!important;line-height:1.5!important}
        .swipe-card-match{color:var(--color-text-success)}
        .swipe-card-match-bar{background:linear-gradient(90deg,rgba(196,104,122,0.6),rgba(201,168,76,0.6))!important}
        .swipe-card-match-bar-bg{height:3px!important}.swipe-card-match-bar{height:3px!important}
        .swipe-card-top-badge{background:rgba(196,104,122,0.75)!important;backdrop-filter:blur(12px);color:#fff;font-weight:600;box-shadow:0 2px 8px rgba(0,0,0,0.3);z-index:2}

        /* ── Swipe actions: frosted ── */
        .swipe-actions{background:rgba(10,9,8,0.8)!important;backdrop-filter:blur(24px) saturate(140%);-webkit-backdrop-filter:blur(24px) saturate(140%);border-top:0.5px solid rgba(255,255,255,0.04)!important;padding:16px 20px 20px!important;border-radius:0 0 24px 24px}
        .swipe-btn{background:rgba(255,255,255,0.04);border:0.5px solid rgba(255,255,255,0.08);transition:all 0.2s cubic-bezier(0.34,1.56,0.64,1)!important}
        .swipe-btn:active{transform:scale(0.9)!important}
        .swipe-btn-x{border-color:rgba(255,255,255,0.08);color:rgba(255,255,255,0.3)}
        .swipe-btn-x:hover{background:rgba(239,68,68,0.1);border-color:rgba(239,68,68,0.25);color:#F87171}
        .swipe-btn-book{background:linear-gradient(135deg,#8B3A4A,#C4687A)!important;border:none;color:#fff;font-weight:700;box-shadow:0 6px 24px rgba(196,104,122,0.4)!important}
        .swipe-btn-heart{border-color:rgba(255,255,255,0.08);color:rgba(255,255,255,0.3)}
        .swipe-btn-heart:hover{background:rgba(196,104,122,0.1);border-color:rgba(196,104,122,0.3);color:#C4687A}

        /* ── Dots: Tide-style pills ── */
        .swipe-dot{background:rgba(255,255,255,0.08)!important;width:6px!important;height:6px!important;transition:all 0.25s}
        .swipe-dot.active{background:rgba(255,255,255,0.45)!important;width:18px!important;border-radius:3px!important}
        .swipe-counter{color:rgba(255,255,255,0.35)!important;font-size:10px!important}

        /* ── Section titles ── */
        .section-title{font-weight:600!important;color:rgba(255,255,255,0.8)!important;letter-spacing:-0.2px!important}
        .section-link{color:rgba(196,104,122,0.7)!important}

        /* ── Stats ── */
        .stat{background:rgba(255,255,255,0.08)!important;border:0.5px solid rgba(255,255,255,0.12)!important;border-radius:18px}
        .stat-val{color:#fff;font-weight:700;background:linear-gradient(135deg,rgba(255,255,255,0.9),rgba(201,168,76,0.7));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

        /* ── Couple pill ── */
        .couple-pill{background:rgba(255,255,255,0.04)!important;border:0.5px solid rgba(255,255,255,0.08)!important;border-radius:24px;transition:all 0.2s}
        .couple-name{color:rgba(255,255,255,0.6);font-weight:500}
        .avatar-a{background:rgba(196,104,122,0.6)!important;color:#fff!important}
        .avatar-b{background:rgba(139,105,20,0.6)!important;color:#fff!important}

        /* ── Occasion chips ── */
        .occasion-chip{background:rgba(255,255,255,0.08)!important;border-color:rgba(255,255,255,0.14)!important;color:rgba(255,255,255,0.7);border-radius:50px;font-size:12.5px}
        .occasion-chip.active{background:rgba(196,104,122,0.12)!important;border-color:rgba(196,104,122,0.3)!important;color:rgba(255,255,255,0.85)!important}

        /* ── Vibe cards ── */
        .vibe-card{background:rgba(255,255,255,0.08)!important;border-color:rgba(255,255,255,0.14)!important;border-radius:20px}
        .vibe-card.active{background:rgba(196,104,122,0.1)!important;border-color:rgba(196,104,122,0.3)!important;box-shadow:none!important}
        .vibe-card.active::after{color:rgba(196,104,122,0.7)!important}
        .vibe-name{font-weight:600;color:rgba(255,255,255,0.8)}
        .vibe-desc{color:rgba(255,255,255,0.3)}

        /* ── Tabs ── */
        .tabs{border-bottom-color:rgba(255,255,255,0.05)}
        .tab{color:rgba(255,255,255,0.3)}
        .tab:hover{color:rgba(255,255,255,0.6)}
        .tab.active{color:rgba(255,255,255,0.85)!important;border-bottom-color:rgba(255,255,255,0.4)!important;font-weight:600}

        /* ── Divider ── */
        .divider{background:rgba(255,255,255,0.04)}

        /* ── Profile ── */
        .profile-half{background:rgba(255,255,255,0.08);border-radius:18px;border:0.5px solid rgba(255,255,255,0.12)}
        .pref-item{border-bottom-color:rgba(255,255,255,0.04);color:rgba(255,255,255,0.45)}

        /* ── Bookings / reminders ── */
        .reminder-item{border-bottom-color:rgba(255,255,255,0.04)}
        .booking-row{border-bottom-color:rgba(255,255,255,0.04)}
        .booking-icon{background:rgba(255,255,255,0.05)}
        .booking-price{color:#fff;font-weight:600}

        /* ── Calendar ── */
        .cal-day{background:rgba(255,255,255,0.02);border-color:rgba(255,255,255,0.04);border-radius:12px}
        .cal-day:hover{background:rgba(255,255,255,0.05);border-color:rgba(255,255,255,0.08)}
        .cal-day.today,.cal-day.selected{background:rgba(196,104,122,0.08);border-color:rgba(196,104,122,0.2)}
        .cal-day.has-ev::after{background:rgba(196,104,122,0.6)}
        .cal-day-n{color:rgba(255,255,255,0.5)}
        .cal-day.other .cal-day-n{color:rgba(255,255,255,0.3)}
        .cal-ev{color:rgba(255,255,255,0.5);background:rgba(255,255,255,0.04);border-left-color:rgba(196,104,122,0.4)}
        .cal-daylabel{color:rgba(255,255,255,0.2)}

        /* ── Idea cards ── */
        .idea-card{background:rgba(255,255,255,0.08);border:0.5px solid rgba(255,255,255,0.12);border-radius:22px;box-shadow:0 4px 16px rgba(0,0,0,0.25)}
        .idea-card:hover{border-color:rgba(255,255,255,0.08);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.35)}
        .idea-emoji{background:rgba(255,255,255,0.02)}
        .idea-name{font-weight:600;color:rgba(255,255,255,0.85)}
        .idea-price{color:rgba(255,255,255,0.8)}
        .match-bar{background:linear-gradient(90deg,rgba(196,104,122,0.5),rgba(201,168,76,0.5))!important}

        /* ── Vote buttons ── */
        .vote-btn{background:rgba(255,255,255,0.04);border-color:rgba(255,255,255,0.06);color:rgba(255,255,255,0.4)}
        .vote-btn.yes.active{background:rgba(201,168,76,0.1);border-color:rgba(201,168,76,0.25);color:rgba(201,168,76,0.8)}

        /* ── Overlays: frosted ── */
        .mood-overlay,.bf-overlay,.checklist-overlay{background:rgba(0,0,0,0.7)!important}
        .mood-sheet,.bf-sheet,.checklist-sheet{background:rgba(12,11,9,0.95)!important;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}
        .mood-btn{background:rgba(255,255,255,0.03);border-color:rgba(255,255,255,0.06)}
        .mood-btn.selected{background:rgba(196,104,122,0.08);border-color:rgba(196,104,122,0.2);box-shadow:none}
        .mood-btn-label{color:rgba(255,255,255,0.8)}
        .mood-btn-desc{color:rgba(255,255,255,0.3)}

        /* ── Booking flow ── */
        .bf-venue-card{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.12)}
        .bf-transport-opt{background:rgba(255,255,255,0.07);border-color:rgba(255,255,255,0.14)}
        .bf-transport-opt:hover{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.1)}
        .bf-transport-opt.highlight{background:rgba(196,104,122,0.06);border-color:rgba(196,104,122,0.2)}
        .bf-dot{background:rgba(255,255,255,0.1)}
        .bf-dot.active{background:rgba(196,104,122,0.6)}
        .bf-dot.done{background:rgba(196,104,122,0.3)}
        .bf-pulse-dot{background:rgba(201,168,76,0.4)}
        .bf-notif-row{background:rgba(255,255,255,0.03)}
        .bf-concierge-banner{background:linear-gradient(135deg,rgba(139,58,74,0.6),rgba(196,104,122,0.6))}

        /* ── Wishlist ── */
        .wish-card{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.12)}
        .wish-check{border-color:rgba(255,255,255,0.1)}
        .wish-check.checked{background:rgba(196,104,122,0.6);border-color:rgba(196,104,122,0.6)}

        /* ── Journal ── */
        .journal-entry{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.12)}

        /* ── Quiz ── */
        .quiz-opt{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.14);color:rgba(255,255,255,0.6)}
        .quiz-opt.active{background:rgba(196,104,122,0.1);border-color:rgba(196,104,122,0.3);color:rgba(255,255,255,0.8);font-weight:600}

        /* ── Toast: frosted ── */
        .toast,.toast.show{background:rgba(12,11,9,0.9)!important;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:0.5px solid rgba(255,255,255,0.06)!important;border-radius:24px;box-shadow:0 8px 28px rgba(0,0,0,0.4)}

        /* ── Spinner ── */
        .spinner{border-color:rgba(255,255,255,0.06);border-top-color:rgba(196,104,122,0.5)}

        /* ── Sophie overlay ── */
        #sophie-overlay{background:var(--bg)!important}

        /* ── Landing page ── */
        #landing{background:#060606}
        .lp-clean{
          display:flex;flex-direction:column;align-items:center;justify-content:center;
          min-height:100vh;padding:60px 24px;text-align:center;
        }
        .lp-clean-logo{margin-bottom:32px}
        .lp-coming-soon{
          display:inline-block;font-size:11px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
          color:rgba(201,168,76,0.7);border:1px solid rgba(201,168,76,0.2);border-radius:24px;padding:7px 18px;margin-bottom:40px;
          background:rgba(201,168,76,0.04);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
        }
        .lp-clean-headline{
          font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(36px,8vw,56px);font-weight:300;
          color:rgba(255,255,255,0.92);line-height:1.2;letter-spacing:-0.5px;margin-bottom:20px;
        }
        .lp-clean-sub{
          font-size:16px;color:rgba(255,255,255,0.4);line-height:1.6;max-width:320px;margin-bottom:48px;
        }
        .lp-clean-form{width:100%;max-width:380px}
        .lp-clean-input-row{display:flex;gap:8px}
        .lp-clean-input{
          flex:1;padding:14px 18px;border-radius:14px;border:0.5px solid rgba(255,255,255,0.08);
          background:rgba(255,255,255,0.03);color:#fff;font-size:14px;font-family:inherit;outline:none;
          transition:border-color 0.2s;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
        }
        .lp-clean-input:focus{border-color:rgba(201,168,76,0.4);box-shadow:0 0 0 3px rgba(201,168,76,0.06)}
        .lp-clean-input::placeholder{color:rgba(255,255,255,0.35)}
        .lp-clean-btn{
          padding:14px 24px;border-radius:14px;border:none;
          background:linear-gradient(135deg,#C9A84C,#8B6914);color:#fff;
          font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;
          transition:all 0.18s;box-shadow:0 4px 16px rgba(201,168,76,0.2);
        }
        .lp-clean-btn:hover{opacity:0.9;box-shadow:0 6px 24px rgba(201,168,76,0.3)}
        .lp-clean-btn:active{transform:scale(0.97)}
        .lp-clean-disclaimer{font-size:12px;color:rgba(255,255,255,0.38);margin-top:12px}
        .lp-clean-footer{
          margin-top:auto;padding-top:60px;display:flex;align-items:center;gap:16px;
          font-size:12px;color:rgba(255,255,255,0.35);
        }
        .lp-clean-footer a{color:rgba(201,168,76,0.4);text-decoration:none;transition:color 0.15s}
        .lp-clean-footer a:hover{color:#C9A84C}
        #partner-overlay select.lp-clean-input{background:#080808}
        #partner-overlay select.lp-clean-input option{background:#0E0D0B;color:#fff}
        #partner-overlay textarea.lp-clean-input{background:rgba(255,255,255,0.03)}

        /* ── Discover filter bar ── */
        #discover-filter-collapsed{background:rgba(255,255,255,0.03)!important;backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);border:0.5px solid rgba(255,255,255,0.05)!important;border-radius:20px!important}
        #discover-filter-panel{animation:slideDown 0.28s cubic-bezier(0.22,0.61,0.36,1)}
        @keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

        /* ── Hidden category bar ── */
        .discover-cats{display:none}

        /* ── Skeleton loading ── */
        @keyframes skeletonShimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
        .skeleton{background:linear-gradient(90deg,rgba(255,255,255,0.02) 25%,rgba(255,255,255,0.05) 50%,rgba(255,255,255,0.02) 75%)!important;background-size:200% 100%;animation:skeletonShimmer 1.8s ease-in-out infinite;border-radius:12px;border:none!important}
        .skeleton-text{height:14px;border-radius:6px;margin-bottom:8px;background:linear-gradient(90deg,rgba(255,255,255,0.03) 25%,rgba(255,255,255,0.06) 50%,rgba(255,255,255,0.03) 75%);background-size:200% 100%;animation:skeletonShimmer 1.8s ease-in-out infinite}

        /* ── Tap feedback ── */
        .occasion-chip:active{transform:scale(0.94)!important;transition:transform 0.08s!important}
        .wh-card:active{transform:scale(0.98)!important;transition:transform 0.1s!important}
        .wish-card:active{transform:scale(0.98)!important}
        .bf-transport-opt:active{transform:scale(0.97)!important;transition:transform 0.08s!important}

        /* ── Page animation ── */
        @keyframes sectionFadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
        .page-anim{animation:sectionFadeUp 0.28s cubic-bezier(0.22,0.61,0.36,1) both}

        /* ── What's Hot ── */
        .wh-section-head{margin-bottom:18px}
        .wh-section-title{font-size:24px;font-weight:700;color:rgba(255,255,255,0.9);letter-spacing:-0.4px}
        .wh-section-sub{font-size:12.5px;color:rgba(184,168,128,0.6);margin-top:4px;line-height:1.4}
        .wh-filters{display:flex;gap:8px;overflow-x:auto;padding:0 0 14px;scrollbar-width:none;-webkit-overflow-scrolling:touch}
        .wh-filters::-webkit-scrollbar{display:none}
        .wh-chip{flex-shrink:0;padding:8px 16px;border-radius:20px;font-size:12px;font-weight:500;border:0.5px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.04);color:rgba(255,255,255,0.35);cursor:pointer;transition:all 0.18s;letter-spacing:0.2px;display:inline-flex;align-items:center;gap:5px}
        .wh-chip.on{background:rgba(196,104,122,0.08)!important;border-color:rgba(196,104,122,0.2)!important;color:rgba(255,255,255,0.7)!important;transform:scale(1.04)}
        .wh-card{background:rgba(255,255,255,0.08);border:0.5px solid rgba(255,255,255,0.12);border-radius:22px;overflow:hidden;margin-bottom:14px;transition:transform 0.22s cubic-bezier(0.34,1.56,0.64,1),box-shadow 0.22s ease;position:relative;cursor:pointer}
        @media(hover:hover){.wh-card:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(0,0,0,0.6);border-color:rgba(255,255,255,0.08)}}
        .wh-card-top{height:150px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
        .wh-card-top::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(6,6,6,0.8) 100%)}
        .wh-card-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform 0.4s ease;filter:contrast(1.05) saturate(1.08)}
        .wh-card:hover .wh-card-img{transform:scale(1.06)}
        .wh-card-top-inner{font-size:52px;filter:drop-shadow(0 4px 16px rgba(0,0,0,0.6));z-index:1;position:absolute;display:none;align-items:center;justify-content:center;inset:0}
        .wh-gradient-concert{background:linear-gradient(135deg,#1a0a2e,#2d1b4e,#180d28)}
        .wh-gradient-dining{background:linear-gradient(135deg,#1c0e06,#301805,#1a0c04)}
        .wh-gradient-experience{background:linear-gradient(135deg,#071510,#0d2218,#071410)}
        .wh-gradient-activity{background:linear-gradient(135deg,#08101a,#121e33,#090e18)}
        .wh-gradient-rooftop{background:linear-gradient(135deg,#0f0c06,#1a1408,#0d0a04)}
        .wh-gradient-theatre{background:linear-gradient(135deg,#1a0a2e,#2d1b4e,#180d28)}
        .wh-gradient-wellness{background:linear-gradient(135deg,#061210,#0c2420,#071510)}
        .wh-gradient-latenight{background:linear-gradient(135deg,#0a0614,#160e28,#0a0614)}
        .wh-trending-pill{position:absolute;top:12px;left:12px;padding:4px 10px;border-radius:12px;font-size:10px;font-weight:700;letter-spacing:0.6px;backdrop-filter:blur(10px);z-index:2}
        .wh-trending-pill.hot{background:rgba(255,80,40,0.22);color:#FF7060;border:0.5px solid rgba(255,80,40,0.38)}
        .wh-trending-pill.rising{background:rgba(201,168,76,0.18);color:#C9A84C;border:0.5px solid rgba(201,168,76,0.38)}
        .wh-trending-pill.new{background:rgba(74,222,128,0.14);color:#4ADE80;border:0.5px solid rgba(74,222,128,0.28)}
        .wh-trending-pill.ending{background:rgba(220,120,60,0.18);color:#E8946A;border:0.5px solid rgba(220,120,60,0.32)}
        .wh-match-pill{position:absolute;top:11px;right:11px;width:44px;height:44px;border-radius:50%;background:rgba(8,8,8,0.82);backdrop-filter:blur(10px);border:1.5px solid rgba(201,168,76,0.38);display:flex;align-items:center;justify-content:center;flex-direction:column;z-index:2}
        .wh-match-pct{font-size:12px;font-weight:800;color:#C9A84C;line-height:1;letter-spacing:-0.3px}
        .wh-match-label{font-size:7px;color:rgba(154,139,106,0.75);letter-spacing:0.4px;margin-top:1px;text-transform:uppercase}
        .wh-card-body{padding:14px 16px 16px}
        .wh-cat-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(154,139,106,0.6);margin-bottom:5px}
        .wh-name{font-size:16px;font-weight:700;color:rgba(255,255,255,0.9);line-height:1.25;margin-bottom:4px;letter-spacing:-0.2px}
        .wh-venue{font-size:11.5px;color:rgba(184,168,128,0.6);margin-bottom:10px;display:flex;align-items:center;gap:5px}
        .wh-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:13px}
        .wh-tag{padding:3px 9px;border-radius:10px;font-size:10.5px;background:rgba(255,255,255,0.04);color:rgba(255,255,255,0.5);border:0.5px solid rgba(255,255,255,0.06);letter-spacing:0.2px}
        .wh-footer{display:flex;align-items:flex-end;justify-content:space-between;gap:8px}
        .wh-booked{display:flex;align-items:center;gap:5px;font-size:11px;color:rgba(154,139,106,0.6);margin-bottom:6px}
        .wh-booked-count{font-weight:700;color:#C9A84C}
        .wh-price{font-size:15px;font-weight:700;color:rgba(255,255,255,0.9);letter-spacing:-0.2px}
        .wh-price-note{font-size:10px;color:rgba(154,139,106,0.55);margin-left:3px;font-weight:400}
        .wh-save-btn{flex-shrink:0;padding:9px 15px;border-radius:13px;border:0.5px solid rgba(196,104,122,0.3);background:rgba(196,104,122,0.09);color:#C4687A;font-size:11px;font-weight:700;cursor:pointer;transition:all 0.2s;letter-spacing:0.3px;display:flex;align-items:center;gap:5px}
        @media(hover:hover){.wh-save-btn:hover{background:rgba(196,104,122,0.2);border-color:rgba(196,104,122,0.5);transform:scale(1.05)}}
        .wh-save-btn:active{transform:scale(0.96)}
        .wh-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.06),transparent);margin:4px 0 16px}

        /* ── Onboarding chips ── */
        .ob-chip.ob-selected{background:rgba(201,168,76,0.12)!important;border-color:rgba(201,168,76,0.4)!important;color:rgba(255,255,255,0.9)!important}
        .ob-chip:active{transform:scale(0.96);transition:transform 0.08s}

        /* ── Personalisation banner: hidden ── */
        #ll-personalisation-banner{display:none!important}

        /* ── Back to top ── */
        .back-to-top{background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.5);box-shadow:0 4px 16px rgba(0,0,0,0.3)}

        /* ── Onboarding ── */
        .ob-overlay{background:rgba(0,0,0,0.6)}
        .ob-tooltip{background:rgba(12,11,9,0.95);backdrop-filter:blur(20px);border:0.5px solid rgba(255,255,255,0.08);border-radius:18px}
        .ob-next{background:linear-gradient(135deg,#8B3A4A,#C4687A);color:#fff;border:none}

        /* ── Booking flow: slots, gen AI, map ── */
        .bf-slot:not(.unavail):hover{background:rgba(201,168,76,0.1);border-color:rgba(201,168,76,0.3)}
        .bf-slot:not(.unavail):active{transform:scale(0.94)}
        .bf-slot.selected{background:rgba(139,105,20,0.2)!important;border:1.5px solid rgba(139,105,20,0.6)!important}
        .bf-slot.unavail{opacity:0.28;cursor:not-allowed}
        @keyframes loadLineIn{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:translateX(0)}}
        @keyframes dotPulse{0%,100%{opacity:0.4;transform:scale(0.8)}50%{opacity:1;transform:scale(1.2)}}
        .bf-gen-line{display:flex;align-items:center;gap:10px;padding:10px 14px;background:rgba(255,255,255,0.04);border-radius:10px;animation:loadLineIn 0.32s cubic-bezier(0.22,0.61,0.36,1) both}
        .bf-gen-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);flex-shrink:0;animation:dotPulse 1.1s ease-in-out infinite}
        .bf-gen-check{width:20px;height:20px;border-radius:50%;background:rgba(74,222,128,0.15);border:1.5px solid rgba(74,222,128,0.5);display:flex;align-items:center;justify-content:center;font-size:10px;color:#4ADE80;flex-shrink:0}
        .bf-map{height:130px;background:linear-gradient(160deg,#09090F,#0E0E1C,#0A1020);position:relative;overflow:hidden;border-radius:14px 14px 0 0}
        @keyframes carMove{0%{transform:translateX(-18px) rotate(-4deg)}100%{transform:translateX(18px) rotate(4deg)}}
        .bf-map-car{animation:carMove 1.8s ease-in-out infinite alternate;display:inline-block;font-size:20px}

        /* ── Onboarding walkthrough ── */
        .ob-highlight{position:relative;z-index:9999!important;border-radius:14px;box-shadow:0 0 0 4px rgba(201,168,76,0.6),0 0 0 9999px rgba(0,0,0,0.55)!important;pointer-events:auto!important}
        .ob-tooltip-title{font-size:14px;font-weight:700;color:#fff;margin-bottom:6px;display:flex;align-items:center;gap:8px}
        .ob-tooltip-body{font-size:12px;color:var(--subtle);line-height:1.55;margin-bottom:14px}
        .ob-tooltip-step{font-size:10px;color:rgba(201,168,76,0.6);font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
        .ob-tooltip-btns{display:flex;gap:8px;align-items:center}
        .ob-skip{background:none;border:none;color:rgba(255,255,255,0.35);font-size:11px;cursor:pointer;font-family:inherit;padding:6px 8px}
        .ob-skip:hover{color:rgba(255,255,255,0.6)}
        .ob-dots{display:flex;gap:5px;margin-left:auto}
        .ob-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.15)}
        .ob-dot.active{background:var(--primary);width:16px;border-radius:3px}

        /* ── Back to top ── */
        .back-to-top{display:none;position:fixed;bottom:calc(72px + env(safe-area-inset-bottom,20px) + 12px);right:16px;width:42px;height:42px;border-radius:50%;border:none;background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.5);font-size:20px;line-height:1;box-shadow:0 4px 16px rgba(0,0,0,0.3);cursor:pointer;z-index:90;opacity:0;transform:translateY(12px);transition:opacity 0.25s,transform 0.25s;align-items:center;justify-content:center}
        .back-to-top.visible{display:flex;opacity:1;transform:translateY(0)}
        @media(min-width:769px){.back-to-top{display:none!important}}

        /* ── Refine bottom sheet ── */
        .rf-group{margin-bottom:18px}
        .rf-label{font-size:11px;font-weight:600;color:rgba(255,255,255,0.4);letter-spacing:0.8px;text-transform:uppercase;margin-bottom:8px}
        .rf-chips{display:flex;flex-wrap:wrap;gap:8px}
        .rf-chip{display:inline-flex;align-items:center;padding:9px 15px;border:1px solid rgba(255,255,255,0.08);border-radius:50px;font-size:13px;font-weight:500;color:rgba(255,255,255,0.45);background:rgba(255,255,255,0.03);cursor:pointer;transition:all 0.15s;user-select:none;-webkit-tap-highlight-color:transparent}
        .rf-chip:active{transform:scale(0.95)}
        .rf-chip.rf-on{background:rgba(201,168,76,0.1);border-color:rgba(201,168,76,0.35);color:rgba(201,168,76,0.9);font-weight:600}
        #refine-sheet.rf-open{transform:translateY(0)!important}

        /* ── Discover category tabs ── */
        .dcat{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 16px 10px;cursor:pointer;position:relative;color:rgba(255,255,255,0.45);font-size:11px;font-weight:500;letter-spacing:0.2px;transition:color 0.2s;-webkit-tap-highlight-color:transparent}
        .dcat svg{stroke:rgba(255,255,255,0.4);transition:stroke 0.2s}
        .dcat.active{color:#fff}
        .dcat.active svg{stroke:#fff}
        .dcat::after{content:'';position:absolute;bottom:0;left:16px;right:16px;height:2px;background:transparent;border-radius:1px;transition:background 0.25s}
        .dcat.active::after{background:#fff}
        .dcat:active{transform:scale(0.92);transition:transform 0.1s}

        /* ── Booking flow UI elements ── */
        .bf-date-pill{background:rgba(255,255,255,0.03);border:0.5px solid rgba(255,255,255,0.06);color:rgba(255,255,255,0.4);border-radius:20px}
        .bf-date-pill.active{background:rgba(196,104,122,0.08);border-color:rgba(196,104,122,0.2);color:rgba(255,255,255,0.7)}
        .bf-slot{background:rgba(255,255,255,0.03);border:0.5px solid rgba(255,255,255,0.05);border-radius:14px}
        .bf-slot.best{background:rgba(201,168,76,0.06);border:1px solid rgba(201,168,76,0.2)}
        .bf-ref-badge{background:rgba(201,168,76,0.06);border:1px solid rgba(201,168,76,0.2);color:rgba(201,168,76,0.7)}
        .bf-confirm-success-ring{background:conic-gradient(#4ADE80 0%,rgba(74,222,128,0.1) 0%);box-shadow:0 0 0 8px rgba(74,222,128,0.05)}
        @keyframes confirmPop{from{transform:scale(0.4);opacity:0}to{transform:scale(1);opacity:1}}
        .bf-confirm-success-ring{animation:confirmPop 0.45s cubic-bezier(0.34,1.56,0.64,1)}

        /* ═══ Plan Cards ═══ */
        .plan-card{background:rgba(255,255,255,0.03);border:0.5px solid rgba(255,255,255,0.06);border-radius:16px;padding:0;margin-bottom:14px;overflow:hidden;transition:border-color 0.2s}
        .plan-card:hover{border-color:rgba(255,255,255,0.12)}
        .plan-card-active{border-color:rgba(201,168,76,0.35)!important;background:rgba(201,168,76,0.03)}
        .plan-card-header{display:flex;align-items:flex-start;gap:14px;padding:18px 18px 0;cursor:pointer}
        .plan-card-title{font-size:15px;font-weight:700;color:#fff;line-height:1.3}
        .plan-card-summary{font-size:13px;color:rgba(255,255,255,0.58);margin-top:4px;line-height:1.45}
        .plan-fit-reason{font-size:12px;color:rgba(201,168,76,0.72);margin-top:6px;line-height:1.4;font-style:italic}
        .plan-card-meta{display:flex;gap:14px;padding:10px 18px 14px;font-size:12px;font-weight:500;color:rgba(255,255,255,0.55);cursor:pointer;flex-wrap:wrap}
        .plan-card-meta span{display:flex;align-items:center;gap:4px}
        /* plan-score-ring removed — replaced by reason tags */
        .plan-status-badge{display:inline-block;padding:2px 8px;border-radius:8px;font-size:9px;font-weight:600;letter-spacing:0.3px;text-transform:uppercase}
        .plan-status-generated{background:rgba(96,165,250,0.1);color:#60A5FA;border:0.5px solid rgba(96,165,250,0.2)}
        .plan-status-viewed{background:rgba(255,255,255,0.04);color:rgba(255,255,255,0.35);border:0.5px solid rgba(255,255,255,0.08)}
        .plan-status-saved{background:rgba(201,168,76,0.1);color:#C9A84C;border:0.5px solid rgba(201,168,76,0.2)}
        .plan-status-active{background:rgba(74,222,128,0.1);color:#4ADE80;border:0.5px solid rgba(74,222,128,0.2)}
        .plan-status-draft{background:rgba(255,255,255,0.04);color:rgba(255,255,255,0.4);border:0.5px solid rgba(255,255,255,0.06)}

        .plan-details{border-top:0.5px solid rgba(255,255,255,0.06);padding:14px 18px}
        .plan-item{display:flex;gap:12px;padding:10px 0;border-bottom:0.5px solid rgba(255,255,255,0.04)}
        .plan-item:last-child{border-bottom:none;padding-bottom:0}
        .plan-item-num{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:rgba(201,168,76,0.1);border:0.5px solid rgba(201,168,76,0.2);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#C9A84C;margin-top:2px}
        .plan-item-img-wrap{flex-shrink:0;width:56px;height:56px;border-radius:10px;overflow:hidden;background:rgba(255,255,255,0.03)}
        .plan-item-img{width:100%;height:100%;object-fit:cover}
        .plan-item-body{flex:1;min-width:0}
        .plan-item-name{font-size:13.5px;font-weight:600;color:rgba(255,255,255,0.9);line-height:1.3}
        .plan-item-loc{font-size:11.5px;color:rgba(255,255,255,0.45);margin-top:2px}
        .plan-item-row{display:flex;gap:10px;margin-top:5px;font-size:11px;color:rgba(255,255,255,0.4);flex-wrap:wrap;align-items:center}
        .plan-item-price{font-weight:600;color:rgba(255,255,255,0.65)}
        .plan-item-dur{color:rgba(255,255,255,0.4)}
        .plan-item-role{padding:2px 7px;background:rgba(255,255,255,0.05);border-radius:6px;font-size:10px;letter-spacing:0.3px;text-transform:uppercase;color:rgba(255,255,255,0.35)}
        .plan-item-why{font-size:12px;color:rgba(255,255,255,0.52);margin-top:5px;line-height:1.45}
        .plan-item-status{display:inline-block;margin-top:5px;padding:2px 8px;border-radius:6px;font-size:9px;font-weight:600;letter-spacing:0.3px}
        .pis-bookable-now{background:rgba(74,222,128,0.08);color:#4ADE80;border:0.5px solid rgba(74,222,128,0.15)}
        .pis-partner-handoff{background:rgba(96,165,250,0.08);color:#60A5FA;border:0.5px solid rgba(96,165,250,0.15)}
        .pis-details-only{background:rgba(255,255,255,0.04);color:rgba(255,255,255,0.4);border:0.5px solid rgba(255,255,255,0.08)}

        .plan-actions{display:flex;gap:8px;padding:0 18px 16px;justify-content:flex-end}
        .plan-btn{padding:9px 16px;border-radius:10px;border:none;font-size:12.5px;font-weight:600;cursor:pointer;font-family:inherit;transition:all 0.15s}
        .plan-btn-save{background:rgba(255,255,255,0.05);border:0.5px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.6)}
        .plan-btn-activate{background:rgba(201,168,76,0.12);border:0.5px solid rgba(201,168,76,0.25);color:#C9A84C}
        .plan-btn-activate:hover{background:rgba(201,168,76,0.2)}

        /* Plan reaction chips */
        .plan-react{padding:5px 11px;border-radius:20px;border:0.5px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.03);color:rgba(255,255,255,0.45);font-size:11px;font-weight:500;cursor:pointer;font-family:inherit;transition:all 0.15s;white-space:nowrap}
        .plan-react:hover{background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.5);border-color:rgba(255,255,255,0.12)}
        .plan-react:active{transform:scale(0.95)}
        .plan-react.plan-react-on{background:rgba(201,168,76,0.1);border-color:rgba(201,168,76,0.25);color:#C9A84C}
        .plan-react-more{border-style:dashed;color:rgba(255,255,255,0.2);font-size:10px}

        /* Plan item booking buttons */
        .plan-item-book-btn{display:inline-block;margin-top:6px;padding:5px 13px;border-radius:8px;font-size:11px;font-weight:600;letter-spacing:0.2px;cursor:pointer;border:none;font-family:inherit;transition:all 0.15s}
        .plan-item-book-btn.pis-bookable-now{background:rgba(74,222,128,0.1);color:#4ADE80;border:0.5px solid rgba(74,222,128,0.2)}
        .plan-item-book-btn.pis-bookable-now:hover{background:rgba(74,222,128,0.18)}
        .plan-item-book-btn.pis-partner-handoff{background:rgba(96,165,250,0.1);color:#60A5FA;border:0.5px solid rgba(96,165,250,0.2)}
        .plan-item-book-btn.pis-partner-handoff:hover{background:rgba(96,165,250,0.18)}
        .plan-item-book-btn.pis-details-only{background:rgba(255,255,255,0.04);color:rgba(255,255,255,0.35);border:0.5px solid rgba(255,255,255,0.08)}
        .plan-item-book-btn.pis-details-only:hover{background:rgba(255,255,255,0.08)}
        .plan-item-book-btn.pis-broken{background:rgba(255,255,255,0.04);color:rgba(255,255,255,0.3);border:0.5px solid rgba(255,255,255,0.08)}
        .plan-item-book-btn.pis-broken:hover{background:rgba(255,255,255,0.08)}
        .plan-item-book-btn.pis-unavailable{background:rgba(201,168,76,0.08);color:rgba(201,168,76,0.6);border:0.5px solid rgba(201,168,76,0.15)}
        .plan-item-book-btn.pis-unavailable:hover{background:rgba(201,168,76,0.15)}

        /* ═══ Booking Handoff Overlay ═══ */
        .booking-handoff-cta{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:14px;border-radius:12px;border:none;background:#C9A84C;color:#000;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:background 0.15s}
        .booking-handoff-cta:hover{background:#D4B86A}
        .booking-confirm-btn{display:flex;align-items:center;gap:14px;width:100%;padding:14px 16px;border-radius:12px;border:0.5px solid rgba(255,255,255,0.08);background:rgba(255,255,255,0.03);cursor:pointer;font-family:inherit;transition:all 0.15s;color:#fff;text-align:left}
        .booking-confirm-btn:hover{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.12)}
        .booking-confirm-yes{border-color:rgba(74,222,128,0.2)}
        .booking-confirm-yes:hover{background:rgba(74,222,128,0.06);border-color:rgba(74,222,128,0.3)}
        .booking-confirm-no{border-color:rgba(255,255,255,0.06)}
        .booking-confirm-retry{border-color:rgba(201,168,76,0.15)}
        .booking-confirm-retry:hover{background:rgba(201,168,76,0.06);border-color:rgba(201,168,76,0.25)}

