:root{
  --g:#075e54;
  --g2:#0b8f72;
  --ok:#25d366;
  --bg:#eef4f1;
  --surface:#ffffff;
  --surface-2:#f8fbf9;
  --text:#132320;
  --muted:#61706c;
  --line:#dce8e3;
  --soft:rgba(7,94,84,.08);
  --shadow:0 14px 40px rgba(17,35,32,.08);
  --shadow-lg:0 22px 60px rgba(7,94,84,.18);
  --safe-top:env(safe-area-inset-top,0px);
  --safe-right:env(safe-area-inset-right,0px);
  --safe-bottom:env(safe-area-inset-bottom,0px);
  --safe-left:env(safe-area-inset-left,0px);
  --head:92px;
  --nav:82px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%;overflow:hidden;background:var(--bg);font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;color:var(--text);-webkit-font-smoothing:antialiased}
button,input,textarea,select{font:inherit;font-size:16px}
button{border:0;cursor:pointer}
a{color:inherit}
body.admin-route{background:linear-gradient(180deg,#eef5f2,#f7fbf9)}
.app{height:100dvh;width:100vw;position:relative;overflow:hidden;background:
  radial-gradient(circle at top left,rgba(37,211,102,.11),transparent 28%),
  radial-gradient(circle at top right,rgba(11,143,114,.12),transparent 26%),
  linear-gradient(180deg,#f8fbf9,#edf4ef)}
.top{position:relative;z-index:8;height:calc(var(--head) + var(--safe-top));padding:calc(14px + var(--safe-top)) calc(16px + var(--safe-right)) 16px calc(16px + var(--safe-left));display:flex;align-items:flex-end;justify-content:space-between;background:linear-gradient(135deg,#073c37 0%, var(--g) 45%, var(--g2) 100%);color:#fff;box-shadow:0 16px 42px rgba(5,69,61,.22)}
.brand{display:flex;align-items:center;gap:12px;min-width:0}
.logoWrap{width:46px;height:46px;border-radius:16px;background:rgba(255,255,255,.16);display:grid;place-items:center;border:1px solid rgba(255,255,255,.18);box-shadow:inset 0 1px 0 rgba(255,255,255,.18)}
.logoImg{width:30px;height:30px;object-fit:contain;display:block}
.brandText{min-width:0}
.title{font-size:clamp(20px,5vw,24px);font-weight:900;letter-spacing:-.03em;line-height:1.04}
.sub{margin-top:4px;font-size:13px;font-weight:700;opacity:.95;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:min(66vw,360px)}
.iconBtn{width:40px;height:40px;border-radius:14px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);color:#fff;font-weight:900;display:grid;place-items:center;box-shadow:0 8px 18px rgba(5,69,61,.18)}
.content{position:absolute;inset:calc(var(--head) + var(--safe-top)) 0 calc(var(--nav) + var(--safe-bottom)) 0;overflow:hidden}
.screen{display:none;height:100%;overflow:auto;padding:14px 0 20px;-webkit-overflow-scrolling:touch}
.screen.active{display:block}
.bottom{position:absolute;left:0;right:0;bottom:0;z-index:9;height:calc(var(--nav) + var(--safe-bottom));padding:10px 10px var(--safe-bottom);display:grid;grid-template-columns:repeat(4,1fr);gap:8px;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border-top:1px solid rgba(220,232,227,.95);box-shadow:0 -12px 30px rgba(19,35,32,.08)}
.tab{position:relative;background:transparent;border-radius:18px;color:#6a7874;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:6px 4px;font-size:10px;font-weight:900;text-align:center}
.tab.active{color:var(--g);background:rgba(7,94,84,.055)}
.tab.active::before{content:"";position:absolute;top:-3px;width:34px;height:4px;border-radius:999px;background:linear-gradient(90deg,var(--ok),var(--g2))}
.navIcon{width:24px;height:24px;object-fit:contain;display:block;filter:saturate(.96)}
.card,.note,.limitHint,.cardLike{background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:24px;margin:0 14px 14px;box-shadow:var(--shadow)}
.card,.listCard{overflow:hidden}
.note,.limitHint,.cardLike{padding:16px}
.limitHint{display:none;background:#fff7e6;color:#7a5400;border-color:#ffdf9a}
.limitHint.show{display:block}
.sectionHero{display:flex;gap:14px;align-items:flex-start;justify-content:space-between}
.sectionHero h2{margin:3px 0 6px;font-size:24px;letter-spacing:-.03em}
.sectionHero p{margin:0;color:var(--muted);font-size:13px;line-height:1.45;max-width:780px}
.sectionKicker,.eyebrow{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:var(--soft);color:var(--g);font-size:11px;font-weight:950;letter-spacing:.02em;text-transform:uppercase}
.inlineBar,.chips{display:flex;gap:8px;align-items:center;overflow:auto;padding:0 14px 12px}
.inlineBar{justify-content:space-between;flex-wrap:wrap}
.leftActions{display:flex;gap:8px;flex-wrap:wrap}
.meta{font-size:12px;color:var(--muted)}
.chip,.miniBtn,.btn{border:1px solid #d7e5df;background:#fff;color:var(--g);padding:12px 16px;border-radius:999px;font-size:13px;font-weight:950;white-space:nowrap;box-shadow:0 5px 14px rgba(19,35,32,.05);min-height:46px}
.chip.active,.miniBtn.primary,.btn{color:#fff;border-color:transparent;background:linear-gradient(135deg,var(--g2),var(--g))}
.btn.compact{padding:11px 14px;align-self:flex-start}
.btn.full{width:100%;justify-content:center;display:inline-flex;align-items:center}
.miniBtn.light{background:rgba(255,255,255,.16);color:#fff;border-color:rgba(255,255,255,.24)}
.hideHintBubble{position:absolute;top:14px;right:58px;padding:8px 11px;border-radius:999px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.18);font-size:12px;font-weight:900;color:#fff;box-shadow:0 8px 16px rgba(0,0,0,.12)}
.search{display:flex;gap:9px;align-items:center;margin:0 14px 14px;padding:12px 14px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}
.search input{width:100%;border:0;outline:0;background:transparent}
.chatScreen.active{display:flex;flex-direction:column;overflow:hidden;padding:0}
.chatIntro{padding:14px 14px 8px;flex:0 0 auto}
.heroCard{position:relative;background:linear-gradient(150deg,#083c37 0%,var(--g) 54%,var(--g2) 100%);color:#fff;border-radius:28px;padding:18px;box-shadow:var(--shadow-lg)}
.heroText h2{margin:8px 0 8px;font-size:clamp(24px,6vw,32px);line-height:1.03;letter-spacing:-.04em}
.heroText p{margin:0;color:rgba(255,255,255,.92);font-size:13px;line-height:1.46;max-width:760px}
.privacyCallout{margin:10px 0 10px;padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.17);border:1px solid rgba(255,255,255,.24);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.privacyTitle{font-size:11px;font-weight:1000;letter-spacing:.04em;text-transform:uppercase;color:#dffaf1;margin-bottom:4px}
.privacyStrong{font-size:15px;font-weight:900;line-height:1.4;color:#fff}
.closeNotice{position:absolute;top:12px;right:12px;width:40px;height:40px;border-radius:14px;background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.18);font-weight:900;display:grid;place-items:center}
.hideIcon{font-size:20px;line-height:1;transform:translateY(-1px)}
.identityCard{margin-top:15px;padding:12px;border-radius:20px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;gap:12px}
.identityAvatar{width:68px;height:68px;border-radius:22px;background:rgba(255,255,255,.18);display:grid;place-items:center;font-size:34px;flex:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.18)}
.identityMeta{flex:1;min-width:0}
.identityName{font-size:19px;font-weight:950;line-height:1.08}
.identitySub{margin-top:4px;font-size:12px;line-height:1.35;color:rgba(255,255,255,.8)}
.renewBtn{padding:12px 16px;border-radius:16px;background:#fff;color:var(--g);font-size:13px;font-weight:950;flex:none;min-height:46px}
.noticeFab{display:none;margin:10px auto 0;padding:10px 12px;border-radius:999px;background:#fff;color:var(--g);font-size:12px;font-weight:950;box-shadow:var(--shadow)}
.noticeFab.show{display:inline-flex}
.chatIntro.collapsed{display:none}
.chatBody{flex:1;min-height:0;overflow:auto;padding:8px calc(12px + var(--safe-right)) 18px calc(12px + var(--safe-left))}
.row{display:flex;gap:10px;align-items:flex-end;margin:11px 0}
.row.mine{justify-content:flex-end}
.avatarBubble{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;flex:none;background:linear-gradient(135deg,#e6f6f2,#d7efe7);border:1px solid #d3ebe4;font-size:28px;color:var(--g)}
.avatarBubble img{width:34px;height:34px;object-fit:contain}
.bubble{max-width:min(84%,760px);background:#fff;border-radius:22px 22px 22px 10px;padding:12px 14px;border:1px solid rgba(220,232,227,.9);box-shadow:0 8px 20px rgba(19,35,32,.06)}
.mine .bubble{background:#def8e5;border-color:#c8eccf;border-radius:20px 20px 8px 20px}
.bName{font-size:11px;font-weight:950;color:var(--g2);margin-bottom:4px;display:flex;align-items:center;gap:6px}
.bText{font-size:15px;line-height:1.46;white-space:pre-wrap;word-wrap:break-word}
.bMeta{margin-top:5px;text-align:right;font-size:10px;color:var(--muted)}
.botRow .bubble{background:#fffdf6;border-color:#f0e4b7}
.messageTools{text-align:right;margin-top:10px}
.composer{position:relative;flex:0 0 auto;display:flex;gap:10px;align-items:flex-end;min-height:78px;padding:10px calc(12px + var(--safe-right)) calc(12px + var(--safe-bottom)) calc(12px + var(--safe-left));background:linear-gradient(180deg,rgba(238,244,241,0) 0%, rgba(238,244,241,.96) 32%)}
.box{flex:1;min-width:0;display:flex;align-items:flex-end;gap:12px;padding:12px 16px;background:#fff;border:1px solid var(--line);border-radius:28px;box-shadow:0 10px 24px rgba(19,35,32,.08)}
.composerLead{width:34px;height:34px;border-radius:14px;background:var(--soft);color:var(--g);display:grid;place-items:center;flex:none;font-size:18px}
.box textarea{width:100%;min-height:24px;max-height:110px;border:0;outline:0;resize:none;background:transparent;padding:4px 0}
.send{width:62px;height:62px;flex:none;border-radius:22px;background:linear-gradient(135deg,var(--ok),var(--g2));display:grid;place-items:center;box-shadow:0 14px 28px rgba(37,211,102,.24)}
.send img{width:30px;height:30px;object-fit:contain;filter:brightness(100)}
.chatInputNotice{display:none;position:absolute;left:12px;right:12px;bottom:calc(100% + 6px);padding:11px 13px;border-radius:16px;background:#fff7e6;color:#7a5400;border:1px solid #ffdf9a;box-shadow:var(--shadow);font-size:12px;z-index:12}
.chatInputNotice.show{display:block}
.item{padding:15px 16px;border-bottom:1px solid #edf3f0}
.item:last-child{border-bottom:0}
.topline{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.ttl{font-size:15px;font-weight:950;line-height:1.24}
.desc{margin-top:8px;font-size:13px;color:#334642;line-height:1.42;white-space:pre-wrap}
.tag,.status,.adminBadge,.ipbBadge{display:inline-flex;align-items:center;padding:6px 9px;border-radius:999px;font-size:11px;font-weight:950;background:#effbf8;color:#0e7763}
.tag.dark,.status.dark,.adminBadge,.ipbBadge{background:#172521;color:#fff}
.tag.warn{background:#fff5dc;color:#956400}
.tag.danger{background:#ffeded;color:#b72f2f}
.btns{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.photo{width:100%;height:180px;object-fit:cover;border-radius:16px;border:1px solid #e7edeb;margin-top:10px}
.poll{padding:15px 16px;border-bottom:1px solid #edf3f0}
.poll:last-child{border-bottom:0}
.opt{margin-top:10px;padding:12px;border:1px solid #dfe9e5;border-radius:16px;background:#fff;cursor:pointer}
.otop{display:flex;justify-content:space-between;gap:10px;font-size:13px;font-weight:900}
.barbg{margin-top:8px;height:8px;border-radius:999px;overflow:hidden;background:#e8efed}
.bar{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--ok),var(--g2))}
.empty{padding:26px;text-align:center;color:var(--muted);font-size:14px}
.overlay{position:absolute;inset:0;background:rgba(0,0,0,.28);backdrop-filter:blur(4px);display:none;z-index:18}
.overlay.active{display:block}
.sheet{position:absolute;left:0;right:0;bottom:0;z-index:19;max-height:86dvh;border-radius:26px 26px 0 0;background:#f8fbf9;box-shadow:0 -18px 44px rgba(19,35,32,.18);display:none;overflow:auto}
.sheet.active{display:block}
.shareActions{padding:14px;display:grid;gap:12px}
.shareAction{width:100%;min-height:56px;border-radius:20px;background:#fff;border:1px solid var(--line);font-size:15px;font-weight:950;color:var(--g);box-shadow:var(--shadow)}
.shareAction.primary{color:#fff;border-color:transparent;background:linear-gradient(135deg,var(--g2),var(--g))}
.grab{width:44px;height:5px;border-radius:999px;background:#d3d8d6;margin:10px auto}
.shead{position:sticky;top:0;z-index:2;display:flex;gap:10px;align-items:center;padding:12px 14px;background:#f8fbf9;border-bottom:1px solid #ecefef}
.back{width:36px;height:36px;border-radius:12px;background:#e7eceb}
.stitle{font-size:17px;font-weight:950}
.form{padding:14px}
.field{margin-bottom:13px}
.field label{display:block;margin-bottom:7px;font-size:12px;font-weight:950;color:#4f6360}
input,select,textarea.ta{width:100%;padding:13px;border-radius:16px;border:1px solid #dce8e3;background:#fff;outline:0;transition:border-color .15s, box-shadow .15s}
input:focus,select:focus,textarea.ta:focus{border-color:rgba(11,143,114,.55);box-shadow:0 0 0 4px rgba(11,143,114,.09)}
.ta{min-height:100px;resize:vertical}
.adminLoginOnly{min-height:100%;display:grid;place-items:center;padding:24px 14px}
.adminLoginCard{width:min(540px,100%);background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:30px;padding:24px;box-shadow:0 28px 80px rgba(19,35,32,.12)}
.adminBrandMark{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:var(--soft);color:var(--g);font-size:12px;font-weight:950;margin-bottom:14px}
.adminBrandMark img{width:20px;height:20px;object-fit:contain}
.adminIllustration{border-radius:22px;overflow:hidden;border:1px solid var(--line);background:#f3f8f6;margin-bottom:16px}
.adminIllustration img{display:block;width:100%;height:auto}
.adminLoginCard h1{margin:0;font-size:30px;letter-spacing:-.04em}
.adminLoginCard p{margin:8px 0 18px;font-size:13px;line-height:1.45;color:var(--muted)}
.adminEnterBtn{height:48px;border-radius:16px}
.adminRouteSmall{margin-top:12px;font-size:11px;color:var(--muted);text-align:center}
.adminShell{display:none;padding:14px;background:transparent;border:0;margin:0}
.adminTop{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding:18px;border-radius:26px;background:linear-gradient(150deg,#11201d 0%, var(--g) 58%, var(--g2) 100%);color:#fff;box-shadow:var(--shadow-lg);margin:0 0 14px}
.adminTop h2{margin:8px 0 0;font-size:25px;letter-spacing:-.03em}
.adminTop p{margin:7px 0 0;font-size:13px;line-height:1.4;color:rgba(255,255,255,.84)}
.routeHint{margin-top:9px;font-size:12px;color:rgba(255,255,255,.78)}
.adminSessionBox{display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.adminSessionPill{padding:8px 10px;border-radius:999px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);font-size:12px;font-weight:950;white-space:nowrap}
.adminTabs{display:flex;gap:8px;overflow:auto;padding:0 0 12px}
.adminTab{padding:10px 13px;border-radius:999px;background:#fff;border:1px solid #dce8e3;color:#51625e;font-size:12px;font-weight:950;white-space:nowrap}
.adminTab.active{background:#172521;border-color:#172521;color:#fff}
.adminBody{padding-bottom:20px}
.adminStats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.adminStat,.adminCard{background:#fff;border:1px solid var(--line);border-radius:24px;padding:14px;box-shadow:var(--shadow);margin-bottom:12px}
.adminStat .num{font-size:28px;font-weight:950;color:var(--g)}
.adminStat .label{font-size:12px;color:var(--muted);font-weight:900}
.adminCard h3{margin:0 0 10px;font-size:16px}
.logLine,.condoRow{padding:11px 0;border-bottom:1px solid #edf3f0;font-size:13px;line-height:1.35}
.logLine:last-child,.condoRow:last-child{border-bottom:0}
.condoTools{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.wide{grid-column:1/-1}
.pillRow{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.adminPill{padding:6px 9px;border-radius:999px;background:#effbf8;color:#0d725f;font-size:11px;font-weight:950}
.moderationGrid{display:grid;grid-template-columns:1fr;gap:12px}
.modActions{margin-top:8px;display:flex;gap:8px;align-items:center}
.modActions select{max-width:190px;padding:9px 11px;border-radius:14px;font-size:13px}
body.admin-route .bottom, body.admin-route .top .iconBtn{display:none!important}
body.admin-route .content{bottom:0!important}
body.admin-route #chat, body.admin-route #reportes, body.admin-route #comunicados, body.admin-route #encuestas{display:none!important}
body.admin-route.admin-logged #adminLoginOnly{display:none}
body.admin-route.admin-logged #adminShell{display:block}
body:not(.admin-route) #admin{display:none!important}
#fab,.fab{display:none!important}
@media (min-width:720px){
  .card,.note,.limitHint,.cardLike,.search,.inlineBar,.chips{margin-left:24px;margin-right:24px}
  .chatIntro{padding-left:24px;padding-right:24px}
  .chatBody,.composer{padding-left:24px;padding-right:24px}
  .bubble{max-width:min(72%,820px)}
  .adminShell{padding:24px}
  .adminStats{grid-template-columns:repeat(4,1fr)}
  .condoTools{grid-template-columns:repeat(4,1fr)}
}
@media (min-width:960px){
  .moderationGrid{grid-template-columns:1fr 1fr}
  .sectionHero{align-items:center}
}
@media (max-width:560px){
  .sectionHero{flex-direction:column;align-items:stretch}
  .btn.compact{width:100%;justify-content:center;display:inline-flex}
  .identityCard{flex-wrap:wrap}
  .renewBtn{width:100%}
  .adminTop{flex-direction:column}
  .adminSessionBox{align-items:flex-start;flex-direction:row}
  .condoTools,.adminStats{grid-template-columns:1fr}
}
@media (max-width:420px){
  .composer{padding-left:10px;padding-right:10px}
  .chatBody{padding-left:10px;padding-right:10px}
  .send{width:58px;height:58px}
  .logoWrap{width:42px;height:42px}
  .logoImg{width:28px;height:28px}
  .hideHintBubble{right:56px;padding:7px 10px}
}

.topActions{display:flex;gap:8px;align-items:center}
.reportGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;padding:14px}
.reportCard{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow);cursor:pointer;transition:transform .18s ease, box-shadow .18s ease}
.reportCard:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(19,35,32,.09)}
.reportThumb{width:100%;height:180px;object-fit:cover;background:#eef4f1;display:block}
.reportBody{padding:14px}
.reportTitle{font-size:15px;font-weight:950;line-height:1.25;margin-bottom:8px}
.reportSnippet{font-size:13px;color:#445652;line-height:1.38;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.reportMetaRow{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-top:12px}
.detailModal{position:absolute;inset:0;display:none;z-index:24;background:rgba(11,23,20,.32);backdrop-filter:blur(6px);padding:20px;align-items:center;justify-content:center}
.detailModal.active{display:flex}
.detailCard{position:relative;width:min(760px,100%);max-height:min(86dvh,860px);overflow:auto;background:#fff;border-radius:30px;border:1px solid var(--line);box-shadow:0 28px 70px rgba(19,35,32,.18);padding:22px}
.detailClose{position:absolute;top:14px;right:14px;width:42px;height:42px;border-radius:14px;background:#f1f5f3;color:var(--g);font-size:26px}
.detailHero{width:100%;max-height:360px;object-fit:contain;border-radius:22px;background:#f5faf8;border:1px solid var(--line);margin:10px 0 16px}
.detailHeader{padding-right:54px}
.detailTitle{font-size:24px;font-weight:950;line-height:1.18;margin:0 0 8px}
.detailText{font-size:15px;line-height:1.52;color:#30423e;white-space:pre-wrap}
.detailFacts{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin:14px 0 18px}
.detailFact{padding:12px;border-radius:16px;background:#f8fbf9;border:1px solid var(--line)}
.detailFact b{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:#5c6f6a;margin-bottom:4px}
.menuActions,.galleryWrap{padding:14px}
.galleryGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.galleryPhotoCard{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}
.galleryPhotoCard img{width:100%;height:150px;object-fit:cover;display:block}
.galleryPhotoCard .cap{padding:10px 12px;font-size:12px;font-weight:900;color:#34504a}
.memberPill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.2);font-size:12px;font-weight:900;color:#fff;margin-top:8px}
.docsGrid{display:grid;grid-template-columns:1.2fr .8fr;gap:12px}
.docRow{padding:12px 0;border-bottom:1px solid #edf3f0;font-size:13px;line-height:1.4}
.docRow:last-child{border-bottom:0}
.docActions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
@media (max-width:760px){.docsGrid{grid-template-columns:1fr}.detailCard{padding:18px}.reportGrid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;padding:12px}.reportThumb{height:150px}}

/* UI Fix v8 */
:root{
  --accent-a:#6ae0c4;
  --accent-b:#7bc8ff;
  --accent-c:#ffd76e;
  --accent-d:#ff9dc7;
}
.top{background:linear-gradient(135deg,#08443e 0%, var(--g) 32%, var(--g2) 62%, #31b7a0 100%)}
.sectionKicker,.eyebrow{background:linear-gradient(135deg,rgba(106,224,196,.22),rgba(123,200,255,.18));border:1px solid rgba(7,94,84,.08)}
.chip{background:linear-gradient(180deg,#fff,#f7fbfa)}
.chip.active,.miniBtn.primary,.btn{background:linear-gradient(135deg,#0d8d74 0%,#14a68a 42%,#2cbf78 100%)}
.hideHintBubble{right:60px;padding:8px 13px;background:linear-gradient(135deg,#fff3b3,#ffffff);color:#5b4700;border-color:rgba(255,219,104,.65);box-shadow:0 10px 20px rgba(63,49,0,.16);transform:rotate(-8deg);animation:floatHide 2.8s ease-in-out infinite}
.closeNotice{background:transparent;border-color:transparent;box-shadow:none;width:34px;height:34px;top:18px;right:12px;opacity:.95}
.hideIcon{font-size:18px;line-height:1;display:inline-block;transform:rotate(28deg)}
@keyframes floatHide{0%,100%{transform:translateY(0) rotate(-8deg)}50%{transform:translateY(-4px) rotate(-11deg)}}
.privacyCallout{background:linear-gradient(135deg,rgba(255,255,255,.2),rgba(255,246,197,.24));border:1px solid rgba(255,255,255,.28)}
.privacyStrong{font-size:15px;font-weight:1000;text-shadow:0 1px 0 rgba(0,0,0,.08)}
.identityCard{background:linear-gradient(135deg,rgba(255,255,255,.16),rgba(200,255,244,.1));}
.identityAvatar{width:74px;height:74px;font-size:38px;background:linear-gradient(135deg,rgba(255,255,255,.2),rgba(255,255,255,.1));}
.avatarBubble{width:58px;height:58px;border-radius:20px;font-size:31px;background:linear-gradient(135deg,#fff8d7,#dff7ef);}
.row:nth-child(4n+1) .avatarBubble{background:linear-gradient(135deg,#fff5bf,#ffe2b0)}
.row:nth-child(4n+2) .avatarBubble{background:linear-gradient(135deg,#dff8f1,#d9edff)}
.row:nth-child(4n+3) .avatarBubble{background:linear-gradient(135deg,#f5e5ff,#e7f0ff)}
.row:nth-child(4n+4) .avatarBubble{background:linear-gradient(135deg,#ffe7ef,#fff4cc)}
.reportCard:nth-child(4n+1){background:linear-gradient(180deg,#ffffff 0%,#f7fffb 100%)}
.reportCard:nth-child(4n+2){background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%)}
.reportCard:nth-child(4n+3){background:linear-gradient(180deg,#ffffff 0%,#fffaf2 100%)}
.reportCard:nth-child(4n+4){background:linear-gradient(180deg,#ffffff 0%,#fff7fb 100%)}
.reportTitle{font-size:16px}
.poll{padding:16px;border:1px solid var(--line);border-radius:24px;background:#fff;margin:0 14px 14px;box-shadow:var(--shadow)}
.pollColor1{background:linear-gradient(180deg,#ffffff,#f7fffb)}
.pollColor2{background:linear-gradient(180deg,#ffffff,#f7fbff)}
.pollColor3{background:linear-gradient(180deg,#ffffff,#fffaf2)}
.pollColor4{background:linear-gradient(180deg,#ffffff,#fff7fb)}
.pollHead{display:flex;gap:10px;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.pollMetaTop{display:flex;flex-direction:column;gap:6px;align-items:flex-end;min-width:120px}
.pollBadge,.pollCounter,.myVoteTag{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:11px;font-weight:950}
.pollBadge.open{background:#eef8f4;color:#0d725f}
.pollBadge.done{background:#eaf2ff;color:#305da8}
.pollCounter{background:#fff;border:1px solid #dfe9e5;color:#53635e}
.opt{transition:transform .14s ease, box-shadow .14s ease, border-color .14s ease}
.opt:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(19,35,32,.05)}
.opt.mine{border-color:#87d2b8;background:linear-gradient(180deg,#f4fffb,#ecfff6);box-shadow:inset 0 0 0 1px rgba(13,141,116,.08)}
.opt.locked{cursor:default}
.pollSubMeta{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-top:8px;font-size:12px;color:#52625e;font-weight:800}
.myVoteTag{background:linear-gradient(135deg,#d5f8e8,#f4fffb);color:#0a7d64;border:1px solid #bfead6}
.bar{height:100%;border-radius:999px}
.bar1{background:linear-gradient(90deg,#25d366,#0b8f72)}
.bar2{background:linear-gradient(90deg,#6cc7ff,#4f83ff)}
.bar3{background:linear-gradient(90deg,#ffd76e,#ff9f43)}
.bar4{background:linear-gradient(90deg,#ff9dc7,#d16bff)}
.menuActions .shareAction:nth-child(1){background:linear-gradient(135deg,#fff,#ecfffb)}
.menuActions .shareAction:nth-child(2){background:linear-gradient(135deg,#fff,#f3f8ff)}
.galleryPhotoCard{background:linear-gradient(180deg,#fff,#f8fbfa)}
@media (max-width:560px){.poll{margin-left:12px;margin-right:12px}.pollHead{flex-direction:column}.pollMetaTop{align-items:flex-start;min-width:0;flex-direction:row;flex-wrap:wrap}.hideHintBubble{top:18px;right:46px;font-size:11px;padding:7px 11px}}

/* UI Fix v9 */
.app{background:
  radial-gradient(circle at 9% 9%,rgba(255,215,110,.20),transparent 26%),
  radial-gradient(circle at 92% 10%,rgba(123,200,255,.23),transparent 25%),
  radial-gradient(circle at 18% 92%,rgba(255,157,199,.16),transparent 26%),
  linear-gradient(180deg,#f8fcfb,#eef7f2 58%,#f7fbff)}
.top{background:linear-gradient(125deg,#073c37 0%,#075e54 28%,#0b8f72 55%,#25b68e 74%,#63c6ff 120%)}
.iconBtn{width:44px;height:44px;border-radius:16px;background:rgba(255,255,255,.18)}
.bottom{background:rgba(255,255,255,.9);border-top:1px solid rgba(214,232,225,.9)}
.tab.active{background:linear-gradient(135deg,rgba(37,211,102,.12),rgba(123,200,255,.12));}
.tab:nth-child(2).active{background:linear-gradient(135deg,rgba(123,200,255,.14),rgba(255,215,110,.12))}
.tab:nth-child(3).active{background:linear-gradient(135deg,rgba(255,157,199,.14),rgba(255,215,110,.12))}
.tab:nth-child(4).active{background:linear-gradient(135deg,rgba(209,107,255,.12),rgba(123,200,255,.12))}
.noticeFab{margin:10px 14px 0;padding:12px 16px;border-radius:24px;background:linear-gradient(135deg,#ffffff,#f0fff9);color:#075e54;border:1px solid rgba(11,143,114,.12);box-shadow:0 16px 34px rgba(7,94,84,.12);align-items:center;gap:10px;animation:bubblePop .32s ease-out, floatBubble 3.4s ease-in-out infinite}
.noticeFab .bubbleIcon{display:grid;place-items:center;width:34px;height:34px;border-radius:14px;background:linear-gradient(135deg,#25d366,#63c6ff);color:#fff}
.noticeFab b{font-size:14px}.noticeFab small{font-size:12px;color:#55706b;font-weight:800}
@keyframes bubblePop{0%{transform:scale(.86) translateY(8px);opacity:0}100%{transform:scale(1) translateY(0);opacity:1}}
@keyframes floatBubble{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.hideHintBubble{right:58px;top:12px;display:flex;flex-direction:column;gap:1px;align-items:center;padding:7px 12px 8px;border-radius:18px;background:linear-gradient(135deg,#fff7c8,#fff,#e7fff8);color:#5c4b00;border:1px solid rgba(255,219,104,.7);box-shadow:0 10px 24px rgba(77,58,0,.17);transform:rotate(-7deg);animation:floatHideV9 2.5s ease-in-out infinite;pointer-events:none}
.hideHintBubble span{font-size:12px;font-weight:1000}.hideHintBubble small{font-size:9.5px;font-weight:900;color:#80670a;white-space:nowrap}
.closeNotice{width:38px;height:38px;top:16px;right:12px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.18);border-radius:15px;box-shadow:0 8px 18px rgba(0,0,0,.12)}
.hideIcon{font-size:20px;line-height:1;transform:none;font-weight:1000}
@keyframes floatHideV9{0%,100%{transform:translateY(0) rotate(-7deg)}50%{transform:translateY(-5px) rotate(-10deg)}}
.heroCard{background:linear-gradient(145deg,#073c37 0%,#075e54 38%,#0b8f72 68%,#2fbf98 100%);box-shadow:0 22px 60px rgba(7,94,84,.22)}
.privacyCallout{background:linear-gradient(135deg,rgba(255,255,255,.22),rgba(255,242,180,.22),rgba(123,200,255,.12));border-color:rgba(255,255,255,.3)}
.learnAnonBtn{margin-top:12px;min-height:44px;padding:11px 14px;border-radius:16px;background:linear-gradient(135deg,#fff,#fff8ce);color:#075e54;font-size:13px;font-weight:1000;box-shadow:0 10px 18px rgba(0,0,0,.11)}
.identityAvatar{background:linear-gradient(135deg,rgba(255,255,255,.26),rgba(255,255,255,.10),rgba(255,215,110,.18))}
.composer{gap:12px;padding-bottom:calc(14px + var(--safe-bottom))}
.box{border-radius:30px;border-color:rgba(11,143,114,.15);background:linear-gradient(180deg,#fff,#fbfffd);}
.box textarea::placeholder{color:#61756f;opacity:.9;font-size:14px;line-height:1.35}
.send{width:64px;height:64px;border-radius:24px;background:linear-gradient(135deg,#25d366 0%,#0b8f72 52%,#4ca3ff 135%);box-shadow:0 15px 30px rgba(37,211,102,.24), inset 0 1px 0 rgba(255,255,255,.24);display:grid;place-items:center;color:#fff;transform:translateY(-1px)}
.sendIcon{font-size:30px;line-height:1;display:block;transform:translateX(2px);text-shadow:0 2px 6px rgba(0,0,0,.18)}
.send:active{transform:translateY(1px) scale(.98)}
.cardLike:nth-of-type(odd),.adminCard:nth-of-type(odd){background:linear-gradient(180deg,#fff,#f8fffb)}
.cardLike:nth-of-type(even),.adminCard:nth-of-type(even){background:linear-gradient(180deg,#fff,#f7fbff)}
.anonInfoHero{display:block;background:linear-gradient(135deg,#073c37,#0b8f72 54%,#63c6ff 145%);color:#fff;border:0;box-shadow:0 22px 60px rgba(7,94,84,.2)}
.anonInfoHero .miniBtn{margin-bottom:14px;background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.2)}
.anonInfoHero .sectionKicker{background:rgba(255,255,255,.16);color:#fff;border-color:rgba(255,255,255,.18)}
.anonInfoHero h2{margin:12px 0 8px;font-size:clamp(28px,7vw,44px);letter-spacing:-.05em;line-height:.98}
.anonInfoHero p{color:rgba(255,255,255,.88);font-size:15px;line-height:1.48;max-width:760px}
.anonInfoGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;padding:0 14px 18px}
.anonInfoCard{min-height:156px;border-radius:26px;padding:18px;border:1px solid rgba(255,255,255,.65);box-shadow:0 14px 34px rgba(19,35,32,.08);display:flex;flex-direction:column;gap:8px}
.anonInfoCard b{font-size:18px;letter-spacing:-.02em}.anonInfoCard span{font-size:14px;color:#40534f;line-height:1.45;font-weight:700}
.anonInfoCard.colorA{background:linear-gradient(135deg,#ecfff7,#ffffff)}
.anonInfoCard.colorB{background:linear-gradient(135deg,#eef7ff,#ffffff)}
.anonInfoCard.colorC{background:linear-gradient(135deg,#fff8d8,#ffffff)}
.anonInfoCard.colorD{background:linear-gradient(135deg,#ffeef7,#ffffff)}
.anonInfoCard.colorE{background:linear-gradient(135deg,#f1e9ff,#ffffff)}
.anonInfoCard.colorF{background:linear-gradient(135deg,#edfff2,#fff6df)}
.shareSheet .stitle{color:#075e54}.shareAction.primary{background:linear-gradient(135deg,#25d366,#0b8f72 58%,#4ca3ff)}
@media (max-width:560px){.send{width:60px;height:60px;border-radius:22px}.sendIcon{font-size:28px}.hideHintBubble{right:54px;top:14px}.anonInfoGrid{grid-template-columns:1fr;padding:0 12px 18px}}

/* UI Fix v10 */
.app{background:
  radial-gradient(circle at 8% 8%,rgba(255,170,64,.18),transparent 27%),
  radial-gradient(circle at 88% 9%,rgba(83,156,255,.18),transparent 24%),
  radial-gradient(circle at 92% 88%,rgba(214,107,255,.13),transparent 25%),
  radial-gradient(circle at 10% 92%,rgba(37,211,102,.13),transparent 25%),
  linear-gradient(180deg,#f7fcfb 0%,#eef8f3 48%,#f8fbff 100%)}
.adminViewBadge{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:8px 10px;border-radius:999px;background:#d71920;color:#fff;font-size:11px;font-weight:1000;letter-spacing:.04em;box-shadow:0 8px 18px rgba(215,25,32,.22)}
body.admin-viewing-site .top{background:linear-gradient(125deg,#8b0000 0%,#d71920 34%,#075e54 72%,#0b8f72 100%)}
body.admin-viewing-site::before{content:'Viendo y usando el sitio como ADMIN';position:absolute;z-index:30;left:50%;top:calc(var(--safe-top) + 8px);transform:translateX(-50%);padding:7px 13px;border-radius:999px;background:#d71920;color:#fff;font-size:11px;font-weight:1000;box-shadow:0 10px 22px rgba(215,25,32,.26);pointer-events:none}
.hideHintBubble{right:54px;top:12px;transform:rotate(-6deg);animation:floatHideV10 2.7s ease-in-out infinite;background:linear-gradient(135deg,#fff2a7,#ffffff 55%,#dffaf3);color:#4b3b00;border:1px solid rgba(255,215,110,.75)}
.closeNotice{width:34px;height:34px;top:16px;right:14px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.20);border-radius:13px;box-shadow:0 8px 18px rgba(0,0,0,.10)}
.hideIcon{font-size:22px;line-height:1;transform:none;display:block;font-weight:900}
@keyframes floatHideV10{0%,100%{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-5px) rotate(-9deg)}}
.renewBtn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#fff,#f3fff9);min-width:156px}
.renewIcon{font-size:18px;font-weight:1000;display:inline-block}
.messageLead{display:flex;flex-direction:column;align-items:center;gap:6px;align-self:flex-start;margin-top:2px;flex:none}
.shareFloating{width:34px;height:34px;border-radius:13px;background:linear-gradient(135deg,#fff,#ecfff9);border:1px solid #d7e9e2;color:#075e54;font-size:17px;font-weight:1000;box-shadow:0 8px 16px rgba(19,35,32,.08)}
.row.mine .messageLead{order:2}.row.mine .bubble{order:1}.row.mine .shareFloating{background:linear-gradient(135deg,#eafff1,#ffffff)}
.messageTools{display:none!important}
.send{width:58px;height:58px;border-radius:21px;background:linear-gradient(135deg,#25d366 0%,#0b8f72 58%,#49a7ff 135%);box-shadow:0 14px 28px rgba(37,211,102,.22);transform:none}
.sendIcon{font-size:27px;line-height:1;display:grid;place-items:center;transform:translateX(1px);text-shadow:none}
.send:active{transform:scale(.97)}
.inputStack{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}
.inputTicker{height:18px;overflow:hidden;color:#60756f;font-size:12px;font-weight:800;line-height:18px;white-space:nowrap;text-overflow:ellipsis}
.inputTicker span{display:block}
.inputTicker .flipIn{animation:pageFlip .42s ease-out}
@keyframes pageFlip{0%{transform:rotateX(85deg) translateY(4px);opacity:0}100%{transform:rotateX(0) translateY(0);opacity:1}}
.composerLead{align-self:flex-start;margin-top:2px}
.calendarStrip{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;padding:0 14px 12px}
.calendarDay{min-height:112px;border-radius:22px;background:linear-gradient(135deg,#ffffff,#f3fffa);border:1px solid #dcebe5;box-shadow:var(--shadow);padding:12px;display:flex;flex-direction:column;gap:6px}
.calendarDay b{font-size:13px;color:#075e54}.calendarDay span{font-size:12px;line-height:1.25;color:#344944;font-weight:800;background:rgba(7,94,84,.06);border-radius:10px;padding:5px 7px}
.pollOptionList{display:grid;gap:9px;margin-bottom:10px}
.pollOptionRow{display:grid;grid-template-columns:34px 1fr 36px;gap:8px;align-items:center;background:#fff;border:1px solid #dce8e3;border-radius:18px;padding:8px;box-shadow:0 6px 16px rgba(19,35,32,.05)}
.pollOptionRow.dragging{opacity:.55;transform:scale(.99)}
.dragHandle{display:grid;place-items:center;height:36px;border-radius:12px;background:linear-gradient(135deg,#eef8f4,#f7fbff);color:#075e54;font-weight:1000;cursor:grab}.dragHandle:active{cursor:grabbing}
.pollOptionInput{border:0!important;padding:8px!important;box-shadow:none!important;background:transparent!important}
.removeOptionBtn{height:36px;width:36px;border-radius:12px;background:#fff1f1;color:#bb2020;font-weight:1000;font-size:20px}
.addOptionBtn{margin-top:2px}
.shareSheet .shareAction{min-height:62px;font-size:16px;border-radius:22px}.shareSheet .shareAction.primary{background:linear-gradient(135deg,#0b8f72,#25d366 70%,#63c6ff)}
@media(max-width:560px){body.admin-viewing-site::before{top:calc(var(--safe-top) + 4px);font-size:10px;padding:6px 10px}.messageLead{gap:5px}.shareFloating{width:32px;height:32px}.avatarBubble{width:54px;height:54px}.send{width:56px;height:56px}.renewBtn{width:100%;min-width:0}.calendarStrip{grid-template-columns:1fr 1fr;padding:0 12px 12px}.pollOptionRow{grid-template-columns:32px 1fr 34px}}
