a {
    text-decoration: none !important;
}

.bubble_remove.room_box.accessibility-quote::before {
	display: none;
}

.rooms_list.accessibility-quote {
	background-color: #0F5EB2 !important
}


/* FORCE desktop menus to natural width */
#header-main .hfe-nav-menu__layout-horizontal {
    width: auto !important;
    max-width: none !important;
    left: auto !important;
}

/* FORCE mobile dropdown full viewport width */
/* #header-main .elementor-nav-menu--dropdown {
    width: 100vw !important;
    left: 0 !important;
    right: 0 !important;
} */



.home header .first_header {
	background-color: unset !important;
}


 header .first_header.sticky {
  animation: slideDown 0.8s ease forwards;
  background-color: #034893 !important;
  position: fixed !important;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 999999999 !important;
  isolation: isolate;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15);
  transition: background-color 0.8s ease, box-shadow 0.8s ease;
  margin-top: 0 !important;
}

@keyframes slideDown {
  from {
    transform: translateY(-100%);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

.sticky .main_header img {
    width: 160px !important;
    height: 100% !important;
}

.sticky .main_header ul li.current-menu-item a{
    color: #ff6600 !important;
}

.sticky .main_header ul li a:hover {
     color: #ff6600 !important;
}

.subscribe-form {
  display: flex;
  width: 650px;
  font-family: inherit;
  gap: 15px;
  align-items: center;
}

.subscribe-form p {
  margin: 0;
  padding: 0;
}

.subscribe-form > p:first-child {
  display: flex;
  align-items: center;
  border: 1px solid #1a1a1a;
  border-radius: 2px 0 0 2px;
  /* overflow: hidden; */
  flex-grow: 1;
  background: #fff;
}

.subscribe-form .icon-box {
  background-color: #000;
  color: #fff;
  width: 50px;
  height: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 18px;
  flex-shrink: 0;
}

.subscribe-form input[type="email"] {
  border: none;
  padding: 0 10px;
  font-size: 16px;
  height: 50px;
  width: 100%;
  outline: none;
  color: #333;
  box-sizing: border-box;
}

.subscribe-form input[type="email"]::placeholder {
  color: #999;
}

.subscribe-form > p:last-child {
  margin: 0;
}

.subscribe-form input.wpcf7-submit.join-btn {
  background-color: #ff6600;
  border: none;
  color: #fff;
  height: 50px;
  cursor: pointer;
  transition: background-color 0.3s ease;
  flex-shrink: 0;

    font-family: "bodoni", Sans-serif;
    font-size: 22px;
    font-weight: 500;
    text-transform: uppercase;
    text-decoration: none;
    line-height: 26px;
    letter-spacing: 1px;
    border-radius: 0px 0px 0px 0px;
    padding: 12px 24px 12px 24px;
}

.subscribe-form input.wpcf7-submit.join-btn:hover {
  background-color: #0350a3;
}

.subscribe-form .wpcf7-spinner {
    display: none !important;
}

.subscribe-form .wpcf7-not-valid-tip {
    position: absolute;
}

.wpcf7-response-output {
    border-color: #0350a3 !important;
    font-family: var(--e-global-typography-9016d23-font-family), Sans-serif;
    font-size: var(--e-global-typography-9016d23-font-size);
    font-weight: var(--e-global-typography-9016d23-font-weight);
    line-height: var(--e-global-typography-9016d23-line-height);
    letter-spacing: var(--e-global-typography-9016d23-letter-spacing);
    color: #000000;
    margin: 30px 0 0 0 !important;
}

.link_btn a:hover span svg path  {
	stroke: #fff !important;
}

.link_btn a:hover span svg {
	fill: transparent !important;
}

.link_btn2 a:hover span svg path  {
	stroke: #0350a3 !important;
}

.link_btn2 a:hover span svg {
	fill: transparent !important;
}



.accessibility-wrapper {
	max-width: 1000px;
	margin: 0 auto;
	padding: 40px 25px;
	font-size: 16px;
	line-height: 1.7;
	background: #f7f7f7;
	border-radius: 10px;

	/* improved shadow */
	box-shadow:
	  0 6px 15px rgba(0, 0, 0, 0.05),
	  0 1px 4px rgba(0, 0, 0, 0.04);

}

.mb-0 {
	margin-bottom: 0 !important;
}

.accessibility-section {
  margin-bottom: 40px;
}

.accessibility-section h2 {
    font-family: var(--e-global-typography-primary-font-family), Sans-serif;
    font-size: 32px;
    font-weight: var(--e-global-typography-primary-font-weight);
    text-transform: var(--e-global-typography-primary-text-transform);
    line-height: var(--e-global-typography-primary-line-height);
    letter-spacing: var(--e-global-typography-primary-letter-spacing);
}

.accessibility-section p {
  margin-bottom: 12px;
  font-family: var(--e-global-typography-text-font-family), Sans-serif;
    font-size: var(--e-global-typography-text-font-size);
    font-weight: var(--e-global-typography-text-font-weight);
    line-height: var(--e-global-typography-text-line-height);
    letter-spacing: var(--e-global-typography-text-letter-spacing);
}

.accessibility-section a {
  color: #ff6702;
  text-decoration: underline;
}

.light-bg {
  background: #efefef;
  padding: 25px;
  border-radius: 12px;
}

.bordered {
  border: 1px solid #e5e5e5;
  padding: 25px;
  border-radius: 12px;
}

.accessibility-section ul {
  padding-left: 20px;
  margin-bottom: 15px;
}

.accessibility-section ul li {
  margin-bottom: 8px;
		font-family: var(--e-global-typography-text-font-family), Sans-serif;
	font-size: 18px;
	font-weight: var(--e-global-typography-text-font-weight);
	line-height: var(--e-global-typography-text-line-height);
	letter-spacing: var(--e-global-typography-text-letter-spacing);
}

/* .accessibility-quote {
	display: inline-block;
    box-shadow: 0 5px 25px rgba(0, 0, 0, 0.08);
    border-radius: 8px;
	padding: 15px 20px;
	margin-top: 20px;
	font-style: italic;
	font-family: var(--e-global-typography-text-font-family), Sans-serif;
	font-size: var(--e-global-typography-text-font-size);
	font-weight: var(--e-global-typography-text-font-weight);
	line-height: var(--e-global-typography-text-line-height);
	letter-spacing: var(--e-global-typography-text-letter-spacing);
	position: relative;
} */

.accessibility-quote {
	margin-bottom: 20px;
	display: inline-block;
	box-shadow: 0 5px 25px rgba(0, 0, 0, 0.08);
	border-radius: 8px;
	padding: 15px 50px 20px 20px;
	margin-top: 20px;
	font-style: italic;
	font-family: var(--e-global-typography-text-font-family), Sans-serif;
	font-size: var(--e-global-typography-text-font-size);
	font-weight: var(--e-global-typography-text-font-weight);
	line-height: var(--e-global-typography-text-line-height);
	letter-spacing: var(--e-global-typography-text-letter-spacing);
	position: relative;
	background: #fff;
}

/* LEFT IMAGE */
.accessibility-quote::before {
    content: "";
    position: absolute;
    right: -2px;
    bottom: -1px;
    width: 36px;
    height: 36px;
    background-image: url(https://hotelivybostoncommon.viratshukla.com/wp-content/uploads/2026/01/right_k.png);
    background-repeat: no-repeat;
}

.accessibility-quote::after {
    content: "";
    position: absolute;
    bottom: -28px;
    right: 25px;
    width: 40px;
    height: 29px;
    background-image: url(https://hotelivybostoncommon.viratshukla.com/wp-content/uploads/2026/01/polygon.png);
    background-repeat: no-repeat;
    background-size: contain;
}


.position_r {
    position: relative;
}

.position_a {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}


/* contact form for hotel booking */


.resv-simple {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: min(380px);
    font-family: "Georgia", serif;
    color: #1b1f27;
    text-align: center;
}

.resv-simple.show{
	padding: 20px;
	background-color: rgba(0,0,0,0.90);
}

.resv-dates {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 12px;
}


.resv-datebox {
    position: relative;
    background: rgba(0, 0, 0, 0.80);
    border: 0px;
    border-radius: 0px;
    padding: 20px 10px;
    text-align: center;
}

.resv-datebox.show {
	border:1px solid white;
}

.resv-datebox__label {
    font-size: 22px;
    margin-bottom: 6px;
    color: white;
    font-family: bodoni;
}

.resv-date-label {
    display: block;
    width: 100%;
    height: 100%;
    cursor: pointer;
}

.resv-date-input {
    width: 100%;
    border: 0px solid transparent !important;
    background: transparent;
    padding: 0 12px;
    font-family: bodoni;
    font-size: 16px;
    font-weight: 500;
    color: white;
    text-align: center;
    cursor: pointer;

}

.occupancy-holder {
    display: none;
    width: 100%;
    grid-column: span 2;
}

.occupancy-holder.show {
    display: block;
}

.occupancy-input {
    width: 100%;
}


.resv-date-input::placeholder {
    color: rgba(27, 31, 39, .5);
}

/* Hide native date text but keep picker */
.resv-date-input {
    color: transparent;
}

/* Remove browser quirks */
.resv-date-input::-webkit-datetime-edit,
.resv-date-input::-webkit-datetime-edit-text,
.resv-date-input::-webkit-datetime-edit-month-field,
.resv-date-input::-webkit-datetime-edit-day-field,
.resv-date-input::-webkit-datetime-edit-year-field {
    color: transparent;
}

/* Custom big date display */
.resv-datebox__label::after {
    content: var(--day, "--");
    display: block;
    font-size: 48px;
    font-family: bodoni;
    color: white;
    line-height: 1;
}

.datebox-filler::after {
    content: var(--month, "---");
    display: block;
    font-size: 14px;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: white;
    margin-top: 4px;
}

.resv-datebox {
    position: relative;
    cursor: pointer;
}

.resv-date-input {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0.01;
    pointer-events: none;
}

.occupancy-display {
	text-align: left;
	width: 100%;
	margin-top:5px;
	padding: 10px;
	color:white;
	background-color: transparent;
	border-radius: 0px;
	border:1px solid white;
}
.occupancy-display:hover {
	cursor: pointer;
}

.occupancy-input {
	margin-top:10px;
	border-radius: 0px !important;
	border:1px solid white !important;
	background-color:transparent;
}

.occupancy-heading {
	margin-bottom: 5px;
	text-align: left;
	color: white;
}

.visibility {
    display: none;
}

/* Button */
.resv-submit {
    margin-top: 8px;
}

.resv-btn,
.resv-submit button {
    margin: auto;
    font-family: bodoni;
    padding: 10px 15px;
    border: 0;
    border-radius: 0px !important;
    cursor: pointer;
    background-color: #FF6702;
    color: #ffffff;
    font-size: 16px;
    text-transform: uppercase;
    font-weight: 500;
}

.resv-submit button:hover,.resv-submit button:active,.resv-submit button:focus {
    background-color: white;
    color: #FF6702;
}
.popup-save {
	margin: auto;
    font-family: bodoni;
    padding: 10px 15px;
    border: 0;
    border-radius: 0px !important;
    background-color: #FF6702;
    color: #ffffff;
    font-size: 16px;
    text-transform: uppercase;
    font-weight: 500;
}
.popup-save:hover,.popup-save:active,.popup-save:focus {
    background-color: white;
    color: #FF6702;
}

/* contact form for hotel booking */



/* ===== POPUP BASE ===== */
.occupancy-heading {
	color: white;
	text-align: left;
	font-family: 18px;
	margin:0px 0px 5px 0px;
	line-height: 100%;
}
.occupancy-popup-overlay {
    display: none;
    position: absolute;
	top: 0px;
    left: calc(100% + 20px);
    z-index: 50;
}
.popup-close {
    position: absolute;
    top: 10px;
    right: 10px;
    background: none;
    border: 0;
    font-size: 18px;
    cursor: pointer;
}
.occupancy-popup-overlay.show {
    display: block;
}

.occupancy-popup {
    background: white;
    width: 320px;
    padding: 20px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.8);
    font-family: bodoni;
	background-color: black;
	border: 1px solid white;
	color: white;
}

.counter-btn {
    width: 44px;
    height: 44px;

    display: inline-flex;
    align-items: center;
    justify-content: center;

    font-size: 22px;
    line-height: 1;

    color: white;
    background-color: #FF6702;

    border: 0;
    border-radius: 0px;

    cursor: pointer;
    padding: 0;
}
.counter-btn:hover, .counter-btn:active, .counter-btn:focus {
	color:#FF6702;
	background-color: white;
}
.counter span {
	margin: 0px 10px;
	font-size: 18px;
}

.occupancy-display,.occupancy-input {
	-webkit-appearance: none;
  appearance: none;
	background-color: black;
	padding: 10px 20px !important;
	border-radius: 0px !important;
	border: 1px solid white !important;
	text-align: left;
	margin-bottom: 15px;
	color: white;
}
.occupancy-display:hover {
	cursor: pointer;
}

.popup-title {
  font-size: 18px;
  margin-bottom: 12px;
}

.popup-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.popup-row input {
  width: 80px;
}
.popup-title {
  font-size: 18px;
  margin-bottom: 12px;
}

.popup-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.popup-row label{
	color: white;
	font-size: 18px;
	display: flex;
	flex-direction: column;
	align-items:start;
	justify-content: start;
}
.popup-row-small {
	font-size: 12px;
}
.popup-title {
	font-family: 18px;
	font-weight: bold;
}
.popup-close {
	color:white;
	border: 0px solid white;
}
.popup-close:hover {
	color: white;
	background-color: #FF6702;
	border-radius: 0px;
}

.popup-row input {
  width: 80px;
}

.popup-row select{
	color: white;
	font-size: 18px;
	width: 25%;
	background-color: black;
	border-radius: 0px;
	border: 1px solid white;
}
.popup-row label{
	-webkit-appearance: none;
  appearance: none;
	font-family: 18px;
}

@media (max-width: 768px) {
    .occupancy-popup-overlay {
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,0.4);
        display: none;
        justify-content: center;
        align-items: center;
        z-index: 999;
    }

    .occupancy-popup-overlay.show {
        display: flex;
    }
	.popup-row label {
		font-size: 16px;
	}

    .occupancy-popup {
        position: relative;
        width: min(320px, 90vw);
    }
}


@media (max-width: 1080px) {
    .occupancy-popup-overlay {
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,0.4);
        display: none;
        justify-content: center;
        align-items: center;
        z-index: 999;
    }

    .occupancy-popup-overlay.show {
        display: flex;
    }

    .occupancy-popup {
        position: relative;
        width: min(320px, 90vw);
    }
}

/* Mobile */
@media (max-width: 768px) {
  .accessibility-wrapper {
    padding: 20px 15px;
  }
}


@media screen and (max-width: 1480px) {
    .eat_contant {
        padding: 35px !important;
    }

    .subscribe-form {
        width: 100% !important;
    }
	.resv-simple{ 
		margin: auto;
	  width: 100%; 
	}
}

@media screen and (max-width: 1080px){
	.accessibility-section h2 {
		font-size: 30px;
	}
	.resv-simple{ 
		margin: auto;
	  width: 100%; 
	}
	.resv-btn, .resv-submit button{
		margin: auto;
		padding:10px 20px;
	}
}

@media screen and (max-width: 995px){
	
	.accessibility-section h2 {
		font-size: 26px;
	}

    .sticky .main_header img {
        width: 140px !important;
        height: 75px !important;
    }


    .sticky .main_header ul li.current-menu-item a{
    color: #fff !important;
}

.sticky .main_header ul li a:hover {
     color: #fff !important;
}
}

@media screen and (max-width: 680px) {
    .subscribe-form input.wpcf7-submit.join-btn {
        font-size: 18px;
        padding: 11px 24px 12px 24px !important;
		line-height: 20px;
    }
	.resv-simple{ 
	  width: 100%;
	}

        .sticky .main_header img {
        width: 120px !important;
        height: 65px !important;
    }
	
	.subscribe-form input[type="email"] , .subscribe-form .icon-box , .subscribe-form input.wpcf7-submit.join-btn {
		height: 40px;
	}
	
	.subscribe-form {
		gap: 10px;
	}
	
	.subscribe-form .wpcf7-not-valid-tip , .wpcf7-response-output {
		font-size: 12px;
		line-height: 16px;
	}
	
	.wpcf7-response-output {
		margin: 24px 0 0 0 !important;
	}
	
	.accessibility-quote {
		padding: 12px 20px 16px 15px;
	}
}



