
:root {
  --bg: #f3f6fb;
  --panel: #ffffff;
  --panel-2: #f8fbff;
  --line: #d9e2ef;
  --text: #101828;
  --muted: #667085;
  --brand: #3b82f6;
  --brand-2: #2563eb;
  --brand-soft: #e8f1ff;
  --sidebar: #08344d;
  --sidebar-2: #0c4563;
  --success: #16a34a;
  --warning: #d97706;
  --danger: #dc2626;
  --shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
  --radius: 22px;
}
* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; font-family: Inter, system-ui, sans-serif; color: var(--text); background: var(--bg); }
.hidden { display:none !important; }
.glass, .glass-lite { background: var(--panel); border: 1px solid var(--line); box-shadow: var(--shadow); }
.auth-shell { min-height: 100vh; display:grid; place-items:center; padding:24px; background: linear-gradient(180deg, #eef5ff, #f8fbff); }
.auth-card { width:min(1180px,100%); display:grid; grid-template-columns: 1.1fr .9fr; gap:24px; padding:24px; border-radius:32px; }
.auth-brand { padding:32px; border-radius:28px; background: linear-gradient(135deg, #f6fbff, #edf5ff); border:1px solid #d9e8ff; }
.auth-brand h1 { margin:0 0 14px; font-size: clamp(34px, 4vw, 60px); line-height:1.02; }
.auth-brand p { color: var(--muted); font-size:17px; max-width: 720px; }
.auth-stack { display:grid; gap:16px; align-content:start; }
.eyebrow { display:inline-block; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:#4b76b8; margin-bottom:10px; }
.form-card, .panel { border-radius: var(--radius); padding: 22px; }
label { display:grid; gap:8px; font-size:14px; color:var(--muted); }
input, textarea, select, button { font: inherit; }
input, textarea, select { width:100%; padding:13px 14px; border-radius:14px; border:1px solid var(--line); background:#fff; color:var(--text); outline:none; }
input:focus, textarea:focus, select:focus { border-color: #9dc2ff; box-shadow: 0 0 0 4px rgba(59,130,246,.12); }
textarea { resize: vertical; min-height: 92px; }
button { border:none; border-radius:14px; padding:12px 16px; cursor:pointer; transition: .18s ease; }
button:hover { transform: translateY(-1px); }
.primary-btn { background: linear-gradient(180deg, var(--brand), var(--brand-2)); color:#fff; font-weight:700; }
.secondary-btn { background: var(--brand-soft); color:#1d4ed8; border: 1px solid #cfe0ff; font-weight:600; }
.ghost-btn { background: #fff; color: var(--text); border:1px solid var(--line); }
.file-chip { display:inline-flex; align-items:center; justify-content:center; min-height:46px; padding:10px 14px; border-radius:14px; border:1px dashed #bfd5fb; background:#f3f8ff; color:#1d4ed8; cursor:pointer; }
.message { min-height: 24px; font-size: 14px; color:#1d4ed8; }
.message[data-tone="error"] { color: var(--danger); }
.app-shell { display:grid; grid-template-columns: 260px minmax(0, 1fr); min-height:100vh; }
.sidebar { background: linear-gradient(180deg, var(--sidebar), #062b40); border-right:1px solid rgba(255,255,255,.08); padding:20px 16px; display:grid; grid-template-rows:auto 1fr auto; gap:20px; color:#dbeafe; min-width:0; }
.brand-block { display:grid; grid-template-columns:52px 1fr; align-items:center; gap:12px; padding-top:6px; }
.brand-mark { width:52px; height:52px; border-radius:18px; display:grid; place-items:center; background: linear-gradient(180deg, #4ba4ff, #2f80ff); color:#fff; font-weight:800; }
.brand-block strong, .brand-block p { display:block; }
.brand-block strong { color:#fff; font-size:16px; }
.brand-block p { margin:4px 0 0; color:rgba(219,234,254,.78); font-size:13px; }
.nav { display:grid; gap:10px; align-content:start; }
.nav-btn { background: rgba(255,255,255,.06); color:#e5f0ff; border:1px solid rgba(255,255,255,.08); padding:14px 14px; min-height:56px; text-align:left; font-size:14px; line-height:1.25; border-radius:16px; width:100%; overflow:hidden; }
.nav-btn.active { background: linear-gradient(180deg, #2f90ff, #2878f0); color:#fff; border-color: rgba(255,255,255,.16); box-shadow: inset 0 1px 0 rgba(255,255,255,.24); }
.sidebar-footer { display:grid; gap:10px; }
.user-pill { padding:10px; border-radius:14px; background: rgba(255,255,255,.08); color:#e5f0ff; font-size:12px; line-height:1.4; }
.sidebar .ghost-btn { background: rgba(255,255,255,.08); color:#e5f0ff; border-color: rgba(255,255,255,.12); }
.workspace { padding: 22px 28px; display:grid; gap:20px; min-width:0; overflow-x:hidden; }
.workspace-top { display:flex; justify-content:space-between; align-items:end; gap:18px; }
.workspace-top h2 { margin:0; font-size: 46px; }
.workspace-top p { margin:6px 0 0; color: var(--muted); font-size: 18px; }
.top-actions { display:flex; gap:10px; flex-wrap:wrap; }
.view { display:none; gap:20px; }
.view.active { display:grid; }
.stats-grid, .stats-grid.compact { display:grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap:14px; }
.stats-grid.compact { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.stat-card { border-radius:20px; padding:18px; background:var(--panel); border:1px solid var(--line); box-shadow: var(--shadow); }
.stat-card .label { color: var(--muted); font-size: 13px; }
.stat-card .value { font-size: 30px; font-weight:800; margin-top: 8px; }
.grid { display:grid; gap:18px; }
.grid.two { grid-template-columns:1fr 1fr; }
.grid.split-40-60 { grid-template-columns: minmax(360px,.95fr) minmax(460px,1.3fr); }
.inbox-grid { grid-template-columns: 360px minmax(0, 1fr) 340px; }
.panel-head { display:flex; justify-content:space-between; align-items:start; gap:16px; margin-bottom:18px; }
.panel-head h3 { margin:0; font-size:28px; }
.stack { display:grid; gap:12px; }
.stack.compact { gap:10px; }
.stack-card, .account-card { padding:16px; border-radius:18px; background: var(--panel); border:1px solid var(--line); }
.stack-card.selectable, .channel-card { cursor:pointer; }
.stack-card.active, .channel-card.active { border-color:#9dc2ff; background:#f5f9ff; }
.meta-row { display:flex; gap:8px; flex-wrap:wrap; align-items:center; margin-top:8px; color:var(--muted); font-size:13px; }
.badge { display:inline-flex; align-items:center; padding:6px 10px; border-radius:999px; background:#f2f4f7; border:1px solid #e4e7ec; color:#344054; font-size:12px; }
.badge.brand { background:#e8f1ff; border-color:#cfe0ff; color:#1d4ed8; }
.badge.success { background:#eafaf0; border-color:#c6f2d7; color:#157f3b; }
.badge.warning { background:#fff5e8; border-color:#f7dbb0; color:#b45309; }
.badge.danger { background:#fef0f0; border-color:#f7c7c7; color:#b42318; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-grid .full { grid-column:1 / -1; }
.compact-form { grid-template-columns:1fr; }
.row { display:flex; align-items:center; }
.row.gap { gap:10px; }
.filters { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:14px; }
.filters.vertical { flex-direction:column; }
.small { font-size:12px; }
.muted { color:var(--muted); }
.mono { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; word-break: break-all; }
.subhead { font-weight:700; margin-bottom:10px; }
.field-help { display:block; margin-top:8px; color:var(--muted); font-size:13px; line-height:1.45; }
.info-box { margin-top:14px; padding:18px; border-radius:18px; background:#f7fbff; border:1px solid #d8e9ff; color:#0f172a; }
.info-box ul, .info-box ol { margin:10px 0 0 18px; padding:0; }
.summary-stack { display:grid; gap:12px; }
.summary-card { padding:14px 16px; border-radius:16px; border:1px solid var(--line); background:#fff; display:grid; gap:8px; }
.summary-card__title { font-weight:700; color:var(--text); }
.summary-card__hint { font-size:13px; color:var(--muted); }
.integration-intro { margin:12px 0 0; line-height:1.6; color:#334155; }
.integration-section { margin-top:16px; padding-top:14px; border-top:1px solid var(--line); }
.integration-section-title { font-weight:700; margin-bottom:8px; }
.actions { display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; }
.calendar-grid { display:grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap:12px; }
.day-card { min-height:126px; border-radius:20px; padding:14px; cursor:pointer; background:#fff; border:1px solid var(--line); box-shadow: var(--shadow); }
.day-card.active { border-color:#9dc2ff; background:#f5f9ff; }
.day-card.dragover { border-color:#2563eb; background:#eff6ff; box-shadow:0 0 0 3px rgba(37,99,235,.12); }
.stack-card[draggable="true"] { cursor:grab; }
.inline-head { align-items:center; justify-content:space-between; }
.day-top { display:flex; justify-content:space-between; color:var(--muted); font-size:13px; }
.day-card strong { display:block; margin-top:14px; font-size:34px; }
.day-card .count { width:28px; height:28px; border-radius:999px; display:grid; place-items:center; background:#e8f1ff; color:#1d4ed8; }
.media-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:12px; margin-top:12px; }
.media-thumb { padding:10px; border-radius:18px; border:1px solid var(--line); background:#fff; }
.media-thumb.selected { border-color:#9dc2ff; }
.media-thumb img, .media-thumb video { width:100%; height:120px; object-fit:cover; border-radius:12px; display:block; }
.file-box { min-height:120px; display:grid; place-items:center; background:#f2f4f7; border-radius:12px; }
.thread { min-height:520px; max-height:62vh; overflow:auto; display:grid; gap:12px; padding:12px; border-radius:18px; background:#f8fbff; border:1px solid var(--line); }
.msg { max-width:88%; padding:14px; border-radius:18px; border:1px solid var(--line); box-shadow: 0 3px 10px rgba(15,23,42,.04); }
.msg.inbound { background:#fff; }
.msg.outbound { margin-left:auto; background:#eff6ff; border-color:#cfe0ff; }
.msg-head { display:flex; justify-content:space-between; gap:14px; margin-bottom:8px; color:var(--muted); font-size:12px; }
.reply-bar { display:grid; grid-template-columns:1fr auto; gap:12px; align-items:end; margin-top:14px; }
.reply-bar button { white-space:nowrap; }
.divider { height:1px; background: var(--line); margin:16px 0; }
.empty-state { padding:18px; text-align:center; color:var(--muted); border-radius:18px; border:1px dashed #cdd8e7; background:#fbfdff; }
.empty-state--hero { min-height: 260px; display:grid; align-content:center; justify-items:center; gap:14px; }
.empty-state--hero strong { font-size: 20px; color: var(--text); max-width: 520px; }
.empty-avatars { display:flex; gap: -6px; }
.empty-avatars span { width:72px; height:72px; border-radius:999px; display:grid; place-items:center; font-weight:800; color:#fff; border:4px solid #fff; margin-left:-8px; box-shadow: var(--shadow); }
.empty-avatars span:nth-child(1){background:#22c55e; margin-left:0;}
.empty-avatars span:nth-child(2){background:#38bdf8;}
.empty-avatars span:nth-child(3){background:#2563eb;}
.empty-avatars span:nth-child(4){background:#8b5cf6;}
.empty-state--channels { min-height:240px; align-content:center; justify-items:center; gap:16px; padding:28px 20px; background:linear-gradient(180deg,#fbfdff 0%, #f4f9ff 100%); border-style:solid; }
.empty-state--inbox { min-height:420px; background:linear-gradient(180deg,#ffffff 0%, #f7fbff 100%); border:1px solid #dbe7f6; }
.empty-state__media { display:flex; align-items:flex-end; justify-content:center; gap:0; margin-bottom:6px; }
.empty-avatar { width:82px; height:82px; border-radius:999px; display:grid; place-items:center; font-weight:800; color:#fff; border:6px solid #fff; margin-left:-10px; box-shadow:0 14px 34px rgba(15,23,42,.10); font-size:20px; }
.empty-avatar:first-child { margin-left:0; }
.empty-avatar--wa { background:linear-gradient(135deg,#22c55e,#34d399); }
.empty-avatar--tg { background:linear-gradient(135deg,#38bdf8,#2563eb); }
.empty-avatar--vk { background:linear-gradient(135deg,#3b82f6,#2563eb); }
.empty-avatar--mx { background:linear-gradient(135deg,#8b5cf6,#06b6d4); }
.channel-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:14px; margin-bottom:18px; }
.channel-card { display:flex; align-items:flex-start; gap:14px; text-align:left; width:100%; padding:18px; border-radius:20px; background:#fff; border:1px solid var(--line); box-shadow: var(--shadow); }
.channel-card__icon { width:52px; height:52px; border-radius:16px; display:grid; place-items:center; background:#e8f1ff; color:#1d4ed8; font-weight:800; flex:0 0 auto; }
.channel-card__body { display:grid; gap:6px; }
.account-card .small.mono { background:#f8fafc; padding:10px; border-radius:12px; margin-top:8px; }
@media (max-width: 1380px) { .channel-grid { grid-template-columns: repeat(2,minmax(0,1fr)); } .inbox-grid { grid-template-columns: 320px 1fr; } }
@media (max-width: 1180px) { .grid.two, .grid.split-40-60, .inbox-grid, .auth-card { grid-template-columns:1fr; } .stats-grid, .stats-grid.compact { grid-template-columns: repeat(2,minmax(0,1fr)); } }
@media (max-width: 920px) { .app-shell { grid-template-columns: 1fr; } .sidebar { grid-template-columns: repeat(4, minmax(0,1fr)); grid-template-rows: auto auto; } .brand-block { grid-template-columns:52px 1fr; justify-items:start; } .nav { grid-column: 1 / -1; grid-template-columns: repeat(4, minmax(0,1fr)); } .nav-btn { min-height:64px; text-align:center; font-size:12px; padding:14px 10px; } .sidebar-footer { grid-column: 1 / -1; } }
@media (max-width: 720px) { .workspace { padding:18px; } .workspace-top { flex-direction:column; align-items:flex-start; } .form-grid, .channel-grid { grid-template-columns:1fr; } .calendar-grid, .media-grid { grid-template-columns: repeat(2,minmax(0,1fr)); } }

/* v7 inbox/integrations refresh */
.panel-soft { background: transparent; border: 0; box-shadow: none; padding: 0; }
.integration-banner { display:flex; gap:16px; align-items:flex-start; padding:22px 24px; border-radius:24px; background:linear-gradient(180deg,#edf5ff 0%, #e7f1ff 100%); border:1px solid #cfe0ff; }
.integration-banner__icon { width:34px; height:34px; border-radius:999px; display:grid; place-items:center; background:#fff; color:#2563eb; font-weight:800; border:1px solid #cfe0ff; flex:0 0 auto; }
.integration-tabs { display:flex; gap:22px; margin:20px 0 18px; padding-left:6px; }
.integration-tab { padding:0 0 12px; background:transparent; border:0; border-bottom:3px solid transparent; border-radius:0; color:#334155; font-weight:700; cursor:pointer; }
.integration-tab.active { color:#2563eb; border-bottom-color:#3b82f6; }
.channel-grid--4 { grid-template-columns: repeat(4, minmax(0,1fr)); }
.channel-tile { position:relative; display:grid; justify-items:center; align-content:start; gap:14px; min-height:226px; padding:26px 18px 22px; border-radius:24px; background:#fff; border:1px solid #d7dde6; box-shadow: 0 10px 28px rgba(15,23,42,.05); transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.channel-tile:hover { transform:translateY(-2px); box-shadow:0 16px 34px rgba(15,23,42,.09); }
.channel-tile strong { font-size:17px; }
.channel-tile__icon { width:74px; height:74px; border-radius:999px; display:grid; place-items:center; font-size:28px; font-weight:800; color:#fff; box-shadow: inset 0 1px 0 rgba(255,255,255,.24); }
.channel-tile__body { display:grid; gap:8px; justify-items:center; text-align:center; }
.channel-tile__meta { color:#334155; font-size:13px; font-weight:600; }
.channel-tile__hint { color:#64748b; font-size:13px; line-height:1.45; max-width:240px; }
.channel-tile__count { position:absolute; top:14px; right:14px; padding:4px 10px; background:#eef6ff; color:#1d4ed8; border-radius:999px; font-size:12px; border:1px solid #cfe0ff; }
.channel-tile.active { border-color:#3b82f6; box-shadow: 0 0 0 3px rgba(59,130,246,.12); }
.channel-tile .channel-tg_personal, .channel-tile .channel-tg { background:#2ea6ff; }
.channel-tile .channel-wa { background:#22c55e; }
.channel-tile .channel-vk { background:#2787f5; }
.channel-tile .channel-max, .channel-tile .channel-max_personal { background:linear-gradient(135deg,#6c4cff,#2bb2ff); }
.channel-tile .channel-avito { background:linear-gradient(135deg,#ff5a5f,#3b82f6,#22c55e); }
.site-chat-panel.hidden { display:none; }
.site-chat-card { display:grid; gap:16px; padding:26px; border-radius:24px; background:linear-gradient(180deg,#fbfdff 0%, #f3f8ff 100%); border:1px solid #dbe7f6; box-shadow:0 14px 40px rgba(15,23,42,.06); }
.site-chat-card h4 { margin:0; font-size:24px; }
.site-chat-card p { margin:0; color:#475569; line-height:1.65; max-width:920px; }
.site-chat-card__badge { width:max-content; padding:6px 12px; border-radius:999px; background:#eaf2ff; color:#2563eb; font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; }
.integration-master { position:sticky; top:18px; align-self:start; }
.modal-shell.hidden { display:none; }
.modal-shell { position:fixed; inset:0; z-index:60; display:grid; place-items:center; }
.modal-backdrop { position:absolute; inset:0; background:rgba(15,23,42,.44); backdrop-filter: blur(2px); }
.modal-card { position:relative; z-index:1; width:min(760px, calc(100vw - 32px)); max-height:calc(100vh - 32px); overflow:auto; border-radius:28px; background:#fff; border:1px solid #d7dde6; box-shadow:0 30px 90px rgba(15,23,42,.24); padding:24px; }
.modal-head { display:flex; justify-content:space-between; gap:20px; align-items:flex-start; margin-bottom:18px; }
.modal-head h3 { margin:0; font-size:28px; }
.modal-body { display:grid; gap:16px; }
.qr-box { display:grid; place-items:center; padding:18px; border-radius:22px; background:#f8fbff; border:1px dashed #bfd5fb; }
.qr-box img { width:280px; height:280px; object-fit:contain; }
.qr-raw { padding:14px; border-radius:18px; background:#f8fafc; border:1px dashed #cbd5e1; overflow:auto; }
.account-card { border-radius:22px; padding:18px; background:#fff; border:1px solid #d7dde6; box-shadow: 0 8px 28px rgba(15,23,42,.05); }
.workspace-top h2 { font-size: 40px; }
.thread { background:#fff; border-radius:22px; }
.msg { border-radius:22px; }
.inbox-grid { grid-template-columns: 320px minmax(0,1fr) 320px; }
@media (max-width: 1380px) { .channel-grid--4 { grid-template-columns: repeat(3,minmax(0,1fr)); } }
@media (max-width: 1000px) { .channel-grid--4 { grid-template-columns: repeat(2,minmax(0,1fr)); } .modal-card { width:min(680px, calc(100vw - 24px)); } }
@media (max-width: 720px) { .channel-grid--4 { grid-template-columns:1fr; } .modal-card { padding:18px; } .qr-box img { width:220px; height:220px; } }

.notice-box { margin-top:16px; padding:16px 18px; border-radius:18px; background:#eef5ff; border:1px solid #cfe0ff; display:grid; gap:8px; }
.notice-box p { margin:0; color:#4b5563; }
.summary-tiles { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:12px; margin-bottom:16px; }
.summary-tile { background:#f8fbff; border:1px solid var(--line); border-radius:18px; padding:14px; display:grid; gap:8px; }
.summary-tile span { color:var(--muted); font-size:13px; }
.summary-tile strong { font-size:24px; }
.day-progress { margin-top:10px; color:#64748b; font-size:12px; }
.plan-detail { display:grid; gap:16px; }
.detail-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
.detail-field, .detail-section { background:#fff; border:1px solid var(--line); border-radius:18px; padding:14px; }
.detail-field span { display:block; color:var(--muted); font-size:12px; margin-bottom:8px; }
.detail-field strong { font-size:14px; line-height:1.5; font-weight:700; }
.detail-field.accent { background:#f5f9ff; border-color:#bfd5ff; }
.detail-copy { color:#0f172a; line-height:1.6; white-space:normal; }
.task-checklist { display:grid; gap:10px; }
.task-row { display:flex; gap:12px; align-items:flex-start; padding:12px 14px; border-radius:14px; background:#f8fafc; border:1px solid #e5e7eb; }
.task-row input { margin-top:3px; }
.task-row span { display:grid; gap:4px; }
.task-row small { color:#64748b; }
.card-studio-shell { min-height:720px; }
.card-studio-frame { width:100%; min-height:760px; border:1px solid var(--line); border-radius:22px; background:#f8fafc; }

.trip-content-page { background:linear-gradient(180deg,#edf4ff 0%, #f8fafc 100%); min-height:100vh; }
.trip-content-page.embedded .trip-header { display:none; }
.trip-shell { width:min(1440px, calc(100vw - 32px)); margin:0 auto; padding:20px 0 32px; display:grid; gap:20px; }
.trip-grid { display:grid; grid-template-columns:420px minmax(0,1fr); gap:20px; }
.trip-panel { min-height:720px; }
.trip-preview-shell { display:grid; place-items:center; min-height:680px; padding:12px; }
.trip-card { position:relative; width:100%; max-width:540px; border-radius:34px; overflow:hidden; background:#0f172a; box-shadow:0 28px 70px rgba(15,23,42,.24); color:#fff; }
.trip-card--45 { aspect-ratio:4 / 5; }
.trip-card--11 { aspect-ratio:1 / 1; }
.trip-card--916 { aspect-ratio:9 / 16; max-width:420px; }
.trip-card__bg { position:absolute; inset:0; background-image:var(--trip-bg); background-size:cover; background-position:center; }
.trip-card__overlay { position:absolute; inset:0; background:linear-gradient(180deg, rgba(15,23,42,.18) 0%, rgba(15,23,42,.55) 40%, rgba(15,23,42,.9) 100%); }
.trip-card__content { position:relative; z-index:1; display:flex; flex-direction:column; justify-content:space-between; height:100%; padding:28px; gap:18px; }
.trip-card__top { display:flex; gap:10px; flex-wrap:wrap; }
.trip-chip { display:inline-flex; align-items:center; padding:10px 14px; border-radius:999px; background:var(--trip-accent,#3b82f6); color:#fff; font-weight:700; font-size:13px; }
.trip-chip--ghost { background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22); }
.trip-card h2 { margin:0; font-size:42px; line-height:1.05; letter-spacing:-.03em; }
.trip-card p { margin:12px 0 0; color:rgba(255,255,255,.88); font-size:17px; line-height:1.5; }
.trip-price-row { display:flex; justify-content:space-between; gap:16px; align-items:flex-end; }
.trip-price { font-size:48px; font-weight:800; letter-spacing:-.04em; }
.trip-old-price { color:rgba(255,255,255,.62); text-decoration:line-through; margin-top:6px; }
.trip-info-stack { display:grid; gap:8px; text-align:right; font-size:14px; color:rgba(255,255,255,.92); }
.trip-hotel { padding:14px 16px; border-radius:18px; background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.18); font-weight:600; }
.trip-card__bottom { display:grid; gap:12px; }
.trip-footer { font-size:13px; color:rgba(255,255,255,.78); }
.trip-cta { padding:16px 18px; border-radius:18px; background:var(--trip-accent,#3b82f6); font-weight:800; text-align:center; }

@media (max-width: 1180px) {
  .summary-tiles, .detail-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .trip-grid { grid-template-columns:1fr; }
}
@media (max-width: 720px) {
  .summary-tiles, .detail-grid { grid-template-columns:1fr; }
  .trip-shell { width:min(100vw - 20px, 100%); }
  .trip-card h2 { font-size:34px; }
}
