.ecap-shell, .ecap-cart-page, .ecap-confirm-page {max-width: 1240px; margin: 0 auto; font-family: inherit;}
.ecap-topbar {display:flex; gap:8px; flex-wrap:wrap; justify-content:center; margin:12px 0 10px;}
.ecap-chip, .ecap-side-item, .ecap-btn {text-decoration:none; transition:.2s ease;}
.ecap-chip {background:#28c7c7; color:#062531; padding:12px 20px; font-weight:700; display:inline-block;}
.ecap-chip.is-active, .ecap-chip:hover {background:#1db3b3; color:#fff;}
.ecap-sticky-cartbar {display:none; margin:0 0 12px; padding:14px 16px; align-items:center; justify-content:space-between; background:#fff; border:1px solid #d6dbe0; border-radius:10px; box-shadow:0 3px 10px rgba(0,0,0,.04);}
.ecap-sticky-cartbar.is-visible {display:flex;}
.ecap-layout {display:grid; grid-template-columns: 240px 1fr; gap:18px; align-items:start;}
.ecap-sidebar {display:flex; flex-direction:column; gap:6px; position:sticky; top:20px;}
.ecap-side-item {background:#28c7c7; color:#062531; font-weight:700; text-align:center; padding:16px 12px;}
.ecap-side-item.is-active, .ecap-side-item:hover {background:#1db3b3; color:#fff;}
.ecap-grid {display:grid; grid-template-columns: repeat(3, minmax(240px,1fr)); gap:22px;}
.ecap-card {background:#fff; border:1px solid #d6dbe0; border-radius:10px; overflow:hidden; display:flex; flex-direction:column; min-height:290px; box-shadow:0 2px 6px rgba(0,0,0,.04);}
.ecap-card.is-in-cart {border-color:#97c100; box-shadow:0 0 0 1px rgba(151,193,0,.15);}
.ecap-card-body {padding:20px 18px 16px; flex:1;}
.ecap-card-kicker {font-size:12px; font-weight:700; color:#1db3b3; text-transform:uppercase; letter-spacing:.03em; margin-bottom:10px;}
.ecap-card-body h3 {font-size:24px; line-height:1.35; margin:0 0 10px; color:#0f2a44;}
.ecap-desc {font-size:14px; color:#516173; margin:0 0 14px;}
.ecap-line {font-size:13px; color:#516173; margin-top:8px;}
.ecap-meta {font-size:13px; color:#516173; margin-top:6px;}
.ecap-card-footer {padding:16px 18px; display:flex; justify-content:space-between; align-items:flex-end; gap:16px; border-top:1px solid #e7ebf0;}
.ecap-card-actions {display:flex; justify-content:flex-end;}
.ecap-price-wrap {display:flex; flex-direction:column; gap:4px;}
.ecap-price {font-weight:800; color:#0f2a44; font-size:24px; line-height:1;}
.ecap-btn {background:#28c7c7; color:#fff; border:none; padding:12px 18px; border-radius:6px; cursor:pointer; font-weight:700; display:inline-block; text-align:center;}
.ecap-btn:hover, .ecap-btn:focus {background:#1db3b3; color:#fff; opacity:1; outline:none;}
.ecap-btn.is-added, .ecap-btn-outline {background:#fff; color:#97c100; border:1px solid #97c100;}
.ecap-btn-outline:hover, .ecap-btn.is-added:hover {background:#97c100; color:#fff;}
.ecap-cart-list {display:flex; flex-direction:column; gap:14px; margin:20px 0;}
.ecap-cart-item {display:flex; justify-content:space-between; align-items:center; gap:16px; padding:18px; border:1px solid #d6dbe0; background:#fff; border-radius:8px;}
.ecap-cart-right {display:flex; align-items:center; gap:12px;}
.ecap-remove {background:#fff; color:#b42318; border:1px solid #f2b8b5; padding:8px 12px; border-radius:4px; cursor:pointer;}
.ecap-arrhes-box {padding:18px; margin:20px 0; background:#f7fbec; border:1px solid #d6e9aa; border-radius:8px;}
.ecap-actions {margin-top:18px; display:flex; gap:12px; flex-wrap:wrap;}
.ecap-actions-split {justify-content:space-between;}
.ecap-confirm-summary {background:#fff; border:1px solid #d6dbe0; border-radius:8px; padding:18px; margin-bottom:20px;}
.ecap-form {background:#fff; border:1px solid #d6dbe0; border-radius:8px; padding:22px;}
.ecap-form-grid {display:grid; grid-template-columns:repeat(2,minmax(240px,1fr)); gap:16px;}
.ecap-form label {display:flex; flex-direction:column; gap:7px; font-weight:600; color:#243647;}
.ecap-form input {height:46px; border:1px solid #ccd5df; border-radius:6px; padding:0 12px; font-size:15px;}
.ecap-form input[type=file] {height:auto; padding:10px 12px;}
.ecap-empty {background:#fff8e1; padding:18px; border:1px solid #f0d68f; border-radius:8px;}
@media (max-width: 980px){
  .ecap-layout {grid-template-columns:1fr;}
  .ecap-sidebar {position:static; flex-direction:row; flex-wrap:wrap;}
  .ecap-grid {grid-template-columns:repeat(2,minmax(200px,1fr));}
}
@media (max-width: 640px){
  .ecap-grid, .ecap-form-grid {grid-template-columns:1fr;}
  .ecap-card-footer, .ecap-cart-item, .ecap-cart-right, .ecap-sticky-cartbar, .ecap-actions-split {flex-direction:column; align-items:flex-start;}
  .ecap-card-body h3 {font-size:20px;}
}

.ecap-hostel-page {max-width: 980px; margin: 0 auto;}
.ecap-hostel-hero {margin-bottom: 22px;}
.ecap-hostel-sessions {margin-top: 18px;}
.ecap-session-picker {border:1px solid #d6dbe0; border-radius:10px; padding:16px; background:#fafcff;}
.ecap-session-picker-bar {display:flex; gap:12px; align-items:center;}
.ecap-session-select {flex:1; min-height:46px; border:1px solid #ccd5df; border-radius:6px; padding:0 12px; font-size:15px; background:#fff;}
.ecap-session-help {font-size:12px; color:#5f6b7a; margin-top:8px;}
.ecap-session-selected {display:flex; flex-wrap:wrap; gap:10px; margin-top:14px;}
.ecap-session-chip {display:inline-flex; align-items:flex-start; gap:10px; background:#eef7ff; border:1px solid #bfd9f5; border-radius:999px; padding:8px 10px 8px 14px; max-width:100%;}
.ecap-session-chip-text {display:flex; flex-direction:column; gap:2px;}
.ecap-session-chip-text strong {font-size:13px; line-height:1.3; color:#0f2a44;}
.ecap-session-chip-text small {font-size:11px; color:#516173; line-height:1.3;}
.ecap-session-chip-remove {border:none; background:transparent; color:#b42318; cursor:pointer; font-size:18px; line-height:1; padding:2px 4px;}
@media (max-width:640px){
  .ecap-session-picker-bar {flex-direction:column; align-items:stretch;}
}


/* Responsive polish for course page */
.ecap-chip, .ecap-side-item {border-radius: 8px;}
.ecap-card-body h3 {word-break: break-word;}

@media (max-width: 980px){
  .ecap-shell, .ecap-cart-page, .ecap-confirm-page, .ecap-hostel-page {padding-left: 14px; padding-right: 14px;}
  .ecap-topbar {display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:10px; margin:18px 0 12px;}
  .ecap-chip {display:flex; align-items:center; justify-content:center; min-height:48px; padding:10px 12px; text-align:center; line-height:1.25; font-size:15px;}
  .ecap-sidebar {display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:10px; margin-bottom:8px;}
  .ecap-side-item {display:flex; align-items:center; justify-content:center; min-height:56px; padding:12px 10px; line-height:1.25; font-size:15px;}
  .ecap-grid {grid-template-columns: repeat(2, minmax(0,1fr)); gap:16px;}
  .ecap-card {min-height:auto;}
  .ecap-card-body {padding:16px 16px 12px;}
  .ecap-card-body h3 {font-size:22px; line-height:1.35;}
  .ecap-card-footer {padding:14px 16px; align-items:center;}
  .ecap-card-actions, .ecap-price-wrap {width:auto;}
  .ecap-btn {min-height:46px; display:inline-flex; align-items:center; justify-content:center;}
}

@media (max-width: 640px){
  .ecap-shell, .ecap-cart-page, .ecap-confirm-page, .ecap-hostel-page {padding-left: 12px; padding-right: 12px;}
  .ecap-topbar {grid-template-columns: repeat(2, minmax(0,1fr)); gap:8px; margin:14px 0 10px;}
  .ecap-chip {min-height:44px; padding:10px 8px; font-size:14px; border-radius:6px;}
  .ecap-sidebar {grid-template-columns: 1fr; gap:8px;}
  .ecap-side-item {min-height:48px; padding:12px; font-size:14px; border-radius:6px;}
  .ecap-grid {grid-template-columns: 1fr; gap:14px;}
  .ecap-card {border-radius:12px; overflow:hidden;}
  .ecap-card-body {padding:14px 14px 10px;}
  .ecap-card-kicker {font-size:11px; margin-bottom:8px;}
  .ecap-card-body h3 {font-size:18px; margin-bottom:8px;}
  .ecap-desc, .ecap-line, .ecap-meta {font-size:13px;}
  .ecap-card-footer {padding:12px 14px 14px; gap:10px; align-items:stretch;}
  .ecap-price-wrap {width:100%;}
  .ecap-price {font-size:22px;}
  .ecap-card-actions {width:100%;}
  .ecap-card-actions .ecap-btn {width:100%;}
  .ecap-sticky-cartbar {position:sticky; bottom:10px; z-index:20; padding:12px; border-radius:12px;}
  .ecap-sticky-cartbar .ecap-btn {width:100%;}
}


.ecap-course-filters{display:flex;justify-content:flex-end;align-items:end;gap:12px;margin:0 0 16px;}
.ecap-course-filters label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#243647;min-width:260px;}
.ecap-course-filters select{height:46px;border:1px solid #ccd5df;border-radius:6px;padding:0 12px;background:#fff;}
.ecap-btn.is-loading{opacity:.8;pointer-events:none;position:relative;}
.ecap-btn.is-loading::after{content:"";width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;display:inline-block;margin-left:8px;animation:ecapSpin .7s linear infinite;vertical-align:-2px;}
@keyframes ecapSpin{to{transform:rotate(360deg)}}
@media (max-width:640px){.ecap-course-filters{justify-content:stretch}.ecap-course-filters label{min-width:0;width:100%;}}


.ecap-filter-toolbar{display:flex;justify-content:space-between;align-items:end;gap:16px;margin:0 0 18px;flex-wrap:wrap;}
.ecap-filter-toolbar-title{font-size:14px;font-weight:700;color:#516173;text-transform:uppercase;letter-spacing:.03em;}
.ecap-course-filters{display:flex;justify-content:flex-end;align-items:end;gap:12px;margin:0;}
.ecap-course-filters label{display:flex;flex-direction:column;gap:6px;font-weight:600;color:#243647;min-width:280px;}
.ecap-course-filters select{height:46px;border:1px solid #ccd5df;border-radius:8px;padding:0 12px;background:#fff;box-shadow:none;}
.ecap-btn.is-loading{opacity:.9;pointer-events:none;position:relative;}
.ecap-btn.is-loading::after{content:'';width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;display:inline-block;margin-left:8px;animation:ecapSpin .7s linear infinite;vertical-align:-2px;}
.ecap-btn.is-loading-loading{cursor:wait;}
@media (max-width:980px){.ecap-filter-toolbar{align-items:stretch}.ecap-course-filters{width:100%;justify-content:stretch}.ecap-course-filters label{width:100%;min-width:0;}}
@media (max-width:640px){.ecap-filter-toolbar{margin:0 0 14px;gap:10px}.ecap-filter-toolbar-title{font-size:13px}.ecap-course-filters select{height:44px}.ecap-sticky-cartbar{position:sticky;bottom:10px;z-index:20}}


/* Cross-site safe loading spinner */
.ecap-btn.is-loading{
  opacity:.92;
  pointer-events:none;
}
.ecap-btn .ecap-spinner{
  display:none;
}
.ecap-btn.is-loading .ecap-spinner{
  display:inline-block;
  width:14px;
  height:14px;
  margin-left:8px;
  border:2px solid rgba(255,255,255,.45);
  border-top-color:#fff;
  border-radius:50%;
  animation:ecapSpin .7s linear infinite;
  vertical-align:-2px;
}
/* Disable older pseudo-element spinner to avoid broken glyph/theme conflicts */
.ecap-btn.is-loading::after{
  content:none !important;
  display:none !important;
}


.ecap-confirm-submit{min-width:260px;min-height:48px;appearance:none;-webkit-appearance:none;}
.ecap-confirm-submit:hover,.ecap-confirm-submit:focus{background:#1db3b3 !important;color:#fff !important;opacity:1 !important;visibility:visible !important;}

/* Hostel booking v2 */
.ecap-hostel-booking-layout{display:grid;grid-template-columns:1.05fr .95fr;gap:24px;align-items:start}
.ecap-hostel-selector-card,.ecap-hostel-form-card{background:#fff;border:1px solid #dfe7ef;border-radius:18px;padding:22px;box-shadow:0 10px 24px rgba(16,24,40,.05)}
.ecap-night-picker-row{display:flex;gap:12px;align-items:center;margin:14px 0}
.ecap-night-input{flex:1 1 auto;height:50px;border:1px solid #cfd8e3;border-radius:12px;padding:0 14px;font-size:15px}
.ecap-selected-nights{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.ecap-night-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;background:#eef8fb;border:1px solid #c7e9f2;color:#16324a}
.ecap-night-chip-remove{width:22px;height:22px;border:none;border-radius:50%;background:#fff;color:#d64545;cursor:pointer;font-size:16px;line-height:1}
.ecap-hostel-summary{margin-top:18px;padding:14px 16px;border-radius:14px;background:#f7fafc;display:grid;gap:8px}
.ecap-night-meta,.ecap-availability-note,.ecap-help{color:#5f6b7a}
.ecap-hostel-image{margin:12px 0 18px}
@media (max-width: 900px){.ecap-hostel-booking-layout{grid-template-columns:1fr}.ecap-night-picker-row{flex-direction:column}.ecap-night-picker-row .ecap-btn,.ecap-night-input{width:100%}}

/* v0.7.6 dormitory cleanup */
.ecap-hostel-hero h2{font-size:56px;line-height:1.05;margin:0 0 18px;color:#08273a}
.ecap-hostel-image img{display:block;width:100%;max-width:980px;object-fit:cover;box-shadow:0 8px 24px rgba(0,0,0,.08)}
.ecap-hostel-booking-layout{display:grid;grid-template-columns:minmax(320px,460px) minmax(320px,1fr);gap:28px;align-items:start;margin-top:26px}
.ecap-hostel-selector-card,.ecap-hostel-form-card{background:#fff;border:1px solid #d7dfe8;border-radius:18px;padding:28px;box-shadow:0 8px 24px rgba(0,0,0,.04)}
.ecap-hostel-course-ref{margin:12px 0 20px}
.ecap-hostel-course-ref label{display:block;font-weight:700;margin-bottom:8px;color:#08273a}
.ecap-hostel-course-ref select{width:100%;height:48px;border:1px solid #cfd8e3;border-radius:10px;padding:0 14px;background:#fff}
.ecap-hostel-summary{background:#f6f8fb;border-radius:14px;padding:16px 18px;margin-top:16px}
.ecap-night-chip{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border:1px solid #a9dcef;background:#eaf8ff;border-radius:999px;margin-bottom:10px}
.ecap-night-chip-remove{border:0;background:#22c7cf;color:#fff;width:35px;height:28px;display:flex;justify-content:center;align-items:center;border-radius:50%;cursor:pointer}
@media (max-width: 900px){.ecap-hostel-booking-layout{grid-template-columns:1fr}.ecap-hostel-hero h2{font-size:42px}}

/* v0.8.1 dorm auto date add */
[data-ecap-hostel-calendar] [data-ecap-add-night]{display:none !important;}
