/*
  VanLifeNet / SocialHub – Theme C: Nordic Adventure
  Patch 008: Modern light UI for Map-first vanlife community (Bootstrap 5 compatible)
*/

:root{
  --sh-primary:#2563EB;
  --sh-accent:#10B981;
  --sh-bg:#F1F5F9;
  --sh-card:#FFFFFF;
  --sh-text:#0B1220;
  --sh-muted:#64748B;
  --sh-border:#E2E8F0;
  --sh-radius-lg:18px;
  --sh-radius-md:14px;
  --sh-shadow:0 16px 40px rgba(2, 8, 23, .10);
  --sh-shadow-soft:0 10px 24px rgba(2, 8, 23, .08);
}

html,body{height:100%}
html{scroll-padding-bottom:calc(var(--vln-bottom-nav-space, 0px) + env(safe-area-inset-bottom));}
body{
  background:var(--sh-bg);
  color:var(--sh-text);
  font-family: Manrope, Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}
body.vln-has-mobile-bottom-nav{
  /* +12px buffer so last elements (e.g. Cookie-Einstellungen) can be fully scrolled above the fixed bottom nav */
  padding-bottom:calc(var(--vln-bottom-nav-space, 84px) + 12px + env(safe-area-inset-bottom));
}
@media (min-width: 992px){
  body.vln-has-mobile-bottom-nav{padding-bottom:0;}
}

/* Ensure the cookie settings link isn't hidden behind the fixed bottom nav on mobile */
@media (max-width: 991.98px){
  .vln-cookie-access{
    padding-bottom:calc(var(--vln-bottom-nav-space, 84px) + 12px + env(safe-area-inset-bottom));
  }
}

/* Topbar */
.sh-topbar{
  background:rgba(255,255,255,.86)!important;
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--sh-border);
}
.navbar .navbar-brand{
  font-weight:900;
  letter-spacing:.2px;
}
.sh-brand-mark{
  width:34px;height:34px;border-radius:12px;
  background:linear-gradient(135deg, var(--sh-primary), color-mix(in srgb, var(--sh-accent) 70%, #fff 0%));
  box-shadow:var(--sh-shadow-soft);
  display:inline-block;
  margin-right:10px;
  vertical-align:middle;
}
.navbar .nav-link{
  font-weight:700;
  color:rgba(11,18,32,.78)!important;
  border-radius:999px;
  padding:.45rem .75rem;
}
.navbar .nav-link:hover{
  background:color-mix(in srgb, var(--sh-primary) 10%, transparent);
  color:var(--sh-primary)!important;
}
.navbar .nav-link.active{
  background:color-mix(in srgb, var(--sh-primary) 14%, transparent);
  color:var(--sh-primary)!important;
}
.navbar .navbar-text{color:rgba(11,18,32,.65)!important;font-weight:700}

/* Cards */
.card{
  border:1px solid var(--sh-border);
  border-radius:var(--sh-radius-lg);
  box-shadow:var(--sh-shadow-soft);
}
.card .card-header{
  background:rgba(255,255,255,.75);
  border-bottom:1px solid var(--sh-border);
  border-top-left-radius:var(--sh-radius-lg);
  border-top-right-radius:var(--sh-radius-lg);
  font-weight:800;
}
.card .card-body{padding:1rem}

/* Buttons */
.btn{
  border-radius:999px;
  font-weight:800;
}
.btn-primary{
  background:var(--sh-primary);
  border-color:var(--sh-primary);
  box-shadow:0 10px 20px rgba(37,99,235,.18);
}
.btn-primary:hover{background:color-mix(in srgb, var(--sh-primary) 88%, #000 12%); border-color:color-mix(in srgb, var(--sh-primary) 88%, #000 12%)}
.btn-outline-primary{
  border-color:color-mix(in srgb, var(--sh-primary) 50%, var(--sh-border));
  color:var(--sh-primary);
}
.btn-outline-primary:hover{
  background:color-mix(in srgb, var(--sh-primary) 10%, transparent);
  border-color:color-mix(in srgb, var(--sh-primary) 70%, var(--sh-border));
  color:var(--sh-primary);
}

/* Alerts (centered slightly more) */
.alert{
  border-radius:var(--sh-radius-md);
  border:1px solid var(--sh-border);
}

/* Forms */
.form-control, .form-select{
  border-radius:var(--sh-radius-md);
  border-color:var(--sh-border);
}
.form-control:focus, .form-select:focus{
  border-color:color-mix(in srgb, var(--sh-primary) 55%, var(--sh-border));
  box-shadow:0 0 0 .2rem rgba(37,99,235,.12);
}

/* Tables */
.table{
  border-color:var(--sh-border);
}
.table thead th{
  font-weight:900;
  color:rgba(11,18,32,.75);
}
.table tbody tr:hover{background:rgba(37,99,235,.05)}

/* Badges */
.badge{
  border-radius:999px;
  font-weight:900;
  letter-spacing:.2px;
}
.badge.bg-danger{background:#EF4444!important}
.badge.bg-primary{background:var(--sh-primary)!important}

/* Map */
.sh-map{
  height:62vh;
  min-height:520px;
  border-radius:var(--sh-radius-lg);
  overflow:hidden;
  border:1px solid var(--sh-border);
}
.sh-map-compact{
  height:320px;
  min-height:320px;
  border-radius:var(--sh-radius-lg);
  overflow:hidden;
  border:1px solid var(--sh-border);
  background:#eaf0f6;
}
@media (max-width: 767.98px){
  .sh-map-compact{height:260px;min-height:260px}
}
.vln-my-comment-box{border:1px solid var(--sh-border);border-radius:18px;background:#fff;box-shadow:var(--sh-shadow-soft);padding:1rem 1.1rem;margin-bottom:1rem}
.sh-map-sidebar .accordion-button{
  border-radius:var(--sh-radius-md)!important;
}
.sh-map-sidebar .accordion-item{
  border:1px solid var(--sh-border);
  border-radius:var(--sh-radius-md);
  overflow:hidden;
  box-shadow:none;
}
.sh-map-sidebar .accordion-button:not(.collapsed){
  background:color-mix(in srgb, var(--sh-primary) 8%, #fff 92%);
  color:var(--sh-primary);
}
.sh-map-sidebar .form-check-input:checked{
  background-color:var(--sh-primary);
  border-color:var(--sh-primary);
}

/* Utility */
.text-muted{color:var(--sh-muted)!important}
hr{border-color:var(--sh-border)}


/* Legacy helpers (kept) */
.post-content{white-space:pre-wrap}
.avatar{width:64px;height:64px;object-fit:cover;border-radius:50%}
.small-avatar{width:36px;height:36px;object-fit:cover;border-radius:50%}
.msg-attachment-img{max-width:240px;max-height:240px;object-fit:cover;border-radius:12px;display:block}
.notif-item.notif-unread{background:rgba(37,99,235,.06)}


/* Classifieds */
.sh-ad-card{border:1px solid var(--sh-border);overflow:hidden;}
.sh-ad-card:hover{box-shadow:0 12px 26px rgba(15,23,42,.10);transform:translateY(-1px);transition:all .15s ease;}
.sh-ad-card .card-body{align-items:flex-start;min-width:0;}
.sh-ad-thumb{width:92px;min-width:92px;height:92px;border-radius:14px;overflow:hidden;border:1px solid var(--sh-border);background:#fff;display:flex;align-items:center;justify-content:center;}
.sh-ad-thumb img{width:100%;height:100%;object-fit:cover;display:block;}
.sh-ad-thumb-placeholder{font-size:28px;opacity:.6}
.sh-ad-main{flex:1 1 auto;min-width:0;overflow:hidden;display:flex;flex-direction:column;align-self:stretch;}
.sh-ad-title{display:block;font-weight:700;line-height:1.25;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sh-ad-price{display:block;margin-top:auto;padding-top:.4rem;font-weight:800;font-size:1.35rem;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sh-ad-location-line,.sh-ad-country-line{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sh-ad-description{display:-webkit-box;min-width:0;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2;line-clamp:2;line-height:1.35;max-height:2.7em;word-break:break-word;overflow-wrap:anywhere;margin-top:.3rem;}

/* Classifieds categories sidebar (root only, children collapsible) */
.vln-cat-all{display:block;margin-bottom:.35rem;font-weight:900;}
.vln-cat-item{padding:.15rem 0;}
.vln-cat-link-inner{display:flex;align-items:center;gap:.65rem;min-width:0;}
.vln-cat-link-inner > span:last-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.vln-cls-cat-icon-img,.vln-cls-cat-icon-fallback{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;min-width:30px;border-radius:10px;border:1px solid #dbe4f0;background:#f8fafc;color:#94a3b8;overflow:hidden;}
.vln-cls-cat-icon-img{object-fit:contain;padding:4px;background:#fff;color:inherit;}
.vln-cls-cat-icon-fallback svg{width:18px;height:18px;display:block;}
.vln-cat-toggle{line-height:1;color:var(--sh-muted);}
.vln-cat-toggle:hover{color:var(--sh-primary);}
.vln-caret{display:inline-block;transition:transform .15s ease;}
.vln-cat-toggle.collapsed .vln-caret{transform:rotate(-90deg);}

/* Classifieds mobile */
.vln-classifieds-page .container{max-width:1180px;}
.vln-cls-mobile-top{margin-bottom:.35rem;}
.vln-cls-mobile-toolbar{position:sticky;top:72px;z-index:1050;display:flex;align-items:center;gap:.45rem;padding:.55rem .45rem .65rem;margin:-.35rem -.15rem .7rem;background:rgba(241,245,249,.96);backdrop-filter:saturate(180%) blur(12px);}
.vln-cls-searchbar{display:flex;align-items:center;flex:1 1 auto;min-width:0;background:#fff;border:1px solid var(--sh-border);border-radius:16px;overflow:hidden;box-shadow:0 8px 18px rgba(2,8,23,.06);}
.vln-cls-search-input{flex:1 1 auto;min-width:0;border:0;background:transparent;padding:.7rem .8rem;font-size:1rem;outline:none;}
.vln-cls-search-submit{flex:0 0 auto;border:0;background:transparent;color:var(--sh-primary);font-weight:800;padding:.45rem .75rem;margin-right:.15rem;}
.vln-cls-country-code{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:46px;padding:0 .55rem;border-radius:14px;background:#fff;border:1px solid var(--sh-border);font-weight:900;letter-spacing:.04em;box-shadow:0 8px 18px rgba(2,8,23,.06);}
.vln-cls-icon-btn{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid var(--sh-border);border-radius:14px;background:#fff;box-shadow:0 8px 18px rgba(2,8,23,.06);text-decoration:none;padding:0;}
.vln-cls-icon-btn img{width:24px;height:24px;object-fit:contain;display:block;}
.vln-cls-mobile-section{overflow:hidden;}
.vln-cls-mobile-section .card-body{padding:1rem;}
.vln-cls-mobile-section-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.85rem;}
.vln-cls-mobile-heading{font-size:1.7rem;font-weight:800;line-height:1.15;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.vln-cls-back-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;border:1px solid var(--sh-border);background:#fff;color:var(--sh-text);font-size:1.2rem;text-decoration:none;box-shadow:0 6px 14px rgba(2,8,23,.06);}
.vln-cls-mobile-cats-title{font-size:.85rem;font-weight:800;color:var(--sh-muted);margin-bottom:.55rem;}
.vln-cls-mobile-subcat-list{display:flex;flex-direction:column;gap:.55rem;}
.vln-cls-mobile-subcat-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.8rem .9rem;border:1px solid #dbe2ea;border-radius:14px;background:#fff;color:var(--sh-text);text-decoration:none;box-shadow:0 8px 18px rgba(15,23,42,.04);}
.vln-cls-mobile-subcat-item.is-active{border-color:#bfdbfe;background:#eff6ff;box-shadow:0 10px 20px rgba(37,99,235,.08);}
.vln-cls-mobile-subcat-label{min-width:0;font-size:.96rem;font-weight:600;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.vln-cls-mobile-subcat-arrow{flex:0 0 auto;font-size:1.15rem;line-height:1;color:#64748b;}

.vln-cls-mobile-cats-scroll{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;padding-bottom:.2rem;}
.vln-cls-mobile-cats-scroll::-webkit-scrollbar{display:none;}
.vln-cls-mobile-cats-row{display:flex;gap:.8rem;width:max-content;min-width:100%;}
.vln-cls-mobile-cat{display:flex;flex-direction:column;align-items:center;gap:.45rem;width:106px;min-width:106px;text-decoration:none;color:var(--sh-text);}
.vln-cls-mobile-cat-icon{display:flex;align-items:center;justify-content:center;width:100px;height:92px;border-radius:18px;background:#dbeafe;border:1px solid #d3e3ff;overflow:hidden;padding:.6rem;box-shadow:0 10px 22px rgba(37,99,235,.08);}
.vln-cls-mobile-cat.is-active .vln-cls-mobile-cat-icon{background:#c7dcff;border-color:#bfdbfe;box-shadow:0 12px 24px rgba(37,99,235,.14);}
.vln-cls-mobile-cat-icon .vln-cls-cat-icon-img,.vln-cls-mobile-cat-icon .vln-cls-cat-icon-fallback{width:64px;height:64px;min-width:64px;border:none;border-radius:0;background:transparent;color:#0f172a;padding:0;}
.vln-cls-mobile-cat-icon .vln-cls-cat-icon-img{object-fit:contain;}
.vln-cls-mobile-cat-icon .vln-cls-cat-icon-fallback svg{width:42px;height:42px;}
.vln-cls-mobile-cat-label{font-size:.84rem;line-height:1.2;text-align:center;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.05rem;}
@media (max-width: 991.98px){
  .vln-classifieds-page main.container{padding-top:.4rem!important;}
  .sh-ad-card .card-body{padding:.9rem;}
  .sh-ad-thumb{width:84px;min-width:84px;height:84px;border-radius:16px;}
  .sh-ad-price{font-size:1.05rem;}
}
@media (max-width: 575.98px){
  .vln-cls-mobile-toolbar{top:66px;gap:.35rem;padding:.45rem 0 .6rem;}
  .vln-cls-search-input{padding:.68rem .72rem;font-size:.97rem;}
  .vln-cls-search-submit{padding:.38rem .65rem;font-size:.92rem;}
  .vln-cls-country-code,.vln-cls-icon-btn{width:44px;height:44px;min-width:44px;}
  .vln-cls-country-code{padding:0 .35rem;}
  .vln-cls-mobile-section-head{align-items:flex-start;}
  .vln-cls-mobile-heading{font-size:1.35rem;white-space:normal;}
  .vln-cls-mobile-cat{width:96px;min-width:96px;}
  .vln-cls-mobile-cat-icon{width:92px;height:86px;border-radius:16px;}
  .vln-cls-mobile-cat-label{font-size:.8rem;}
}

/* Gallery thumb + watermark (shared) */
.vln-thumb{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--sh-border);background:#fff;}
.vln-thumb img{display:block;width:100%;height:120px;object-fit:cover;}
@media (min-width:768px){.vln-thumb img{height:140px;}}

.vln-watermark::after{
  content:'VanLifeNet.com';
  position:absolute;
  right:8px;
  bottom:8px;
  font-size:12px;
  font-weight:900;
  color:#fff;
  background:rgba(0,0,0,.35);
  padding:2px 8px;
  border-radius:999px;
  text-shadow:0 1px 2px rgba(0,0,0,.75);
  pointer-events:none;
}

.vln-modal-img-wrap{position:relative;}
.vln-modal-img{width:100%;height:auto;max-height:78vh;object-fit:contain;border-radius:16px;}

.vln-kv dt{font-weight:900;color:rgba(11,18,32,.75)}
.vln-kv dd{margin-bottom:.65rem}

/* Classifieds attributes */
.vln-attr-checks{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.25rem .75rem;}
@media (max-width:576px){.vln-attr-checks{grid-template-columns:1fr;}}

/* Pages + Footer CMS */
.vln-page-content p{margin-bottom:1rem}
.vln-page-content h2,.vln-page-content h3{margin-top:1.25rem}

.vln-footer{
  background:rgba(11,18,32,.94);
  color:rgba(255,255,255,.82);
  border-top:1px solid rgba(255,255,255,.08);
}
.vln-footer a{color:rgba(255,255,255,.84);text-decoration:none}
.vln-footer a:hover{color:#fff;text-decoration:underline}
.vln-footer-logo{height:34px;width:auto;display:block;border-radius:10px}
.vln-footer-title{font-weight:900;letter-spacing:.2px}
.vln-footer-text{font-size:.92rem;line-height:1.45;color:rgba(255,255,255,.72)}
.vln-footer-sub{font-size:.9rem;color:rgba(255,255,255,.72);margin-bottom:.35rem;font-weight:800}
.vln-footer-coltitle{font-weight:900;margin-bottom:.5rem;color:#fff}
.vln-footer-links{padding-left:1rem;margin:0}
.vln-footer-links li{margin:.25rem 0}

.vln-social{
  width:38px;height:38px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:12px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.12);
}
.vln-social:hover{background:rgba(255,255,255,.16);text-decoration:none}

.vln-appbtn{
  display:flex;align-items:center;gap:.55rem;
  padding:.6rem .75rem;
  border-radius:14px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.12);
  font-weight:800;
}
.vln-appbtn:hover{background:rgba(255,255,255,.16);text-decoration:none}

.vln-ico{width:18px;height:18px;fill:currentColor;opacity:.95}
.vln-footer-hr{border-color:rgba(255,255,255,.10)}
.vln-footer-copy{color:rgba(255,255,255,.60)}


/* Userchat (Inbox left, Chat right) */
.uc-chatlist .uc-chatitem{
  border:0;
  border-bottom:1px solid var(--sh-border);
}
.uc-chatlist .uc-chatitem:last-child{ border-bottom:0; }

.uc-leftthumb{ width:46px; flex:0 0 46px; }
.uc-thumb{
  width:44px; height:44px;
  border-radius:14px;
  object-fit:cover;
  display:block;
  border:1px solid var(--sh-border);
  background:var(--sh-border);
}
.uc-thumb-link{ display:inline-block; border-radius:14px; overflow:hidden; }
.uc-thumb-placeholder{
  width:44px; height:44px;
  border-radius:14px;
  border:1px solid var(--sh-border);
  background:color-mix(in srgb, var(--sh-border) 70%, #fff 0%);
  display:flex;
  align-items:center;
  justify-content:center;
}
.uc-thumb-placeholder span{
  font-size:12px;
  font-weight:900;
  color:var(--sh-muted);
}

.uc-name{ font-weight:900; line-height:1.1; }
.uc-title{ font-size:.86rem; line-height:1.1; }
.uc-preview{ font-size:.80rem; line-height:1.2; }

.uc-threadcard .card-body.uc-thread{
  max-height:72vh;
  overflow:auto;
  background:color-mix(in srgb, var(--sh-bg) 72%, #fff 0%);
  border-radius:16px;
}

.uc-msgrow{ display:flex; margin-bottom:10px; }
.uc-msgrow.uc-me{ justify-content:flex-end; }
.uc-msgrow.uc-other{ justify-content:flex-start; }

.uc-bubble{
  max-width:78%;
  padding:10px 12px;
  border-radius:16px;
  border:1px solid var(--sh-border);
  background:#fff;
  box-shadow:var(--sh-shadow-soft);
  word-wrap:break-word;
  overflow-wrap:anywhere;
}
.uc-me .uc-bubble{
  background:color-mix(in srgb, var(--sh-primary) 12%, #fff 0%);
}
.uc-body{ white-space:pre-wrap; }

.uc-chatitem.active .uc-name-link{ color:#fff !important; }

/* Profile view + dashboard */
.vln-profile-grid{align-items:flex-start}
.vln-sidecard .card-body{padding:1.25rem}
.vln-profile-avatar{
  width:150px;height:150px;object-fit:cover;border-radius:50%;display:block;margin:0 auto 1rem;
  border:4px solid rgba(37,99,235,.14);background:#fff;box-shadow:var(--sh-shadow-soft);
}
.vln-profile-name{font-size:2rem;font-weight:900;line-height:1.1;margin-bottom:.25rem;text-align:center}
.vln-profile-since{text-align:center;color:var(--sh-muted);font-weight:700}
.vln-action-icons{display:flex;justify-content:center;gap:1.4rem;margin:1rem 0 1.2rem;flex-wrap:wrap}
.vln-action-iconbtn{background:none;border:0;padding:0;text-align:center;color:var(--sh-text);font-size:.78rem;font-weight:800}
.vln-action-iconbtn img{width:64px;height:64px;display:block;margin:0 auto .25rem}
.vln-contact-row{display:flex;align-items:center;gap:.65rem;margin:.7rem 0;word-break:break-word}
.vln-contact-row img{width:32px;height:32px;flex:0 0 32px}
.vln-stacked-btns .btn{margin-top:.75rem}
.vln-box-title{font-size:1.05rem;font-weight:900;margin-bottom:.85rem}
.vln-social-icons{display:flex;gap:.9rem;flex-wrap:wrap}
.vln-social-icons a img{width:32px;height:32px;display:block}
.vln-profile-tabs{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem}
.vln-profile-tabs .nav-link{border:1px solid color-mix(in srgb, var(--sh-primary) 45%, var(--sh-border));color:var(--sh-text);font-weight:800;border-radius:999px;padding:.6rem 1.35rem;background:#fff}
.vln-profile-tabs .nav-link.active{background:rgba(37,99,235,.12);color:var(--sh-primary);border-color:var(--sh-primary)}
.vln-feed-card .card-body{padding:1.1rem 1.15rem}
.vln-feed-meta{color:var(--sh-muted);font-size:.92rem;font-weight:700}
.vln-feed-images{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.6rem;margin-top:.9rem}
.vln-feed-images img{width:100%;height:130px;object-fit:cover;border-radius:14px;border:1px solid var(--sh-border)}
.vln-list-item{border:1px solid var(--sh-border);border-radius:18px;background:#fff;box-shadow:var(--sh-shadow-soft);padding:1rem 1.1rem;margin-bottom:.9rem}
.vln-list-item h3{font-size:1.05rem;margin:0 0 .35rem;font-weight:900}
.vln-list-meta{font-size:.92rem;color:var(--sh-muted);font-weight:700}
.vln-dashboard-wrap{display:grid;grid-template-columns:280px minmax(0,1fr);gap:1.25rem;align-items:flex-start}
.vln-dashboard-menu .list-group-item{border:1px solid var(--sh-border);border-radius:16px!important;margin-bottom:.55rem;font-weight:800}
.vln-dashboard-menu .list-group-item.active{background:rgba(37,99,235,.10);color:var(--sh-primary);border-color:var(--sh-primary)}
.vln-dashboard-content .card-body{padding:1.15rem}
.vln-dashboard-danger{border-color:rgba(239,68,68,.22)}
.vln-readonly{background:#f8fafc}
@media (max-width: 991.98px){
  .vln-dashboard-wrap{grid-template-columns:1fr}
  .vln-profile-avatar{width:150px;height:150px}
}
@media (max-width: 575.98px){
  .vln-profile-tabs .nav-link{width:100%;text-align:center}
  .vln-feed-images{grid-template-columns:repeat(2,minmax(0,1fr))}
}


/* Dashboard mobile cards */
.vln-dash-mobile-cards{display:grid;gap:.9rem}
.vln-dash-card{
  border:1px solid var(--sh-border);
  border-radius:18px;
  background:#fff;
  box-shadow:var(--sh-shadow-soft);
  padding:1rem;
}
.vln-dash-card-head{margin-bottom:.8rem}
.vln-dash-card-title{font-weight:900;font-size:1rem;line-height:1.25}
.vln-dash-card-sub{color:var(--sh-muted);font-weight:700;font-size:.88rem;margin-top:.2rem}
.vln-dash-card-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.7rem .9rem;
}
.vln-dash-card-grid span{
  display:block;
  color:var(--sh-muted);
  font-size:.78rem;
  font-weight:800;
  margin-bottom:.12rem;
}
.vln-dash-card-grid strong{
  display:block;
  font-size:.92rem;
  line-height:1.3;
  word-break:break-word;
}
.vln-dash-card-actions{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.65rem;
  margin-top:.95rem;
}
.vln-dash-card-actions form{margin:0}
.vln-dash-card-actions .btn{width:100%}
@media (max-width: 420px){
  .vln-dash-card-grid{grid-template-columns:1fr}
  .vln-dash-card-actions{grid-template-columns:1fr}
}

/* --- Hard fix: menu icon sizes after mobile-card patch --- */
.vln-icon-nav{
  display:flex;
  align-items:center;
  gap:8px !important;
  flex-direction:row-reverse;
  min-width:0;
}
.vln-nav-icon{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:var(--vln-menu-button-size, 44px) !important;
  height:var(--vln-menu-button-size, 44px) !important;
  border-radius:12px !important;
  text-decoration:none;
  user-select:none;
  flex:0 0 auto;
}
.vln-nav-icon img{
  width:var(--vln-menu-icon-size, 22px) !important;
  height:var(--vln-menu-icon-size, 22px) !important;
  max-width:var(--vln-menu-icon-size, 22px) !important;
  max-height:var(--vln-menu-icon-size, 22px) !important;
  min-width:var(--vln-menu-icon-size, 22px) !important;
  min-height:var(--vln-menu-icon-size, 22px) !important;
  object-fit:contain !important;
  display:block;
}
.vln-menu-fallback{display:inline-flex;align-items:center;justify-content:center;width:var(--vln-menu-icon-size,22px);height:var(--vln-menu-icon-size,22px);border-radius:999px;background:rgba(37,99,235,.10);color:var(--sh-primary);font-size:calc(var(--vln-menu-icon-size,22px) * .58);font-weight:900;line-height:1;text-transform:uppercase}
.vln-badge{
  position:absolute;
  top:2px !important;
  right:2px !important;
  min-width:16px !important;
  height:16px !important;
  line-height:16px !important;
  padding:0 4px !important;
  border-radius:999px;
  font-size:9px !important;
  font-weight:900;
}
.vln-bottom-nav{
  position:fixed !important;
  left:0 !important;
  right:0 !important;
  bottom:0;
  width:auto !important;
  max-width:none;
  box-sizing:border-box;
  z-index:1095;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:2px !important;
  flex-direction:row-reverse;
  padding:6px 6px calc(6px + env(safe-area-inset-bottom)) !important;
  background:rgba(255,255,255,.98);
  border-top:1px solid var(--sh-border);
  box-shadow:0 -8px 24px rgba(15,23,42,.08);
  transform:translate3d(0,0,0);
  -webkit-transform:translate3d(0,0,0);
  -webkit-backface-visibility:hidden;
  backface-visibility:hidden;
  will-change:bottom, transform;
  isolation:isolate;
}
.vln-bottom-nav .vln-nav-icon{
  flex:1 1 0;
  min-width:0;
  width:auto !important;
  height:var(--vln-menu-button-size, 46px) !important;
  min-height:var(--vln-menu-button-size, 46px) !important;
  border-radius:12px !important;
}
.vln-bottom-nav .vln-nav-icon img{
  width:var(--vln-menu-icon-size, 18px) !important;
  height:var(--vln-menu-icon-size, 18px) !important;
  max-width:var(--vln-menu-icon-size, 18px) !important;
  max-height:var(--vln-menu-icon-size, 18px) !important;
  min-width:var(--vln-menu-icon-size, 18px) !important;
  min-height:var(--vln-menu-icon-size, 18px) !important;
}
@media (max-width: 575.98px){
  .vln-nav-icon{
    width:var(--vln-menu-button-size, 42px) !important;
    height:var(--vln-menu-button-size, 42px) !important;
  }
  .vln-nav-icon img{
    width:var(--vln-menu-icon-size, 20px) !important;
    height:var(--vln-menu-icon-size, 20px) !important;
    max-width:var(--vln-menu-icon-size, 20px) !important;
    max-height:var(--vln-menu-icon-size, 20px) !important;
    min-width:var(--vln-menu-icon-size, 20px) !important;
    min-height:var(--vln-menu-icon-size, 20px) !important;
  }
  .vln-bottom-nav .vln-nav-icon{
    height:var(--vln-menu-button-size, 44px) !important;
    min-height:var(--vln-menu-button-size, 44px) !important;
  }
  .vln-bottom-nav .vln-nav-icon img{
    width:var(--vln-menu-icon-size, 17px) !important;
    height:var(--vln-menu-icon-size, 17px) !important;
    max-width:var(--vln-menu-icon-size, 17px) !important;
    max-height:var(--vln-menu-icon-size, 17px) !important;
    min-width:var(--vln-menu-icon-size, 17px) !important;
    min-height:var(--vln-menu-icon-size, 17px) !important;
  }
}

.vln-lang-options{display:grid;gap:.75rem}
.vln-lang-option{display:flex;align-items:center;gap:.6rem;padding:.8rem .9rem;border:1px solid #dbe4f0;border-radius:14px;background:#fff;cursor:pointer}
.vln-lang-option input{margin:0}
.i18n-usertext-meta{margin-top:.45rem;font-size:.82rem;color:#64748b}
.i18n-usertext-meta a{text-decoration:none}

/* Header branding / SEO admin */
.sh-topbar{
  background:var(--vln-header-bg, rgba(255,255,255,.86)) !important;
  color:var(--vln-header-text, var(--sh-text));
  z-index:1105;
}
.sh-topbar .container, .sh-topbar .navbar-brand, .sh-topbar .nav-link{color:var(--vln-header-text, var(--sh-text)) !important;}
.vln-header-sticky{position:sticky;top:0;z-index:1105}
.vln-brand{display:flex;align-items:center;gap:.8rem;text-decoration:none;min-width:0}
.vln-site-logo{height:42px;max-width:180px;object-fit:contain;display:block;flex:0 0 auto}
.vln-site-logo-mobile{height:36px;max-width:140px}
.vln-brand-copy{display:flex;flex-direction:column;line-height:1.05;min-width:0}
.vln-brand-title{font-weight:900;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vln-brand-subtitle{font-size:.78rem;font-weight:700;opacity:.72;margin-top:.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media (min-width: 768px){.vln-site-logo-desktop{height:84px;max-width:360px}.vln-brand-title{font-size:1.15rem}.vln-brand-subtitle{font-size:.86rem}}
body.vln-has-sticky-header{scroll-padding-top:84px}
.navbar,.dropdown,.dropdown-menu{z-index:1106}
.dropdown-menu{box-shadow:var(--sh-shadow-soft);border-radius:16px}

.vln-admin-preview-logo{max-height:52px;max-width:220px;object-fit:contain;display:block}
.vln-admin-preview-favicon{width:40px;height:40px;object-fit:contain;display:block}
.vln-admin-preview-social{max-width:100%;max-height:150px;object-fit:cover;border-radius:14px;border:1px solid var(--sh-border);display:block}
.vln-admin-header-preview{border:1px solid var(--sh-border);border-radius:18px;padding:1rem;background:#f8fafc}
.vln-admin-header-preview-bar{display:flex;align-items:center;gap:.8rem;padding:.9rem 1rem;border-radius:16px;background:var(--vln-preview-bg,#fff);color:var(--vln-preview-text,#111827);border:1px solid var(--sh-border)}
.vln-admin-preview-title{font-weight:900;font-size:1.05rem;line-height:1.1}
.vln-admin-preview-subtitle{font-size:.82rem;opacity:.75;margin-top:.2rem}

.vln-google-preview{border:1px solid var(--sh-border);border-radius:18px;background:#fff;padding:1rem}
.vln-google-preview-url{color:#1a0dab;font-size:.85rem;opacity:.7;margin-bottom:.25rem}
.vln-google-preview-title{color:#1a0dab;font-size:1.2rem;line-height:1.3;margin-bottom:.2rem}
.vln-google-preview-desc{color:#4d5156;font-size:.92rem;line-height:1.45}

.vln-social-card-preview{border:1px solid var(--sh-border);border-radius:18px;overflow:hidden;background:#fff}
.vln-social-card-preview img{display:block;width:100%;height:180px;object-fit:cover;background:#e2e8f0}
.vln-social-card-copy{padding:1rem}
.vln-social-card-title{font-weight:900;margin-bottom:.35rem}
.vln-social-card-desc{color:var(--sh-muted);font-size:.92rem;line-height:1.45}
.vln-social-card-site{margin-top:.6rem;font-size:.82rem;font-weight:800;color:var(--sh-primary);text-transform:uppercase;letter-spacing:.06em}


/* Menu manager */
.vln-menu-admin-sortable{display:flex;flex-direction:column;gap:1rem}
.vln-menu-admin-card{border-radius:20px;box-shadow:0 10px 24px rgba(2,8,23,.06)}
.vln-menu-admin-card.dragging{opacity:.55}
.vln-menu-admin-card.is-legacy{border:1px dashed #93c5fd;background:#f8fbff}
.vln-menu-drag-handle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid #dbe4f0;border-radius:12px;background:#fff;font-size:22px;line-height:1;cursor:grab;user-select:none;box-shadow:0 4px 12px rgba(2,8,23,.06)}
.vln-menu-drag-handle.disabled{opacity:.45;cursor:not-allowed}
.vln-menu-admin-thumb{width:34px;height:34px;object-fit:contain;display:block}
.vln-menu-admin-thumb.small{width:28px;height:28px}
@media (max-width: 767.98px){
  .vln-menu-drag-handle{width:36px;height:36px;font-size:20px}
}

/* Cookie consent */
.vln-cookie-access{background:transparent}
.vln-cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:1080}
.vln-cookie-banner-inner{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;background:#0f172a;color:#fff;border-radius:20px;padding:1rem 1.1rem;box-shadow:0 20px 45px rgba(15,23,42,.35)}
.vln-cookie-banner-title{font-size:1rem;font-weight:900;margin-bottom:.3rem}
.vln-cookie-banner-text{max-width:820px;color:rgba(255,255,255,.82);font-size:.95rem;line-height:1.45}
.vln-cookie-banner-actions{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.vln-cookie-banner-actions form{margin:0}
.vln-cookie-option{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}
.vln-cookie-option .form-check-input{margin-top:.2rem}
.vln-cookie-preview{border:1px solid #e2e8f0;border-radius:18px;padding:1rem 1.1rem;background:#f8fafc}
.vln-cookie-preview-title{font-size:1rem;font-weight:900;margin-bottom:.4rem}
@media (max-width: 767.98px){
  .vln-cookie-banner{left:10px;right:10px;bottom:10px}
  .vln-cookie-banner-inner{padding:1rem;border-radius:18px}
  .vln-cookie-banner-actions{width:100%}
  .vln-cookie-banner-actions .btn,.vln-cookie-banner-actions form{width:100%}
  .vln-cookie-banner-actions form .btn{width:100%}
}

@media (max-width: 991.98px){
  .vln-cookie-access,
  .vln-footer{padding-bottom:calc(var(--vln-bottom-nav-space, 84px) + env(safe-area-inset-bottom));}
  .vln-cookie-banner{bottom:calc(10px + var(--vln-bottom-nav-space, 84px));}
}


/* Homepage slider */
body.vln-home-page{background:#eef2f7}
.vln-home-main{max-width:none;padding-left:0;padding-right:0;padding-top:0!important}
.vln-home-feed-wrap{position:relative;max-width:1120px;margin:0 auto;padding:0 12px 1rem;z-index:2}
.vln-home-compose-card,.vln-home-post-card{overflow:hidden}

.vln-home-hero{
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  min-height:720px;
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  position:relative;
}
.vln-home-hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.02) 0%, rgba(0,0,0,.10) 100%);
  pointer-events:none;
}
.vln-home-hero-inner{
  position:relative;
  z-index:1;
  min-height:720px;
  max-width:1331px;
  margin:0 auto;
  padding:18px 14px 14px;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.vln-home-search{
  width:min(470px, calc(100vw - 28px));
  height:48px;
  display:flex;
  align-items:center;
  gap:.55rem;
  padding:0 .85rem;
  background:rgba(255,255,255,.98);
  border:1px solid #d7e2f1;
  border-radius:16px;
  box-shadow:0 10px 26px rgba(15,23,42,.10);
}
.vln-home-search input{
  flex:1 1 auto;
  border:0;
  outline:0;
  background:transparent;
  min-width:0;
  color:#475569;
  font-size:.98rem;
}
.vln-home-search input::placeholder{color:#94a3b8;opacity:1}
.vln-home-search-icon{font-size:.9rem;line-height:1;color:#60a5fa}
.vln-home-slider-grid{
  width:min(1030px, calc(100vw - 28px));
  margin-top:24px;
  display:grid;
  grid-template-columns:minmax(0, 1fr);
  gap:14px;
}
.vln-home-tile{
  min-height:180px;
  background:rgba(255,255,255,.90);
  border:1px solid rgba(226,232,240,.95);
  border-radius:24px;
  padding:22px 18px 16px;
  box-shadow:0 16px 34px rgba(15,23,42,.14);
  display:flex;
  flex-direction:column;
}
.vln-home-tile-title{
  font-size:1.05rem;
  font-weight:900;
  line-height:1.2;
  margin-bottom:.2rem;
  color:#111827;
}
.vln-home-tile-text{
  font-size:.92rem;
  color:#4b5563;
  line-height:1.45;
  white-space:pre-line;
}
.vln-home-tile-btn{
  min-width:124px;
  padding:.34rem 1.2rem;
  margin:18px auto 0;
  line-height:1.15;
  box-shadow:none;
}
.vln-home-hero-feed-title{
  width:100%;
  margin-top:24px;
  padding-bottom:8px;
  text-align:center;
  font-size:2rem;
  font-weight:300;
  color:#fff;
  text-shadow:0 4px 14px rgba(0,0,0,.35);
}
.vln-home-compose-card .card-body,
.vln-home-post-card .card-body{padding:1rem 1.15rem}

@media (min-width: 768px){
  .vln-home-hero{min-height:760px}
  .vln-home-hero-inner{min-height:760px;padding:24px 20px 14px}
  .vln-home-search{height:50px}
  .vln-home-slider-grid{margin-top:32px;gap:18px;width:min(760px, calc(100vw - 56px))}
  .vln-home-tile{padding:24px 20px 18px}
  .vln-home-feed-wrap{padding:0 16px 1rem}
}

@media (min-width: 992px){
  .vln-home-hero{min-height:640px}
  .vln-home-hero-inner{min-height:640px;padding:28px 0 0}
  .vln-home-search{width:470px;max-width:calc(100vw - 140px)}
  .vln-home-slider-grid{
    width:1030px;
    max-width:calc(100vw - 160px);
    margin-top:56px;
    grid-template-columns:repeat(3, minmax(0, 1fr));
    gap:128px;
  }
  .vln-home-tile{min-height:205px;padding:26px 20px 18px}
  .vln-home-hero-feed-title{margin-top:auto;padding-bottom:14px;font-size:2.15rem}
  .vln-home-feed-wrap{margin:-4px auto 0;padding:0 16px}
}

/* Admin slider preview */
.vln-slider-admin-preview{
  min-height:310px;
  border-radius:22px;
  border:1px solid var(--sh-border);
  overflow:hidden;
  padding:18px 22px 20px;
  background-size:cover;
  background-position:center;
  position:relative;
  display:flex;
  flex-direction:column;
}
.vln-slider-admin-preview::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.05) 0%, rgba(15,23,42,.08) 100%);
}
.vln-slider-admin-search,
.vln-slider-admin-grid,
.vln-slider-admin-feed{position:relative;z-index:1}
.vln-slider-admin-search{
  width:min(360px, 100%);
  margin:0 auto;
  padding:.7rem .9rem;
  background:rgba(255,255,255,.96);
  border:1px solid #dbe4f0;
  border-radius:15px;
  color:#64748b;
  font-size:.95rem;
}
.vln-slider-admin-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
  margin-top:22px;
}
.vln-slider-admin-tile{
  min-height:145px;
  background:rgba(255,255,255,.90);
  border-radius:18px;
  padding:16px 14px;
  display:flex;
  flex-direction:column;
  box-shadow:0 12px 26px rgba(15,23,42,.16);
}
.vln-slider-admin-title{font-weight:900;color:#111827;line-height:1.2}
.vln-slider-admin-text{margin-top:.3rem;color:#4b5563;font-size:.9rem;line-height:1.4}
.vln-slider-admin-button{margin-top:auto;align-self:center;background:#2563eb;color:#fff;font-weight:800;border-radius:999px;padding:.3rem 1rem;line-height:1.1}
.vln-slider-admin-feed{margin-top:auto;padding-top:18px;text-align:center;color:#fff;font-size:1.45rem;font-weight:300;text-shadow:0 4px 14px rgba(0,0,0,.35)}
@media (max-width: 991.98px){
  .vln-slider-admin-grid{grid-template-columns:1fr}
}


/* Place sharing */
.vln-share-iconbtn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid var(--sh-border);border-radius:999px;background:#fff;box-shadow:var(--sh-shadow-soft);text-decoration:none;transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease}
.vln-share-iconbtn:hover{transform:translateY(-1px);border-color:color-mix(in srgb, var(--sh-primary) 35%, var(--sh-border));box-shadow:0 14px 28px rgba(2,8,23,.10)}
.vln-share-iconbtn img{display:block;width:28px;height:28px;object-fit:contain}
.vln-popup-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.vln-popup-footer-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.vln-share-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.75rem}
.vln-share-option{display:flex;align-items:center;justify-content:center;gap:.55rem;padding:.85rem 1rem;border:1px solid var(--sh-border);border-radius:16px;background:#fff;color:var(--sh-text);font-weight:800;text-decoration:none;box-shadow:var(--sh-shadow-soft)}
.vln-share-option:hover{border-color:color-mix(in srgb, var(--sh-primary) 35%, var(--sh-border));color:var(--sh-primary);text-decoration:none}
.vln-share-preview{display:flex;align-items:flex-start;gap:1rem}
.vln-share-preview-thumb{width:96px;height:96px;border-radius:20px;overflow:hidden;flex:0 0 auto;border:1px solid var(--sh-border);background:#fff}
.vln-share-preview-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.vln-share-recipient{display:flex;align-items:center;gap:.75rem;border:1px solid var(--sh-border);border-radius:16px;padding:.7rem .85rem;background:#fff}
.vln-share-note{border:1px dashed var(--sh-border);background:rgba(255,255,255,.7);border-radius:16px;padding:.85rem 1rem}
@media (max-width: 575.98px){.vln-share-preview{flex-direction:column}.vln-share-preview-thumb{width:84px;height:84px}}
