/* ═══════════════════════════════════════════════════════════════
   Frontend Components — compiled at 2026-05-07 14:36:41
   Source: css/ (14 partials)
   ═══════════════════════════════════════════════════════════════ */

/* ── article-body.css ── */
.article-body {
   font-size: 1.05rem;
   line-height: 1.85;
   color: rgba(255, 255, 255, .82)
}

.article-body h1,
.article-body h2,
.article-body h3 {
   color: var(--text-primary, #f2f2f2)
}

.article-body a {
   color: var(--primary, #2d8a4e)
}

.article-body img {
   max-width: 100%;
   border-radius: 10px;
   margin: 24px 0
}

.article-body blockquote {
   border-left: 4px solid var(--primary, #2d8a4e);
   margin: 24px 0;
   padding: 12px 20px;
   background: rgba(124, 110, 245, .06);
   border-radius: 0 10px 10px 0;
   font-style: italic;
   color: rgba(255, 255, 255, .65)
}

.article-body hr {
   border: none;
   border-top: 1px solid rgba(255, 255, 255, .1);
   margin: 40px 0
}

.fs-lg.text-muted {
   line-height: 1.8
}

/* ── article-view.css ── */
.article-hero {
   min-height: 48vh;
   display: flex;
   align-items: flex-end;
   padding-bottom: 60px;
   position: relative;
   overflow: hidden
}

.article-hero--fallback {
   background: linear-gradient(135deg, rgba(124, 110, 245, .1) 0%, rgba(10, 10, 16, 1) 100%)
}

.article-hero .container--narrow {
   max-width: 840px;
   margin: 0 auto;
   padding: 0 24px;
   width: 100%
}

.breadcrumb--hero a.breadcrumb-section {
   color: rgba(255, 255, 255, .6)
}

.article-section-badge {
   display: inline-block;
   background: rgba(124, 110, 245, .15);
   border: 1px solid rgba(124, 110, 245, .35);
   border-radius: 20px;
   padding: 4px 14px;
   font-size: 0.78rem;
   font-weight: 600;
   color: var(--primary, #2d8a4e);
   margin-bottom: 14px;
   letter-spacing: .06em;
   text-transform: uppercase
}

.article-main {
   background: var(--bg-base, #0f0f13);
   padding: 56px 0 80px
}

.article-layout {
   max-width: 1140px;
   margin: 0 auto;
   padding: 0 24px;
   display: grid;
   grid-template-columns: 1fr 300px;
   gap: 48px
}

.article-outro {
   margin-top: 48px;
   padding-top: 32px;
   border-top: 1px solid rgba(255, 255, 255, .08)
}

.article-back-wrap {
   margin-top: 48px;
   padding-top: 24px;
   border-top: 1px solid rgba(255, 255, 255, .08)
}

.article-back-link {
   display: inline-flex;
   align-items: center;
   gap: 8px;
   color: var(--primary, #2d8a4e);
   text-decoration: none;
   font-size: 0.9rem;
   font-weight: 600;
   transition: gap .2s
}

.article-back-link:hover {
   gap: 12px
}

.article-back-link .material-icons-outlined {
   font-size: 18px
}

.article-sidebar {
   border-left: 1px solid rgba(255, 255, 255, .06);
   padding-left: 40px;
   position: sticky;
   top: 100px;
   align-self: start
}

.article-sidebar-heading {
   font-size: 0.85rem;
   font-weight: 600;
   text-transform: uppercase;
   letter-spacing: .07em;
   color: var(--text-secondary, #888);
   margin: 0 0 20px
}

.article-sidebar-list {
   display: flex;
   flex-direction: column;
   gap: 16px
}

.article-related-card {
   display: block;
   background: rgba(255, 255, 255, .04);
   border: 1px solid rgba(255, 255, 255, .07);
   border-radius: 12px;
   padding: 14px;
   text-decoration: none;
   transition: background .2s, border-color .2s
}

.article-related-card:hover {
   border-color: rgba(124, 110, 245, .3);
   background: rgba(124, 110, 245, .07)
}

.article-related-title {
   font-size: 0.88rem;
   font-weight: 600;
   color: var(--text-primary, #f2f2f2);
   margin: 0 0 4px;
   line-height: 1.3
}

.article-related-excerpt {
   font-size: 0.8rem;
   color: var(--text-secondary, #888);
   margin: 0;
   line-height: 1.5
}

@media (max-width:768px) {
   .article-layout {
      grid-template-columns: 1fr
   }

   .article-sidebar {
      border-left: none;
      padding-left: 0;
      position: static;
      border-top: 1px solid rgba(255, 255, 255, .06);
      padding-top: 32px
   }
}

/* ── contacto-view.css ── */
.contacto-main {
   background: var(--bg-base, #0f0f13);
   padding: 64px 0 80px
}

.contacto-unavailable {
   color: var(--text-secondary, #888)
}

/* ── encuesta-view.css ── */
.encuesta-badge {
   display: inline-block;
   background: rgba(245, 158, 11, .12);
   border: 1px solid rgba(245, 158, 11, .3);
   border-radius: 20px;
   padding: 4px 14px;
   font-size: 0.78rem;
   font-weight: 600;
   color: #fbbf24;
   margin-bottom: 14px;
   letter-spacing: .06em;
   text-transform: uppercase
}

.encuesta-hero-title {
   font-size: clamp(1.7rem, 4vw, 3rem);
   font-weight: 800;
   color: #fff;
   margin: 0 0 12px
}

.encuesta-hero-desc {
   font-size: 1rem;
   color: rgba(255, 255, 255, .65);
   max-width: 560px;
   margin: 0;
   line-height: 1.65
}

.encuesta-main {
   background: var(--bg-base, #0f0f13);
   padding: 56px 0 80px
}

/* ── frontpage.css ── */
.about-card__read-more,
.service-card__read-more {
   display: inline-flex;
   align-items: center;
   gap: 6px;
   font-weight: 600;
   color: var(--primary, #2d8a4e);
   text-decoration: none;
   transition: gap .2s
}

.about-card__read-more:hover,
.service-card__read-more:hover {
   gap: 10px
}

.about-card__read-more {
   font-size: 0.84rem;
   margin-top: 14px
}

.service-card__read-more {
   font-size: 0.82rem;
   margin-top: 12px
}

.about-card__read-more .material-icons-sharp {
   font-size: 16px
}

.service-card__read-more .material-icons-sharp {
   font-size: 15px
}

.section--banner .fs-lg.text-muted,
.section--vet .fs-lg.text-muted {
   line-height: 1.8
}

/* ── header.css ── */
#header-user-btn,
#header-login-btn {
   display: inline-flex;
   align-items: center;
   gap: 7px;
   border-radius: 22px;
   color: rgba(255, 255, 255, .9);
   text-decoration: none;
   font-size: 0.82rem;
   font-weight: 600;
   transition: background .2s, border-color .2s
}

#header-user-btn {
   background: rgba(255, 255, 255, .08);
   border: 1px solid rgba(255, 255, 255, .14);
   padding: 6px 14px 6px 8px
}

#header-user-btn:hover {
   background: rgba(124, 110, 245, .2);
   border-color: rgba(124, 110, 245, .4)
}

#header-login-btn {
   gap: 6px;
   background: rgba(255, 255, 255, .07);
   border: 1px solid rgba(255, 255, 255, .13);
   padding: 7px 16px 7px 12px;
   color: rgba(255, 255, 255, .85)
}

#header-login-btn:hover {
   background: rgba(124, 110, 245, .18);
   border-color: rgba(124, 110, 245, .38)
}

#header-user-btn .material-icons-outlined {
   font-size: 18px
}

#header-login-btn .material-icons-outlined {
   font-size: 17px
}

/* ── hero.css ── */
.hero-title img {
   width: 520px
}

/* ── modals.css ── */
.pat-modal-readmore-wrap {
   text-align: center;
   margin-top: 1.25rem
}

.tag-pill-readmore {
   display: inline-flex;
   align-items: center;
   gap: 6px;
   padding: 9px 20px;
   border-radius: var(--radius-pill, 999px);
   font-size: 0.9rem;
   font-weight: 600;
   color: var(--primary, #2d8a4e);
   border: 1px solid rgba(124, 110, 245, .4);
   text-decoration: none;
   transition: background .2s, transform .15s
}

.tag-pill-readmore:hover {
   background: rgba(124, 110, 245, .12);
   transform: translateY(-1px)
}

.tag-pill-readmore .material-icons-sharp {
   font-size: 16px
}

.modal-icon-wrap--article {
   background-color: var(--color-purple);
   color: #fff
}

/* ── news.css ── */
.news-card-img {
   width: 100%;
   border-radius: var(--radius-md, 8px);
   margin-bottom: 1rem;
   object-fit: cover
}

.news-readmore-wrap {
   display: flex;
   justify-content: flex-end
}

/* ── product-view.css ── */
.product-breadcrumb-strip {
   padding-top: 80px;
   background: var(--bg-base, #0f0f13)
}

.container--product {
   max-width: 1100px;
   margin: 0 auto;
   padding: 20px 24px 0
}

.product-breadcrumb {
   display: flex;
   align-items: center;
   gap: 8px;
   font-size: 0.82rem;
   color: rgba(255, 255, 255, .45)
}

.product-breadcrumb a {
   text-decoration: none
}

.product-breadcrumb a.breadcrumb-home {
   color: rgba(255, 255, 255, .45)
}

.product-breadcrumb a.breadcrumb-category {
   color: rgba(255, 255, 255, .55)
}

.product-breadcrumb .material-icons-outlined {
   font-size: 14px
}

.product-breadcrumb .breadcrumb-current {
   color: var(--text-primary, #f2f2f2)
}

.product-category-badge {
   display: inline-block;
   background: rgba(124, 110, 245, .1);
   border: 1px solid rgba(124, 110, 245, .25);
   border-radius: 20px;
   padding: 3px 12px;
   font-size: 0.76rem;
   font-weight: 600;
   color: var(--primary, #2d8a4e);
   margin-bottom: 12px;
   letter-spacing: .05em;
   text-transform: uppercase
}

.product-main {
   background: var(--bg-base, #0f0f13);
   padding: 40px 0 0
}

.product-related-divider {
   height: 1px;
   background: rgba(255, 255, 255, .06);
   margin-bottom: 48px
}

.product-related-title {
   font-size: 1.1rem;
   font-weight: 600;
   color: var(--text-primary, #f2f2f2);
   margin: 0 0 4px
}

.related-card-placeholder {
   width: 100%;
   aspect-ratio: 1;
   background: rgba(255, 255, 255, .04);
   display: flex;
   align-items: center;
   justify-content: center
}

.related-card-placeholder .material-icons-outlined {
   color: rgba(255, 255, 255, .1);
   font-size: 28px
}

.product-detail {
   max-width: 1100px;
   margin: 0 auto;
   padding: 0 24px 80px;
   display: grid;
   grid-template-columns: 1fr 1fr;
   gap: 56px;
   align-items: start
}

.product-gallery {
   position: sticky;
   top: 100px
}

.main-img {
   width: 100%;
   aspect-ratio: 1;
   object-fit: cover;
   border-radius: 20px;
   background: rgba(255, 255, 255, .04)
}

.main-img-ph {
   width: 100%;
   aspect-ratio: 1;
   border-radius: 20px;
   background: rgba(255, 255, 255, .04);
   border: 1px solid rgba(255, 255, 255, .08);
   display: flex;
   align-items: center;
   justify-content: center
}

.main-img-ph .material-icons-outlined {
   font-size: 64px;
   color: rgba(255, 255, 255, .1)
}

.product-info h1 {
   font-size: clamp(1.5rem, 3vw, 2.2rem);
   font-weight: 800;
   color: var(--text-primary, #f2f2f2);
   margin: 0 0 8px
}

.product-price-tag {
   font-size: 2rem;
   font-weight: 700;
   color: var(--primary, #2d8a4e);
   margin: 16px 0
}

.product-desc {
   font-size: 0.95rem;
   color: var(--text-secondary, #aaa);
   line-height: 1.8;
   margin: 0 0 28px
}

.product-desc p {
   margin: 0 0 12px
}

.product-actions {
   display: flex;
   gap: 12px;
   flex-wrap: wrap;
   margin-bottom: 36px
}

.btn-cart {
   display: inline-flex;
   align-items: center;
   gap: 8px;
   padding: 14px 28px;
   background: var(--primary, #2d8a4e);
   color: #fff;
   border: none;
   border-radius: 12px;
   font-size: 1rem;
   font-weight: 600;
   cursor: pointer;
   transition: transform .15s, box-shadow .2s;
   text-decoration: none
}

.btn-cart:hover {
   background: #6959e8;
   transform: translateY(-2px);
   box-shadow: 0 10px 28px rgba(124, 110, 245, .35)
}

.btn-contact {
   display: inline-flex;
   align-items: center;
   gap: 8px;
   padding: 14px 24px;
   background: transparent;
   border: 1px solid rgba(255, 255, 255, .2);
   color: var(--text-primary, #f2f2f2);
   border-radius: 12px;
   font-size: 0.95rem;
   font-weight: 500;
   cursor: pointer;
   transition: all .2s;
   text-decoration: none
}

.btn-contact:hover {
   border-color: var(--primary, #2d8a4e);
   color: var(--primary, #2d8a4e)
}

.product-meta {
   display: flex;
   flex-direction: column;
   gap: 10px;
   padding-top: 24px;
   border-top: 1px solid rgba(255, 255, 255, .08)
}

.product-meta-row {
   display: flex;
   gap: 10px;
   font-size: 0.85rem
}

.product-meta-row label {
   color: var(--text-secondary, #888);
   min-width: 100px
}

.product-meta-row span {
   color: var(--text-primary, #f2f2f2)
}

.related-section {
   max-width: 1100px;
   margin: 0 auto;
   padding: 0 24px 80px
}

.related-grid {
   display: grid;
   grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
   gap: 20px;
   margin-top: 24px
}

.related-card {
   background: rgba(255, 255, 255, .04);
   border: 1px solid rgba(255, 255, 255, .07);
   border-radius: 12px;
   overflow: hidden;
   text-decoration: none;
   display: block;
   transition: transform .2s
}

.related-card:hover {
   transform: translateY(-4px)
}

.related-card img {
   width: 100%;
   aspect-ratio: 1;
   object-fit: cover;
   display: block;
   background: rgba(255, 255, 255, .04)
}

.related-card-body {
   padding: 12px
}

.related-card-name {
   font-size: 0.88rem;
   font-weight: 600;
   color: var(--text-primary, #f2f2f2);
   margin: 0 0 4px
}

.related-card-price {
   font-size: 0.88rem;
   color: var(--primary, #2d8a4e);
   margin: 0;
   font-weight: 600
}

@media (max-width:768px) {
   .product-detail {
      grid-template-columns: 1fr
   }

   .product-gallery {
      position: static
   }
}

/* ── section-module.css ── */
.sec-article-card {
   border: 1px solid #e0e0e0;
   border-radius: 4px
}

.sec-subsection-list {
   gap: 0.25rem
}

.sec-back-link {
   text-decoration: underline
}

/* ── section-view.css ── */
.page-hero {
   min-height: 48vh;
   display: flex;
   align-items: flex-end;
   padding-bottom: 60px;
   position: relative;
   overflow: hidden
}

.page-hero--fallback {
   background: linear-gradient(135deg, rgba(124, 110, 245, .1) 0%, rgba(10, 10, 16, 1) 100%)
}

.page-hero .container--narrow {
   max-width: 840px;
   margin: 0 auto;
   padding: 0 24px;
   width: 100%
}

.breadcrumb--hero {
   margin-bottom: 16px;
   display: flex;
   align-items: center;
   gap: 8px;
   font-size: 0.82rem;
   color: rgba(255, 255, 255, .5)
}

.breadcrumb--hero a {
   color: rgba(255, 255, 255, .5);
   text-decoration: none;
   transition: color .2s
}

.breadcrumb--hero a:hover {
   color: #fff
}

.breadcrumb--hero .material-icons-outlined {
   font-size: 14px
}

.breadcrumb--hero .breadcrumb-current {
   color: #fff
}

.page-hero-title {
   font-size: clamp(1.75rem, 4.5vw, 3rem);
   font-weight: 800;
   color: #fff;
   margin: 0 0 16px;
   line-height: 1.18
}

.page-hero-desc {
   font-size: 1.12rem;
   color: rgba(255, 255, 255, .7);
   max-width: 620px;
   margin: 0;
   line-height: 1.6
}

.section-main {
   background: var(--bg-base, #0f0f13);
   padding: 56px 0 80px
}

.container--narrow {
   max-width: 840px;
   margin: 0 auto;
   padding: 0 24px
}

.container--wide {
   max-width: 1100px;
   margin: 0 auto;
   padding: 0 24px
}

.section-content-body {
   background: rgba(255, 255, 255, .02);
   border: 1px solid rgba(255, 255, 255, .05);
   border-radius: 16px;
   padding: 44px 50px;
   box-shadow: 0 8px 32px rgba(0, 0, 0, .2);
   margin-bottom: 56px
}

.section-articles-header {
   margin-bottom: 40px
}

.section-articles-title {
   font-size: 1.4rem;
   font-weight: 700;
   color: var(--text-primary, #f2f2f2);
   margin: 0 0 8px
}

.section-divider-bar {
   width: 48px;
   height: 3px;
   background: var(--primary, #2d8a4e);
   border-radius: 2px;
   margin-bottom: 32px
}

.section-articles-grid {
   display: grid;
   grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
   gap: 24px
}

.section-article-card {
   background: rgba(255, 255, 255, .04);
   border: 1px solid rgba(255, 255, 255, .08);
   border-radius: 16px;
   overflow: hidden;
   transition: transform .22s, box-shadow .22s;
   cursor: pointer
}

.section-article-card:hover {
   transform: translateY(-6px);
   box-shadow: 0 16px 40px rgba(0, 0, 0, .5)
}

.section-article-card img {
   width: 100%;
   height: 200px;
   object-fit: cover;
   display: block
}

.section-article-body {
   padding: 24px
}

.section-article-title {
   font-size: 1.05rem;
   font-weight: 700;
   color: var(--text-primary, #f2f2f2);
   margin: 0 0 10px;
   line-height: 1.3;
   transition: color .2s;
   text-decoration: none;
   display: block
}

.section-article-title:hover {
   color: var(--primary, #2d8a4e)
}

.section-article-excerpt {
   font-size: 0.88rem;
   color: var(--text-secondary, #888);
   line-height: 1.65;
   margin: 0 0 18px
}

.section-read-more {
   display: inline-flex;
   align-items: center;
   gap: 6px;
   font-size: 0.85rem;
   font-weight: 600;
   color: var(--primary, #2d8a4e);
   text-decoration: none;
   transition: gap .2s
}

.section-read-more:hover {
   gap: 10px
}

.section-read-more .material-icons-outlined {
   font-size: 16px
}

/* ── user-panel.css ── */
.u-heading-icon {
   color: var(--primary, #2d8a4e)
}

.u-status--active {
   color: #48c78e
}

.u-info-item--full {
   grid-column: 1 / -1
}

.u-logout .material-icons-outlined {
   font-size: 14px;
   vertical-align: middle
}

.btn-auth--register {
   margin-top: 8px
}

.orders-table-wrap {
   background: rgba(255, 255, 255, .03);
   border: 1px solid rgba(255, 255, 255, .08);
   border-radius: 14px;
   overflow: hidden
}

.orders-date-cell {
   color: var(--text-secondary, #888)
}

.orders-empty a {
   color: var(--primary, #2d8a4e)
}

/* ── views-shared.css ── */
.form-unavailable {
   color: var(--text-secondary, #888)
}

.form-main,
.asociacion-main {
   background: var(--bg-base, #0f0f13);
   padding: 56px 0 80px
}

.category-main {
   background: var(--bg-base, #0f0f13);
   padding: 64px 0 80px
}

.category-count-bar {
   display: flex;
   align-items: center;
   justify-content: space-between;
   margin-bottom: 32px
}

.category-count {
   font-size: 0.88rem;
   color: var(--text-secondary, #888)
}