/**
 * one-cotroceni.css
 * Styles pentru pagina locatie: Monona Vision – One Cotroceni Park
 * PrestaShop 1.7 override
 *
 * Paleta culori (din mockup):
 *   --oc-orange   : #F5821F  (CTA principal)
 *   --oc-blue 	   : #639ECE  (CTA principal medium sky blue)
 *   --oc-green    : #27AE60  (succes / check-uri)
 *   --oc-dark     : #1C1C2E  (hero background, footer CTA)
 *   --oc-text     : #2D2D2D  (text principal)
 *   --oc-muted    : #666666  (text secundar)
 *   --oc-border   : #E8E8E8  (borduri carduri)
 *   --oc-bg-light : #F9F9FB  (fundal sectiuni alternante)
 */

/* ============================================================
   VARIABILE & RESET LOCAL
   ============================================================ */
.oc-hero,
.oc-benefits,
.oc-booking,
.oc-services,
.oc-reviews,
.oc-gallery,
.oc-contact,
.oc-faq,
.oc-cta-final,
.oc-breadcrumb-nav {
  --oc-orange:     #F5821F;
  --oc-blue:       #639ECE;
  --oc-orange-dk:  #D96D0A;
  --oc-blue-dk:    #288BDB;
  --oc-green:      #27AE60;
  --oc-dark:       #1C1C2E;
  --oc-text:       #2D2D2D;
  --oc-muted:      #666666;
  --oc-border:     #E8E8E8;
  --oc-bg-light:   #F9F9FB;
  --oc-white:      #FFFFFF;
  --oc-radius:     10px;
  --oc-shadow:     0 2px 16px rgba(0,0,0,.08);
  --oc-font:       'Nunito', sans-serif;
  --oc-font-body:  'Open Sans', sans-serif;
  box-sizing: border-box;
}

*, *::before, *::after { box-sizing: inherit; }

/* ============================================================
   CONTAINER
   ============================================================ */
.oc-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ============================================================
   TIPOGRAFIE COMUNE
   ============================================================ */
.oc-section-title {
  font-family: var(--oc-font);
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--oc-text);
  text-align: center;
  margin: 0 0 2rem;
}

.oc-text-sm { font-size: .85rem; color: var(--oc-muted); }

/* ============================================================
   BUTOANE
   ============================================================ */
.oc-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  border-radius: 6px;
  font-family: var(--oc-font);
  font-weight: 700;
  font-size: .95rem;
  text-decoration: none;
  cursor: pointer;
  transition: background .2s, transform .15s;
  white-space: nowrap;
}

.oc-btn:hover { transform: translateY(-1px); }

.oc-btn--primary {
  background: var(--oc-blue);
  color: var(--oc-white);
}
.oc-btn--primary:hover { 
  background: var(--oc-blue-dk); 
  color: var(--oc-white);
}

.oc-btn--phone {
  background: #2ecc71;
  color: var(--oc-white);
}
.oc-btn--phone:hover { 
  background: #27ae60; 
  color: var(--oc-white);
}

.oc-btn--map {
  background: var(--oc-white);
  color: var(--oc-text);
  border: 2px solid rgba(255,255,255,.5);
}
.oc-btn--map:hover { background: rgba(255,255,255,.15); color: var(--oc-white); }

.oc-btn--google {
  background: var(--oc-white);
  color: var(--oc-text);
  border: 1.5px solid var(--oc-border);
  font-size: .9rem;
}
.oc-btn--google:hover { border-color: #4285F4; }

.oc-btn--maps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 12px;
  margin-top: 10px;
  background: var(--oc-white);
  color: var(--oc-text);
  border: 1.5px solid var(--oc-border);
  border-radius: 6px;
  font-family: var(--oc-font);
  font-weight: 700;
  font-size: .9rem;
  text-decoration: none;
  transition: border-color .2s;
}
.oc-btn--maps:hover { border-color: #4285F4; }

.oc-btn--lg { padding: 15px 30px; font-size: 1.05rem; }

/* ============================================================
   BADGE-URI
   ============================================================ */
.oc-badge {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 4px;
  font-family: var(--oc-font);
  font-weight: 800;
  font-size: .72rem;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.oc-badge--new    { background: var(--oc-blue); color: var(--oc-white); }
.oc-badge--sector { background: #27AE60;           color: var(--oc-white); margin-left: 6px; }

/* ============================================================
   LINK CU SAGEATA
   ============================================================ */
.oc-link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--oc-blue);
  font-family: var(--oc-font);
  font-weight: 700;
  font-size: .9rem;
  text-decoration: none;
  transition: gap .2s;
}
.oc-link-arrow:hover { gap: 10px; }

/* ============================================================
   1. HERO SECTION
   ============================================================ */
.oc-hero {
  position: relative;
  min-height: 420px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 48px 32px 44px;
  background:
    linear-gradient(
      105deg,
      rgba(28, 28, 46, .92) 0%,
      rgba(28, 28, 46, .72) 55%,
      rgba(28, 28, 46, .30) 100%
    ),
    url('../img/locations/cotroceni/hero-bg.jpg') center/cover no-repeat;
  overflow: hidden;
}

.oc-hero__badge {
  position: absolute;
  top: 20px;
  left: 24px;
}

.oc-hero__content {
  position: relative;
  z-index: 2;
  max-width: 560px;
  margin-top: 20px;
}

.oc-hero__title {
  font-family: var(--oc-font);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  font-weight: 900;
  color: var(--oc-white);
  line-height: 1.15;
  margin: 0 0 .75rem;
}

.oc-hero__subtitle {
  font-family: var(--oc-font-body);
  font-size: 1.05rem;
  color: rgba(255,255,255,.88);
  line-height: 1.55;
  margin: 0 0 1.75rem;
}

.oc-hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

/* ============================================================
   2. BENEFICII RAPIDE
   ============================================================ */
.oc-benefits {
  background: var(--oc-white);
  border-bottom: 1px solid var(--oc-border);
  padding: 24px 0;
}

.oc-benefits__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.oc-benefit-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 8px 0;
}

.oc-benefit-item__icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.oc-benefit-item__icon--green {
  background: #E8F8EF;
  color: var(--oc-green);
}

.oc-benefit-item div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.oc-benefit-item strong {
  font-family: var(--oc-font);
  font-weight: 700;
  font-size: .9rem;
  color: var(--oc-text);
}

.oc-benefit-item span {
  font-family: var(--oc-font-body);
  font-size: .8rem;
  color: var(--oc-muted);
}

/* ============================================================
   3. PROGRAMARE DEDICATA
   ============================================================ */
.oc-booking {
  background: var(--oc-bg-light);
  padding: 28px 0;
}

.oc-booking__card {
  background: var(--oc-white);
  border: 1.5px solid var(--oc-border);
  border-radius: var(--oc-radius);
  padding: 28px 32px;
  display: flex;
  align-items: center;
  gap: 24px;
  box-shadow: var(--oc-shadow);
}

.oc-booking__icon {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  background: #e8f5ff;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--oc-blue);
}

.oc-booking__text {
  flex: 1;
}

.oc-booking__text h2 {
  font-family: var(--oc-font);
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--oc-text);
  margin: 0 0 4px;
}

.oc-booking__text p {
  font-family: var(--oc-font-body);
  font-size: .88rem;
  color: var(--oc-muted);
  margin: 0 0 10px;
}

.oc-booking__checks {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.oc-booking__checks span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--oc-font);
  font-size: .82rem;
  font-weight: 700;
  color: var(--oc-green);
}

.oc-booking__cta {
  flex-shrink: 0;
  text-align: center;
}

.oc-booking__alt {
  margin: 8px 0 0;
  font-size: .8rem;
  color: var(--oc-muted);
  font-family: var(--oc-font-body);
}

.oc-booking__alt a {
  color: var(--oc-blue);
  text-decoration: none;
}

/* ============================================================
   4. SERVICII DISPONIBILE
   ============================================================ */
.oc-services {
  background: var(--oc-white);
  padding: 56px 0 52px;
}

.oc-services__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
}

.oc-service-card {
  background: var(--oc-white);
  border: 1.5px solid var(--oc-border);
  border-radius: var(--oc-radius);
  padding: 24px 16px 20px;
  text-align: center;
  transition: box-shadow .2s, transform .2s;
}

.oc-service-card:hover {
  box-shadow: 0 6px 24px rgba(31,138,245,.15);
  transform: translateY(-3px);
}

.oc-service-card__icon {
  width: 56px;
  height: 56px;
  background: #e8f5ff;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 14px;
  color: var(--oc-blue);
}

.oc-service-card h3 {
  font-family: var(--oc-font);
  font-size: .9rem;
  font-weight: 800;
  color: var(--oc-text);
  margin: 0 0 4px;
}

.oc-service-card__sub {
  display: block;
  font-family: var(--oc-font-body);
  font-size: .75rem;
  color: var(--oc-muted);
  margin-bottom: 10px;
}

.oc-service-card__time {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 20px;
  font-family: var(--oc-font);
  font-size: .75rem;
  font-weight: 700;
  background: #F0F0F4;
  color: var(--oc-text);
}

.oc-service-card__time--included { background: #E8F8EF; color: var(--oc-green); }
.oc-service-card__time--fast     { background: #FFF3E8; color: var(--oc-orange); }
.oc-service-card__time--onsite   { background: #EBF4FF; color: #2980B9; }

/* ============================================================
   5. SOCIAL PROOF
   ============================================================ */
.oc-reviews {
  background: var(--oc-bg-light);
  padding: 52px 0;
}

.oc-reviews__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: center;
}

.oc-stars {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-bottom: 6px;
}

.oc-star {
  font-size: 1.6rem;
  color: #F5C518;
  line-height: 1;
}

.oc-rating {
  font-family: var(--oc-font);
  font-size: 1.6rem;
  font-weight: 900;
  color: var(--oc-text);
  margin-left: 8px;
}

.oc-reviews__count {
  font-family: var(--oc-font-body);
  font-size: .85rem;
  color: var(--oc-muted);
  margin: 0 0 16px;
}

.oc-reviews__quote {
  font-family: var(--oc-font);
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--oc-text);
  font-style: normal;
  border-left: 4px solid var(--oc-blue);
  padding-left: 16px;
  margin: 0 0 20px;
  line-height: 1.5;
}

.oc-reviews__badge { margin-bottom: 12px; }

.oc-reviews__cta-box {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--oc-white);
  border: 1.5px solid var(--oc-border);
  border-radius: var(--oc-radius);
  padding: 16px 20px;
  margin-bottom: 14px;
}

.oc-reviews__cta-icon {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  background: #e8f5ff;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--oc-blue);
}

.oc-reviews__cta-box p {
  margin: 0;
  font-family: var(--oc-font-body);
  font-size: .88rem;
  color: var(--oc-text);
}

/* ============================================================
   6. GALERIE FOTO
   ============================================================ */
.oc-gallery {
  background: var(--oc-white);
  padding: 52px 0;
}

.oc-gallery__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 180px 180px;
  gap: 8px;
  border-radius: var(--oc-radius);
  overflow: hidden;
}

.oc-gallery__item {
  overflow: hidden;
  position: relative;
}

.oc-gallery__item--large {
  grid-row: span 2;
}

.oc-gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s;
}

.oc-gallery__item:hover img { transform: scale(1.05); }

.oc-gallery__item--overlay .oc-gallery__overlay {
  position: absolute;
  inset: 0;
  background: rgba(28,28,46,.65);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--oc-white);
  font-family: var(--oc-font);
  cursor: pointer;
}

.oc-gallery__overlay span { font-size: 1.8rem; font-weight: 900; line-height: 1; }
.oc-gallery__overlay small { font-size: .8rem; font-weight: 600; opacity: .85; }

/* ============================================================
   7. HARTA + CONTACT
   ============================================================ */
.oc-contact {
  background: var(--oc-bg-light);
  padding: 52px 0;
}

.oc-contact__grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 36px;
  align-items: start;
}

.oc-contact__info {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.oc-contact__item {
  display: flex;
  gap: 14px;
  font-family: var(--oc-font-body);
  font-size: .9rem;
  color: var(--oc-text);
  line-height: 1.6;
}

.oc-contact__item small {
  font-size: .78rem;
  color: var(--oc-muted);
}

.oc-contact__item-icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  background: #e8f5ff;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--oc-blue);
  margin-top: 2px;
}

.oc-contact__item a {
  color: var(--oc-text);
  text-decoration: none;
  font-weight: 600;
}

.oc-contact__item a:hover { color: var(--oc-blue); }

.oc-contact__map iframe {
  width: 100%;
  border-radius: var(--oc-radius);
  display: block;
}

/* ============================================================
   8. FAQ
   ============================================================ */
.oc-faq {
  background: var(--oc-white);
  padding: 52px 0;
}

.oc-faq__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}

.oc-faq__item {
  background: var(--oc-white);
  border: 1.5px solid var(--oc-border);
  border-radius: var(--oc-radius);
  overflow: hidden;
  transition: box-shadow .2s;
}

.oc-faq__item[open] { box-shadow: var(--oc-shadow); }

.oc-faq__item summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 20px;
  font-family: var(--oc-font);
  font-size: .9rem;
  font-weight: 700;
  color: var(--oc-text);
  cursor: pointer;
  list-style: none;
  gap: 10px;
}

.oc-faq__item summary::-webkit-details-marker { display: none; }
.oc-faq__item summary::marker { display: none; }

.oc-faq__chevron {
  flex-shrink: 0;
  transition: transform .25s;
  color: var(--oc-muted);
}

.oc-faq__item[open] .oc-faq__chevron { transform: rotate(180deg); }

.oc-faq__answer {
  padding: 0 20px 18px;
  font-family: var(--oc-font-body);
  font-size: .88rem;
  color: var(--oc-muted);
  line-height: 1.65;
}

.oc-faq__more { text-align: center; }

/* ============================================================
   9. CTA FINAL
   ============================================================ */
.oc-cta-final {
  background: var(--oc-dark);
  padding: 52px 0;
}

.oc-cta-final__inner {
  text-align: center;
}

.oc-cta-final h2 {
  font-family: var(--oc-font);
  font-size: clamp(1.3rem, 3vw, 1.9rem);
  font-weight: 900;
  color: var(--oc-white);
  margin: 0 0 8px;
}

.oc-cta-final p {
  font-family: var(--oc-font-body);
  font-size: .95rem;
  color: rgba(255,255,255,.7);
  margin: 0 0 28px;
}

.oc-cta-final__btns {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 24px;
}

.oc-cta-final__trust {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 24px;
}

.oc-cta-final__trust span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--oc-font);
  font-size: .82rem;
  font-weight: 600;
  color: rgba(255,255,255,.65);
}

.oc-cta-final__trust svg { color: var(--oc-green); }

/* ============================================================
   BREADCRUMB NAV FOOTER
   ============================================================ */
.oc-breadcrumb-nav {
  background: var(--oc-dark);
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 14px 0;
}

.oc-breadcrumb-nav__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}

.oc-breadcrumb-nav__left {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--oc-font-body);
  font-size: .82rem;
}

.oc-breadcrumb-nav__left a {
  color: rgba(255,255,255,.6);
  text-decoration: none;
}
.oc-breadcrumb-nav__left a:hover { color: var(--oc-white); }

.oc-breadcrumb-nav__left span {
  color: rgba(255,255,255,.85);
  font-weight: 600;
}

.oc-breadcrumb-nav__right {
  display: flex;
  align-items: center;
  gap: 16px;
}

.oc-breadcrumb-nav__arrow,
.oc-breadcrumb-nav__all {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--oc-font);
  font-size: .82rem;
  font-weight: 700;
  color: rgba(255,255,255,.65);
  text-decoration: none;
  transition: color .2s;
}

.oc-breadcrumb-nav__arrow:hover,
.oc-breadcrumb-nav__all:hover { color: var(--oc-white); }

/* ============================================================
   RESPONSIVE – Tablet (max 900px)
   ============================================================ */
@media (max-width: 900px) {

  .oc-benefits__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .oc-booking__card {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
  }

  .oc-booking__cta { width: 100%; }
  .oc-booking__cta .oc-btn { width: 100%; justify-content: center; }

  .oc-services__grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .oc-reviews__grid {
    grid-template-columns: 1fr;
  }

  .oc-gallery__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 180px 180px 180px;
  }

  .oc-gallery__item--large {
    grid-column: span 2;
    grid-row: span 1;
  }

  .oc-contact__grid {
    grid-template-columns: 1fr;
  }

  .oc-faq__grid {
    grid-template-columns: 1fr;
  }
}

/* ============================================================
   RESPONSIVE – Mobile (max 600px)
   ============================================================ */
@media (max-width: 600px) {

  .oc-hero {
    min-height: 360px;
    padding: 36px 20px 36px;
  }

  .oc-hero__ctas {
    flex-direction: column;
    align-items: stretch;
  }
  .oc-hero__ctas .oc-btn { justify-content: center; }

  .oc-benefits__grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .oc-services__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .oc-gallery__grid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 150px 150px 150px;
  }

  .oc-gallery__item--large {
    grid-column: span 2;
    height: 200px;
  }

  .oc-cta-final__btns {
    flex-direction: column;
    align-items: stretch;
  }
  .oc-cta-final__btns .oc-btn { justify-content: center; }

  .oc-breadcrumb-nav__inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .oc-section-title { font-size: 1.4rem; }
}
