:root{
  --green-900:#1f5f3f;
  --green-800:#2d7b47;
  --green-700:#3b9357;
  --green-500:#66bb6a;
  --amber-700:#d38a1f;
  --amber-500:#f2b544;
  --cream:#fff8eb;
  --sand:#f7f2e7;
  --mint:#eef8ef;
  --sky:#edf5ff;
  --ink:#18302d;
  --muted:#687b76;
  --line:#d6e1d3;
  --white:#ffffff;
  --radius-xl:28px;
  --radius-lg:22px;
  --radius-md:18px;
  --radius-sm:12px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:"Inter",sans-serif;background:linear-gradient(180deg,#f9fcf8 0%,#f4f8f1 35%,#fffdf7 100%);color:var(--ink)}
a{text-decoration:none}
img{max-width:100%;display:block}
.site-shell{overflow:hidden}
.container-xxl{position:relative;z-index:2}
.eyebrow{display:inline-flex;align-items:center;gap:.45rem;padding:.35rem .7rem;border:1px solid rgba(255,255,255,.35);border-radius:999px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--green-900);background:rgba(255,255,255,.65)}
.topbar-public{position:sticky;top:0;z-index:100;background:rgba(251,253,249,.9);backdrop-filter:blur(14px);border-bottom:1px solid rgba(45,123,71,.12)}
.topbar-public::before,.hero-section::before,.section-alt::before{content:"";position:absolute;inset:auto -10% 0 auto;width:42vw;height:42vw;border-radius:50%;background:radial-gradient(circle, rgba(102,187,106,.12) 0%, rgba(102,187,106,0) 70%);pointer-events:none}
.topbar-grid{display:grid;grid-template-columns:auto 1fr auto;gap:1.2rem;align-items:center;padding:1rem 0}
.brand-mark{display:inline-flex;align-items:center;gap:.9rem;color:var(--green-900)}
.brand-mark strong{display:block;font-family:"Oswald",sans-serif;letter-spacing:.02em;font-size:1.45rem;line-height:1}
.brand-mark small{display:block;color:var(--muted);font-size:.83rem;margin-top:.15rem}
.brand-icon{width:52px;height:52px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#2d7b47,#66bb6a);color:#fff;font-size:1.4rem;border:1px solid rgba(255,255,255,.4)}
.main-nav{display:flex;align-items:center;justify-content:center;gap:.35rem;flex-wrap:wrap}
.main-nav a{padding:.75rem 1rem;border-radius:999px;color:var(--ink);font-weight:600}
.main-nav a:hover,.main-nav a:focus{background:var(--mint);color:var(--green-900)}
.topbar-actions{display:flex;align-items:center;gap:.65rem}
.btn-install,.btn-outline-green,.btn-outline-amber,.btn-outline-white,.btn-green,.btn-cream{border-radius:999px;padding:.8rem 1.1rem;font-weight:700;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:.55rem}
.btn-green{background:var(--green-800);color:#fff;border-color:var(--green-800)}
.btn-green:hover{background:var(--green-900);color:#fff}
.btn-outline-green{background:transparent;color:var(--green-900);border-color:rgba(31,95,63,.25)}
.btn-outline-amber{background:transparent;color:#9a620f;border-color:rgba(211,138,31,.25)}
.btn-outline-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-cream{background:var(--cream);color:var(--green-900);border-color:rgba(255,255,255,.6)}
.btn-install{background:var(--cream);color:var(--green-900);border-color:rgba(31,95,63,.12)}
.nav-toggle{width:48px;height:48px;border-radius:16px;border:1px solid rgba(31,95,63,.15);background:#fff;color:var(--green-900)}
.backend-access-wrap{padding-bottom:1rem}
.backend-access-card{display:grid;grid-template-columns:1.5fr 1fr 1fr auto;gap:1rem;align-items:end;padding:1rem 1.15rem;border:1px solid var(--line);border-radius:26px;background:linear-gradient(90deg,rgba(238,248,239,.92),rgba(255,248,235,.92));}
.backend-copy strong{display:block;font-size:1rem;color:var(--green-900)}
.backend-buttons{display:flex;gap:.7rem;flex-wrap:wrap}
.mini-field,.form-label-group{position:relative}
.mini-field label,.form-label-group label{display:block;font-size:.78rem;font-weight:700;color:var(--muted);margin:0 0 .45rem .1rem}
.mini-field input,.form-label-group input,.form-label-group select,.form-label-group textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:14px;padding:.82rem .95rem;color:var(--ink);outline:none}
.form-label-group textarea{min-height:140px;resize:vertical}
.hero-section{position:relative;padding:2rem 0 1rem;background:
  linear-gradient(135deg, rgba(31,95,63,.95), rgba(59,147,87,.88)),
  radial-gradient(circle at 20% 15%, rgba(255,255,255,.12), transparent 28%),
  radial-gradient(circle at 85% 20%, rgba(242,181,68,.18), transparent 24%);
}
.hero-section::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='380' height='380' viewBox='0 0 380 380'%3E%3Cg fill='none' stroke='rgba(255,255,255,0.09)' stroke-width='2'%3E%3Cpath d='M40 225c30-80 90-130 175-150 42-10 84-8 125 5'/%3E%3Cpath d='M55 290c52-88 127-142 224-160'/%3E%3Cpath d='M100 30c32 15 54 44 58 79 4 33-8 68-31 95'/%3E%3C/g%3E%3C/svg%3E");opacity:.65;mix-blend-mode:screen;pointer-events:none}
.hero-wrapper{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(0,.92fr);gap:2rem;align-items:center}
.hero-copy{color:#fff;padding:1rem 0}
.hero-copy .eyebrow{color:#fff;background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.25)}
.hero-copy h1{font-family:"Oswald",sans-serif;font-size:clamp(2.6rem,4vw,4.55rem);line-height:1.05;margin:1rem 0 1rem;max-width:12ch;text-wrap:balance}
.hero-copy p{font-size:1.06rem;line-height:1.8;max-width:62ch;color:rgba(255,255,255,.88)}
.hero-highlights{display:flex;flex-wrap:wrap;gap:1rem 1.15rem;margin:1.1rem 0 1.7rem;color:#fff;font-weight:600}
.hero-highlights span{display:inline-flex;align-items:center;gap:.55rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem}
.hero-carousel-wrap{position:relative}
.banner-carousel,.hero-banner-card{height:100%;min-height:540px}
.hero-banner-card{position:relative;border-radius:30px;overflow:hidden;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08)}
.hero-banner-visual{position:absolute;inset:0;background-size:cover;background-position:center;filter:saturate(1.05)}
.hero-banner-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,42,31,.12) 0%,rgba(14,42,31,.72) 100%)}
.hero-banner-overlay{position:absolute;inset:auto 0 0 0;z-index:2;padding:2rem;color:#fff}
.hero-banner-overlay h3{font-family:"Oswald",sans-serif;font-size:2rem;line-height:1.1;margin:.7rem 0}
.hero-banner-overlay p{max-width:48ch;color:rgba(255,255,255,.92)}
.hero-banner-fallback{background:linear-gradient(135deg,rgba(255,255,255,.14),rgba(242,181,68,.18))}
.hero-banner-fallback .hero-banner-overlay{position:relative;padding:2.2rem}
.carousel-indicators{bottom:1rem;z-index:5}
.carousel-indicators [data-bs-target]{width:12px;height:12px;border-radius:50%;border:none;background:rgba(255,255,255,.45)}
.carousel-indicators .active{background:#fff}
.stats-strip{padding:1.2rem 0 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}
.stat-pill{display:flex;align-items:center;gap:1rem;padding:1rem 1.1rem;background:#fff;border:1px solid var(--line);border-radius:24px}
.stat-pill i{width:52px;height:52px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--green-800),var(--green-500));color:#fff;font-size:1.2rem}
.stat-pill strong{display:block;font-size:1.45rem;font-family:"Oswald",sans-serif;color:var(--green-900)}
.stat-pill span{display:block;color:var(--muted)}
.section-block{position:relative;padding:5rem 0}
.section-alt{background:linear-gradient(180deg,rgba(238,248,239,.55),rgba(255,255,255,0))}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.7rem}
.section-head h2{font-family:"Oswald",sans-serif;font-size:2.15rem;line-height:1.1;color:var(--green-900);max-width:17ch;margin:.55rem 0 0}
.section-tools{display:flex;gap:.6rem}
.slider-btn{width:46px;height:46px;border-radius:14px;border:1px solid var(--line);background:#fff;color:var(--green-900)}
.card-slider{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(260px, 24%);gap:1rem;overflow-x:auto;padding-bottom:.45rem;scroll-snap-type:x proximity;scrollbar-width:thin}
.card-slider>*{scroll-snap-align:start}
.info-card,.news-card,.widget-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:26px;padding:1.15rem;min-height:100%}
.card-topline{display:flex;justify-content:space-between;gap:.5rem;flex-wrap:wrap;margin-bottom:.9rem}
.mini-chip{display:inline-flex;align-items:center;justify-content:center;padding:.35rem .65rem;border-radius:999px;font-size:.73rem;font-weight:800;letter-spacing:.02em}
.chip-green{background:var(--mint);color:var(--green-900)}
.chip-neutral{background:#f1f4f3;color:var(--ink)}
.chip-outline{background:#fff;color:var(--muted);border:1px solid var(--line)}
.info-card h3,.news-card h3{font-size:1.12rem;font-weight:800;color:var(--green-900);margin:.15rem 0 .3rem}
.muted{color:var(--muted)}
.small{font-size:.88rem}
.card-text{color:#344c47;line-height:1.65}
.clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.info-list{display:grid;gap:.55rem;margin:.65rem 0 1rem}
.info-list.compact{font-size:.93rem}
.info-list span{display:flex;gap:.6rem;color:#4d625d}
.farm-avatar,.professional-avatar{width:84px;height:84px;border-radius:24px;background:linear-gradient(145deg,var(--mint),var(--cream));display:flex;align-items:center;justify-content:center;color:var(--green-900);font-size:2rem;border:1px solid var(--line);overflow:hidden;margin-bottom:1rem}
.farm-avatar img,.professional-avatar img{width:100%;height:100%;object-fit:cover}
.sale-media,.news-media{border-radius:20px;height:195px;background-size:cover;background-position:center;margin-bottom:1rem;border:1px solid rgba(0,0,0,.04)}
.price-line{display:inline-flex;padding:.45rem .85rem;border-radius:999px;background:var(--cream);color:#8c5600;font-weight:800;margin:.35rem 0 .85rem}
.sale-actions{display:flex;gap:.65rem;align-items:center;flex-wrap:wrap;margin-top:auto}
.news-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}
.news-card{padding:0;overflow:hidden}
.news-body{padding:1rem 1rem 1.2rem;display:flex;flex-direction:column;min-height:100%}
.news-date{display:inline-flex;align-items:center;gap:.5rem;color:var(--amber-700);font-size:.83rem;font-weight:700;margin-bottom:.6rem}
.map-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:1rem}
.map-panel{height:560px;border-radius:28px;border:1px solid var(--line);overflow:hidden;background:#ddebd8}
.map-sidebar{padding:1.15rem;background:#fff;border:1px solid var(--line);border-radius:28px}
.map-sidebar h3{font-size:1.15rem;color:var(--green-900);font-weight:800;margin-bottom:1rem}
.map-farm-list{display:grid;gap:.65rem;max-height:500px;overflow:auto;padding-right:.2rem}
.map-farm-item{width:100%;text-align:left;padding:.9rem 1rem;border-radius:18px;border:1px solid var(--line);background:#fbfdfb}
.map-farm-item strong{display:block;color:var(--green-900)}
.map-farm-item span,.map-farm-item small{display:block;color:var(--muted)}
.widget-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}
.widget-card{padding:1.2rem;gap:.7rem;color:var(--ink)}
.widget-card i{width:52px;height:52px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--sky),var(--mint));color:var(--green-900);font-size:1.25rem}
.widget-card strong{font-size:1.05rem;color:var(--green-900)}
.site-footer{position:relative;padding:2.4rem 0;background:linear-gradient(135deg,var(--green-900),#174a37);color:#fff}
.site-footer::before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='440' height='220' viewBox='0 0 440 220'%3E%3Cg fill='none' stroke='rgba(255,255,255,0.08)' stroke-width='2'%3E%3Cpath d='M0 154c76-31 144-43 220-39 70 4 144 22 220 53'/%3E%3Cpath d='M0 185c94-31 170-41 256-35 62 4 122 17 184 40'/%3E%3C/g%3E%3C/svg%3E");opacity:.9}
.footer-grid{display:grid;grid-template-columns:1.35fr .7fr auto;gap:1.5rem;align-items:center}
.footer-links{display:grid;gap:.55rem}
.footer-links a,.footer-meta small,.site-footer p{color:rgba(255,255,255,.8)}
.footer-brand small{color:rgba(255,255,255,.8)}
.footer-brand .brand-icon{background:linear-gradient(145deg,#3f9a59,#a8df70)}
.public-modal{border:none;border-radius:28px;overflow:hidden}
.public-modal .modal-header{padding:1.1rem 1.25rem;border-bottom:1px solid var(--line)}
.public-modal .modal-body{padding:1.3rem}
.detail-grid-two{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:1.2rem}
.detail-cover,.detail-gallery{border:1px solid var(--line);border-radius:24px;background:#f8fbf7;overflow:hidden;min-height:320px;display:flex;align-items:center;justify-content:center}
.detail-cover img,.detail-gallery img,.news-detail-image{width:100%;height:100%;object-fit:cover}
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem;padding:.7rem}
.detail-tags{display:flex;gap:.6rem;flex-wrap:wrap;margin:0 0 1rem}
.detail-tags span{display:inline-flex;align-items:center;gap:.45rem;padding:.55rem .75rem;border-radius:14px;background:var(--mint);color:var(--green-900);font-size:.9rem;font-weight:600}
.detail-block{margin-top:1rem}
.detail-block h4{font-size:1rem;font-weight:800;color:var(--green-900);margin-bottom:.55rem}
.public-table th{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.empty-illustration{width:100%;height:100%;min-height:320px;display:flex;align-items:center;justify-content:center;font-size:4rem;color:#7ba98b;background:linear-gradient(145deg,var(--mint),var(--cream))}
.lead{color:#395651}
@media (max-width:1399.98px){.news-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.widget-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:1199.98px){
  .topbar-grid{grid-template-columns:auto auto;grid-template-areas:"brand actions" "nav nav"}
  .brand-mark{grid-area:brand}.topbar-actions{grid-area:actions;justify-content:flex-end}.main-nav{grid-area:nav;justify-content:flex-start;display:none;padding-bottom:.5rem}.main-nav.is-open{display:flex}
  .backend-access-card{grid-template-columns:1fr 1fr;}
  .hero-wrapper,.map-layout,.footer-grid,.detail-grid-two{grid-template-columns:1fr}
  .stats-grid,.news-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .card-slider{grid-auto-columns:minmax(280px,55%)}
}
@media (max-width:767.98px){
  .topbar-grid{padding:.85rem 0}.brand-icon{width:46px;height:46px;border-radius:16px}.brand-mark strong{font-size:1.25rem}
  .backend-access-card{grid-template-columns:1fr;align-items:stretch}
  .hero-section{padding-top:1rem}.hero-copy h1{font-size:2.25rem}.banner-carousel,.hero-banner-card{min-height:440px}.hero-banner-overlay h3{font-size:1.55rem}
  .stats-grid,.news-grid,.widget-grid{grid-template-columns:1fr}
  .card-slider{grid-auto-columns:minmax(82%,82%)}
  .section-block{padding:3.6rem 0}.section-head h2{font-size:1.8rem}.map-panel{height:420px}
}

/* Ajustes visuales FrontEnd público v2 */
.hero-full{padding:0;background:#163c39}
.hero-banner-full,.hero-banner-full .carousel-inner,.hero-banner-full .carousel-item{width:100%}
.hero-slide{min-height:600px;background-size:cover;background-position:center;position:relative;display:flex;align-items:center}
.hero-slide::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(14,48,45,.92) 0%,rgba(23,79,63,.64) 45%,rgba(219,126,38,.28) 100%)}
.hero-slide::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='520' height='260' viewBox='0 0 520 260'%3E%3Cg fill='none' stroke='rgba(255,255,255,0.13)' stroke-width='2'%3E%3Cpath d='M0 205c78-48 157-65 237-50 72 14 140 54 283 14'/%3E%3Cpath d='M12 102c61-33 137-52 226-37 84 14 147 58 270 45'/%3E%3Cpath d='M102 255c27-59 70-104 128-136 53-29 111-39 175-31'/%3E%3C/g%3E%3C/svg%3E");background-size:520px 260px;background-position:right bottom;background-repeat:repeat-x;opacity:.75;pointer-events:none}
.hero-slide-content{position:relative;z-index:2;color:#fff;padding-top:4rem;padding-bottom:4rem}
.hero-slide-content .eyebrow{color:#fff;background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.3)}
.hero-slide-content h1{font-family:"Oswald",sans-serif;font-size:clamp(2.8rem,5.8vw,5.7rem);line-height:.98;max-width:12ch;margin:1rem 0;text-wrap:balance}
.hero-slide-content p{font-size:1.08rem;line-height:1.7;max-width:58ch;color:rgba(255,255,255,.92)}
.hero-banner-full .carousel-control-prev,.hero-banner-full .carousel-control-next{width:5rem}
.hero-banner-full .carousel-indicators{bottom:1.4rem}
.hero-banner-full .carousel-indicators [data-bs-target]{width:38px;height:6px;border-radius:999px;background:rgba(255,255,255,.45)}
.hero-banner-full .carousel-indicators .active{background:#fff}

.section-fincas{background:linear-gradient(135deg,#f1fff5 0%,#ffffff 58%,#e9f7ff 100%)}
.section-tienda{background:linear-gradient(135deg,#fff5df 0%,#ffffff 55%,#fff0ee 100%)}
.section-profesionales{background:linear-gradient(135deg,#eef4ff 0%,#ffffff 55%,#f1edff 100%)}
.section-noticias{background:linear-gradient(135deg,#fff0e6 0%,#ffffff 55%,#f7f0ff 100%)}
.section-mapa{background:linear-gradient(135deg,#edf9f7 0%,#ffffff 60%,#f3ffe7 100%)}
.section-widgets{background:linear-gradient(135deg,#f8f6eb 0%,#ffffff 60%,#eaf7ff 100%)}
.section-fincas::after,.section-tienda::after,.section-profesionales::after,.section-noticias::after,.section-mapa::after,.section-widgets::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='340' height='340' viewBox='0 0 340 340'%3E%3Cg fill='none' stroke='rgba(31,95,63,0.075)' stroke-width='2'%3E%3Cpath d='M34 245c45-92 120-150 225-174'/%3E%3Cpath d='M74 298c51-73 120-119 205-138'/%3E%3Cpath d='M118 33c23 25 34 55 29 90-5 34-24 63-55 86'/%3E%3C/g%3E%3C/svg%3E");background-size:340px 340px;opacity:.65;pointer-events:none}
.section-tienda .eyebrow,.section-tienda .section-head h2{color:#8d4f00}
.section-profesionales .eyebrow,.section-profesionales .section-head h2{color:#244a9a}
.section-noticias .eyebrow,.section-noticias .section-head h2{color:#9b3f18}
.section-mapa .eyebrow,.section-mapa .section-head h2{color:#136d63}
.section-widgets .eyebrow,.section-widgets .section-head h2{color:#73520d}
.section-tienda .mini-chip.chip-green{background:#fff0cd;color:#8d4f00}
.section-profesionales .mini-chip.chip-green{background:#e9f0ff;color:#244a9a}
.section-noticias .mini-chip.chip-green{background:#ffe9db;color:#9b3f18}
.section-tienda .btn-green{background:#c96f12;border-color:#c96f12}
.section-profesionales .btn-green{background:#315db5;border-color:#315db5}
.section-noticias .btn-green{background:#bf5528;border-color:#bf5528}
.section-tienda .btn-outline-green{color:#8d4f00;border-color:rgba(141,79,0,.28)}
.section-profesionales .btn-outline-green{color:#244a9a;border-color:rgba(36,74,154,.28)}
.section-noticias .btn-outline-green{color:#9b3f18;border-color:rgba(155,63,24,.28)}

.card-carousel{position:relative}
.card-slider{scroll-behavior:smooth;scrollbar-width:none;gap:1.1rem}
.card-slider::-webkit-scrollbar{display:none}
.news-grid.card-slider{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(290px,24%);grid-template-columns:none;overflow-x:auto}
.carousel-dots{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:1.15rem}
.carousel-dots button{width:10px;height:10px;border-radius:999px;border:1px solid transparent;background:#b7c9bd;padding:0;transition:width .2s ease, background .2s ease}
.carousel-dots button.is-active{width:34px;background:var(--green-800)}
.section-tienda .carousel-dots button.is-active{background:#c96f12}
.section-profesionales .carousel-dots button.is-active{background:#315db5}
.section-noticias .carousel-dots button.is-active{background:#bf5528}
.info-card,.news-card,.widget-card,.stat-pill,.map-panel,.map-sidebar,.backend-access-card{box-shadow:none!important}
.info-card{border-width:1px;background:rgba(255,255,255,.88)}
.section-tienda .info-card{border-color:#f4d6a2;background:rgba(255,252,246,.94)}
.section-profesionales .info-card{border-color:#cbd9ff;background:rgba(250,252,255,.94)}
.section-noticias .news-card{border-color:#f3c7b1;background:rgba(255,252,249,.95)}
.farm-card .farm-avatar{background:linear-gradient(145deg,#e4fbeb,#dff5ff)}
.sale-card .sale-media{border-color:#f2cf95}
.professional-card .professional-avatar{background:linear-gradient(145deg,#eaf1ff,#f2edff)}
.news-card .news-media{height:180px}
.news-body{min-height:220px}

.map-layout{grid-template-columns:minmax(0,1fr) 270px}
.map-sidebar{padding:.9rem;border-radius:22px;background:rgba(255,255,255,.88)}
.map-sidebar h3{font-size:1rem;margin-bottom:.75rem}
.map-farm-list{gap:.45rem;max-height:500px}
.map-farm-item{padding:.65rem .75rem;border-radius:14px;font-size:.86rem;background:#fbfffc}
.map-farm-item strong{font-size:.9rem;line-height:1.2}
.map-farm-item span{font-size:.78rem;line-height:1.25;margin-top:.15rem}
.map-farm-item small{font-size:.72rem;line-height:1.25;margin-top:.15rem;color:#2d7b47}

.article-hero{min-height:520px;background:linear-gradient(135deg,#193641,#bd6822);background-size:cover;background-position:center;display:flex;align-items:center;position:relative;color:#fff}
.article-hero::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='520' height='260' viewBox='0 0 520 260'%3E%3Cg fill='none' stroke='rgba(255,255,255,0.12)' stroke-width='2'%3E%3Cpath d='M0 190c80-31 160-39 240-24 70 13 150 44 280 8'/%3E%3Cpath d='M60 80c64-27 134-34 210-17 77 17 142 49 230 39'/%3E%3C/g%3E%3C/svg%3E");opacity:.75;pointer-events:none}
.article-hero-content{position:relative;z-index:2;padding-top:4rem;padding-bottom:4rem}
.article-hero .eyebrow{color:#fff;background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.25)}
.article-hero h1{font-family:"Oswald",sans-serif;font-size:clamp(2.5rem,5vw,5rem);line-height:1;max-width:13ch;margin:1rem 0;text-wrap:balance}
.article-hero p{font-size:1.1rem;line-height:1.75;max-width:62ch;color:rgba(255,255,255,.92)}
.article-back{display:inline-flex;align-items:center;gap:.55rem;color:#fff;margin-bottom:1rem;font-weight:700}
.article-meta{display:flex;gap:.8rem;flex-wrap:wrap;margin-top:1.2rem}
.article-meta span{display:inline-flex;gap:.5rem;align-items:center;border:1px solid rgba(255,255,255,.25);border-radius:999px;padding:.55rem .85rem;background:rgba(255,255,255,.12)}
.article-content-section{padding:4rem 0;background:linear-gradient(135deg,#fff8ed 0%,#fff 55%,#eef8ff 100%)}
.article-layout{display:grid;grid-template-columns:minmax(0,1fr) 310px;gap:1.2rem;align-items:start}
.article-content-card,.article-side-card{background:#fff;border:1px solid var(--line);border-radius:28px;padding:1.5rem;box-shadow:none}
.article-content-card{font-size:1.05rem;line-height:1.9;color:#314844}
.article-side-card h3{font-size:1.1rem;font-weight:800;color:#9b3f18;margin-bottom:1rem}
.related-list{display:grid;gap:.7rem}
.related-list a{display:block;border:1px solid #f1d3c4;border-radius:18px;padding:.85rem;color:var(--ink);background:#fffaf7}
.related-list strong{display:block;line-height:1.25;color:#9b3f18}
.related-list span{display:block;font-size:.8rem;color:var(--muted);margin-top:.35rem}
.article-not-found{background:linear-gradient(135deg,#193641,#2d7b47)}

@media (max-width:1199.98px){
  .hero-slide{min-height:560px}
  .map-layout{grid-template-columns:1fr}
  .article-layout{grid-template-columns:1fr}
  .news-grid.card-slider{grid-auto-columns:minmax(280px,45%)}
}
@media (max-width:767.98px){
  .hero-slide{min-height:520px}
  .hero-slide-content h1{font-size:2.45rem;max-width:12ch}
  .news-grid.card-slider{grid-auto-columns:minmax(82%,82%)}
  .map-sidebar{max-height:310px;overflow:auto}
}

/* Navegación pública refinada */
.topbar-public{background:rgba(255,255,255,.88);border-bottom:1px solid rgba(24,48,45,.08)}
.pro-nav{gap:.55rem;background:linear-gradient(90deg,rgba(255,248,235,.72),rgba(237,245,255,.72),rgba(238,248,239,.72));padding:.42rem;border:1px solid rgba(24,48,45,.08);border-radius:999px;justify-self:center}
.pro-nav a{position:relative;display:inline-flex;align-items:center;gap:.5rem;padding:.58rem .85rem .58rem .6rem;border-radius:999px;background:#fff;border:1px solid rgba(24,48,45,.07);font-size:.92rem;color:#253d39;line-height:1;transition:transform .18s ease, background .18s ease, color .18s ease}
.pro-nav a i{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:.82rem}
.pro-nav a:hover{transform:translateY(-1px)}
.pro-nav .nav-home i{background:#2d7b47}.pro-nav .nav-home:hover{background:#edf8ef;color:#1f5f3f}
.pro-nav .nav-farms i{background:#cc6f2d}.pro-nav .nav-farms:hover{background:#fff0e5;color:#984c17}
.pro-nav .nav-shop i{background:#b58a00}.pro-nav .nav-shop:hover{background:#fff7d6;color:#815f00}
.pro-nav .nav-news i{background:#365bd8}.pro-nav .nav-news:hover{background:#eef2ff;color:#223fa8}
.pro-nav .nav-map i{background:#8f3fb0}.pro-nav .nav-map:hover{background:#f8ecff;color:#6b248b}

/* Títulos sin salto innecesario */
.section-head{align-items:center}
.section-head h2{max-width:none;text-wrap:normal;white-space:normal;width:100%;font-size:clamp(1.65rem,2.3vw,2.25rem)}
.section-head>div:first-child{min-width:0;flex:1}

/* Lista del mapa más compacta */
.map-sidebar{padding:.9rem;border-radius:22px}
.map-sidebar h3{font-size:1rem;margin-bottom:.65rem}
.map-farm-list{gap:.42rem;max-height:500px}
.map-farm-item{padding:.58rem .7rem;border-radius:14px;display:grid;gap:.12rem}
.map-farm-item strong{font-size:.88rem;line-height:1.15}
.map-farm-item span{font-size:.78rem;line-height:1.15}
.map-farm-item small{font-size:.72rem;line-height:1.1;color:#7b8c88}

/* Footer gtbyte */
.footer-meta{display:grid;gap:.7rem;justify-items:end}
.powered-by{display:inline-flex;align-items:center;gap:.42rem;color:rgba(255,255,255,.85);font-size:.78rem;font-weight:700;letter-spacing:.02em;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:.35rem .55rem;background:rgba(255,255,255,.08)}
.powered-by:hover{color:#fff;background:rgba(255,255,255,.14)}
.powered-by img{width:44px;height:auto;display:block}

/* Más color diferencial por zonas */
.section-fincas{background:linear-gradient(135deg,#f2fbef 0%,#fffaf1 100%)}
.section-tienda{background:linear-gradient(135deg,#fff3df 0%,#fffdf7 48%,#f7f0ff 100%)}
.section-profesionales{background:linear-gradient(135deg,#edf5ff 0%,#f4fff7 100%)}
.section-noticias{background:linear-gradient(135deg,#fff7d8 0%,#fff0ec 45%,#eef2ff 100%)}
.section-mapa{background:linear-gradient(135deg,#eef8f6 0%,#f4f2ff 100%)}
.section-widgets{background:linear-gradient(135deg,#f7f2ff 0%,#fff9e8 55%,#eef8ef 100%)}
.section-fincas .info-card{border-color:#bcdcbc;background:linear-gradient(180deg,#ffffff 0%,#f7fff5 100%)}
.section-tienda .info-card{border-color:#f0c98c;background:linear-gradient(180deg,#ffffff 0%,#fff7eb 100%)}
.section-profesionales .info-card{border-color:#b9d3ff;background:linear-gradient(180deg,#ffffff 0%,#f3f8ff 100%)}
.section-noticias .news-card{border-color:#f0c5a2;background:linear-gradient(180deg,#ffffff 0%,#fff8ef 100%)}

@media (max-width:1199.98px){
  .pro-nav{border-radius:24px;justify-content:flex-start;background:transparent;border:0;padding:0}
  .pro-nav a{border-radius:18px}
  .footer-meta{justify-items:start}
}
@media (max-width:767.98px){
  .pro-nav{display:none}.pro-nav.is-open{display:flex}
  .pro-nav a span{display:inline}
  .section-head{align-items:flex-start}.section-head h2{font-size:1.55rem;line-height:1.12}
}

/* Páginas públicas independientes */
.main-nav a.active{
  background:linear-gradient(135deg,rgba(255,248,235,.95),rgba(238,248,239,.95));
  color:var(--green-900);
  border-color:rgba(31,95,63,.18);
}
.listing-page .topbar-public{position:sticky}
.listing-hero{
  position:relative;
  min-height:330px;
  display:flex;
  align-items:center;
  overflow:hidden;
  color:#fff;
  background-size:cover;
  background-position:center;
}
.listing-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 80% 18%,rgba(255,255,255,.16),transparent 24%),
             radial-gradient(circle at 15% 78%,rgba(255,255,255,.12),transparent 26%),
             linear-gradient(115deg,rgba(18,54,47,.92),rgba(18,54,47,.64));
}
.listing-hero::after{
  content:"";
  position:absolute;
  inset:0;
  opacity:.55;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='520' height='260' viewBox='0 0 520 260'%3E%3Cg fill='none' stroke='rgba(255,255,255,0.13)' stroke-width='2'%3E%3Cpath d='M-20 180c90-46 170-62 265-54 92 8 170 44 295 34'/%3E%3Cpath d='M-18 216c112-39 221-41 332-12 75 20 138 20 226-12'/%3E%3C/g%3E%3C/svg%3E");
}
.listing-hero .container-xxl{position:relative;z-index:2}
.listing-hero .eyebrow{color:#fff;background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.28)}
.listing-hero h1{
  font-family:"Oswald",sans-serif;
  font-size:clamp(2.4rem,4.5vw,4.8rem);
  line-height:1;
  margin:.9rem 0 .65rem;
}
.listing-hero p{
  max-width:780px;
  color:rgba(255,255,255,.9);
  font-size:1.08rem;
  line-height:1.7;
}
.listing-hero-fincas{
  background-image:linear-gradient(120deg,rgba(31,95,63,.9),rgba(81,129,58,.72)),url("https://images.unsplash.com/photo-1500937386664-56d1dfef3854?auto=format&fit=crop&w=1800&q=85");
}
.listing-hero-tienda{
  background-image:linear-gradient(120deg,rgba(129,75,22,.9),rgba(220,146,44,.66)),url("https://images.unsplash.com/photo-1501004318641-b39e6451bec6?auto=format&fit=crop&w=1800&q=85");
}
.listing-hero-profesionales{
  background-image:linear-gradient(120deg,rgba(31,74,105,.9),rgba(74,131,151,.66)),url("https://images.unsplash.com/photo-1556761175-b413da4baf72?auto=format&fit=crop&w=1800&q=85");
}
.listing-section{
  padding:2rem 0 5rem;
  background:radial-gradient(circle at 85% 8%,rgba(242,181,68,.12),transparent 22%),
             radial-gradient(circle at 12% 30%,rgba(73,160,179,.11),transparent 22%),
             linear-gradient(180deg,#fbfdf9,#fffaf1);
}
.listing-search{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto auto;
  gap:.8rem;
  align-items:end;
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  padding:1rem;
  margin-top:-3.2rem;
  position:relative;
  z-index:5;
}
.search-box{position:relative}
.search-box i{
  position:absolute;
  left:1rem;
  bottom:1rem;
  color:var(--green-900);
  z-index:2;
}
.search-box input{
  width:100%;
  border:1px solid var(--line);
  border-radius:18px;
  padding:1.1rem 1rem 1.1rem 2.8rem;
  outline:none;
  background:#fbfefb;
  font-weight:600;
}
.search-box label{
  display:block;
  margin:0 0 .45rem .2rem;
  color:var(--muted);
  font-size:.82rem;
  font-weight:800;
}
.listing-summary{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:.4rem;
  margin:1rem 0;
  color:var(--muted);
  font-weight:600;
}
.listing-summary strong{
  font-size:1.25rem;
  color:var(--green-900);
}
.listing-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:1rem;
}
.listing-card{min-height:100%}
.public-pagination{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:.45rem;
  margin-top:2rem;
  flex-wrap:wrap;
}
.page-pill{
  min-width:44px;
  height:44px;
  padding:0 .85rem;
  border-radius:14px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--green-900);
  font-weight:800;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.page-pill.active{
  background:linear-gradient(135deg,var(--green-800),var(--green-500));
  color:#fff;
  border-color:transparent;
}
.page-pill.disabled{opacity:.35;pointer-events:none}
.page-gap{color:var(--muted);padding:.2rem}
.page-tienda .listing-card{border-color:rgba(211,138,31,.25)}
.page-profesionales .listing-card{border-color:rgba(49,126,151,.24)}

.card-carousel{position:relative}
.carousel-dots{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:.45rem;
  margin-top:1rem;
}
.carousel-dots button{
  width:10px;
  height:10px;
  border-radius:999px;
  border:0;
  background:rgba(31,95,63,.22);
  padding:0;
}
.carousel-dots button.active{
  width:30px;
  background:var(--green-800);
}
.section-tienda .carousel-dots button.active{background:var(--amber-700)}
.section-profesionales .carousel-dots button.active{background:#367f99}
.section-noticias .carousel-dots button.active{background:#be5b36}

@media (max-width:1199.98px){
  .listing-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:991.98px){
  .listing-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .listing-search{grid-template-columns:1fr}
}
@media (max-width:575.98px){
  .listing-grid{grid-template-columns:1fr}
  .listing-hero{min-height:285px}
}


/* Corrección explícita v4: menú a páginas, títulos en línea y carruseles */
.pro-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.45rem;
}
.pro-nav a{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  border:1px solid transparent;
  padding:.7rem .9rem;
  border-radius:999px;
  font-weight:800;
  white-space:nowrap;
}
.pro-nav a i{
  width:28px;
  height:28px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-size:.85rem;
}
.pro-nav .nav-home i{background:#2d7b47}
.pro-nav .nav-farms i{background:#4a9a3b}
.pro-nav .nav-shop i{background:#d38a1f}
.pro-nav .nav-pros i{background:#367f99}
.pro-nav .nav-news i{background:#be5b36}
.pro-nav .nav-map i{background:#7c5cc4}
.pro-nav a:hover{
  background:#fff;
  border-color:rgba(24,48,45,.12);
}
.section-head h2{
  max-width:none !important;
  width:auto !important;
  text-wrap:normal !important;
}
.section-head{
  align-items:center !important;
}
.map-farm-list{
  gap:.35rem !important;
}
.map-farm-item{
  padding:.55rem .65rem !important;
  border-radius:12px !important;
}
.map-farm-item strong{
  font-size:.86rem !important;
  line-height:1.15 !important;
}
.map-farm-item span,
.map-farm-item small{
  font-size:.73rem !important;
  line-height:1.2 !important;
}
.carousel-dots{
  display:flex !important;
}
@media (max-width:1199.98px){
  .pro-nav{
    justify-content:flex-start;
    overflow-x:auto;
    padding-bottom:.35rem;
  }
}


/* Fix v5: separación de iconos en menú/footer y lupa de buscadores */
.pro-nav a,
.main-nav a{
  gap:.62rem !important;
}

.pro-nav a i,
.main-nav a i{
  margin-right:.22rem !important;
  flex:0 0 auto;
  line-height:1 !important;
}

.pro-nav a span,
.main-nav a span{
  display:inline-block;
  line-height:1.15;
}

.topbar-actions .btn i,
.footer-meta .btn i,
.powered-by img,
.powered-by span{
  margin-right:.42rem;
}

.btn i{
  margin-right:.38rem;
}

.btn i:only-child{
  margin-right:0;
}

.powered-by{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
}

.powered-by img{
  width:28px;
  height:auto;
  object-fit:contain;
}

/* Buscadores de páginas públicas */
.listing-search{
  align-items:end !important;
}

.search-box{
  position:relative !important;
  display:flex;
  flex-direction:column;
  gap:.42rem;
}

.search-box label{
  order:1;
  position:static !important;
  display:block !important;
  margin:0 0 .1rem .15rem !important;
  color:var(--muted) !important;
  font-size:.82rem !important;
  font-weight:800 !important;
  line-height:1.15 !important;
}

.search-box input{
  order:2;
  padding-left:3rem !important;
  min-height:58px;
}

.search-box > i{
  position:absolute !important;
  left:1.05rem !important;
  top:auto !important;
  bottom:1.18rem !important;
  transform:none !important;
  z-index:3 !important;
  width:18px;
  height:18px;
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  color:var(--green-900) !important;
  font-size:1rem !important;
  pointer-events:none;
}

/* Evita que el icono de lupa se pegue al borde o quede sobre el label */
.listing-search .btn{
  min-height:52px;
  align-self:end;
}


/* Fix v6: index sin acceso administrativo, botón único Ingresar */
.backend-access-wrap{
  display:none !important;
}

.btn-login-public{
  min-height:48px;
  border-radius:999px;
  padding:.78rem 1.15rem;
  background:#fff;
  color:var(--green-900);
  border:1px solid rgba(31,95,63,.22);
  font-weight:800;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
}

.btn-login-public i{
  width:28px;
  height:28px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#eaf6ec;
  color:var(--green-900);
  margin-right:.1rem !important;
}

.btn-login-public:hover{
  background:var(--green-900);
  color:#fff;
  border-color:var(--green-900);
}

.btn-login-public:hover i{
  background:rgba(255,255,255,.18);
  color:#fff;
}

.topbar-actions{
  justify-content:flex-end;
}

@media (max-width:575.98px){
  .btn-login-public span{
    display:none;
  }
  .btn-login-public{
    width:48px;
    height:48px;
    padding:0;
  }
}


/* Fix v7: menú superior unificado en index y páginas internas */
.topbar-public .topbar-grid{
  grid-template-columns:auto 1fr auto;
}

.topbar-public .main-nav.pro-nav,
.topbar-public .main-nav.is-inline,
.topbar-public .main-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.45rem;
}

.topbar-public .main-nav.pro-nav a,
.topbar-public .main-nav.is-inline a,
.topbar-public .main-nav a{
  display:inline-flex !important;
  align-items:center !important;
  gap:.62rem !important;
  border:1px solid transparent;
  padding:.7rem .9rem;
  border-radius:999px;
  font-weight:800;
  white-space:nowrap;
}

.topbar-public .main-nav a.active{
  background:transparent !important;
  border-color:transparent !important;
}

.topbar-public .topbar-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:.65rem;
}

@media (max-width:1199.98px){
  .topbar-public .main-nav.pro-nav,
  .topbar-public .main-nav.is-inline,
  .topbar-public .main-nav{
    justify-content:flex-start;
    overflow-x:auto;
  }
}


/* Fix v8: footer centralizado en partial reutilizable */
.site-footer .footer-meta{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:.75rem;
}

.site-footer .btn-outline-white{
  min-height:44px;
}

.powered-by{
  display:inline-flex;
  align-items:center;
  justify-content:flex-end;
  gap:.45rem;
  color:#fff;
  font-weight:800;
}

.powered-by span{
  color:rgba(255,255,255,.82);
  font-size:.82rem;
}

.powered-by img{
  width:34px;
  height:auto;
  object-fit:contain;
}

@media (max-width:991.98px){
  .site-footer .footer-meta{
    align-items:flex-start;
  }
}


/* Fix v9: componentes públicos reutilizables */
.main-nav a.active{
  background:linear-gradient(135deg,rgba(255,248,235,.95),rgba(238,248,239,.95));
  border-color:rgba(31,95,63,.16);
}

.public-partial-ready{
  display:block;
}


/* PWA pulida v10 */
.btn-install[hidden]{
  display:none !important;
}

.sw-update-toast{
  position:fixed;
  right:1rem;
  bottom:1rem;
  z-index:9999;
}


/* Ficha pública de finca v11 */
.farm-detail-hero{
  position:relative;
  overflow:hidden;
  color:#fff;
  padding:clamp(3.5rem,6vw,6rem) 0;
  background:
    linear-gradient(115deg,rgba(18,74,49,.94),rgba(71,138,55,.74)),
    radial-gradient(circle at 80% 15%,rgba(255,255,255,.16),transparent 26%),
    radial-gradient(circle at 12% 78%,rgba(242,181,68,.22),transparent 28%);
}
.farm-detail-hero::after{
  content:"";
  position:absolute;
  inset:0;
  opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='520' height='260' viewBox='0 0 520 260'%3E%3Cg fill='none' stroke='rgba(255,255,255,0.12)' stroke-width='2'%3E%3Cpath d='M-20 180c90-46 170-62 265-54 92 8 170 44 295 34'/%3E%3Cpath d='M-18 216c112-39 221-41 332-12 75 20 138 20 226-12'/%3E%3C/g%3E%3C/svg%3E");
}
.farm-detail-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 280px;
  gap:2rem;
  align-items:center;
  position:relative;
  z-index:2;
}
.farm-detail-identity h1{
  font-family:"Oswald",sans-serif;
  font-size:clamp(2.5rem,5.5vw,5rem);
  line-height:1;
  margin:.8rem 0 1rem;
}
.farm-detail-identity p{
  max-width:850px;
  color:rgba(255,255,255,.9);
  font-size:1.08rem;
  line-height:1.75;
}
.farm-detail-actions{
  display:flex;
  gap:.75rem;
  flex-wrap:wrap;
  margin-top:1.2rem;
}
.article-back{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  color:#fff;
  font-weight:800;
  margin-bottom:1rem;
}
.farm-detail-logo-card{
  width:260px;
  height:260px;
  border-radius:34px;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(255,255,255,.16);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  justify-self:end;
}
.farm-detail-logo-card img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:1.1rem;
}
.farm-detail-logo-card i{
  font-size:5rem;
  color:#fff;
}
.farm-detail-section{
  padding:2rem 0 5rem;
  background:
    radial-gradient(circle at 86% 8%,rgba(242,181,68,.12),transparent 22%),
    radial-gradient(circle at 10% 20%,rgba(102,187,106,.12),transparent 24%),
    linear-gradient(180deg,#fbfdf9,#fffaf1);
}
.farm-detail-layout{
  display:grid;
  grid-template-columns:330px minmax(0,1fr);
  gap:1rem;
  align-items:start;
}
.farm-detail-sidebar{
  position:sticky;
  top:110px;
  display:grid;
  gap:1rem;
}
.farm-resume-card,
.farm-detail-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:1.25rem;
}
.farm-resume-card h2{
  font-size:1.1rem;
  color:var(--green-900);
  font-weight:900;
  margin:0 0 1rem;
}
.farm-resume-list{
  display:grid;
  gap:.65rem;
}
.farm-resume-list span{
  display:grid;
  grid-template-columns:32px 1fr;
  gap:.55rem;
  align-items:start;
  padding:.75rem;
  border:1px solid #e3ecdf;
  border-radius:16px;
  background:#fbfefb;
}
.farm-resume-list i{
  width:32px;
  height:32px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  background:linear-gradient(135deg,var(--green-800),var(--green-500));
  grid-row:span 2;
}
.farm-resume-list strong{
  display:block;
  color:var(--ink);
  font-size:.83rem;
  line-height:1.1;
}
.farm-resume-list em{
  display:block;
  color:var(--muted);
  font-style:normal;
  font-size:.86rem;
  line-height:1.25;
}
.farm-detail-content{
  display:grid;
  gap:1rem;
}
.compact-head{
  margin-bottom:1rem !important;
}
.compact-head h2{
  max-width:none !important;
  font-size:1.6rem !important;
}
.farm-detail-card p{
  line-height:1.75;
  color:#3d5751;
}
.farm-detail-map{
  height:420px;
  border:1px solid var(--line);
  border-radius:24px;
  overflow:hidden;
  background:#e5efdf;
}
.public-mini-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.8rem;
}
.public-mini-card{
  border:1px solid #e3ecdf;
  border-radius:20px;
  background:linear-gradient(180deg,#fff,#fbfefb);
  padding:1rem;
  display:flex;
  flex-direction:column;
  gap:.35rem;
}
.public-mini-card > i{
  width:44px;
  height:44px;
  border-radius:16px;
  background:var(--mint);
  color:var(--green-900);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:1.2rem;
  margin-bottom:.2rem;
}
.public-mini-card strong{
  color:var(--green-900);
}
.public-mini-card span,
.public-mini-card small{
  color:var(--muted);
}
.public-mini-card img{
  width:100%;
  height:130px;
  object-fit:cover;
  border-radius:16px;
  margin-bottom:.35rem;
}
.public-mini-card .mini-avatar{
  width:64px;
  height:64px;
  border-radius:20px;
  object-fit:cover;
}
.farm-detail-table{
  margin:0;
}
.farm-public-gallery{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:.8rem;
}
.farm-gallery-item{
  position:relative;
  border-radius:20px;
  overflow:hidden;
  min-height:165px;
  border:1px solid var(--line);
  color:#fff;
}
.farm-gallery-item img{
  width:100%;
  height:190px;
  object-fit:cover;
}
.farm-gallery-item span{
  position:absolute;
  left:.7rem;
  right:.7rem;
  bottom:.7rem;
  padding:.45rem .65rem;
  border-radius:12px;
  background:rgba(18,63,49,.74);
  color:#fff;
  font-size:.82rem;
  font-weight:800;
}
.farm-attachments-list{
  display:grid;
  gap:.6rem;
}
.farm-attachments-list a{
  display:flex;
  align-items:center;
  gap:.7rem;
  border:1px solid var(--line);
  border-radius:16px;
  padding:.8rem 1rem;
  color:var(--green-900);
  font-weight:800;
  background:#fbfefb;
}
.farm-attachments-list a i{
  width:34px;
  height:34px;
  border-radius:999px;
  background:var(--cream);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#9a620f;
}
.farm-attachments-list a small{
  margin-left:auto;
  color:var(--muted);
}
.empty-public-state{
  display:flex;
  align-items:center;
  gap:.8rem;
  padding:1rem;
  border:1px dashed #c8d7c5;
  border-radius:18px;
  color:var(--muted);
  background:#fbfefb;
}
.empty-public-state i{
  color:var(--green-900);
  font-size:1.4rem;
}
@media (max-width:1199.98px){
  .farm-detail-layout{grid-template-columns:1fr}
  .farm-detail-sidebar{position:static;grid-template-columns:repeat(2,minmax(0,1fr))}
  .farm-public-gallery{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width:991.98px){
  .farm-detail-hero-grid{grid-template-columns:1fr}
  .farm-detail-logo-card{justify-self:start;width:190px;height:190px}
  .public-mini-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .farm-detail-sidebar{grid-template-columns:1fr}
}
@media (max-width:575.98px){
  .farm-public-gallery,.public-mini-grid{grid-template-columns:1fr}
  .farm-detail-map{height:330px}
}


/* Página pública de detalle de producto v13 */
.product-detail-hero{
  position:relative;
  overflow:hidden;
  color:#fff;
  padding:clamp(3rem,5vw,5rem) 0;
  background:
    linear-gradient(115deg,rgba(126,75,22,.94),rgba(211,138,31,.72)),
    radial-gradient(circle at 82% 12%,rgba(255,255,255,.16),transparent 24%),
    radial-gradient(circle at 14% 82%,rgba(102,187,106,.20),transparent 28%);
}
.product-detail-hero::after{
  content:"";
  position:absolute;
  inset:0;
  opacity:.42;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='520' height='260' viewBox='0 0 520 260'%3E%3Cg fill='none' stroke='rgba(255,255,255,0.13)' stroke-width='2'%3E%3Cpath d='M-20 180c90-46 170-62 265-54 92 8 170 44 295 34'/%3E%3Cpath d='M-18 216c112-39 221-41 332-12 75 20 138 20 226-12'/%3E%3C/g%3E%3C/svg%3E");
}
.product-detail-hero-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);
  gap:2rem;
  align-items:center;
}
.product-detail-gallery{
  display:grid;
  gap:.8rem;
}
.product-main-photo{
  border-radius:32px;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(255,255,255,.14);
  min-height:430px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}
.product-main-photo img{
  width:100%;
  height:100%;
  min-height:430px;
  object-fit:cover;
}
.product-empty-photo i{
  font-size:5rem;
  color:#fff;
}
.product-thumbs{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:.6rem;
}
.product-thumbs button{
  border:2px solid transparent;
  padding:0;
  border-radius:16px;
  overflow:hidden;
  background:rgba(255,255,255,.18);
  height:74px;
}
.product-thumbs button.active{
  border-color:#fff8eb;
}
.product-thumbs img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.product-detail-info h1{
  font-family:"Oswald",sans-serif;
  font-size:clamp(2.5rem,5.2vw,5rem);
  line-height:1;
  margin:.8rem 0 1rem;
}
.product-detail-info p{
  max-width:760px;
  color:rgba(255,255,255,.92);
  line-height:1.75;
  font-size:1.06rem;
}
.product-price{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.65rem 1rem;
  border-radius:999px;
  background:#fff8eb;
  color:#87550a;
  font-weight:900;
  font-size:1.35rem;
  margin:.6rem 0 1rem;
}
.product-action-row{
  display:flex;
  flex-wrap:wrap;
  gap:.75rem;
}
.product-detail-section{
  padding:2rem 0 5rem;
  background:
    radial-gradient(circle at 86% 8%,rgba(211,138,31,.12),transparent 22%),
    radial-gradient(circle at 10% 20%,rgba(102,187,106,.12),transparent 24%),
    linear-gradient(180deg,#fffaf1,#fbfdf9);
}
.product-detail-layout{
  display:grid;
  grid-template-columns:330px minmax(0,1fr);
  gap:1rem;
  align-items:start;
}
.product-side{
  position:sticky;
  top:110px;
  display:grid;
  gap:1rem;
}
.product-side-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:1.25rem;
}
.product-side-card h2{
  font-size:1.1rem;
  color:#87550a;
  font-weight:900;
  margin:0 0 1rem;
}
.product-content{
  display:grid;
  gap:1rem;
}
.product-farm-box{
  display:grid;
  grid-template-columns:120px minmax(0,1fr);
  gap:1rem;
  align-items:start;
}
.product-farm-logo{
  width:120px;
  height:120px;
  border:1px solid var(--line);
  border-radius:26px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  background:linear-gradient(145deg,var(--mint),var(--cream));
  color:var(--green-900);
  font-size:2.2rem;
}
.product-farm-logo img{
  width:100%;
  height:100%;
  object-fit:contain;
  padding:.6rem;
}
.product-offer-form{
  border:1px solid #e3ecdf;
  background:linear-gradient(180deg,#fff,#fbfefb);
  border-radius:22px;
  padding:1rem;
}
.product-offer-form .form-label-group label{
  display:block;
  margin:0 0 .42rem .15rem;
  font-size:.82rem;
  font-weight:800;
  color:var(--muted);
}
.product-offer-form .form-control{
  min-height:52px;
  border-radius:16px;
  border:1px solid var(--line);
}
@media (max-width:1199.98px){
  .product-detail-layout{grid-template-columns:1fr}
  .product-side{position:static;grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:991.98px){
  .product-detail-hero-grid{grid-template-columns:1fr}
  .product-side{grid-template-columns:1fr}
  .product-main-photo,.product-main-photo img{min-height:330px}
  .product-thumbs{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media (max-width:575.98px){
  .product-farm-box{grid-template-columns:1fr}
  .product-thumbs{grid-template-columns:repeat(3,minmax(0,1fr))}
}


/* Optimización móvil ECAMPO 3.0 v15 */
@media (max-width:1199.98px){
  body.menu-open{
    overflow:hidden;
  }

  .topbar-public{
    z-index:1050;
  }

  .topbar-grid{
    grid-template-columns:auto 1fr auto !important;
    gap:.75rem !important;
    padding:.65rem .75rem !important;
  }

  .brand-mark img{
    max-width:170px;
    height:auto;
  }

  .nav-toggle{
    display:inline-flex !important;
    align-items:center;
    justify-content:center;
    width:46px;
    height:46px;
    border-radius:15px;
    border:1px solid rgba(31,95,63,.18);
    background:#fff;
    color:var(--green-900);
    font-size:1.05rem;
  }

  .main-nav.pro-nav{
    position:fixed !important;
    top:74px;
    left:.75rem;
    right:.75rem;
    display:none !important;
    grid-template-columns:1fr 1fr;
    gap:.55rem !important;
    padding:.8rem;
    border-radius:24px;
    border:1px solid rgba(31,95,63,.14);
    background:rgba(255,255,255,.97);
    backdrop-filter:blur(14px);
    overflow:visible !important;
    max-height:calc(100vh - 92px);
    z-index:1060;
  }

  .main-nav.pro-nav.is-open{
    display:grid !important;
  }

  .main-nav.pro-nav a{
    justify-content:flex-start !important;
    width:100%;
    padding:.75rem .8rem !important;
    background:#fbfefb;
    border:1px solid #e5eee2 !important;
    border-radius:18px !important;
    font-size:.92rem;
  }

  .main-nav.pro-nav a.active{
    background:linear-gradient(135deg,#eef8ef,#fff8ea) !important;
  }

  .topbar-actions{
    justify-content:flex-end;
    gap:.45rem !important;
  }

  .btn-login-public{
    min-height:46px !important;
    padding:.65rem .9rem !important;
  }

  .btn-login-public span{
    display:inline-block;
  }

  .site-shell{
    overflow:hidden;
  }
}

@media (max-width:767.98px){
  html, body{
    width:100%;
    overflow-x:hidden;
  }

  .container-xxl{
    padding-left:1rem !important;
    padding-right:1rem !important;
  }

  .topbar-grid{
    padding:.58rem .7rem !important;
  }

  .brand-mark img{
    max-width:145px;
  }

  .btn-login-public{
    width:46px;
    height:46px;
    padding:0 !important;
    border-radius:15px !important;
  }

  .btn-login-public span{
    display:none !important;
  }

  .btn-login-public i{
    margin:0 !important;
  }

  .main-nav.pro-nav{
    top:66px;
    left:.6rem;
    right:.6rem;
    grid-template-columns:1fr;
    border-radius:22px;
  }

  .hero-slide,
  .hero-banner-full .carousel-item,
  .hero-full{
    min-height:560px;
  }

  .hero-slide{
    display:flex;
    align-items:flex-end;
    padding:4.5rem 0 3rem;
    background-position:center;
  }

  .hero-slide-content{
    padding-bottom:1rem;
  }

  .hero-slide-content h1,
  .hero-copy h1,
  .listing-hero h1,
  .farm-detail-identity h1,
  .product-detail-info h1,
  .article-hero h1{
    font-size:clamp(2rem,12vw,3.05rem) !important;
    line-height:1.02 !important;
    max-width:none !important;
  }

  .hero-slide-content p,
  .hero-copy p,
  .listing-hero p,
  .farm-detail-identity p,
  .product-detail-info p,
  .article-hero p{
    font-size:.96rem !important;
    line-height:1.55 !important;
  }

  .hero-actions,
  .farm-detail-actions,
  .product-action-row,
  .sale-actions{
    gap:.55rem !important;
  }

  .hero-actions .btn,
  .farm-detail-actions .btn,
  .product-action-row .btn{
    flex:1 1 auto;
    min-width:135px;
  }

  .stats-grid{
    grid-template-columns:1fr 1fr !important;
    gap:.65rem !important;
  }

  .stat-pill{
    padding:.75rem !important;
    border-radius:18px !important;
    gap:.65rem !important;
  }

  .stat-pill i{
    width:42px !important;
    height:42px !important;
    border-radius:14px !important;
  }

  .stat-pill strong{
    font-size:1.15rem !important;
  }

  .stat-pill span{
    font-size:.78rem !important;
  }

  .section-block{
    padding:3rem 0 !important;
  }

  .section-head{
    flex-direction:column;
    align-items:flex-start !important;
    gap:.8rem !important;
    margin-bottom:1rem !important;
  }

  .section-head h2{
    font-size:1.55rem !important;
    line-height:1.12 !important;
  }

  .section-tools{
    align-self:flex-end;
    margin-top:-.4rem;
  }

  .card-slider{
    grid-auto-columns:minmax(84%,84%) !important;
    gap:.8rem !important;
    padding-bottom:.25rem;
  }

  .info-card,
  .news-card,
  .widget-card,
  .farm-detail-card,
  .farm-resume-card,
  .product-side-card{
    border-radius:22px !important;
    padding:1rem !important;
  }

  .sale-media,
  .news-media{
    height:170px !important;
    border-radius:18px !important;
  }

  .listing-hero{
    min-height:300px !important;
    align-items:flex-end !important;
    padding:2rem 0 2.4rem;
  }

  .listing-search{
    grid-template-columns:1fr !important;
    gap:.65rem !important;
    padding:.8rem !important;
    border-radius:22px !important;
    margin-top:-2.1rem !important;
  }

  .search-box input{
    min-height:54px !important;
    border-radius:16px !important;
  }

  .listing-summary{
    justify-content:flex-start !important;
    margin:.9rem 0 !important;
  }

  .listing-grid{
    grid-template-columns:1fr !important;
    gap:.85rem !important;
  }

  .public-pagination{
    gap:.35rem !important;
    margin-top:1.3rem !important;
  }

  .page-pill{
    min-width:40px !important;
    height:40px !important;
    border-radius:13px !important;
    padding:0 .65rem !important;
    font-size:.9rem;
  }

  .map-layout{
    grid-template-columns:1fr !important;
  }

  .map-panel,
  .farm-detail-map{
    height:340px !important;
    border-radius:22px !important;
  }

  .map-sidebar{
    border-radius:22px !important;
    padding:1rem !important;
  }

  .map-farm-list{
    max-height:260px !important;
  }

  .widget-grid,
  .news-grid{
    grid-template-columns:1fr !important;
  }

  .footer-grid{
    grid-template-columns:1fr !important;
    text-align:left !important;
    gap:1.1rem !important;
  }

  .footer-links{
    display:grid !important;
    grid-template-columns:1fr 1fr;
    gap:.55rem !important;
  }

  .footer-links a{
    padding:.55rem .65rem;
    border:1px solid rgba(255,255,255,.12);
    border-radius:14px;
    background:rgba(255,255,255,.06);
  }

  .site-footer .footer-meta{
    align-items:flex-start !important;
  }

  .public-modal .modal-dialog{
    margin:.6rem !important;
  }

  .public-modal .modal-content,
  .modal-content.public-modal{
    border-radius:22px !important;
  }

  .public-modal .modal-body{
    padding:1rem !important;
  }

  .detail-grid-two{
    grid-template-columns:1fr !important;
  }

  .detail-cover,
  .detail-gallery{
    min-height:240px !important;
  }

  .gallery-grid{
    grid-template-columns:1fr 1fr !important;
  }
}

@media (max-width:575.98px){
  .container-xxl{
    padding-left:.85rem !important;
    padding-right:.85rem !important;
  }

  .brand-mark img{
    max-width:130px;
  }

  .nav-toggle,
  .btn-login-public{
    width:43px !important;
    height:43px !important;
  }

  .hero-slide,
  .hero-banner-full .carousel-item,
  .hero-full{
    min-height:520px;
  }

  .stats-grid{
    grid-template-columns:1fr !important;
  }

  .card-slider{
    grid-auto-columns:minmax(90%,90%) !important;
  }

  .farm-detail-hero,
  .product-detail-hero{
    padding:2.4rem 0 !important;
  }

  .farm-detail-hero-grid,
  .product-detail-hero-grid{
    grid-template-columns:1fr !important;
    gap:1rem !important;
  }

  .farm-detail-logo-card{
    width:150px !important;
    height:150px !important;
    border-radius:24px !important;
  }

  .product-main-photo,
  .product-main-photo img{
    min-height:280px !important;
    border-radius:24px !important;
  }

  .product-thumbs{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  }

  .product-thumbs button{
    height:66px !important;
  }

  .farm-detail-layout,
  .product-detail-layout{
    grid-template-columns:1fr !important;
  }

  .farm-detail-sidebar,
  .product-side{
    position:static !important;
    grid-template-columns:1fr !important;
  }

  .public-mini-grid,
  .farm-public-gallery{
    grid-template-columns:1fr !important;
  }

  .product-farm-box{
    grid-template-columns:1fr !important;
  }

  .product-farm-logo{
    width:96px !important;
    height:96px !important;
    border-radius:22px !important;
  }

  .farm-resume-list span{
    grid-template-columns:30px 1fr !important;
    padding:.65rem !important;
  }

  .farm-resume-list i{
    width:30px !important;
    height:30px !important;
  }

  .table-responsive{
    border-radius:18px;
    border:1px solid var(--line);
  }

  .public-table{
    min-width:720px;
  }

  .article-layout{
    grid-template-columns:1fr !important;
  }

  .article-content-card{
    padding:1.1rem !important;
    border-radius:22px !important;
  }

  .article-side-card{
    border-radius:22px !important;
  }
}
