/* =========================================
   Itinerary Builder – Main Styles (v2.9.2)
   ========================================= */

.ibml-wrap{ max-width:1100px; margin:0 auto; }
.ibml-title{ font-size:50px; line-height:1.15; margin:8px 0 14px; font-weight:800; }
.ibml-empty{ font-size:15px; text-align:center; padding:15px; }

/* Builder Header */
.ibml-builder-header{ display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; }
.ibml-add-day-btn{ display: inline-block; padding: 10px 18px; background: #F78300; color: #fff; border-radius: 99px; text-decoration: none; font-weight: 700; font-size: 15px; transition: background .2s ease; }
.ibml-add-day-btn:hover{ background: #cf6d00; color: #fff; }

/* Name Your Trip & Your Name */
.ibml-name-row{ display:flex; align-items:flex-start; gap:20px; margin:6px 0 20px; }
.ibml-name-field { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.ibml-name-row label{ font-weight:700; }
.ibml-name-row input{ width:100%; padding:8px 10px; border:1px solid #ddd; border-radius:8px; font-size:14px; background:#fff; }

/* ---------- Finalize Page Header ---------- */
.ibml-finalize-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 15px; }
.ibml-tripname-display{ font-size: 35px !important; font-weight: 800; color: #111; line-height: 1.2; }
.ibml-creatorname-display { font-size: 17px !important; font-weight: 500; color: #555; margin-top: 4px; }
.ibml-back-btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; background: #f5f5f5; border: 1px solid #ddd; border-radius: 10px; color: #333; font-weight: 700; font-size: 14px; text-decoration: none; transition: all 0.15s ease; flex-shrink: 0; }
.ibml-back-btn:hover { background: #e9e9e9; border-color: #ccc; }
.ibml-back-btn i { font-size: 14px; }

/* ---------- Header bar ---------- */
.ibml-headbar{ display:grid; gap:10px; align-items:center; background:#F78300; color:#fff; padding:10px 12px; border-radius:8px; margin-bottom:12px; font-weight:700; font-size:15px; line-height:1.2; }
.ibml-headbar i{ color:#fff; margin-right:6px; }
.ibml-headbar:not(.ibml-headbar-final) { grid-template-columns: 56px 1.35fr 0.9fr 1fr 1fr 1.2fr 68px; }
.ibml-headbar-final { grid-template-columns: 40px 1.6fr 1fr 1fr 1fr 1.2fr; }

/* ---------- Day Containers ---------- */
.ibml-days-wrap{ display: flex; flex-direction: column; gap: 20px; }
.ibml-day-container{ border: 3px dashed #c8c8c8; border-radius: 14px; padding: 10px 15px 1px 15px; background: #fcfcfc; }
.ibml-day-header{ display: flex; align-items: center; gap: 15px; margin-bottom: 12px; position: relative; }
.ibml-day-header::after { content: ''; position: absolute; bottom: -8px; left: 0; right: 0; height: 1px; background: linear-gradient(to right, #ddd, transparent); }
.ibml-day-label{ background: #040951; color: #fff; font-weight: 800; font-size: 16px; border-radius: 50px; padding: 1px 50px; flex-shrink: 0; }
.ibml-day-title{ flex: 1; padding: 6px 10px; border: 1px solid #ddd; border-radius: 8px; font-size: 14px; background: #fff; }
.ibml-day-date{ padding: 6px 10px; border: 1px solid #ddd; border-radius: 8px; font-size: 14px; background: #fff; max-width: 140px; }
.ibml-remove-day-btn { background: none; border: none; color: #cc1f1a; cursor: pointer; font-size: 14px; padding: 5px; }
.ibml-remove-day-btn:hover { color: #b71812; }
.ibml-unassigned-items-wrapper { margin-top: 20px; }
.ibml-unassigned-header { font-weight: 700; font-size: 20px; color: #555; margin-bottom: 10px; }
.ibml-day-placeholder{ color:#aaa; font-style:italic; border:2px dashed #eee; padding:0px; border-radius:10px; }
.ibml-main-placeholder{ text-align:center; padding:20px; }

/* ---------- Cards container ---------- */
.ibml-cards{ display:block; }
.ibml-card{ margin:8px 0; }
.ibml-card:not(.ibml-final){ display:grid; grid-template-columns: 56px 1.35fr 0.9fr 1fr 1fr 1.2fr 68px; gap:10px; align-items:center; background:#fafafa; border:2px solid #ddd; border-radius:14px; box-shadow:0 3px 9px rgba(0,0,0,.08); padding:10px; position:relative; font-size:15px !important; line-height:1.35; }
.ibml-card:not(.ibml-final):hover{ background:#f3f3f3; }
.ibml-card-placeholder{ margin:8px 0; outline:2px dashed #bbb; border-radius:14px; height:64px; background:rgba(0,0,0,.03); }

/* Card Columns */
.c-order{ text-align:center; }
.c-order a{ display:block; color:#F78300; margin:2px 0; text-decoration:none; font-size:15px; }
.c-order a:hover{ color:#cf6d00; }
.ibml-handle{ cursor:grab; }
.ibml-handle:active{ cursor:grabbing; }
.c-site{ display:flex; align-items:center; gap:12px; min-width:0; }
.ibml-thumb{ width:48px; height:48px; border-radius:50%; object-fit:cover; flex:0 0 48px; }
.c-site .c-title{ font-weight:700; text-decoration:none; color:inherit; line-height:1.2; font-size:17px; display:inline-block; }
.c-site .c-title:hover{ text-decoration:underline; }
.c-region, .c-exp, .c-dates, .c-notes { color:#333; font-size:15px; }
.c-num { font-weight: 700; color: #aaa; text-align: center; font-size: 16px; }
.c-notes textarea{ width:100%; min-height:70px; padding:8px 10px; font-size:14px; line-height:1.35; border:1px solid #ddd; border-radius:8px; resize:vertical; background:#fff; -webkit-appearance:none; -moz-appearance:none; appearance:none; }
.ibml-date-summary{ margin-top:4px; font-size:13px; color:#444; }
.c-actions{ text-align:center; }
.ibml-remove-icon{ display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:8px; background:#ffeaea; color:#cc1f1a; text-decoration:none; }
.ibml-remove-icon:hover{ background:#ffdede; color:#b71812; }
.ibml-remove-icon i{ font-size:16px; line-height:1; }

/* ---------- Builder page CTA buttons ---------- */
.ibml-actions{ margin-top:10px; display:flex; gap:10px; flex-wrap:wrap; }
.ibml-btn{ display:inline-flex; align-items:center; gap:8px; text-decoration:none; cursor:pointer; padding:10px 14px; border-radius:10px; border:1px solid #F78300; font-weight:700; transition: all .15s ease-in-out; background:#fff; color:#F78300; }
.ibml-btn i{ font-size:16px; color:#F78300; transition:color .15s; }
.ibml-btn-primary, .ibml-btn-secondary { background: #F78300; color: #fff; border-color: #F78300; }
.ibml-btn-primary i, .ibml-btn-secondary i { color: #fff; }
.ibml-btn-primary:hover, .ibml-btn-secondary:hover { background: #cf6d00; border-color: #cf6d00; color: #fff; }
.ibml-btn-primary:hover i, .ibml-btn-secondary:hover i { color: #fff; }
.ibml-btn-outline { background: #fff; color: #F78300; border-color: #F78300; }
.ibml-btn-outline:hover{ background:#f2f2f2; }

/* Floating Add button on listing pages */
.ibml-floating-btn{ position:fixed; left:16px; bottom:18px; z-index:9999; display:inline-flex; align-items:center; gap:8px; padding:10px 14px; border-radius:999px; text-decoration:none; background:#f2f2f2; color:#000; font:14px/1.2 sans-serif; border:1px solid #ddd; box-shadow:0 6px 18px rgba(0,0,0,.10); transition:background .15s,color .15s,border-color .15s,opacity .15s; }
.ibml-floating-btn i{ margin-right:2px; color:inherit !important; }
.ibml-floating-btn:hover{ background:#F78300; color:#fff; border-color:#F78300; }
.ibml-floating-btn.is-saved{ background:#F78300; color:#fff; border-color:#F78300; }
.ibml-floating-btn.is-loading, .ibml-floating-btn.is-saving { opacity:.7; pointer-events:none; }
.ibml-floating-btn.is-saving { background: #f2f2f2; color: #000; border-color: #ddd; }

/* Toast */
.ibml-toast-container{ position:fixed; background:rgba(0,0,0,0.85); color:#fff; padding:6px 14px; border-radius:6px; font-size:14px; z-index:10000; pointer-events:none; white-space:nowrap; bottom: 60px; left: 16px; opacity: 0; transform: translateY(20px); transition: all 0.3s ease-out; }
.ibml-toast-container.is-visible { opacity: 1; transform: translateY(0); }
.ibml-toast-container.is-error { background-color: #d9534f; }

/* ---------- Finalize Toolbar (Modern) ---------- */
.ibml-toolbar{ display:flex; flex-wrap:wrap; align-items:center; gap:10px; background: #fdfdfd; border: 0; padding: 15px 0; margin-top:20px; }
.ibml-style-selector { display: flex; align-items: center; gap: 8px; margin-right: 10px; }
.ibml-style-selector label { font-weight: 600; font-size: 14px; }
.ibml-style-selector select { padding: 6px 8px; border-radius: 8px; border: 1px solid #ddd; font-size: 13px; }
.ibml-tool{ display:inline-flex; align-items:center; gap:8px; padding:8px 16px; border-radius:999px; background:#f5f5f5; color:#333; text-decoration:none; border:1px solid #f5f5f5; cursor:pointer; font-weight:600; font-size:14px; transition: all .15s ease; }
.ibml-tool:hover{ background:#e9e9e9; border-color:#e0e0e0; }
.ibml-tool i { color: #F78300; }
.ibml-tool.ibml-tool-disabled, .ibml-tool.is-loading { opacity:.6; pointer-events:none; }
.ibml-btn-mini{ display:inline-flex; align-items:center; padding:6px 10px; border-radius:8px; border:1px solid #ddd; background:#fff; cursor:pointer; font-size:13px; }
.ibml-email-inline input[type="email"]{ padding:6px 8px; border:1px solid #ddd; border-radius:8px; font-size:13px; }
.ibml-inline-status{ font-size:12px; color:#444; }

/* ---------- Finalized list ---------- */
.ibml-final-list .ibml-card.ibml-final{ display: grid; grid-template-columns: 40px 1.6fr 1fr 1fr 1fr 1.2fr; background:#fff; border:0; border-radius:0; box-shadow:none; padding:12px 0; margin:0; border-bottom:1px solid #eee; gap: 10px; align-items: center; }
.ibml-final-list .ibml-card.ibml-final:last-child{ border-bottom:0; }
.ibml-final-day-container { border-top: 1px solid #040951; border-radius: 0px; padding: 0px; background: #fff; margin-top: 20px; margin-bottom: 20px; }
.ibml-final-day-header{ display: flex; align-items: center; gap: 15px; margin-bottom: 12px; }
.ibml-final-day-header h3{ font-weight: 800; font-size: 18px; color: #fff; background: #040951; border-radius: 0px; padding: 1px 20px; flex-shrink: 0; margin: 0; }
.ibml-final-day-header p{ font-size: 15px; font-weight: 700; color: #040951; margin: 0; font-family: 'futura bold'; }
.ibml-pdf-area{ background:#fff;padding:40px;padding-bottom:100px;border-radius:40px;box-shadow:0 3px 9px rgba(0,0,0,.08);margin-bottom:30px; }

/* ---------- Saved Trips Dashboard ---------- */
.ibml-dashboard-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 25px; flex-wrap: wrap; gap: 15px; }
.ibml-search-wrap { position: relative; }
.ibml-search-wrap i { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: #999; }
#ibml-trip-search { padding: 8px 12px 8px 35px; border: 1px solid #ddd; border-radius: 8px; min-width: 280px; font-size: 14px; }
.ibml-saved-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 20px; }
.ibml-saved-item-card { background: #fff; border: 1px solid #e5e5e5; border-radius: 12px; box-shadow: 0 4px 12px rgba(0,0,0,.06); display: flex; flex-direction: column; transition: all .2s ease-out; }
.ibml-saved-item-card:hover { transform: translateY(-3px); box-shadow: 0 6px 16px rgba(0,0,0,.09); }
.ibml-saved-item-card.is-deleting { opacity: 0.4; pointer-events: none; }
.ibml-card-content { padding: 15px 20px; flex-grow: 1; }
.ibml-card-title { font-size: 20px; font-weight: 700; margin: 0 0 10px; }
.ibml-card-meta { display: flex; gap: 15px; font-size: 13px; color: #666; }
.ibml-card-meta span { display: inline-flex; align-items: center; gap: 6px; }
.ibml-card-actions { display: flex; border-top: 1px solid #e5e5e5; padding: 10px; gap: 10px; }
.ibml-btn-icon { display: inline-flex; align-items: center; justify-content: center; gap: 8px; background: #f5f5f5; border: 1px solid #ddd; color: #333; font-weight: 600; padding: 8px 12px; border-radius: 8px; cursor: pointer; transition: all .15s ease; flex-grow: 1; font-size: 14px; }
.ibml-btn-icon:hover { background: #e9e9e9; border-color: #ccc; }
.ibml-btn-icon .fa-trash { color: #d9534f; }
.ibml-no-results { text-align: center; padding: 20px; }


/* ---------- Shared View Page ---------- */
.ibml-view-header{ margin-bottom: 25px; padding-bottom: 20px; border-bottom: 1px solid #eee; }
.ibml-view-title {font-size:40px !important;line-height:1 !important;margin-bottom:0px !important;}
.ibml-view-meta{ font-size: 15px; color: #555; margin: 4px 0; }
.ibml-view-permalink{ margin-top: 15px; }
.ibml-view-permalink label{ display: block; font-weight: 700; margin-bottom: 5px; font-size: 14px; }
.ibml-view-permalink .ibml-permalink-input-wrap{ display: flex; align-items: center; gap: 8px; max-width: 500px; }
.ibml-view-permalink input[type="text"]{ flex: 1; padding: 8px 10px; font-size: 14px; background: #f5f5f5; border: 1px solid #ddd; border-radius: 8px; color: #333; }
.ibml-view-permalink button{ padding: 8px 12px; border-radius: 8px; border: 1px solid #ddd; background: #f7f7f7; cursor: pointer; font-size: 15px; color: #333; line-height: 1; }
.ibml-view-permalink button:hover{ background: #eee; }
.ibml-view-permalink button .fa-check { color: #1a9c33; }

/* ---------- Responsive ---------- */
@media (max-width: 960px){
  .ibml-headbar{ display:none; }
  .ibml-card,
  .ibml-final-list .ibml-card.ibml-final { grid-template-columns: 1fr; gap:8px; padding:12px; border: 1px solid #eee; border-radius: 12px; }
  .c-num { display: none; }
  .c-site{ align-items:flex-start; }
}
@media (max-width: 600px){
  .ibml-name-row,
  .ibml-finalize-header,
  .ibml-builder-header,
  .ibml-dashboard-header { flex-direction: column; gap: 15px; align-items: stretch; }
}

/*Trip Share*/
body.single-ibml_public .blog-title { display: none !important; }
body.single-ibml_public .i-section {Padding-top:10px;}
body.single-ibml_public .ibml-final-list .c-site img.ibml-thumb,
body.single-ibml_public .c-site img.ibml-thumb { width: 48px !important; height: 48px !important; aspect-ratio: 1 / 1 !important; border-radius: 50% !important; object-fit: cover !important; display: block !important; flex: 0 0 48px; max-width: none !important; }
