/* Client Portal — concierge premium */

body{background:
  radial-gradient(80% 40% at 0% 0%, rgba(185,135,34,.08), transparent 60%),
  linear-gradient(180deg,#F5F7F4,#FAF6EC 900px)}

.brand .logo{background:linear-gradient(135deg,#D6A330,#7A4B00)}
.serif{font-family:"Cormorant Garamond","Playfair Display",Georgia,serif;font-weight:600;letter-spacing:-.01em}

/* greeting */
.greet{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;
  background:
    radial-gradient(80% 70% at 100% 0%, rgba(185,135,34,.16), transparent 60%),
    linear-gradient(135deg,#FAF6EC,#FFFCF3);
  border:1px solid #ECDFBE;border-radius:var(--r-xl);
  padding:26px 28px;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.greet h1{font-family:"Cormorant Garamond","Playfair Display",Georgia,serif;
  font-size:34px;font-weight:600;margin:0 0 6px;letter-spacing:-.015em;color:#3D2700}
.greet .sub{color:#7A6A4C;font-size:14.5px}
.greet .countdown{background:#fff;border:1px solid #ECDFBE;border-radius:var(--r-md);
  padding:14px 22px;text-align:center;min-width:170px;
  box-shadow:0 4px 12px -4px rgba(122,75,0,.18)}
.greet .countdown .v{font-size:36px;font-weight:800;color:var(--green-darker);
  font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1}
.greet .countdown .l{font-size:10.5px;color:var(--muted);text-transform:uppercase;
  letter-spacing:.1em;font-weight:700;margin-top:6px}

/* trip hero */
.trip-hero{position:relative;border-radius:var(--r-xl);overflow:hidden;min-height:280px;
  background:linear-gradient(135deg,#0F766E,var(--green-darker));color:#fff;
  padding:28px;display:flex;flex-direction:column;justify-content:flex-end;
  box-shadow:var(--shadow-lg);border:1px solid var(--onyx-line)}
.trip-hero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 80% at 80% 20%, rgba(255,255,255,.18), rgba(0,0,0,.45) 70%)}
.trip-hero::after{content:"";position:absolute;inset:auto 0 0 0;height:50%;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.45))}
.trip-hero>*{position:relative;z-index:1}
.trip-hero h2{color:#fff;font-size:30px;letter-spacing:-.015em;
  font-family:"Cormorant Garamond","Playfair Display",Georgia,serif;margin:0 0 4px}
.trip-hero .meta{display:flex;gap:14px;align-items:center;flex-wrap:wrap;
  color:rgba(255,255,255,.88);font-size:13px;font-weight:500}
.trip-hero .actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}
.trip-hero .actions .btn.ghost{
  background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.32);
  backdrop-filter:saturate(140%) blur(8px);box-shadow:none}
.trip-hero .actions .btn.ghost:hover{background:rgba(255,255,255,.24)}

/* checklist */
.checklist{display:flex;flex-direction:column;gap:8px}
.check{display:flex;align-items:center;gap:12px;padding:10px 12px;
  background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-sm);
  transition:background var(--t-fast),border-color var(--t-fast)}
.check:hover{border-color:var(--green-3);background:#fff}
.check .tick{width:22px;height:22px;border-radius:50%;border:2px solid var(--line-strong);
  display:grid;place-items:center;font-size:13px;color:transparent;flex-shrink:0;
  transition:all var(--t-fast)}
.check.done .tick{background:linear-gradient(135deg,var(--green),var(--green-darker));
  border-color:var(--green-darker);color:#fff;
  box-shadow:0 4px 10px -4px rgba(21,160,90,.45)}
.check .who{flex:1;font-size:13px;font-weight:500}
.check.done .who{color:var(--muted);text-decoration:line-through}
.check .act{font-size:12px;color:var(--green-darker);font-weight:700;cursor:pointer;letter-spacing:.01em}
.check .act:hover{color:var(--green)}

/* planner */
.planner{display:flex;align-items:center;gap:12px;background:#fff;
  border:1px solid var(--line);border-radius:var(--r-md);padding:14px}
.planner .ava{width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-3),var(--gold));
  display:grid;place-items:center;color:#3D2700;font-weight:800;font-size:18px;flex-shrink:0;
  border:2px solid #fff;box-shadow:0 0 0 1px var(--gold-3),0 4px 12px -4px rgba(185,135,34,.4)}
.planner .who{flex:1}
.planner .who b{display:block;font-size:14px;font-weight:700}
.planner .who .live{display:flex;align-items:center;gap:6px;color:var(--good);
  font-size:11.5px;font-weight:600;margin-top:2px}
.planner .who .live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--good);
  box-shadow:0 0 0 3px rgba(31,178,87,.22)}

/* trip card */
.trip-card{display:grid;grid-template-columns:300px 1fr;gap:0;
  border:1px solid var(--line);border-radius:var(--r-xl);overflow:hidden;
  background:#fff;margin-bottom:14px;box-shadow:var(--shadow-sm);
  transition:transform var(--t-mid),box-shadow var(--t-mid)}
.trip-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.trip-card .cover{min-height:220px;background-size:cover;background-position:center;background-color:#0F766E}
.trip-card .body{padding:22px 24px;display:flex;flex-direction:column;justify-content:center}
.trip-card .body h3{font-family:"Cormorant Garamond","Playfair Display",Georgia,serif;
  font-size:26px;margin:6px 0 4px;letter-spacing:-.015em}
.trip-card .meta{color:var(--muted);font-size:13px;display:flex;flex-wrap:wrap;gap:14px;margin:4px 0 10px}
.trip-card .pay{font-size:13px;margin:6px 0 12px;color:var(--text-2)}
.trip-card .actions{display:flex;gap:8px;flex-wrap:wrap}
.trip-card.t-bali .cover{background-image:linear-gradient(135deg,rgba(15,118,110,.55),rgba(11,49,28,.7)),url('https://images.unsplash.com/photo-1537996194471-e657df975ab4?w=900&q=70')}
.trip-card.t-lang .cover{background-image:linear-gradient(135deg,rgba(8,145,178,.55),rgba(11,49,28,.7)),url('https://images.unsplash.com/photo-1469474968028-56623f02e42e?w=900&q=70')}
.trip-card.t-ker .cover{background-image:linear-gradient(135deg,rgba(132,204,22,.55),rgba(11,49,28,.7)),url('https://images.unsplash.com/photo-1602216056096-3b40cc0c9944?w=900&q=70')}
.trip-card.t-mal .cover{background-image:linear-gradient(135deg,rgba(56,189,248,.45),rgba(11,49,28,.65)),url('https://images.unsplash.com/photo-1514282401047-d79a71a590e8?w=900&q=70')}

/* wallet hero */
.wallet-hero{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;
  background:
    radial-gradient(70% 60% at 100% 0%, rgba(185,135,34,.18), transparent 60%),
    linear-gradient(135deg,#FAF6EC,#FCF3DE 70%);
  border:1px solid #ECDFBE;border-radius:var(--r-xl);padding:28px 30px;
  box-shadow:var(--shadow-sm)}
.wallet-hero .bal{font-family:"Cormorant Garamond","Playfair Display",Georgia,serif;
  font-size:54px;line-height:1;font-variant-numeric:tabular-nums;color:var(--green-darker);
  letter-spacing:-.025em;font-weight:700}
.wallet-hero .bal-sub{color:#7A6A4C;font-size:14px;margin-top:6px}

/* refer */
.share-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.share-row .btn{padding:10px 16px}
.share-link{display:flex;align-items:center;gap:10px;background:#fff;
  border:1.5px dashed var(--green-3);border-radius:var(--r-md);padding:12px 16px;margin-top:12px;
  font-family:ui-monospace,"JetBrains Mono",SFMono-Regular,Menlo,Consolas,monospace;
  font-size:13px;color:var(--text-2)}

/* photo edit */
.photo-edit{display:flex;align-items:center;gap:16px}
.photo-edit .ava-lg{width:84px;height:84px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold),#7A4B00);
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:32px;
  border:3px solid #fff;box-shadow:0 0 0 1px var(--gold-3),0 8px 22px -8px rgba(185,135,34,.5)}

/* day plan */
.day{display:flex;gap:16px;padding:14px 0;border-top:1px dashed var(--line)}
.day:first-child{border-top:none}
.day .num{width:64px;text-align:center;flex-shrink:0;
  background:linear-gradient(135deg,var(--green-2),#fff);
  border:1px solid var(--green-3);border-radius:var(--r-sm);padding:10px 0;height:fit-content}
.day .num .d{font-family:"Cormorant Garamond","Playfair Display",Georgia,serif;
  font-size:24px;color:var(--green-darker);font-weight:700;line-height:1}
.day .num .l{font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;
  font-weight:700;margin-top:4px}
.day .body h4{margin:0 0 4px;font-size:14.5px;font-weight:600}
.day .body p{margin:0 0 8px;color:var(--muted);font-size:13px;line-height:1.55}
.day .body .extra{display:flex;gap:12px;color:var(--muted);font-size:11.5px;
  flex-wrap:wrap;font-weight:500}

/* mobile bottom bar */
.mob-bar{display:none}
@media(max-width:760px){
  .mob-bar{display:flex;position:fixed;bottom:0;left:0;right:0;
    background:rgba(255,255,255,.95);backdrop-filter:saturate(140%) blur(12px);
    border-top:1px solid var(--line);padding:8px 4px env(safe-area-inset-bottom);
    justify-content:space-around;z-index:30;
    box-shadow:0 -8px 24px -10px rgba(11,49,28,.18)}
  .mob-bar a{display:flex;flex-direction:column;align-items:center;gap:3px;
    padding:6px 12px;color:var(--muted);font-size:10.5px;text-decoration:none;font-weight:600}
  .mob-bar a.active{color:var(--green-darker)}
}

/* floating planner */
.float-planner{position:fixed;right:22px;bottom:22px;background:#fff;
  border:1px solid var(--line);border-radius:var(--r-lg);padding:14px;
  display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-xl);
  z-index:25;max-width:320px;
  background:linear-gradient(135deg,#fff,#FAFBF9)}
.float-planner .ava{width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-3),var(--gold));
  display:grid;place-items:center;color:#3D2700;font-weight:800;
  border:2px solid #fff;box-shadow:0 0 0 1px var(--gold-3)}
.float-planner small{display:block;color:var(--muted);font-size:11px}
.float-planner .btn.sm{padding:5px 11px;font-size:11.5px}

/* lite pdf chip */
.lite{display:inline-flex;align-items:center;gap:6px;background:var(--good-2);color:#0E5E2C;
  font-weight:700;padding:3px 10px;border-radius:99px;font-size:10.5px;
  border:1px solid #9CD9B0;letter-spacing:.02em}
