/* ============================================================
 * trips.css — Trips view, trip cards, share badge
 * My Travel History v2.0 — Modular CSS
 * ============================================================ */

/* ========== Trips View (Stage 2) ========== */
#trips-view{background:var(--g50);z-index:10}
.tv-nav{display:flex;align-items:center;justify-content:space-between;padding:0 var(--sp-6);height:var(--tv-nav-h);
  background:var(--white);border-bottom:1px solid var(--g200);flex-shrink:0}
.tv-nav-brand{display:flex;align-items:center;gap:10px;font-family:var(--font-h);font-size:20px;font-weight:800;color:var(--g900);letter-spacing:-.02em}
.brand-icon{width:30px;height:30px;border-radius:7px;flex-shrink:0;object-fit:cover}
.tv-nav-brand i{font-size:26px;font-style:normal}
.tv-nav-right{display:flex;align-items:center;gap:8px}
.tv-user{display:flex;align-items:center;gap:6px;padding:4px 10px 4px 4px;border-radius:var(--r-full);
  background:var(--g50);border:1px solid var(--g200);color:var(--g700);font-size:12px;font-weight:500;transition:.2s}
.tv-user:hover{background:var(--g100)}
.tv-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#2563EB,#60A5FA);
  color:#fff;display:grid;place-items:center;font-size:11px;font-weight:700;flex-shrink:0;
  line-height:28px;text-align:center;overflow:hidden;letter-spacing:0}
.tv-body{flex:1;overflow-y:auto;padding:var(--sp-6);-webkit-overflow-scrolling:touch}

/* Sticky top area — header + search fixed while cards scroll */
.tv-top{position:sticky;top:0;z-index:5;background:var(--g50);
  margin:calc(var(--sp-6) * -1);margin-bottom:0;
  padding:var(--sp-6);padding-bottom:0}
.tv-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-4)}
.tv-header h2{font-family:var(--font-h);font-size:24px;font-weight:800;color:var(--g900);letter-spacing:-.02em}
.tv-greeting{font-size:14px;color:var(--g500);margin-bottom:2px;font-weight:500}
.tv-search{padding:0 0 var(--sp-3)}
.tv-search .fi{width:100%;min-height:44px;font-size:14px}
.tv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--sp-5)}

/* ========== Trip Cards ========== */
.tcard{border-radius:var(--r-xl);overflow:hidden;background:var(--white);box-shadow:var(--shadow-md);cursor:pointer;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);position:relative}
.tcard:hover{transform:translateY(-4px) scale(1.01);box-shadow:var(--shadow-lg)}
.tcard:active{transform:scale(.98);box-shadow:var(--shadow)}

/* Card hero with image support */
.tcard-hero{position:relative;height:180px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.tcard-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s var(--ease)}
.tcard:hover .tcard-hero-bg{transform:scale(1.06)}
.tcard-hero::after{content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.55) 0%,rgba(0,0,0,.1) 50%,rgba(0,0,0,.05) 100%);pointer-events:none}
.tcard-dest{position:absolute;bottom:14px;left:16px;right:16px;z-index:1;font-family:var(--font-h);
  font-size:22px;font-weight:800;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.4);letter-spacing:-.02em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* Badges row — top right */
.tcard-badges{position:absolute;top:16px;right:16px;z-index:1;
  display:flex;flex-direction:row;flex-wrap:nowrap;gap:6px;align-items:center}
.tcard-status{padding:4px 12px;border-radius:var(--r-full);white-space:nowrap;
  font-size:12px;font-weight:700;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);letter-spacing:.02em}
.tcard-status.active{background:rgba(34,197,94,.9);color:#fff}
.tcard-status.upcoming{background:rgba(59,130,246,.85);color:#fff}
.tcard-status.past{background:rgba(255,255,255,.85);color:var(--g600)}
.tcard-body{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.tcard-date{font-size:15px;color:var(--g600);font-weight:600;white-space:nowrap}
.tcard-date-icon{font-size:18px;vertical-align:middle}
.tcard-acts{display:flex;gap:4px;flex-shrink:0}
.tcard-btn{width:36px;height:36px;min-height:36px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;
  font-size:18px;transition:.2s;color:var(--g400);background:none;border:none}
.tcard-btn:hover{background:var(--g100)}.tcard-btn.del:hover{background:var(--error-bg);color:var(--error)}

/* Trip card share badge — inside badges row */
.tcard-share-badge{padding:4px 12px;border-radius:var(--r-full);white-space:nowrap;
  font-size:12px;font-weight:700;letter-spacing:.04em;
  background:rgba(59,130,246,.9);color:#fff;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:0 2px 8px rgba(59,130,246,.3)}
.tcard-share-badge.linked{background:rgba(16,185,129,.9);box-shadow:0 2px 8px rgba(16,185,129,.3)}
.tcard-linked{border:2px solid var(--success)}
.tcard-owner{position:absolute;bottom:8px;right:12px;font-size:11px;color:rgba(255,255,255,.85);
  font-weight:600;text-shadow:0 1px 4px rgba(0,0,0,.4)}
