@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
:root{
  --otm-primary:#0f3b87;
  --otm-primary-dark:#0b2f6b;
  --otm-accent:#d89a3d;
  --otm-accent-soft:#f5e3c6;
  --otm-cream:#fff8ef;
  --otm-panel:#ffffff;
  --otm-border:#d9e3f2;
  --otm-text:#17335f;
  --otm-muted:#61718f;
}


.otm-login-page,.otm-account-page{font-family:'Inter',Arial,sans-serif !important;color:var(--otm-text)}
.otm-login-page *,.otm-account-page *{box-sizing:border-box;font-family:'Inter',Arial,sans-serif !important}
.otm-login-page{padding:24px 12px;background:#F5F5F5;min-height:100vh;display:flex;align-items:center;justify-content:center}
.otm-login-wrap{max-width:520px;width:100%;margin:0 auto}
.otm-login-card{max-width:460px;margin:0 auto;background:#fff;border:1px solid rgba(215,161,102,.20);border-radius:18px;box-shadow:0 14px 30px rgba(64,38,18,.10);padding:30px !important;text-align:center}
.otm-brand-mark{margin:0 0 10px}
.otm-login-card::before{content:"";position:absolute;inset:0 0 auto 0;height:6px;background:linear-gradient(90deg,var(--otm-primary) 0%,var(--otm-accent) 100%)}
.otm-logo{display:block;margin:0 auto;height:auto}
.otm-login-card .otm-logo{width:220px;max-width:84%;object-fit:contain}
.otm-login-card h1{margin:0 0 6px;font-size:30px !important;line-height:1.05;letter-spacing:-.03em;font-weight:800;color:#0E3480 !important}
.otm-login-subtitle{margin:0 0 14px;color:var(--otm-muted);font-size:14px;line-height:1.45}
.otm-form-stack{display:grid;gap:8px;text-align:left}
.otm-field-label{display:block;margin:0 0 5px;font-size:14px;font-weight:700;color:var(--otm-text)}
.otm-input,.otm-select,.otm-textarea{width:100%;padding:13px 14px;border-radius:14px;border:1px solid var(--otm-border);background:#fff;color:#203252;font-size:14px;line-height:1.45;outline:none}
.otm-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:44px;min-height:54px;color:#2a2a2a;background-image:linear-gradient(45deg,transparent 50%, #6f6a63 50%),linear-gradient(135deg,#6f6a63 50%,transparent 50%);background-position:calc(100% - 20px) calc(50% - 3px),calc(100% - 14px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat}
.otm-select option{color:#2a2a2a;background:#fff}
.otm-textarea{min-height:120px;resize:vertical}
.otm-input::placeholder,.otm-textarea::placeholder{color:#8c857c;opacity:1}
.otm-input:focus,.otm-select:focus,.otm-textarea:focus{border-color:var(--otm-primary);box-shadow:0 0 0 4px rgba(15,59,135,.12)}
.otm-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:14px;padding:13px 18px;font-size:14px;font-weight:700;text-decoration:none;cursor:pointer;transition:.18s ease}
.otm-btn-primary{background:#0E3480 !important;color:#fff;box-shadow:0 12px 24px rgba(14,52,128,.20)}
.otm-btn-primary:hover{transform:translateY(-1px)}
.otm-btn-secondary{background:#fff;border:1px solid var(--otm-border);color:var(--otm-primary)}
.otm-form-message{font-size:14px;color:var(--otm-muted)}
.otm-help-line{margin:8px 0 0;color:var(--otm-muted);font-size:12px;text-align:center;line-height:1.4}
.otm-help-line a{color:#0E3480 !important;font-weight:700;text-decoration:none}

.otm-account-page{padding:18px 10px}
.otm-account-layout{display:grid;grid-template-columns:280px minmax(0,1fr);gap:22px;max-width:1280px;margin:0 auto}
.otm-sidebar{background:#fff;border:1px solid var(--otm-border);border-radius:22px;padding:20px 16px;box-shadow:0 8px 24px rgba(44,26,10,.05);height:fit-content;position:sticky;top:24px}
.otm-sidebar-title{font-size:20px;font-weight:800;color:var(--otm-primary);margin:0 0 16px;padding-left:10px;border-left:4px solid var(--otm-primary)}
.otm-nav{display:grid;gap:8px}
.otm-nav-section{margin-top:12px;padding:4px 8px;font-size:12px;letter-spacing:.04em;color:#263b72;font-weight:800}
.otm-nav-link,.otm-nav-link:visited{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-radius:18px;color:#262626 !important;text-decoration:none;font-size:14px;font-weight:500;cursor:pointer;border:1px solid #efe7dc;background:#fff;transition:.15s ease}.otm-nav-link span{color:inherit !important}.otm-nav-link:hover span,.otm-nav-link.is-active span,.otm-nav-link:focus span{color:var(--otm-primary) !important}
.otm-nav-link:hover,.otm-nav-link.is-active,.otm-nav-link:focus{background:#f7f0e8;color:var(--otm-primary) !important;border-color:#cf9c68;outline:none}
.otm-main{min-width:0}
.otm-account-pane{display:none}
.otm-account-pane.is-active{display:block}
.otm-hero{margin-bottom:18px}
.otm-hero h1{margin:0 0 4px;font-size:30px;line-height:1.05;letter-spacing:-.03em;font-weight:800;color:var(--otm-text)}
.otm-customer-line{margin:0;color:#322d28;font-size:18px;font-weight:500}
.otm-section-title{margin:0 0 14px;font-size:25px;line-height:1.12;font-weight:800;letter-spacing:-.02em;color:var(--otm-text)}
.otm-summary-grid,.otm-grid-split,.otm-card-grid{display:grid;gap:18px}
.otm-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:14px}
.otm-grid-split{grid-template-columns:repeat(2,minmax(0,1fr))}
.otm-card,.otm-panel,.otm-stat-card,.otm-ticket-item,.otm-update-card,.otm-doc-card{background:#fff;border:1px solid var(--otm-border);border-radius:22px;padding:18px;box-shadow:0 6px 18px rgba(44,26,10,.04)}
.otm-stat-card{min-height:168px;display:flex;flex-direction:column;justify-content:flex-start}.otm-referral-card{justify-content:space-between}
.otm-stat-label{font-size:14px;color:#2f2b29;line-height:1.3;font-weight:600;margin-bottom:14px}
.otm-stat-value{font-size:30px;font-weight:800;line-height:1.1;color:var(--otm-text)}
.otm-referral-track{display:grid;grid-template-columns:repeat(4,minmax(0,56px));gap:10px;max-width:254px}
.otm-ref-chip{min-width:0;padding:10px 0;text-align:center;border:1px solid #d8c8b6;border-radius:16px;font-size:14px;font-weight:700;background:#fff;color:var(--otm-text)}.otm-ref-chip.is-earned{background:#f7efe6;border-color:var(--otm-accent);color:var(--otm-primary-dark)}
.otm-ref-chip.is-final{grid-column:span 2;color:var(--otm-primary);border-color:var(--otm-primary);padding:14px 0}
.otm-benefit-note{margin:0 0 22px;color:var(--otm-muted);font-size:14px}
.otm-benefit-note a{color:var(--otm-primary);font-weight:700;text-decoration:none}
.otm-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:8px}
.otm-card-title{font-size:18px;font-weight:700;line-height:1.3;color:var(--otm-text)}
.otm-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:12px;align-items:start}
.otm-kv{font-size:14px;color:var(--otm-muted);line-height:1.5;word-break:break-word}
.otm-kv strong{display:block;font-size:14px;color:var(--otm-text);margin-top:4px;line-height:1.45;font-weight:600}
.otm-muted{color:var(--otm-muted);font-size:14px}
.otm-status{display:inline-flex;align-items:center;padding:7px 12px;border-radius:999px;font-size:12px;font-weight:800;text-transform:capitalize}
.otm-status.pending,.otm-status.unpaid,.otm-status.open{background:#fff4dd;color:#7a581c}
.otm-status.confirmed,.otm-status.paid,.otm-status.resolved{background:#eaf7ed;color:#246137}
.otm-status.partial,.otm-status.in_progress,.otm-status.completed{background:#f0f2ff;color:#344ea4}
.otm-status.cancelled{background:#fdecec;color:#9a2d2d}
.otm-single-col,.otm-list{display:grid;gap:14px}
.otm-empty-copy{margin:0;color:var(--otm-muted);font-size:14px;line-height:1.5}
.otm-update-card img,.otm-doc-card img{width:100%;height:180px;object-fit:cover;border-radius:16px;margin:0 0 14px}
.otm-update-card h3,.otm-doc-card h3{margin:0 0 8px;font-size:18px;line-height:1.25;color:var(--otm-text)}
.otm-update-date{font-size:12px;color:var(--otm-muted);margin-bottom:10px}
.otm-admin-reply{margin-top:12px;padding:14px;border-radius:14px;background:#faf6f1}
.otm-subnav-card{padding:14px 16px;border:1px solid var(--otm-border);border-radius:18px;background:#fff;cursor:pointer;font-weight:500;color:#352f29;font-size:14px}
.otm-subnav-card:hover,.otm-subnav-card.is-active{background:var(--otm-cream);color:var(--otm-primary);border-color:rgba(140,45,28,.2)}
.otm-download-meta{display:grid;gap:6px;margin:10px 0 14px;font-size:14px;color:var(--otm-muted)}
.otm-popup-backdrop{position:fixed;inset:0;background:rgba(15,17,26,.45);display:none;align-items:center;justify-content:center;padding:16px;z-index:99999}
.otm-popup-backdrop.is-open{display:flex}
.otm-popup{max-width:430px;width:100%;background:#fff;border-radius:24px;padding:22px;border:1px solid var(--otm-border);box-shadow:0 24px 80px rgba(32,21,12,.20);text-align:center}
.otm-popup-ill{width:84px;height:84px;margin:0 auto 14px;border-radius:50%;background:linear-gradient(135deg,#fde3bb,#fff3de);display:flex;align-items:center;justify-content:center;color:var(--otm-primary)}
.otm-popup h3{margin:0 0 10px;font-size:22px;color:var(--otm-text)}
.otm-popup p{margin:0 0 16px;font-size:14px;color:var(--otm-muted);line-height:1.55}

@media (max-width: 1024px){
  .otm-account-layout{grid-template-columns:1fr}
  .otm-sidebar{position:static}
  .otm-summary-grid,.otm-grid-split,.otm-card-grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .otm-login-page{padding:16px 8px;min-height:100vh;display:flex;align-items:center;justify-content:center}
  .otm-login-wrap,.otm-login-card{max-width:100%}
  .otm-login-card{padding:30px}
  .otm-login-card .otm-logo{width:190px;max-width:80%}
  .otm-login-card h1{font-size:30px}
  .otm-sidebar{padding:16px 12px}
}


.otm-reply-title{font-size:13px;font-weight:800;color:var(--otm-primary);margin-bottom:6px}
.otm-admin-reply{margin-top:12px;padding:14px;border-radius:14px;background:#faf6f1;border:1px solid rgba(215,161,102,.35)}
@media (max-width: 1024px){
  .otm-account-page{padding:12px 8px}
  .otm-account-layout{grid-template-columns:1fr;gap:14px}
  .otm-sidebar{position:static;padding:14px 12px;border-radius:18px}
  .otm-nav{gap:6px}
  .otm-nav-link{padding:11px 12px;font-size:14px}
  .otm-summary-grid{grid-template-columns:1fr;gap:12px}
  .otm-stat-card{min-height:auto}
}
@media (max-width: 640px){
  .otm-account-layout{grid-template-columns:1fr}
  .otm-sidebar-title{font-size:18px}
  .otm-hero h1{font-size:26px}
  .otm-customer-line{font-size:16px}
  .otm-section-title{font-size:22px}
  .otm-card,.otm-panel,.otm-stat-card,.otm-ticket-item,.otm-update-card,.otm-doc-card{padding:14px;border-radius:18px}
  .otm-referral-track{grid-template-columns:repeat(4,minmax(0,1fr));max-width:none}
  .otm-ref-chip{padding:9px 0;font-size:13px}
  .otm-ref-chip.is-final{grid-column:span 2}
  .otm-card-grid,.otm-grid-split{grid-template-columns:1fr}
  .otm-login-wrap{max-width:420px}
  .otm-login-card{max-width:420px;padding:15px}
}

@media (max-width: 900px){.otm-account-page{grid-template-columns:1fr;gap:18px}.otm-sidebar{position:static;top:auto}.otm-stats{grid-template-columns:1fr}.otm-card-grid{grid-template-columns:1fr}.otm-referral-grid{grid-template-columns:repeat(4,minmax(48px,1fr))}.otm-login-card{max-width:420px;padding:15px}}
@media (max-width: 640px){.otm-account-shell{padding:14px}.otm-sidebar{padding:14px 12px;border-radius:16px}.otm-nav-link{padding:12px 14px;font-size:15px}.otm-section-title{font-size:25px}.otm-welcome{font-size:30px}.otm-login-card{max-width:100%;padding:15px}}


/* v1.8.8 overrides */
.otm-booking-card{padding:20px}
.otm-booking-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:12px}
.otm-booking-col{display:grid;gap:16px;align-content:start}
.otm-booking-footer{margin-top:18px;padding-top:14px;border-top:1px solid var(--otm-border)}
.otm-admin-reply-body{font-size:14px;line-height:1.55;color:var(--otm-text)}
button.otm-nav-link{width:100%;text-align:left;background:#fff}
button.otm-nav-link:hover,button.otm-nav-link.is-active{background:#f7f0e8}
@media (max-width: 900px){
  .otm-account-page{overflow-x:auto}
  .otm-account-layout{grid-template-columns:260px minmax(720px,1fr);min-width:980px;align-items:start}
  .otm-sidebar{position:sticky;top:16px}
}
@media (max-width: 640px){
  .otm-login-wrap,.otm-login-card{max-width:100%}
  .otm-login-card{padding:30px}
  .otm-login-card .otm-logo{width:176px;max-width:78%}
  .otm-login-card h1{font-size:30px}
  .otm-login-subtitle{font-size:12px;margin-bottom:10px}
  .otm-booking-grid{grid-template-columns:1fr}
  .otm-account-layout{min-width:920px}
}


/* v1.8.10 mobile redesign */
@media (max-width: 900px){
  .otm-account-page{padding:12px 10px;overflow-x:visible}
  .otm-account-layout{grid-template-columns:1fr !important;min-width:0 !important;gap:14px;max-width:100%}
  .otm-sidebar{position:static;top:auto;padding:14px 12px;border-radius:18px}
  .otm-sidebar-title{font-size:20px;margin-bottom:12px}
  .otm-nav{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
  .otm-nav::-webkit-scrollbar{display:none}
  .otm-nav-section{width:100%;margin:10px 0 4px;padding:0;font-size:12px}
  .otm-nav-link,button.otm-nav-link{flex:0 0 auto;min-width:max-content;padding:10px 14px;border-radius:999px;font-size:14px;white-space:nowrap}
  .otm-main{min-width:0}
  .otm-hero h1{font-size:28px;line-height:1.05}
  .otm-customer-line{font-size:16px}
  .otm-section-title{font-size:22px;line-height:1.15;margin-bottom:12px}
  .otm-summary-grid,.otm-grid-split,.otm-card-grid,.otm-booking-grid{grid-template-columns:1fr !important;gap:12px}
  .otm-card,.otm-panel,.otm-stat-card,.otm-ticket-item,.otm-update-card,.otm-doc-card,.otm-booking-card{padding:14px;border-radius:18px}
  .otm-card-head{gap:10px;align-items:flex-start;flex-wrap:wrap}
  .otm-card-title{font-size:18px}
  .otm-status{font-size:11px;padding:6px 10px}
  .otm-stat-card{min-height:0}
  .otm-stat-label{font-size:13px;margin-bottom:10px}
  .otm-stat-value{font-size:24px}
  .otm-referral-track{grid-template-columns:repeat(4,minmax(0,1fr));max-width:none;gap:8px}
  .otm-ref-chip{font-size:13px;border-radius:14px;padding:10px 0}
  .otm-ref-chip.is-final{grid-column:span 4;padding:12px 0}
  .otm-benefit-note,.otm-muted,.otm-empty-copy,.otm-kv,.otm-admin-reply-body,.otm-download-meta{font-size:14px}
  .otm-kv strong{font-size:14px}
  .otm-booking-col{gap:12px}
  .otm-booking-footer{margin-top:14px;padding-top:12px}
  .otm-update-card img,.otm-doc-card img{height:150px}
  .otm-popup{padding:18px;border-radius:20px}
}
@media (max-width: 640px){
  .otm-login-page{padding:10px 8px}
  .otm-login-wrap,.otm-login-card{max-width:100%}
  .otm-login-card{padding:20px;border-radius:18px}
  .otm-login-card .otm-logo{width:176px;max-width:78%}
  .otm-login-card h1{font-size:30px}
  .otm-login-subtitle{font-size:12px}
  .otm-input,.otm-select,.otm-textarea{font-size:16px;padding:12px 13px}
  .otm-btn{width:100%}
  .otm-sidebar{padding:12px 10px}
  .otm-sidebar-title{font-size:18px}
  .otm-nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;overflow:visible}
  .otm-nav-section{grid-column:1/-1;margin:8px 0 0}
  .otm-nav-link,button.otm-nav-link{min-width:0;width:100%;justify-content:flex-start;white-space:normal;line-height:1.2;border-radius:14px;padding:12px 12px}
  .otm-hero h1{font-size:26px}
  .otm-customer-line{font-size:15px}
  .otm-section-title{font-size:20px}
  .otm-stat-value{font-size:22px}
  .otm-popup h3{font-size:20px}
}
@media (max-width: 420px){
  .otm-account-page{padding:10px 8px}
  .otm-nav{grid-template-columns:1fr}
  .otm-hero h1{font-size:24px}
  .otm-card-title{font-size:17px}
  .otm-referral-track{grid-template-columns:repeat(3,minmax(0,1fr))}
  .otm-ref-chip.is-final{grid-column:span 3}
}


/* Mobile redesign matching reference */
.otm-account-mobilebar{display:none}
.otm-mobile-nav-toggle{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 18px;border-radius:999px;border:1.5px solid #7b6d5f;background:#fff;color:var(--otm-text);font-size:18px;font-weight:700;box-shadow:0 8px 18px rgba(44,26,10,.06)}
.otm-mobile-nav-icon{font-size:20px;line-height:1;color:#4d443d}

@media (max-width: 767px){
  .otm-account-page{padding:14px 12px 20px;background:transparent}
  .otm-account-mobilebar{display:block;max-width:420px;margin:0 auto 14px}
  .otm-account-layout{display:block;max-width:420px;margin:0 auto;position:relative}
  .otm-sidebar{position:fixed;left:12px;right:12px;top:70px;z-index:9999;display:none;max-height:calc(100vh - 92px);overflow:auto;padding:14px 12px 16px;border-radius:24px;box-shadow:0 20px 50px rgba(22,18,14,.16);background:#fff}
  .otm-account-page.otm-mobile-nav-open .otm-sidebar{display:block}
  .otm-sidebar-title{font-size:18px;margin-bottom:12px}
  .otm-nav-section{font-size:11px;margin-top:10px}
  .otm-nav-link,.otm-nav-link:visited{padding:12px 14px;border-radius:16px;font-size:15px}
  .otm-main{max-width:420px}
  .otm-hero{margin-bottom:12px}
  .otm-hero h1{font-size:28px;line-height:1.1;margin-bottom:10px}
  .otm-customer-line{font-size:16px;margin-bottom:10px}
  .otm-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:12px}
  .otm-stat-card{padding:16px;min-height:108px;border-radius:18px;box-shadow:0 8px 20px rgba(44,26,10,.05)}
  .otm-referral-card{grid-column:1/-1;min-height:auto}
  .otm-stat-label{font-size:13px;margin-bottom:12px}
  .otm-stat-value{font-size:18px}
  .otm-referral-track{grid-template-columns:repeat(8,minmax(0,1fr));gap:4px;max-width:none;align-items:center}
  .otm-ref-chip{padding:4px 0;border-radius:6px;font-size:12px;line-height:1.1}
  .otm-ref-chip.is-final{grid-column:auto;padding:5px 6px;min-width:72px}
  .otm-benefit-note{font-size:14px;line-height:1.55;margin:0 0 16px}
  .otm-section-title{font-size:22px;margin-bottom:12px}
  .otm-single-col,.otm-list{gap:12px}
  .otm-card,.otm-panel,.otm-ticket-item,.otm-update-card,.otm-doc-card{padding:16px;border-radius:18px}
  .otm-card-head{display:block;margin-bottom:12px}
  .otm-card-title{font-size:16px;margin-bottom:6px}
  .otm-status{margin-top:6px}
  .otm-card-grid,.otm-grid-split{grid-template-columns:1fr 1fr;gap:12px}
  .otm-kv,.otm-kv strong,.otm-muted,.otm-empty-copy,.otm-update-card p,.otm-doc-card p,.otm-download-meta{font-size:14px;line-height:1.5}
  .otm-update-card img,.otm-doc-card img{height:140px;border-radius:14px}
  .otm-update-card h3,.otm-doc-card h3{font-size:17px}
  .otm-popup{padding:18px;border-radius:20px}
  .otm-popup h3{font-size:20px}
}

@media (max-width: 480px){
  .otm-account-page{padding:12px 10px 18px}
  .otm-account-mobilebar,.otm-account-layout,.otm-main{max-width:100%}
  .otm-mobile-nav-toggle{font-size:17px;padding:12px 16px}
  .otm-hero h1{font-size:26px}
  .otm-summary-grid{grid-template-columns:1fr 1fr;gap:10px}
  .otm-stat-card{padding:14px;min-height:102px}
  .otm-stat-label{font-size:12px}
  .otm-stat-value{font-size:17px}
  .otm-referral-track{grid-template-columns:repeat(8,minmax(0,1fr));gap:3px}
  .otm-ref-chip{font-size:11px;border-radius:5px;padding:4px 0}
  .otm-ref-chip.is-final{font-size:11px;min-width:66px;padding:5px 4px}
  .otm-section-title{font-size:20px}
  .otm-card-grid,.otm-grid-split{grid-template-columns:1fr}
  .otm-sidebar{left:10px;right:10px;top:66px;max-height:calc(100vh - 82px)}
}


@media (max-width: 767px){
  .otm-account-page.otm-mobile-nav-open .otm-sidebar{display:block !important}
  .otm-sidebar{width:auto}
}


/* v1.8.14 clean mobile fix */
@media (max-width: 767px){
  .otm-account-page{padding:12px 12px 20px !important;background:transparent !important;overflow-x:hidden !important}
  .otm-account-mobilebar{display:block !important;max-width:420px;margin:0 auto 12px !important}
  .otm-mobile-nav-toggle{width:100% !important;display:flex !important;align-items:center !important;justify-content:space-between !important;gap:10px !important;padding:13px 16px !important;border-radius:18px !important;border:1px solid var(--otm-border) !important;background:rgba(255,255,255,.94) !important;color:var(--otm-text) !important;box-shadow:0 6px 16px rgba(44,26,10,.05) !important;outline:none !important}
  .otm-mobile-nav-toggle:focus,.otm-mobile-nav-toggle:hover{background:#fff !important;border-color:#d2b08b !important;box-shadow:0 8px 18px rgba(44,26,10,.08) !important}
  .otm-mobile-nav-icon{color:var(--otm-primary) !important}
  .otm-account-layout{display:block !important;max-width:420px !important;min-width:0 !important;margin:0 auto !important;gap:0 !important}
  .otm-sidebar{display:none !important;position:fixed !important;left:12px !important;right:12px !important;top:72px !important;z-index:9999 !important;max-height:calc(100vh - 96px) !important;overflow:auto !important;padding:14px 12px 16px !important;border-radius:22px !important;background:#fff !important;box-shadow:0 18px 45px rgba(22,18,14,.16) !important}
  .otm-account-page.otm-mobile-nav-open .otm-sidebar{display:block !important}
  .otm-sidebar-title{font-size:18px !important;margin-bottom:12px !important;padding-left:10px !important}
  .otm-nav{display:grid !important;grid-template-columns:1fr 1fr !important;gap:8px !important;overflow:visible !important}
  .otm-nav-section{grid-column:1/-1 !important;margin:10px 0 2px !important;padding:0 4px !important}
  .otm-nav-link,.otm-nav-link:visited,button.otm-nav-link{width:100% !important;min-width:0 !important;justify-content:flex-start !important;white-space:normal !important;padding:12px 12px !important;border-radius:14px !important;background:#fff !important;color:#262626 !important}
  .otm-nav-link:hover,.otm-nav-link.is-active,.otm-nav-link:focus,button.otm-nav-link:hover,button.otm-nav-link.is-active{background:#f7f0e8 !important;color:var(--otm-primary) !important;border-color:#cf9c68 !important}
  .otm-main{max-width:420px !important;min-width:0 !important}
  .otm-hero{margin-bottom:12px !important}
  .otm-hero h1{font-size:28px !important;line-height:1.08 !important;margin-bottom:6px !important}
  .otm-customer-line{font-size:16px !important}
  .otm-summary-grid{grid-template-columns:1fr 1fr !important;gap:12px !important;margin-bottom:12px !important}
  .otm-stat-card{padding:16px !important;min-height:112px !important;border-radius:18px !important}
  .otm-stat-label{font-size:13px !important;margin-bottom:12px !important}
  .otm-stat-value{font-size:24px !important}
  .otm-referral-card{grid-column:1/-1 !important;min-height:auto !important}
  .otm-referral-track{display:grid !important;grid-template-columns:repeat(4,minmax(0,1fr)) !important;gap:8px !important;max-width:none !important;align-items:stretch !important}
  .otm-ref-chip{padding:8px 0 !important;border-radius:10px !important;font-size:13px !important;line-height:1.2 !important}
  .otm-ref-chip.is-final{grid-column:1/-1 !important;padding:10px 0 !important}
  .otm-benefit-note{font-size:14px !important;line-height:1.55 !important;margin:0 0 16px !important}
  .otm-section-title{font-size:22px !important;margin-bottom:12px !important}
  .otm-single-col,.otm-list{gap:12px !important}
  .otm-card,.otm-panel,.otm-ticket-item,.otm-update-card,.otm-doc-card,.otm-booking-card{padding:16px !important;border-radius:18px !important}
  .otm-card-head{display:block !important;margin-bottom:10px !important}
  .otm-card-title{font-size:16px !important;line-height:1.35 !important;margin-bottom:4px !important}
  .otm-status{display:inline-flex !important;margin-top:4px !important}
  .otm-booking-grid{display:grid !important;grid-template-columns:1fr 1fr !important;gap:14px !important;margin-top:12px !important}
  .otm-booking-col{gap:12px !important}
  .otm-booking-footer{margin-top:14px !important;padding-top:12px !important}
  .otm-card-grid,.otm-grid-split{grid-template-columns:1fr !important;gap:12px !important}
  .otm-kv,.otm-kv strong,.otm-muted,.otm-empty-copy,.otm-download-meta{font-size:14px !important;line-height:1.5 !important}
  .otm-kv strong{margin-top:3px !important}
  .otm-update-card img,.otm-doc-card img{width:100% !important;height:140px !important;border-radius:14px !important}
  .otm-update-card h3,.otm-doc-card h3{font-size:17px !important}
}
@media (max-width: 420px){
  .otm-account-page,.otm-account-layout,.otm-account-mobilebar,.otm-main{max-width:100% !important}
  .otm-nav{grid-template-columns:1fr !important}
  .otm-summary-grid{grid-template-columns:1fr !important}
  .otm-booking-grid{grid-template-columns:1fr 1fr !important}
  .otm-referral-track{grid-template-columns:repeat(4,minmax(0,1fr)) !important}
  .otm-login-page{padding:10px 8px !important}
  .otm-login-wrap,.otm-login-card{max-width:420px !important}
}


.otm-login-page .otm-login-card h1{font-size:30px !important;color:#0E3480 !important}
.otm-login-page .otm-help-line a{color:#0E3480 !important}
.otm-login-page .otm-btn-primary{background:#0E3480 !important}


/* ===== Mobile login-only redesign (scoped) ===== */
@media (max-width: 767px){
  .otm-login-page{
    min-height:100svh;
    padding:18px 12px 24px !important;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(180deg, rgba(14,52,128,.04) 0%, rgba(14,52,128,0) 38%), #f5f5f5;
  }

  .otm-login-page .otm-login-wrap{
    width:100%;
    max-width:420px !important;
    margin:0 auto;
  }

  .otm-login-page .otm-login-card{
    width:100%;
    max-width:100% !important;
    margin:0 auto;
    padding:22px 16px 18px !important;
    border-radius:22px !important;
    border:1px solid rgba(14,52,128,.08) !important;
    box-shadow:0 16px 40px rgba(14,52,128,.10) !important;
    text-align:left !important;
    position:relative;
    overflow:hidden;
  }

  .otm-login-page .otm-login-card::before{
    height:5px !important;
    background:linear-gradient(90deg,#0E3480 0%, #3554d1 100%) !important;
  }

  .otm-login-page .otm-brand-mark{
    margin:0 0 14px !important;
    text-align:center !important;
  }

  .otm-login-page .otm-login-card .otm-logo{
    width:160px !important;
    max-width:78% !important;
    margin:0 auto !important;
  }

  .otm-login-page .otm-login-card h1{
    margin:0 0 8px !important;
    font-size:24px !important;
    line-height:1.15 !important;
    letter-spacing:-.02em !important;
    text-align:center !important;
  }

  .otm-login-page .otm-login-subtitle{
    margin:0 0 16px !important;
    font-size:13px !important;
    line-height:1.55 !important;
    text-align:center !important;
    color:#61718f !important;
  }

  .otm-login-page .otm-login-form.otm-form-stack,
  .otm-login-page form.otm-form-stack{
    gap:12px !important;
  }

  .otm-login-page .otm-field-label{
    margin:0 0 6px !important;
    font-size:13px !important;
    line-height:1.35 !important;
    font-weight:700 !important;
    color:#17335f !important;
  }

  .otm-login-page .otm-input,
  .otm-login-page .otm-select,
  .otm-login-page .otm-textarea{
    height:50px !important;
    min-height:50px !important;
    padding:0 14px !important;
    border-radius:14px !important;
    font-size:16px !important;
    line-height:1.2 !important;
    border:1px solid #d9e3f2 !important;
    background:#fff !important;
    color:#17335f !important;
    box-shadow:none !important;
  }

  .otm-login-page .otm-textarea{
    min-height:120px !important;
    padding:14px !important;
  }

  .otm-login-page .otm-input::placeholder,
  .otm-login-page .otm-textarea::placeholder{
    color:#8a97b1 !important;
  }

  .otm-login-page .otm-input:focus,
  .otm-login-page .otm-select:focus,
  .otm-login-page .otm-textarea:focus{
    border-color:#3554d1 !important;
    box-shadow:0 0 0 4px rgba(53,84,209,.10) !important;
  }

  .otm-login-page .otm-btn{
    min-height:50px !important;
    width:100% !important;
    border-radius:14px !important;
    font-size:15px !important;
    font-weight:700 !important;
  }

  .otm-login-page .otm-btn-primary{
    width:100% !important;
    margin-top:2px !important;
    box-shadow:0 12px 24px rgba(14,52,128,.18) !important;
  }

  .otm-login-page .otm-form-message{
    margin-top:2px !important;
    font-size:13px !important;
    line-height:1.45 !important;
    text-align:center !important;
  }

  .otm-login-page .otm-help-line{
    margin:14px 0 0 !important;
    padding-top:12px !important;
    border-top:1px solid rgba(217,227,242,.8) !important;
    font-size:12px !important;
    line-height:1.55 !important;
    text-align:center !important;
  }

  .otm-login-page .otm-help-line a{
    word-break:break-word;
  }
}

@media (max-width: 420px){
  .otm-login-page{
    padding:14px 10px 20px !important;
  }

  .otm-login-page .otm-login-card{
    padding:20px 14px 16px !important;
    border-radius:18px !important;
  }

  .otm-login-page .otm-login-card .otm-logo{
    width:145px !important;
    max-width:76% !important;
  }

  .otm-login-page .otm-login-card h1{
    font-size:22px !important;
  }

  .otm-login-page .otm-login-subtitle{
    font-size:12px !important;
    margin-bottom:14px !important;
  }

  .otm-login-page .otm-field-label{
    font-size:12px !important;
  }

  .otm-login-page .otm-input,
  .otm-login-page .otm-select{
    height:48px !important;
    min-height:48px !important;
    border-radius:12px !important;
    padding:0 13px !important;
  }

  .otm-login-page .otm-textarea{
    border-radius:12px !important;
    padding:13px !important;
  }

  .otm-login-page .otm-btn{
    min-height:48px !important;
    font-size:14px !important;
    border-radius:12px !important;
  }

  .otm-login-page .otm-help-line{
    font-size:11px !important;
  }
}
