/*
Theme Name: Rajakatu 2
Theme URI: https://example.com/rajakatu2
Author: Rajakatu 2
Author URI: https://example.com
Description: Warm and welcoming block theme for Rajakatu 2 housing cooperative in Lahti, Finland.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: rajakatu2
*/

/* =============================================
   RESET & BASE
   ============================================= */

.wp-site-blocks { padding-block-start: 0 !important; }
.wp-site-blocks > footer { margin-block-start: 0; }
.wp-site-blocks > .wp-block-post-content { margin-block-start: 0 !important; }
.wp-site-blocks > .entry-content { margin-block-start: 0 !important; }

body { margin: 0; padding: 0; }
html { margin: 0; padding: 0; }

/* =============================================
   SECTION LABELS (small italic text above headings)
   Inspired by the reference "About Us" / "Our Philosophy" pattern
   ============================================= */

/* Section heading (h2 after section-label) — tighten bottom margin */
.section-label + .wp-block-heading {
  margin-bottom: 0 !important;
}

.section-label {
  font-family: var(--wp--preset--font-family--heading);
  font-style: italic;
  font-weight: 400;
  color: var(--wp--preset--color--primary);
  font-size: 1.1rem;
  letter-spacing: 0.02em;
  margin-bottom: -1.75rem !important;
}

/* =============================================
   ABOUT-STYLE TWO-COLUMN LAYOUT
   Large heading left, body text right
   ============================================= */

.about-layout {
  gap: var(--wp--preset--spacing--60);
}

.about-layout > .wp-block-column:first-child {
  flex-basis: 45%;
}

.about-layout > .wp-block-column:last-child {
  flex-basis: 55%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.about-layout > .wp-block-column:last-child p {
  font-size: 0.95rem !important;
}

.about-heading {
  font-size: clamp(2.25rem, 4.5vw, 3.25rem);
  line-height: 1.1;
  font-weight: 500;
  letter-spacing: -0.01em;
}

/* =============================================
   NUMERICAL STAT HIGHLIGHTS
   Large accent number + label + description
   ============================================= */

.stat-number {
  font-family: var(--wp--preset--font-family--heading);
  font-size: clamp(2.5rem, 5vw, 3.5rem);
  font-weight: 400;
  color: var(--wp--preset--color--primary);
  line-height: 1.15;
  margin-bottom: 0.5rem;
  letter-spacing: -0.02em;
}

.stat-label {
  font-family: var(--wp--preset--font-family--body);
  font-weight: 600;
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--wp--preset--color--text);
  margin-bottom: 0.4rem;
}

.stat-description {
  font-size: 0.9rem;
  color: var(--wp--preset--color--muted);
  line-height: 1.5;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.stats-grid > .wp-block-column {
  text-align: center;
  padding: var(--wp--preset--spacing--40) var(--wp--preset--spacing--30);
}

.stats-grid > .wp-block-column + .wp-block-column {
  border-left: 1px solid #E8E2D8;
}

@media (max-width: 768px) {
  .stats-grid > .wp-block-column + .wp-block-column {
    border-left: none;
    border-top: 1px solid #E8E2D8;
  }
}

/* =============================================
   VALUES GRID
   Clean cards with top border accent
   ============================================= */

.values-grid > .wp-block-column {
  padding: var(--wp--preset--spacing--50) var(--wp--preset--spacing|40);
}

.value-card {
  padding: var(--wp--preset--spacing--50) 3rem;
  border-top: none;
  height: 100%;
  text-align: center;
}

.value-card > * {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.value-card h3 {
  font-size: 1.35rem;
  font-weight: 500;
  margin-bottom: 0.5rem !important;
}

.value-card p {
  font-size: 0.95rem;
  color: var(--wp--preset--color--muted);
  line-height: 1.6;
}

/* =============================================
   HERO SECTION
   ============================================= */

.hero-section {
  background: linear-gradient(155deg, #2D2926 0%, #3D322B 30%, #5A4A3E 60%, #7A5C48 100%);
  background-position: center center !important;
  position: relative;
  overflow: hidden;
  min-height: 80vh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.hero-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top right, rgba(45,41,38,0.75) 17%, rgba(45,41,38,0.45) 40%, transparent 70%);
  pointer-events: none;
  z-index: 1;
}

.hero-section > * {
  position: relative;
  z-index: 2;
}

.hero-content {
  position: relative;
  z-index: 10;
  padding-bottom: var(--wp--preset--spacing--80);
  width: 100%;
  max-width: 1240px;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 768px) {
  .hero-content {
    padding-left: 10vh;
  }
}

.hero-content .hero-title {
  font-size: clamp(3rem, 7vw, 5.5rem);
  font-weight: 300;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: #FAF7F2;
}

.hero-content .hero-description {
  font-family: var(--wp--preset--font-family--heading);
  font-style: italic;
  font-size: clamp(1.05rem, 1.5vw, 1.2rem);
  color: rgba(250,247,242,0.7);
  font-weight: 400;
}

.hero-scroll-indicator {
  position: absolute;
  bottom: var(--wp--preset--spacing--50);
  right: var(--wp--preset--spacing--50);
  color: rgba(250,247,242,0.4);
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  writing-mode: vertical-rl;
  animation: scrollBounce 2s ease-in-out infinite;
}

@keyframes scrollBounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(8px); }
}

/* =============================================
   PHOTO PLACEHOLDERS
   ============================================= */

.photo-placeholder {
  background: linear-gradient(135deg, #E8DFD3 0%, #D4C9BB 50%, #C4B7A7 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  min-height: 280px;
  border-radius: 4px;
}

.photo-placeholder::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background:
    linear-gradient(45deg, transparent 48%, rgba(196,149,108,0.06) 49%, rgba(196,149,108,0.06) 51%, transparent 52%),
    linear-gradient(-45deg, transparent 48%, rgba(196,149,108,0.06) 49%, rgba(196,149,108,0.06) 51%, transparent 52%);
  background-size: 30px 30px;
  pointer-events: none;
}

.photo-placeholder-tall { min-height: 400px; }
.photo-placeholder-hero { min-height: 450px; border-radius: 0; }

/* =============================================
   CARD LAYOUTS
   ============================================= */

.equal-cards > .wp-block-column { display: flex; flex-direction: column; flex-grow: 0; }
.equal-cards > .wp-block-column > .wp-block-group { display: flex; flex-direction: column; flex-grow: 1; }
.equal-cards .cta-bottom { margin-top: auto; justify-content: center; }

.news-card {
  border-radius: 4px;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  padding-bottom: var(--wp--preset--spacing--60) !important;
  padding-left: 2rem !important;
  padding-right: 2rem !important;
  text-align: left !important;
}

.news-card > * {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  max-width: none !important;
  text-align: left !important;
}

.news-card p,
.news-card h3 {
  text-align: left !important;
}

.news-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 30px rgba(45,41,38,0.08);
}

.news-card h3 {
  margin-top: 0.5rem !important;
  margin-bottom: 0.5rem !important;
}

.news-card p:last-child {
  margin-top: 0 !important;
  text-align: left !important;
}

/* =============================================
   TABLES
   ============================================= */

.wp-block-table table { border-collapse: collapse; width: 100%; font-size: 0.95rem; }
.wp-block-table thead th {
  background-color: var(--wp--preset--color--surface);
  font-family: var(--wp--preset--font-family--heading);
  font-weight: 500;
  padding: 0.75rem 1rem;
  text-align: left;
  border-bottom: 2px solid var(--wp--preset--color--primary);
  font-size: 1.05rem;
}
.wp-block-table tbody td { padding: 0.6rem 1rem; border-bottom: 1px solid #E8E2D8; vertical-align: top; }
.wp-block-table tbody tr:hover { background-color: rgba(240,234,224,0.4); }
.wp-block-table.is-style-stripes tbody tr:nth-child(odd) { background-color: rgba(240,234,224,0.25); }

/* =============================================
   CONTACT
   ============================================= */

.contact-card {
  border: 1px solid #E8E2D8;
  border-radius: 4px;
  transition: box-shadow 0.3s ease;
}

.contact-card:hover { box-shadow: 0 6px 20px rgba(45,41,38,0.06); }

.omaretta-cta {
  border: 2px solid var(--wp--preset--color--primary);
  border-radius: 4px;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.omaretta-cta:hover {
  border-color: var(--wp--preset--color--secondary);
  box-shadow: 0 8px 24px rgba(196,149,108,0.12);
}

/* =============================================
   MAP
   ============================================= */

.map-container iframe {
  border-radius: 4px;
  filter: saturate(0.75) sepia(0.12) contrast(0.95);
  transition: filter 0.4s ease;
}

.map-container iframe:hover { filter: saturate(1) sepia(0) contrast(1); }

.map-fullwidth {
  width: 100%;
  height: min(60vh, 650px);
  position: relative;
  overflow: hidden;
}

.map-fullwidth iframe {
  width: 100%;
  height: 100%;
  border: 0;
  filter: saturate(0.6) sepia(0.15) contrast(0.92) brightness(1.02);
  transition: filter 0.5s ease;
}

.map-fullwidth iframe:hover {
  filter: saturate(0.85) sepia(0.05) contrast(0.96) brightness(1);
}

.map-fullwidth__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 220px;
  height: 120px;
  background: linear-gradient(135deg, #F0EAE0 60%, transparent 100%);
  pointer-events: none;
  z-index: 1;
}

/* =============================================
   SERVICE CATEGORIES (Sijainti page)
   ============================================= */

.service-category {
  height: 100%;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.service-category:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(45,41,38,0.06);
}

.service-list > * {
  margin-top: 0 !important;
}

.service-item {
  padding: 0.35rem 0;
  border-bottom: 1px solid rgba(45,41,38,0.06);
  align-items: baseline;
}

.service-item p {
  margin: 0 !important;
  line-height: 1.4;
}

.service-item:last-child {
  border-bottom: none;
}

/* When a description paragraph follows a service-item, remove the separator from the item above */
.service-item:has(+ .has-text-color) {
  border-bottom: none;
  padding-bottom: 0;
}

.service-distance {
  font-family: var(--wp--preset--font-family--heading);
  font-weight: 600;
  font-size: 1.25rem !important;
  color: var(--wp--preset--color--primary) !important;
  white-space: nowrap;
  margin: 0 !important;
}

.service-list > .has-text-color {
  border-bottom: 1px solid rgba(45,41,38,0.06);
  padding-bottom: 0.35rem;
  padding-right: 4.5rem;
}

/* =============================================
   DARK CTA CARD
   ============================================= */

.cta-dark-card {
  background-color: var(--wp--preset--color--text) !important;
  position: relative;
  overflow: hidden;
}

.cta-dark-card::before {
  content: '';
  position: absolute;
  top: -60%;
  right: -20%;
  width: 500px;
  height: 500px;
  border: 1px solid rgba(196,149,108,0.08);
  border-radius: 50%;
  pointer-events: none;
}

.cta-dark-card::after {
  content: '';
  position: absolute;
  bottom: -40%;
  left: -10%;
  width: 400px;
  height: 400px;
  border: 1px solid rgba(196,149,108,0.06);
  border-radius: 50%;
  pointer-events: none;
}

.cta-dark-card .section-label {
  color: var(--wp--preset--color--primary) !important;
}

.cta-dark-card .wp-block-heading {
  color: var(--wp--preset--color--background) !important;
}

.cta-dark-card p {
  color: #b8ada1 !important;
}

.cta-dark-card p.section-label {
  color: var(--wp--preset--color--primary) !important;
}

.cta-dark-card .has-text-color {
  color: #b8ada1 !important;
}

.cta-dark-card p[style*="font-size:1.5rem"] {
  color: var(--wp--preset--color--background) !important;
  font-family: var(--wp--preset--font-family--heading);
}

.cta-dark-card p[style*="letter-spacing"] {
  color: var(--wp--preset--color--muted) !important;
}

.cta-dark-card .wp-block-button__link {
  color: var(--wp--preset--color--surface) !important;
}

/* =============================================
   CONTACT DETAILS
   ============================================= */

.contact-details p {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

/* =============================================
   SERVICES LIST (legacy)
   ============================================= */

.services-list h5, .services-list h4 {
  color: var(--wp--preset--color--primary);
  margin-bottom: 0.75rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid #E8E2D8;
}

/* =============================================
   HEADER & NAV
   ============================================= */

.site-header {
  border-bottom: 1px solid rgba(45,41,38,0.06);
  position: relative;
  z-index: 100;
}

/* Transparent overlay header on front page */
.front-page-hero-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
}

.front-page-hero-wrapper {
  background: linear-gradient(to bottom, rgba(45,41,38,0.7) 0%, rgba(61,50,43,0.3) 60%, transparent 100%);
}

.front-page-hero-wrapper .site-header {
  background: transparent !important;
  border-bottom: none;
}

.front-page-hero-wrapper .site-header .wp-block-site-title a,
.front-page-hero-wrapper .site-header .wp-block-site-title {
  color: #FAF7F2 !important;
}

.front-page-hero-wrapper .site-header .header-subtitle {
  color: rgba(250,247,242,0.5) !important;
}

.front-page-hero-wrapper .site-header .wp-block-navigation a,
.front-page-hero-wrapper .site-header .wp-block-navigation .wp-block-navigation-item__content {
  color: rgba(250,247,242,0.85) !important;
}

.front-page-hero-wrapper .site-header .wp-block-navigation a:hover,
.front-page-hero-wrapper .site-header .wp-block-navigation .wp-block-navigation-item__content:hover {
  color: #FAF7F2 !important;
}

/* Normal header (non-front-page) */
.site-header .wp-block-navigation .wp-block-navigation-item a {
  transition: color 0.2s ease;
}

.site-header .wp-block-navigation .wp-block-navigation-item a:hover {
  color: var(--wp--preset--color--primary) !important;
}

@media (max-width: 768px) {
  /* Keep logo left and nav right on smaller screens */
  .site-header > .wp-block-group.alignwide {
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 0.5rem;
  }
}

/* =============================================
   FOOTER — Elegant dark footer
   ============================================= */

.site-footer {
  font-size: 0.9rem;
}

.site-footer a {
  text-decoration: none;
  transition: color 0.2s ease;
}

.site-footer a:hover {
  color: var(--wp--preset--color--primary) !important;
}

.footer-heading {
  font-family: var(--wp--preset--font-family--heading);
  font-weight: 400;
  font-size: 1.25rem;
  letter-spacing: 0.02em;
  color: rgba(250,247,242,0.5);
}

.footer-col-heading {
  font-family: var(--wp--preset--font-family--heading) !important;
  font-weight: 400 !important;
  font-style: italic;
  letter-spacing: 0.01em;
}

.footer-thin-line {
  width: 40px;
  height: 1px;
  background: var(--wp--preset--color--primary);
  border: none;
  margin: 0.75rem 0 1rem 0;
}

/* =============================================
   PAGE HEADER
   ============================================= */

.page-hero {
  background-color: var(--wp--preset--color--background);
  position: relative;
}

.page-hero .wp-block-post-title {
  font-family: var(--wp--preset--font-family--heading);
  font-weight: 400;
  color: var(--wp--preset--color--primary-dark);
}

.page-hero-image {
  background-color: var(--wp--preset--color--background);
  overflow: hidden;
}

.page-hero-image .wp-block-post-featured-image img {
  width: 100%;
  height: 400px;
  object-fit: cover;
}

/* =============================================
   CONTENT-IMAGE ROWS (alternating layouts)
   ============================================= */

.content-image-row {
  align-items: center;
}

.wp-block-image.talo-fullwidth-image img {
  width: 100%;
  height: min(60vh, 650px);
  object-fit: cover;
}

.talo-section-image img {
  width: 100%;
  height: 100%;
  min-height: 350px;
  object-fit: cover;
  border-radius: 4px;
}

@media (max-width: 767px) {
  .content-image-row--reverse {
    flex-direction: column-reverse !important;
  }
}

/* =============================================
   IMAGE CARDS (Yhteiset tilat grid)
   ============================================= */

.image-card {
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  height: 100%;
}

.image-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 30px rgba(45,41,38,0.08);
}

.image-card__img img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.image-card__img {
  margin-bottom: 0 !important;
}

.image-card h3 {
  margin-bottom: 0.25rem;
}

.image-card > * {
  margin-top: 0 !important;
}

.image-card .wp-block-group:not(.image-card) {
  padding-left: 2rem !important;
  padding-right: 2rem !important;
  margin-top: 0 !important;
}

.image-card .wp-block-group:not(.image-card) * {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  max-width: none !important;
}

.image-card .wp-block-group:not(.image-card) h3 {
  margin-bottom: 0.25rem !important;
}

@media (max-width: 767px) {
  .image-card-grid {
    flex-wrap: wrap !important;
  }
  .image-card-grid > .wp-block-column {
    flex-basis: 100% !important;
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  .image-card-grid {
    flex-wrap: wrap !important;
  }
  .image-card-grid > .wp-block-column {
    flex-basis: calc(50% - var(--wp--preset--spacing--40) / 2) !important;
  }
}

/* =============================================
   PARKING STATS
   ============================================= */

.parking-stats .stat-number {
  font-family: var(--wp--preset--font-family--heading);
  margin-bottom: -0.5rem;
}

.parking-stats .stat-label {
  font-size: 0.9rem;
  color: var(--wp--preset--color--muted);
}

/* =============================================
   SEPARATOR
   ============================================= */

hr.wp-block-separator { border-color: #E8E2D8; opacity: 0.5; }

.section-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--wp--preset--color--primary) 50%, transparent 100%);
  opacity: 0.25;
  border: none;
}

/* =============================================
   BLOCKQUOTE
   ============================================= */

.wp-block-quote {
  border-left: 2px solid var(--wp--preset--color--primary);
  padding-left: 1.5rem;
  font-family: var(--wp--preset--font-family--heading);
  font-style: italic;
  font-size: 1.15rem;
  color: var(--wp--preset--color--secondary);
}

/* =============================================
   LISTS
   ============================================= */

.wp-block-list li { margin-bottom: 0.35rem; }
.wp-block-list li::marker { color: var(--wp--preset--color--primary); }

/* =============================================
   SITE TITLE SPACING
   ============================================= */

.wp-block-site-title {
  margin-bottom: -10px;
}

/* =============================================
   HAMBURGER MENU CONTRAST
   ============================================= */

.front-page-hero-wrapper .wp-block-navigation__responsive-container-open {
  color: #FAF7F2 !important;
}

.front-page-hero-wrapper .wp-block-navigation__responsive-container-open svg {
  fill: #FAF7F2 !important;
  stroke: #FAF7F2 !important;
}

.wp-block-navigation__responsive-container-open {
  color: var(--wp--preset--color--text) !important;
}

@media (max-width: 600px) {
  .site-header .wp-block-navigation {
    margin-left: auto;
  }
  .site-header .wp-block-navigation__responsive-container-open {
    margin-left: auto;
  }
}

/* =============================================
   MOBILE OVERLAY MENU (< 768px)
   Full-screen dark overlay with centered serif links
   ============================================= */

/* Force hamburger at < 768px */
@media (max-width: 767px) {
  .wp-block-navigation__responsive-container:not(.is-menu-open) {
    display: none !important;
  }
  .wp-block-navigation__responsive-container-open:not(.always-shown) {
    display: flex !important;
  }
  .site-header .wp-block-navigation {
    margin-left: auto;
  }
}

/* Force regular nav at >= 768px */
@media (min-width: 768px) {
  .wp-block-navigation__responsive-container:not(.is-menu-open) {
    display: flex !important;
    position: relative !important;
    width: auto !important;
    background: transparent !important;
    overflow: visible !important;
  }
  .wp-block-navigation__responsive-container-open {
    display: none !important;
  }
}

/* Full-screen overlay styling */
.wp-block-navigation__responsive-container.is-menu-open {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  background-color: rgba(30, 26, 23, 0.97) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  z-index: 100000 !important;
  padding: 0 !important;
}

/* Close button */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close {
  position: fixed !important;
  top: 1.5rem !important;
  right: 2rem !important;
  color: rgba(250, 247, 242, 0.6) !important;
  z-index: 100001 !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close:hover {
  color: #FAF7F2 !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close svg {
  fill: currentColor !important;
  stroke: currentColor !important;
  width: 28px !important;
  height: 28px !important;
}

/* Center the nav list */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-dialog {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item {
  display: block !important;
  text-align: center !important;
  margin: 0 !important;
  padding: 0.75rem 0 !important;
}

/* Large serif menu links */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
  font-family: var(--wp--preset--font-family--heading) !important;
  font-size: clamp(1.75rem, 5vw, 2.5rem) !important;
  font-weight: 400 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: rgba(250, 247, 242, 0.85) !important;
  text-decoration: none !important;
  transition: color 0.3s ease !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content:hover {
  color: var(--wp--preset--color--primary) !important;
}

/* Stack nav items vertically in overlay */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  width: auto !important;
}

/* =============================================
   ANIMATIONS
   ============================================= */

.fade-up { opacity: 0; transform: translateY(30px); animation: fadeUp 0.7s ease forwards; }
.fade-in { opacity: 0; animation: fadeIn 0.7s ease forwards; }
.slide-in-left { opacity: 0; transform: translateX(-40px); animation: slideInLeft 0.8s ease forwards; }

.stagger-children > * { opacity: 0; transform: translateY(20px); animation: fadeUp 0.6s ease forwards; }
.stagger-children > *:nth-child(1) { animation-delay: 0.1s; }
.stagger-children > *:nth-child(2) { animation-delay: 0.2s; }
.stagger-children > *:nth-child(3) { animation-delay: 0.3s; }
.stagger-children > *:nth-child(4) { animation-delay: 0.4s; }

@keyframes fadeUp { to { opacity: 1; transform: translateY(0); } }
@keyframes fadeIn { to { opacity: 1; } }
@keyframes slideInLeft { to { opacity: 1; transform: translateX(0); } }

.animate-on-scroll { opacity: 0; transform: translateY(25px); transition: opacity 0.8s ease, transform 0.8s ease; }
.animate-on-scroll.is-visible { opacity: 1; transform: translateY(0); }

/* Staggered children inside scroll-triggered sections */
.animate-on-scroll.stagger-children > * { opacity: 0; transform: translateY(15px); transition: opacity 0.5s ease, transform 0.5s ease; }
.animate-on-scroll.is-visible.stagger-children > * { opacity: 1; transform: translateY(0); }
.animate-on-scroll.is-visible.stagger-children > *:nth-child(1) { transition-delay: 0.05s; }
.animate-on-scroll.is-visible.stagger-children > *:nth-child(2) { transition-delay: 0.15s; }
.animate-on-scroll.is-visible.stagger-children > *:nth-child(3) { transition-delay: 0.25s; }
.animate-on-scroll.is-visible.stagger-children > *:nth-child(4) { transition-delay: 0.35s; }

.hover-lift { transition: transform 0.3s ease, box-shadow 0.3s ease; }
.hover-lift:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(45,41,38,0.1); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* =============================================
   INFO CARDS (two-column variant of image-card)
   ============================================= */

.info-card { overflow: hidden; transition: transform 0.3s ease, box-shadow 0.3s ease; height: 100%; }
.info-card:hover { transform: translateY(-3px); box-shadow: 0 8px 30px rgba(45,41,38,0.08); }
.info-card__img img { width: 100%; height: 240px; object-fit: cover; }
.info-card__img { margin-bottom: 0 !important; }
.info-card h3 { margin-bottom: 0.25rem; }
.info-card > * { margin-top: 0 !important; }
.info-card .wp-block-group:not(.info-card) {
  padding-left: 2rem !important;
  padding-right: 2rem !important;
  margin-top: 0 !important;
}
.info-card .wp-block-group:not(.info-card) * {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  max-width: none !important;
}
.info-card .wp-block-group:not(.info-card) h3 {
  margin-bottom: 0.25rem !important;
}

@media (max-width: 767px) {
  .info-card-grid { flex-wrap: wrap !important; }
  .info-card-grid > .wp-block-column { flex-basis: 100% !important; }
}

/* =============================================
   DETAIL ITEM CARDS (services/features)
   ============================================= */

.detail-item { transition: transform 0.3s ease, box-shadow 0.3s ease; height: 100%; }
.detail-item:hover { transform: translateY(-2px); box-shadow: 0 6px 24px rgba(45,41,38,0.06); }
.detail-item > * {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  max-width: none !important;
}
.detail-item h3 { margin-bottom: 0.5rem !important; }

@media (max-width: 767px) {
  .detail-list-grid { flex-wrap: wrap !important; }
  .detail-list-grid > .wp-block-column { flex-basis: 100% !important; }
}

/* =============================================
   CHECKLIST ITEMS (icon-card style)
   ============================================= */

.checklist {
  list-style: none !important;
  padding-left: 0 !important;
}

.checklist-item {
  padding-left: 2.75rem;
  position: relative;
  padding-top: 0.15rem;
  padding-bottom: 0.15rem;
  list-style: none;
}

.checklist-item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.25em;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background-color: var(--wp--preset--color--primary);
  opacity: 0.18;
}

.checklist-item::after {
  content: '';
  position: absolute;
  left: 6px;
  top: calc(0.25em + 6px);
  width: 12px;
  height: 12px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C4956C' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: contain;
}

/* =============================================
   NOTICE CARDS (icon-card style info boxes)
   ============================================= */

.notice-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.notice-card > * {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  max-width: none !important;
}
.notice-card .notice-card__header {
  margin-bottom: 0.5rem !important;
}

.notice-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(45,41,38,0.06);
}

.notice-card__icon {
  width: 40px;
  height: 40px;
  min-width: 40px;
  border-radius: 50%;
  background-color: rgba(196,149,108,0.15);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 20px 20px;
  margin: 0 !important;
}

.notice-card__icon--document {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C4956C' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z'%3E%3C/path%3E%3Cpolyline points='14 2 14 8 20 8'%3E%3C/polyline%3E%3Cline x1='16' y1='13' x2='8' y2='13'%3E%3C/line%3E%3Cline x1='16' y1='17' x2='8' y2='17'%3E%3C/line%3E%3Cpolyline points='10 9 9 9 8 9'%3E%3C/polyline%3E%3C/svg%3E");
}

.notice-card__icon--lightbulb {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C4956C' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 18h6'%3E%3C/path%3E%3Cpath d='M10 22h4'%3E%3C/path%3E%3Cpath d='M12 2a7 7 0 0 0-4 12.7V17h8v-2.3A7 7 0 0 0 12 2z'%3E%3C/path%3E%3C/svg%3E");
}

.notice-card__icon--shield {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C4956C' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 22s8-4 8-10V5l-8-3-8 3v7c0 6 8 10 8 10z'%3E%3C/path%3E%3C/svg%3E");
}

.notice-card__icon--trending {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C4956C' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='22 7 13.5 15.5 8.5 10.5 2 17'%3E%3C/polyline%3E%3Cpolyline points='16 7 22 7 22 13'%3E%3C/polyline%3E%3C/svg%3E");
}

/* train/bus icon */
.notice-card__icon--transport {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C4956C' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='3' width='16' height='16' rx='2'%3E%3C/rect%3E%3Cpath d='M4 11h16'%3E%3C/path%3E%3Cpath d='M12 3v8'%3E%3C/path%3E%3Ccircle cx='8' cy='15' r='1'%3E%3C/circle%3E%3Ccircle cx='16' cy='15' r='1'%3E%3C/circle%3E%3Cpath d='M8 19l-2 3'%3E%3C/path%3E%3Cpath d='M16 19l2 3'%3E%3C/path%3E%3C/svg%3E");
}

/* shopping cart icon */
.notice-card__icon--cart {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C4956C' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 2L3 6v14a2 2 0 002 2h14a2 2 0 002-2V6l-3-4z'%3E%3C/path%3E%3Cline x1='3' y1='6' x2='21' y2='6'%3E%3C/line%3E%3Cpath d='M16 10a4 4 0 01-8 0'%3E%3C/path%3E%3C/svg%3E");
}

/* map pin icon */
.notice-card__icon--pin {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C4956C' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0118 0z'%3E%3C/path%3E%3Ccircle cx='12' cy='10' r='3'%3E%3C/circle%3E%3C/svg%3E");
}

/* family/people icon */
.notice-card__icon--family {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C4956C' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M17 21v-2a4 4 0 00-4-4H5a4 4 0 00-4 4v2'%3E%3C/path%3E%3Ccircle cx='9' cy='7' r='4'%3E%3C/circle%3E%3Cpath d='M23 21v-2a4 4 0 00-3-3.87'%3E%3C/path%3E%3Cpath d='M16 3.13a4 4 0 010 7.75'%3E%3C/path%3E%3C/svg%3E");
}

/* =============================================
   STYLED TABLES
   ============================================= */

.styled-table-wrapper {
  overflow: hidden;
  background-color: transparent !important;
  border-radius: 4px;
}

.styled-table-wrapper.has-background {
  background-color: transparent !important;
}

.styled-table {
  border-radius: 4px;
  overflow: hidden;
}

.styled-table table {
  border-collapse: collapse;
  width: 100%;
  font-size: 0.9rem;
  line-height: 1.6;
}

.wp-block-table.is-style-stripes.styled-table thead tr,
.styled-table thead tr {
  background-color: var(--wp--preset--color--text) !important;
  color: var(--wp--preset--color--background) !important;
}

.wp-block-table.is-style-stripes.styled-table thead th,
.styled-table thead th {
  padding: 1rem 1.25rem 0.75rem;
  font-family: var(--wp--preset--font-family--heading);
  font-weight: 500;
  font-size: 0.85rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: none !important;
  color: var(--wp--preset--color--background) !important;
  background-color: var(--wp--preset--color--text) !important;
}

.wp-block-table.is-style-stripes.styled-table tbody td,
.styled-table tbody td {
  padding: 0.85rem 1.25rem;
  border: none !important;
  border-bottom: 1px solid rgba(45,41,38,0.06) !important;
  color: var(--wp--preset--color--text);
}

.wp-block-table.is-style-stripes.styled-table tbody tr:nth-child(odd),
.styled-table tbody tr:nth-child(odd) {
  background-color: transparent !important;
}

.wp-block-table.is-style-stripes.styled-table tbody tr:nth-child(even),
.styled-table tbody tr:nth-child(even) {
  background-color: rgba(45,41,38,0.02) !important;
}

.styled-table tbody tr:hover {
  background-color: rgba(196,149,108,0.06) !important;
}

.styled-table tbody td:first-child {
  font-weight: 600;
  color: var(--wp--preset--color--primary);
  white-space: nowrap;
}

@media (max-width: 767px) {
  .styled-table table {
    font-size: 0.8rem;
  }
  .styled-table thead th,
  .styled-table tbody td {
    padding: 0.65rem 0.75rem;
  }
}
