:root{
  --bg: #edf4ff;
  --bg-soft: #f7faff;
  --surface: rgba(255, 255, 255, 0.96);
  --surface-2: rgba(242, 247, 255, 0.96);
  --surface-3: rgba(228, 238, 252, 0.98);
  --border: rgba(123, 154, 198, 0.18);

  --text: #182235;
  --text-soft: #5d6f8a;
  --text-muted: #8392ab;

  --primary: #1877f2;
  --secondary: #5e8bff;
  --accent: #ff6b93;
  --info: #56c2ff;

  --success: #22C55E;
  --warning: #F59E0B;
  --danger: #EF4444;

  --brand-gradient: linear-gradient(135deg, #1877f2 0%, #56c2ff 48%, #ff6b93 100%);
  --brand-gradient-soft: linear-gradient(135deg, rgba(24, 119, 242, 0.12) 0%, rgba(86, 194, 255, 0.12) 48%, rgba(255, 107, 147, 0.14) 100%);
  --shadow-soft: 0 18px 48px rgba(60, 91, 138, 0.12);
  --shadow-strong: 0 28px 80px rgba(60, 91, 138, 0.18);
  --glow-primary: 0 0 0 4px rgba(24, 119, 242, 0.12);
  --glow-secondary: 0 0 0 4px rgba(86, 194, 255, 0.12);

  /* Troque esta imagem pelo seu fundo principal */
  --app-background-image: url("../img/background-evento.jpg");
}

body{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.78), rgba(237,244,255,0.94)),
    radial-gradient(circle at top left, rgba(24,119,242,0.14), transparent 28%),
    radial-gradient(circle at top right, rgba(86,194,255,0.10), transparent 22%),
    radial-gradient(circle at bottom center, rgba(255,107,147,0.12), transparent 28%),
    var(--app-background-image) center/cover no-repeat fixed,
    #edf4ff;
  background-attachment: fixed, fixed, fixed, fixed, fixed, fixed;
}

body::before{
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 20% 10%, rgba(255, 244, 210, 0.05), transparent 18%),
    radial-gradient(circle at 80% 0%, rgba(212, 175, 55, 0.07), transparent 18%),
    radial-gradient(circle at 50% 100%, rgba(212, 175, 55, 0.05), transparent 26%);
  opacity: 1;
  z-index: -1;
}

.feed-topbar-banner,
.admin-header,
.countdown-premium,
.auth-card-brand,
.gallery-hero{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01)),
    radial-gradient(circle at top right, rgba(255,231,168,0.1), transparent 24%),
    radial-gradient(circle at left center, rgba(94,139,255,0.08), transparent 20%),
    rgba(34, 24, 40, 0.9);
}

.feed-topbar-banner{
  position: fixed;
  inset: 0 0 auto 0;
  width: 100%;
  border: 0;
  border-bottom: 1px solid rgba(255, 228, 240, 0.12);
  box-shadow: 0 10px 24px rgba(20, 11, 19, 0.22);
  overflow: hidden;
  border-radius: 0;
  transform: translateZ(0);
  will-change: transform;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01)),
    radial-gradient(circle at right top, rgba(255,231,168,0.08), transparent 24%),
    rgba(29, 22, 34, 0.94);
  backdrop-filter: blur(18px);
  z-index: 80;
}

.feed-topbar-inner{
  width: min(100%, var(--container));
  margin: 0 auto;
  min-height: 68px;
  padding: max(8px, env(safe-area-inset-top)) 14px 8px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  background: transparent;
}

.feed-appbar-brand{
  min-width: 0;
  display: grid;
  gap: 2px;
}

.feed-appbar-title{
  display: block;
  color: #FFF8FC;
  font-family: "Segoe Script", "Snell Roundhand", "Brush Script MT", "Georgia", serif;
  font-size: clamp(1.15rem, 5vw, 1.7rem);
  font-weight: 400;
  line-height: 1.02;
  letter-spacing: 0.01em;
  white-space: normal;
  overflow: visible;
}

.feed-appbar-subtitle{
  display: block;
  color: #EEDFEA;
  font-size: 0.76rem;
  line-height: 1.22;
  white-space: normal;
  overflow: visible;
}

.feed-topbar-actions{
  gap: 10px;
  align-items: center;
}

.feed-stage{
  margin-top: 18px;
  padding-top: 30px;
}

.feed-gallery-lock{
  margin: 10px 0 16px;
  padding: 18px 20px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02)), rgba(54, 39, 52, 0.9);
  border: 1px solid rgba(255, 228, 240, 0.14);
  box-shadow: 0 18px 34px rgba(30, 13, 27, 0.2);
  display: grid;
  gap: 10px;
}

.feed-gallery-lock strong{
  color: #FFF8FC;
  font-size: 1.02rem;
}

.feed-gallery-lock p{
  color: #F6D8E8;
  line-height: 1.6;
}

.feed-promo-card{
  margin: 10px 0 14px;
  padding: 16px 18px;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02)), rgba(72, 36, 64, 0.86);
  border: 1px solid rgba(255, 214, 227, 0.14);
  box-shadow: 0 18px 34px rgba(30, 13, 27, 0.2);
}

.install-banner{
  background:
    radial-gradient(circle at top right, rgba(255,214,126,0.12), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)),
    rgba(62, 33, 52, 0.9);
}

.gallery-filter-chip{
  box-shadow: 0 12px 28px rgba(10, 12, 20, 0.18), inset 0 1px 0 rgba(255,255,255,0.08);
}

.notification-permission-card{
  background:
    radial-gradient(circle at top right, rgba(255,214,126,0.12), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)),
    rgba(62, 33, 52, 0.9);
  border-color: rgba(255, 214, 126, 0.16);
  box-shadow: 0 18px 34px rgba(29, 13, 26, 0.2);
}

.feed-promo-text{
  color: #FFF4FB;
  font-size: 1rem;
  line-height: 1.62;
  text-align: center;
}

.feed-section-head{
  margin: 0 0 16px;
  display: grid;
  gap: 4px;
  justify-items: center;
  text-align: center;
}

.feed-section-head strong{
  color: #FFF8FC;
  font-size: 0.92rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.feed-section-head span{
  color: #FFD67E;
  font-size: 1.3rem;
  line-height: 1;
}

.feed-footer-bar{
  position: fixed;
  left: 50%;
  bottom: max(10px, env(safe-area-inset-bottom));
  transform: translateX(-50%);
  z-index: 85;
  width: min(calc(100% - 20px), 520px);
  min-height: 62px;
  padding: 8px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  border-radius: 24px;
  background: rgba(27, 22, 32, 0.92);
  border: 1px solid rgba(255, 228, 240, 0.14);
  backdrop-filter: blur(18px);
  box-shadow: 0 20px 44px rgba(18, 9, 18, 0.26);
}

.feed-footer-link{
  min-height: 46px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.04);
  color: #FFF8FC;
  border: 1px solid rgba(255,255,255,0.04);
  font-weight: 700;
}

.feed-footer-link.is-active{
  background: linear-gradient(135deg, rgba(255,255,255,0.12), rgba(255,255,255,0.04));
}

.feed-footer-action{
  appearance: none;
  cursor: pointer;
}
.feed-footer-action.is-submit-mode{
  background: linear-gradient(135deg, #19995C 0%, #2BD67B 100%);
  color: #ffffff;
  border-color: rgba(43,214,123,0.26);
  box-shadow: 0 14px 30px rgba(43,214,123,0.22);
}
.feed-footer-action.is-submit-mode span{
  color: #ffffff;
}

/* 2026 visual refresh */
:root{
  --bg: #f4f8ff;
  --bg-soft: #edf4ff;
  --surface: rgba(255, 255, 255, 0.94);
  --surface-2: rgba(247, 250, 255, 0.98);
  --surface-3: rgba(235, 242, 252, 0.98);
  --border: rgba(112, 144, 190, 0.18);
  --text: #18263f;
  --text-soft: #5c6d88;
  --text-muted: #8191a8;
  --primary: #2e78ff;
  --secondary: #45b6ff;
  --accent: #ff6fa3;
  --info: #4dbdff;
  --success: #26bf72;
  --warning: #f5a623;
  --danger: #ef5757;
  --brand-gradient: linear-gradient(135deg, #2e78ff 0%, #43b5ff 52%, #ff7aa8 100%);
  --brand-gradient-soft: linear-gradient(135deg, rgba(46, 120, 255, 0.12) 0%, rgba(67, 181, 255, 0.14) 52%, rgba(255, 122, 168, 0.14) 100%);
  --shadow-soft: 0 18px 45px rgba(80, 112, 162, 0.12);
  --shadow-strong: 0 28px 80px rgba(80, 112, 162, 0.18);
}

body{
  background:
    radial-gradient(circle at top left, rgba(46, 120, 255, 0.18), transparent 24%),
    radial-gradient(circle at top right, rgba(67, 181, 255, 0.12), transparent 24%),
    radial-gradient(circle at bottom left, rgba(255, 122, 168, 0.14), transparent 26%),
    linear-gradient(180deg, rgba(255,255,255,0.82), rgba(244,248,255,0.95)),
    var(--app-background-image) center/cover no-repeat fixed,
    #f4f8ff;
  color: var(--text);
}

body::before{
  background:
    radial-gradient(circle at 15% 8%, rgba(255,255,255,0.78), transparent 20%),
    radial-gradient(circle at 85% 0%, rgba(255,255,255,0.58), transparent 20%),
    radial-gradient(circle at 50% 100%, rgba(255,255,255,0.4), transparent 24%);
}

.feed-topbar-banner,
.admin-header,
.countdown-premium,
.auth-card-brand,
.gallery-hero{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,251,255,0.92)),
    radial-gradient(circle at top right, rgba(67,181,255,0.18), transparent 30%),
    radial-gradient(circle at top left, rgba(255,122,168,0.12), transparent 24%);
  border-color: rgba(115, 145, 188, 0.16);
  box-shadow: 0 20px 48px rgba(88, 116, 160, 0.14);
}

.feed-topbar-banner{
  border-bottom: 1px solid rgba(112, 144, 190, 0.14);
  box-shadow: 0 14px 34px rgba(84, 111, 156, 0.14);
  backdrop-filter: blur(16px);
}

.feed-topbar-inner{
  min-height: 82px;
  padding: max(10px, env(safe-area-inset-top)) 16px 10px;
}

.feed-appbar-brand{
  gap: 6px;
}

.feed-appbar-title{
  color: #22304b;
  font-family: "Georgia", "Times New Roman", serif;
  font-size: clamp(1.25rem, 4.6vw, 1.95rem);
  font-weight: 700;
  line-height: 1.08;
}

.feed-appbar-subtitle{
  color: #5b6f89;
  font-size: 0.84rem;
  line-height: 1.38;
}

.feed-topbar-actions{
  display: inline-flex;
  gap: 10px;
}

.btn,
.btn-topbar,
.feed-footer-link,
.gallery-filter-chip{
  border-radius: 18px;
  border: 1px solid rgba(117, 146, 186, 0.14);
  box-shadow: 0 10px 24px rgba(94, 123, 170, 0.1);
}

.btn{
  background: rgba(255,255,255,0.88);
  color: #22324d;
  font-weight: 700;
}

.btn:hover,
.btn:focus-visible,
.feed-footer-link:hover,
.feed-footer-link:focus-visible{
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(94, 123, 170, 0.14);
}

.btn-primary,
.btn-glow,
.btn-auth-main,
.btn-auth-create,
.btn-publish,
.feed-create-trigger,
.feed-footer-action.is-submit-mode{
  background: var(--brand-gradient);
  color: #fff;
  border-color: rgba(46, 120, 255, 0.18);
  box-shadow: 0 16px 34px rgba(67, 136, 231, 0.24);
}

.btn-secondary,
.btn-topbar,
.btn-mini.btn-share,
.feed-footer-link{
  background: rgba(255,255,255,0.86);
  color: #2b4f91;
}

.btn-comment{
  background: linear-gradient(135deg, #26bf72 0%, #4bdc92 100%);
  color: #fff;
  border-color: rgba(38, 191, 114, 0.18);
}

.btn-share{
  background: linear-gradient(135deg, #2f80ff 0%, #53bcff 100%);
  color: #fff;
  border-color: rgba(46, 120, 255, 0.16);
}

.btn-danger,
.media-modal-close,
.notification-panel-close{
  background: linear-gradient(135deg, #ff7171 0%, #ef5757 100%);
  color: #fff;
  border-color: rgba(239, 87, 87, 0.18);
}

.auth-shell,
.countdown-shell{
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap: 24px;
  width: min(1120px, 100%);
  margin: 0 auto;
  align-items: stretch;
}

.auth-story,
.auth-card,
.countdown-card,
.feed-stage,
.feed-promo-card,
.composer-card,
.gallery-story-card,
.notification-panel,
.notification-permission-card,
.table-wrap,
.stat-card{
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,251,255,0.94));
  border: 1px solid rgba(112, 144, 190, 0.16);
  box-shadow: var(--shadow-soft);
}

.auth-story,
.auth-card,
.countdown-card{
  padding: 28px;
}

.auth-story h1,
.countdown-story h1{
  font-family: "Georgia", "Times New Roman", serif;
  color: #22304b;
  font-weight: 700;
}

.auth-story-lead,
.lead,
.auth-story-card p,
.feed-promo-text,
.gallery-story-text,
.notification-empty p{
  color: var(--text-soft);
}

.auth-story-card,
.auth-highlight,
.field input,
.field textarea,
.field select,
.comment-form input,
.composer-textarea,
.checkbox{
  background: rgba(245, 249, 255, 0.96);
  border-color: rgba(112, 144, 190, 0.14);
}

.field input,
.field textarea,
.field select,
.comment-form input,
.composer-textarea{
  color: var(--text);
}

.feed-shell{
  width: min(100%, 720px);
  margin: 0 auto;
  padding: 112px 16px 120px;
}

.feed-create-trigger{
  min-height: 60px;
  border-radius: 22px;
}

.composer-card{
  padding: 20px;
  border-radius: 24px;
}

.composer-titlebar{
  color: #2b5db5;
  background: rgba(46, 120, 255, 0.08);
  border: 1px solid rgba(46, 120, 255, 0.08);
}

.upload-chip{
  background: rgba(246, 249, 255, 0.96);
  color: #34507a;
  border: 1px solid rgba(112, 144, 190, 0.14);
}

.upload-chip-photo{
  box-shadow: inset 0 0 0 1px rgba(46, 120, 255, 0.08);
}

.upload-chip-video{
  box-shadow: inset 0 0 0 1px rgba(255, 122, 168, 0.08);
}

.feed-promo-card{
  padding: 16px 18px;
  border-radius: 22px;
}

.feed-section-head strong{
  color: #3a5f9c;
}

.feed-section-head span{
  color: var(--accent);
}

.post-card,
.post-card-premium{
  background: linear-gradient(180deg, rgba(255,255,255,0.97), rgba(247,250,255,0.95));
  border: 1px solid rgba(112, 144, 190, 0.15);
  box-shadow: 0 16px 40px rgba(89, 118, 166, 0.12);
}

.post-card-verified{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(248,250,255,0.96)),
    linear-gradient(135deg, rgba(46,120,255,0.08), rgba(255,122,168,0.06));
  border-color: rgba(67, 136, 231, 0.18);
}

.post-author-meta strong,
.gallery-story-head strong,
.notification-item strong{
  color: #21304d;
}

.post-author-meta span,
.gallery-story-head span,
.notification-item span{
  color: #6e7f96;
}

.verified-badge{
  background: linear-gradient(135deg, #2e78ff 0%, #4cc0ff 100%);
  color: #fff;
  border: 0;
}

.post-text,
.comment-body p{
  color: #314563;
}

.media-frame,
.gallery-story-media{
  background: #eff5ff;
  border: 1px solid rgba(112, 144, 190, 0.12);
}

.reaction-row{
  background: rgba(243, 248, 255, 0.92);
  border: 1px solid rgba(112, 144, 190, 0.1);
}

.reaction-btn{
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(112, 144, 190, 0.12);
}

.reaction-btn.is-active,
.reaction-btn:hover{
  background: rgba(46, 120, 255, 0.08);
  border-color: rgba(46, 120, 255, 0.18);
}

.comments-block{
  background: rgba(247, 250, 255, 0.82);
  border: 1px solid rgba(112, 144, 190, 0.1);
  border-radius: 20px;
  padding: 12px;
}

.comments-list{
  max-height: 176px;
}

.comment-item{
  background: rgba(255,255,255,0.86);
}

.floating-badge{
  background: var(--brand-gradient);
  color: #fff;
  box-shadow: 0 18px 36px rgba(67, 136, 231, 0.26);
}

.notification-panel{
  color: var(--text);
}

.notification-panel-head strong,
.notification-permission-copy strong{
  color: #22304b;
}

.notification-permission-backdrop,
.media-modal-backdrop{
  background: rgba(77, 98, 135, 0.28);
  backdrop-filter: blur(6px);
}

.notification-permission-card,
.media-modal-dialog{
  border-radius: 26px;
  border: 1px solid rgba(112, 144, 190, 0.16);
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,250,255,0.96));
  box-shadow: var(--shadow-strong);
}

.media-modal-close{
  border-radius: 999px;
}

.feed-footer-bar{
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(112, 144, 190, 0.14);
  box-shadow: 0 20px 46px rgba(86, 115, 160, 0.16);
}

.feed-footer-link{
  color: #35538f;
}

.feed-footer-link.is-active{
  background: rgba(46, 120, 255, 0.08);
  color: #1f4f9f;
}

.gallery-page{
  padding-top: 16px;
  padding-bottom: 96px;
}

.gallery-filter-bar{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.gallery-filter-chip.is-active{
  background: var(--brand-gradient);
  color: #fff;
  border-color: transparent;
}

.gallery-grid-rich{
  gap: 18px;
}

.gallery-story-card{
  padding: 16px;
  border-radius: 22px;
}

.gallery-hero-pills{
  margin-top: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.gallery-story-card{
  display: grid;
  gap: 14px;
}

.gallery-story-head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.gallery-story-head span{
  font-size: 0.85rem;
  color: var(--text-soft);
}

.gallery-story-text{
  line-height: 1.7;
  color: var(--text-soft);
}

.gallery-download{
  margin-top: 10px;
}

.hero-card,
.legal-card{
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(247,250,255,0.94));
}

.legal-page .auth-card{
  width: min(760px, 100%);
}

.legal-intro-card,
.legal-highlight{
  padding: 18px 20px;
  border-radius: 20px;
  background: rgba(246, 250, 255, 0.92);
  border: 1px solid rgba(112, 144, 190, 0.12);
}

.legal-list{
  display: grid;
  gap: 12px;
}

.legal-item{
  display: grid;
  grid-template-columns: 14px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(250, 252, 255, 0.95);
  border: 1px solid rgba(112, 144, 190, 0.1);
}

.legal-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  margin-top: 8px;
  background: var(--brand-gradient);
  box-shadow: 0 6px 18px rgba(67, 136, 231, 0.24);
}

.legal-actions{
  display: flex;
  justify-content: flex-start;
}

.admin-login-page .auth-story-card,
.admin-login-page .auth-card{
  min-height: 100%;
}

.admin-screen .stats-grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.admin-screen .stat-card{
  padding: 22px 20px;
  text-align: left;
}

.admin-screen .stat-card strong{
  display: block;
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  color: #21304d;
}

.admin-screen .stat-card span{
  color: var(--text-soft);
}

.admin-shell{
  background:
    radial-gradient(circle at top left, rgba(46, 120, 255, 0.12), transparent 22%),
    linear-gradient(180deg, #f7faff 0%, #eef4ff 100%);
}

.admin-header,
.stat-card,
.table-wrap{
  color: var(--text);
}

@media (max-width: 900px){
  .auth-shell,
  .countdown-shell{
    grid-template-columns: 1fr;
  }

  .feed-topbar-inner{
    grid-template-columns: minmax(0, 1fr) auto;
  }
}

@media (max-width: 640px){
  .feed-shell{
    padding-inline: 12px;
    padding-top: 106px;
  }

  .feed-topbar-inner{
    min-height: 76px;
    padding-inline: 12px;
  }

  .feed-appbar-title{
    font-size: clamp(1.1rem, 6vw, 1.55rem);
  }

  .feed-topbar-actions{
    gap: 8px;
  }

  .auth-story,
  .auth-card,
  .countdown-card,
  .composer-card{
    padding: 20px;
  }
}

.gallery-hero-rich{
  padding: 24px;
}

.gallery-grid-story{
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.gallery-story-card{
  padding: 14px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01)), rgba(58, 28, 52, 0.9);
  border: 1px solid rgba(255, 228, 240, 0.14);
  box-shadow: 0 18px 34px rgba(29, 13, 26, 0.22);
  display: grid;
  gap: 12px;
}

.gallery-story-head{
  display: grid;
  gap: 4px;
}

.gallery-story-head strong{
  color: #FFF8FC;
  font-size: 1rem;
}

.gallery-story-head span{
  color: #EEDFEA;
  font-size: 0.78rem;
}

.gallery-story-media{
  display: grid;
  gap: 10px;
}

.gallery-story-media img,
.gallery-story-media video{
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 18px;
}

.gallery-story-text{
  color: #FFF4FB;
  line-height: 1.68;
}

.gallery-download{
  justify-self: start;
}

.feed-stage-copy{
  margin-top: 6px;
  margin-bottom: 24px;
  padding: 16px 18px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(242,155,195,0.1), rgba(255,255,255,0.03));
  border: 1px solid rgba(255,214,227,0.14);
  color: var(--accent);
  animation: themeFadeInOut 9s ease-in-out infinite;
}

.btn-primary,
.floating-badge,
.composer-titlebar,
.toast-info{
  background: var(--brand-gradient);
  color: #ffffff;
}

.btn-secondary,
.btn-mini,
.upload-chip,
.reaction-btn,
.btn-topbar{
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.018)), rgba(31,33,45,0.82);
  border-color: rgba(255, 228, 240, 0.14);
}

.btn-primary{
  border: 1px solid rgba(255, 241, 214, 0.24);
  border-radius: 22px;
  box-shadow: 0 18px 40px rgba(201, 119, 176, 0.24), inset 0 1px 0 rgba(255,255,255,0.18);
}

.btn-primary:hover,
.btn-primary:focus-visible{
  box-shadow: 0 22px 46px rgba(201, 119, 176, 0.3), inset 0 1px 0 rgba(255,255,255,0.22);
}

.btn-secondary,
.btn-mini,
.btn-topbar{
  border-radius: 20px;
  box-shadow: 0 12px 28px rgba(10, 12, 20, 0.18), inset 0 1px 0 rgba(255,255,255,0.08);
}

.btn-icon{
  border-radius: 20px;
}

.feed-create-trigger{
  border-radius: 24px;
}

.btn-create-post,
.btn-create-icon{
  background: linear-gradient(135deg, #1D9D61 0%, #2FD27E 52%, #7BE6AF 100%);
  color: #ffffff;
  border-color: rgba(123, 230, 175, 0.22);
  box-shadow: 0 18px 38px rgba(47, 210, 126, 0.24), inset 0 1px 0 rgba(255,255,255,0.18);
}

.btn-create-post:hover,
.btn-create-post:focus-visible,
.btn-create-icon:hover,
.btn-create-icon:focus-visible{
  box-shadow: 0 22px 44px rgba(47, 210, 126, 0.3), inset 0 1px 0 rgba(255,255,255,0.2);
}

.feed-create-trigger.is-open{
  background: linear-gradient(135deg, #D93636 0%, #F16A6A 100%);
  border-color: rgba(255, 171, 171, 0.22);
  box-shadow: 0 20px 40px rgba(217, 54, 54, 0.24), inset 0 1px 0 rgba(255,255,255,0.18);
}

.btn-share-event,
.btn-share{
  background: linear-gradient(135deg, #2E73E8 0%, #5CA4FF 100%);
  color: #ffffff;
  border-color: rgba(92, 164, 255, 0.24);
}

.btn-notification{
  background: linear-gradient(135deg, rgba(255,255,255,0.1), rgba(255,214,126,0.12));
  color: #fff8ea;
  border-color: rgba(255, 214, 126, 0.2);
  box-shadow: 0 16px 34px rgba(255, 214, 126, 0.12), inset 0 1px 0 rgba(255,255,255,0.12);
}
.btn-notification.is-open{
  background: linear-gradient(135deg, rgba(255,214,126,0.2), rgba(242,155,195,0.16));
}

.btn-share-event,
.btn-create-icon{
  min-height: 50px;
}

.btn-create-icon{
  width: 50px;
  min-width: 50px;
  padding: 0;
}

.btn-auth-enter{
  background: linear-gradient(135deg, #C98919 0%, #F2B84B 54%, #FFE29A 100%);
  color: #25180E;
  border-color: rgba(255, 226, 154, 0.28);
  box-shadow: 0 18px 38px rgba(242, 184, 75, 0.24), inset 0 1px 0 rgba(255,255,255,0.26);
}

.btn-auth-create{
  background: linear-gradient(135deg, #D84D6A 0%, #F47F94 52%, #FFD3DB 100%);
  color: #ffffff;
  border-color: rgba(255, 211, 219, 0.26);
  box-shadow: 0 18px 38px rgba(244, 127, 148, 0.22), inset 0 1px 0 rgba(255,255,255,0.2);
}

.btn-notification-enable{
  background: linear-gradient(135deg, #C98919 0%, #F2B84B 54%, #FFE29A 100%);
  color: #25180E;
  border-color: rgba(255, 226, 154, 0.28);
  box-shadow: 0 18px 38px rgba(242, 184, 75, 0.24), inset 0 1px 0 rgba(255,255,255,0.26);
}

.feed-create-trigger,
.btn-icon{
  backdrop-filter: blur(16px);
}

.hero-card,
.auth-card,
.countdown-card,
.composer-card,
.post-card,
.event-card,
.stat-card,
.gallery-item,
.table-wrap,
.feed-stage,
.feed-intro-card,
.legal-card,
.admin-form{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.028), rgba(255,255,255,0.012)),
    rgba(58, 28, 52, 0.84);
  border-color: rgba(255, 214, 227, 0.16);
}

.post-card{
  box-shadow: 0 16px 40px rgba(60, 91, 138, 0.12);
}

.post-card-verified{
  box-shadow: 0 20px 46px rgba(60, 91, 138, 0.16), 0 0 0 1px rgba(24, 119, 242, 0.08), 0 0 18px rgba(86, 194, 255, 0.08);
}

.post-card,
.composer-card,
.gallery-item,
.table-wrap,
.auth-card,
.countdown-card,
.legal-card{
  animation: themeFadeUp 440ms ease both;
}

.feed-tip,
.form-message.is-status{
  background: linear-gradient(180deg, rgba(242,155,195,0.14), rgba(255,231,168,0.05));
  border-color: rgba(255,214,227,0.18);
  color: var(--accent);
}

.feed-top-hint{
  background: linear-gradient(180deg, rgba(34, 164, 116, 0.22), rgba(92, 164, 255, 0.12));
  border-color: rgba(123, 230, 175, 0.2);
  color: #F8FFF8;
  box-shadow: 0 14px 28px rgba(17, 71, 55, 0.16);
}

.field input,
.field textarea,
.field select,
.comment-form input,
.composer-textarea{
  background: rgba(247, 250, 255, 0.92);
  border-color: rgba(123, 154, 198, 0.18);
}

.field input:focus,
.field textarea:focus,
.field select:focus,
.comment-form input:focus,
.composer-textarea:focus{
  border-color: rgba(242, 155, 195, 0.48);
  box-shadow: var(--glow-primary);
}

.feed-topbar-copy h1,
.brand-lockup strong,
.countdown-premium h1,
.auth-card h1{
  font-family: "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  font-weight: 800;
  letter-spacing: 0.01em;
}

.countdown-premium,
.auth-card-brand{
  overflow: hidden;
}
.auth-story{
  background:
    radial-gradient(circle at top right, rgba(255, 214, 126, 0.12), transparent 36%),
    radial-gradient(circle at bottom left, rgba(244, 127, 148, 0.12), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.015)),
    rgba(41, 21, 36, 0.88);
}
.register-stepper-fill{
  background: linear-gradient(135deg, #C98919 0%, #F2B84B 45%, #F47F94 100%);
  box-shadow: 0 10px 22px rgba(244, 127, 148, 0.28);
}
.auth-story-card{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.022)),
    rgba(64, 34, 55, 0.82);
}

.countdown-premium h1,
.auth-card h1{
  line-height: 1.08;
  font-size: clamp(2.1rem, 7vw, 4rem);
}

.countdown-premium .lead,
.auth-card-brand .notice,
.auth-card-brand small{
  color: #FFE7F1;
}

.auth-highlight{
  background:
    radial-gradient(circle at top right, rgba(255,214,126,0.12), transparent 38%),
    linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.025)),
    rgba(66, 31, 55, 0.82);
  border-color: rgba(255, 214, 227, 0.18);
  box-shadow: 0 18px 34px rgba(30, 13, 27, 0.16);
}

.auth-linkline{
  text-align: center;
  color: #FFE7F1;
}

.countdown-grid{
  margin-top: 34px;
}

.countdown-box{
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));
  border-color: rgba(255, 214, 227, 0.16);
  box-shadow: 0 18px 34px rgba(51, 17, 41, 0.28);
}

.countdown-separator{
  color: #FFE19F;
  text-shadow: 0 0 18px rgba(255, 214, 126, 0.24);
}

.composer-titlebar{
  letter-spacing: 0.18em;
}

.post-author-meta strong{
  color: #FFF8EA;
}

.countdown-premium .eyebrow,
.brand-badge,
.eyebrow{
  background: rgba(255, 231, 168, 0.12);
  color: #FFEAAF;
  border-color: rgba(255, 231, 168, 0.2);
}

.comment-form{
  align-items: center;
}

.comment-form input{
  min-height: 38px;
  padding-block: 10px;
  font-size: 0.92rem;
}

.btn-comment{
  background: linear-gradient(135deg, #19995C 0%, #2BD67B 100%);
  color: #ffffff;
  border-color: rgba(43,214,123,0.26);
  box-shadow: 0 14px 30px rgba(43,214,123,0.22);
}

.btn-share{
  background: linear-gradient(135deg, #3B82F6 0%, #60A5FA 100%);
  color: #ffffff;
  border-color: rgba(96,165,250,0.22);
  box-shadow: 0 14px 30px rgba(96,165,250,0.22);
}

.danger,
.btn.danger{
  background: linear-gradient(135deg, #D93636 0%, #F16A6A 100%);
  color: #ffffff;
  border-color: rgba(241,106,106,0.24);
  box-shadow: 0 14px 30px rgba(217,54,54,0.18);
}

.warning,
.btn.warning{
  background: linear-gradient(135deg, #D18D12 0%, #F4C354 100%);
  color: #24140A;
  border-color: rgba(244,195,84,0.24);
  box-shadow: 0 14px 30px rgba(209,141,18,0.2);
}

.media-frame,
.preview-media{
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.24);
}

.media-modal-dialog{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.015)),
    rgba(28, 22, 33, 0.98);
  border-color: rgba(255, 228, 240, 0.12);
}

.media-modal-loading{
  min-height: min(70vh, 420px);
  width: 100%;
  display: grid;
  place-items: center;
  gap: 14px;
  color: var(--accent);
  text-align: center;
  padding: 20px;
}

.media-modal-loading span{
  font-size: 0.98rem;
  color: var(--text-soft);
}

.media-modal-meta{
  color: #fff4dd;
}

.floating-badge{
  animation: themeBadgeFloat 2.8s ease-in-out infinite;
}

.reaction-btn.is-active{
  background: linear-gradient(135deg, rgba(255, 231, 168, 0.18), rgba(242, 155, 195, 0.18));
}

.admin-screen{
  padding-bottom: 32px;
}

.admin-live-banner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  padding: 18px 20px;
  border-radius: 22px;
  border: 1px solid rgba(255,214,126,0.2);
  background:
    radial-gradient(circle at top left, rgba(255,214,126,0.18), transparent 48%),
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)),
    rgba(27, 18, 28, 0.84);
  box-shadow: 0 18px 42px rgba(16, 8, 17, 0.24);
}

.admin-live-banner strong{
  display: block;
  color: #fff5da;
}

.admin-live-banner span{
  color: var(--text-soft);
  flex: 1 1 280px;
}

.admin-person{
  display: flex;
  align-items: flex-start;
  gap: 12px;
  min-width: 240px;
}

.admin-person-meta{
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.admin-person-meta strong{
  color: var(--text);
}

.admin-inline-input{
  min-height: 42px;
  padding: 10px 12px;
  font-size: 0.95rem;
}

.admin-post-preview{
  display: grid;
  gap: 10px;
  min-width: 220px;
}

.admin-post-preview p{
  margin: 0;
  color: var(--text-soft);
  line-height: 1.55;
}

.admin-post-thumb{
  width: 88px;
  height: 88px;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.08);
}

.status-pill{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
  color: var(--text);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.status-pill.is-success{
  background: rgba(34,197,94,0.14);
  border-color: rgba(34,197,94,0.22);
  color: #b7f7cb;
}

.status-pill.is-warning{
  background: rgba(245,158,11,0.14);
  border-color: rgba(245,158,11,0.22);
  color: #ffe0a8;
}

.status-pill.is-danger{
  background: rgba(239,68,68,0.14);
  border-color: rgba(239,68,68,0.2);
  color: #fecaca;
}

.text-muted{
  color: var(--text-muted);
}

@keyframes themeFadeUp{
  from{ opacity: 0; transform: translateY(16px); }
  to{ opacity: 1; transform: translateY(0); }
}

@keyframes themeFadeInOut{
  0%,100%{ opacity: 0.86; transform: translateY(0); }
  50%{ opacity: 1; transform: translateY(-2px); }
}

@keyframes themeBadgeFloat{
  0%,100%{ transform: translateY(0); box-shadow: 0 18px 40px rgba(242, 155, 195, 0.24); }
  50%{ transform: translateY(-2px); box-shadow: 0 24px 46px rgba(255, 231, 168, 0.26); }
}

@media (max-width: 720px){
  body{
    background-position: center top, center top, center top, center bottom, center top, center top;
    background-size: auto, auto, auto, auto, cover, auto;
  }
  .feed-topbar-inner{
    min-height: 62px;
    padding-inline: 10px;
    gap: 8px;
  }
  .feed-topbar-actions{
    width: auto;
    justify-content: flex-end;
    flex-wrap: nowrap;
  }
  .btn-topbar,
  .btn-icon{
    min-height: 42px;
  }
  .btn-share-event,
  .btn-create-icon{
    min-width: 0;
  }
  .feed-appbar-title{
    font-size: 1.28rem;
  }
  .feed-appbar-subtitle{
    font-size: 0.74rem;
  }
  .feed-promo-card{
    padding: 14px 16px;
  }
  .feed-promo-text{
    font-size: 0.95rem;
  }
  .btn-secondary,
  .btn-primary,
  .btn-mini{
    padding-inline: 14px;
    max-width: 100%;
  }
  .comment-form{
    gap: 8px;
  }
  .comment-form input{
    min-height: 40px;
  }
  .media-modal-loading{
    min-height: 100%;
    padding: 12px;
  }
  .feed-footer-bar{
    width: calc(100% - 16px);
    bottom: max(8px, env(safe-area-inset-bottom));
  }
  .gallery-grid-story{
    grid-template-columns: 1fr;
  }

  .gallery-story-head{
    align-items: flex-start;
    flex-direction: column;
  }

  .admin-screen .stats-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-live-banner{
    align-items: flex-start;
  }
  .admin-live-banner .btn-mini{
    width: 100%;
  }
  .admin-person,
  .admin-post-preview{
    min-width: 0;
  }
}

@media (max-width: 900px){
  .feed-topbar-inner{
    grid-template-columns: minmax(0, 1fr) auto;
  }
  .feed-topbar-actions{
    justify-content: flex-end;
  }

  .admin-screen .stats-grid{
    grid-template-columns: 1fr;
  }
}

/* Microacabamento final */
.app-shell,
.admin-shell{
  color: #17324f;
}

.feed-topbar-banner{
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.feed-topbar-inner,
.feed-stage,
.composer-card,
.feed-promo-card,
.gallery-hero-card,
.gallery-grid-story .gallery-card,
.auth-card,
.auth-story,
.countdown-card,
.legal-card,
.admin-card,
.table-wrap{
  box-shadow:
    0 18px 40px rgba(28, 71, 120, 0.08),
    0 2px 10px rgba(28, 71, 120, 0.04);
}

.feed-appbar-title,
.auth-kicker,
.countdown-kicker{
  text-wrap: balance;
}

.feed-appbar-subtitle,
.auth-lead,
.countdown-copy,
.gallery-hero-copy,
.legal-intro-card p{
  text-wrap: pretty;
}

.btn,
.upload-chip,
.feed-footer-link,
.notification-item,
.gallery-filter{
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    background-color 180ms ease,
    border-color 180ms ease,
    color 180ms ease;
}

.btn:active,
.upload-chip:active,
.feed-footer-link:active,
.notification-item:active,
.gallery-filter:active{
  transform: scale(0.985);
}

.btn-primary{
  box-shadow:
    0 14px 28px rgba(38, 111, 255, 0.18),
    inset 0 1px 0 rgba(255,255,255,0.46);
}

.btn-secondary,
.btn-topbar,
.btn-mini,
.gallery-filter{
  box-shadow:
    0 10px 22px rgba(36, 74, 114, 0.08),
    inset 0 1px 0 rgba(255,255,255,0.68);
}

.composer-titlebar{
  letter-spacing: 0.12em;
}

.composer-textarea{
  line-height: 1.65;
}

.upload-preview-rich,
.media-frame,
.gallery-card-media{
  overflow: hidden;
}

.media-frame img,
.gallery-card-media img{
  transform: scale(1.001);
}

.post-card{
  overflow: hidden;
}

.post-head{
  margin-bottom: 14px;
}

.post-author strong,
.comment-body strong,
.admin-person-meta strong{
  letter-spacing: -0.01em;
}

.comments-block{
  background: linear-gradient(180deg, rgba(244,249,255,0.92), rgba(234,244,255,0.86));
}

.comments-list{
  scrollbar-width: thin;
  scrollbar-color: rgba(83,129,209,0.44) rgba(213,228,248,0.52);
}

.comments-list::-webkit-scrollbar{
  width: 6px;
}

.comments-list::-webkit-scrollbar-thumb{
  background: rgba(83,129,209,0.42);
  border-radius: 999px;
}

.notification-panel,
.notification-permission-card,
.media-modal-dialog{
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
}

.notification-panel{
  border-color: rgba(133, 175, 232, 0.34);
}

.notification-item{
  border-radius: 18px;
}

.toast{
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.feed-footer-bar{
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.gallery-grid-rich{
  align-items: start;
}

.gallery-card-message p,
.gallery-story-text{
  line-height: 1.7;
}

.legal-item{
  background: linear-gradient(180deg, rgba(255,255,255,0.9), rgba(244,249,255,0.82));
}

.admin-live-banner{
  border-color: rgba(93, 139, 220, 0.22);
  background:
    radial-gradient(circle at top left, rgba(104, 184, 255, 0.16), transparent 45%),
    linear-gradient(180deg, rgba(255,255,255,0.9), rgba(241,247,255,0.82));
  box-shadow:
    0 16px 34px rgba(31, 78, 134, 0.12),
    inset 0 1px 0 rgba(255,255,255,0.6);
}

.admin-live-banner strong{
  color: #19406e;
}

.admin-live-banner span{
  color: #496787;
}

@media (max-width: 720px){
  .feed-promo-card,
  .feed-section-head,
  .feed-tip,
  .notification-panel,
  .composer-card,
  .gallery-hero-card,
  .legal-card,
  .admin-card{
    border-radius: 20px;
  }

  .feed-topbar-banner{
    border-radius: 0 0 24px 24px;
  }

  .feed-appbar-title{
    line-height: 1.12;
  }

  .feed-appbar-subtitle{
    line-height: 1.35;
  }
}

/* Identidade visual completa */
:root{
  --bg: #f7f3eb;
  --bg-soft: #fdfaf4;
  --surface: rgba(255,255,255,0.96);
  --surface-2: rgba(247, 244, 238, 0.96);
  --surface-3: rgba(240, 233, 221, 0.96);
  --border: rgba(31, 63, 96, 0.10);

  --text: #17324f;
  --text-soft: #58708d;
  --text-muted: #8494a6;

  --primary: #2f6fed;
  --secondary: #d6b98c;
  --accent: #ff7a59;
  --info: #5fa8ff;

  --success: #21b66f;
  --warning: #f1a53a;
  --danger: #eb5b5b;

  --brand-gradient: linear-gradient(135deg, #2f6fed 0%, #5fa8ff 48%, #ff7a59 100%);
  --brand-gradient-soft: linear-gradient(135deg, rgba(47,111,237,0.14) 0%, rgba(95,168,255,0.10) 52%, rgba(255,122,89,0.14) 100%);
  --shadow-soft: 0 18px 48px rgba(23, 50, 79, 0.08);
  --shadow-strong: 0 26px 70px rgba(23, 50, 79, 0.12);
  --glow-primary: 0 0 0 4px rgba(47, 111, 237, 0.12);
  --glow-secondary: 0 0 0 4px rgba(255, 122, 89, 0.12);
}

body{
  font-family: "Inter", "Segoe UI", Arial, sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(47,111,237,0.10), transparent 26%),
    radial-gradient(circle at top right, rgba(255,122,89,0.08), transparent 24%),
    radial-gradient(circle at bottom center, rgba(214,185,140,0.10), transparent 22%),
    linear-gradient(180deg, rgba(255,250,243,0.95), rgba(247,243,235,0.98)),
    var(--app-background-image) center/cover no-repeat fixed,
    #f7f3eb;
  background-attachment: fixed, fixed, fixed, fixed, fixed, fixed;
}

body::before{
  background:
    radial-gradient(circle at 15% 12%, rgba(214,185,140,0.16), transparent 16%),
    radial-gradient(circle at 86% 4%, rgba(47,111,237,0.10), transparent 18%),
    radial-gradient(circle at 50% 100%, rgba(255,122,89,0.08), transparent 24%);
  opacity: 1;
}

.app-shell,
.admin-shell{
  color: var(--text);
}

.eyebrow,
.brand-badge{
  background: rgba(47,111,237,0.08);
  border-color: rgba(47,111,237,0.08);
  color: var(--primary);
}

.feed-shell{
  padding-top: 116px;
}

.feed-topbar-banner{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.95), rgba(250,245,238,0.92)),
    radial-gradient(circle at top right, rgba(47,111,237,0.10), transparent 28%),
    radial-gradient(circle at top left, rgba(255,122,89,0.10), transparent 20%);
  border-bottom: 1px solid rgba(23,50,79,0.08);
  box-shadow: 0 18px 46px rgba(23,50,79,0.08);
}

.feed-topbar-inner{
  min-height: 78px;
  padding: max(10px, env(safe-area-inset-top)) 18px 12px;
}

.feed-appbar-brand{
  gap: 6px;
}

.feed-appbar-kicker{
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(47,111,237,0.08);
  color: var(--primary);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.feed-appbar-title{
  color: #16304b;
  font-family: "Fraunces", "Georgia", serif;
  font-size: clamp(1.35rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1;
}

.feed-appbar-subtitle{
  max-width: 720px;
  color: #5b6f88;
  font-size: 0.92rem;
  line-height: 1.45;
}

.btn{
  border-radius: 18px;
  font-weight: 800;
  box-shadow: none;
}

.btn-primary{
  background: var(--brand-gradient);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 18px 32px rgba(47,111,237,0.18);
}

.btn-primary:hover,
.btn-primary:focus-visible{
  box-shadow: 0 22px 40px rgba(47,111,237,0.20);
}

.btn-secondary,
.btn-topbar,
.btn-mini,
.feed-footer-link{
  background: rgba(255,255,255,0.88);
  color: var(--text);
  border-color: rgba(23,50,79,0.10);
  box-shadow: 0 10px 24px rgba(23,50,79,0.06);
}

.btn-create-icon,
.btn-create-post{
  background: linear-gradient(135deg, #ff7a59 0%, #ff9b6f 100%);
  box-shadow: 0 16px 32px rgba(255,122,89,0.24);
}

.btn-create-post{
  color: #fff;
}

.btn-comment{
  background: linear-gradient(135deg, #25b36a 0%, #3fcb83 100%);
  color: #fff;
  border-color: transparent;
}

.btn-share{
  background: linear-gradient(135deg, #2f6fed 0%, #5fa8ff 100%);
  color: #fff;
  border-color: transparent;
}

.feed-promo-card,
.feed-gallery-lock,
.composer-card,
.feed-stage,
.gallery-hero-card,
.gallery-card,
.gallery-story-card,
.auth-card,
.auth-story,
.countdown-card,
.legal-card,
.admin-card,
.table-wrap,
.notification-panel,
.notification-permission-card{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.95), rgba(249,245,239,0.92)),
    var(--brand-gradient-soft);
  border: 1px solid rgba(23,50,79,0.08);
  box-shadow: var(--shadow-soft);
}

.feed-promo-card{
  display: grid;
  gap: 10px;
  padding: 20px 22px;
}

.feed-promo-kicker{
  color: var(--accent);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.feed-promo-text{
  color: var(--text);
  font-size: 1.04rem;
  line-height: 1.7;
  text-align: left;
}

.feed-section-head strong{
  color: var(--text-soft);
  letter-spacing: 0.2em;
  font-size: 0.84rem;
}

.feed-section-head span{
  color: var(--accent);
}

.composer-titlebar{
  background: linear-gradient(135deg, rgba(47,111,237,0.10), rgba(255,122,89,0.12));
  color: var(--text);
  border-bottom: 1px solid rgba(23,50,79,0.08);
}

.upload-chip{
  background: rgba(255,255,255,0.82);
  border: 1px solid rgba(23,50,79,0.08);
  color: var(--text);
  box-shadow: 0 10px 24px rgba(23,50,79,0.05);
}

.composer-textarea,
.field input,
.field textarea,
.comment-form input{
  background: rgba(255,255,255,0.88);
  border-color: rgba(23,50,79,0.10);
}

.post-card{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,244,238,0.93));
  border: 1px solid rgba(23,50,79,0.08);
  box-shadow: 0 18px 38px rgba(23,50,79,0.08);
}

.post-card-verified{
  border-color: rgba(255,122,89,0.18);
  box-shadow:
    0 20px 42px rgba(23,50,79,0.08),
    0 0 0 1px rgba(255,122,89,0.08);
}

.verified-badge{
  background: linear-gradient(135deg, rgba(255,122,89,0.12), rgba(214,185,140,0.18));
  color: #a24a30;
  border-color: rgba(255,122,89,0.14);
}

.post-author-meta strong,
.comment-body strong{
  color: var(--text);
}

.post-author-meta span,
.comment-body p{
  color: var(--text-soft);
}

.media-frame{
  border-radius: 22px;
  border: 1px solid rgba(23,50,79,0.08);
  background: #f2f6fb;
}

.reaction-row{
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(23,50,79,0.06);
  border-radius: 18px;
  padding: 8px;
}

.reaction-btn{
  background: rgba(248,250,255,0.92);
  border-color: rgba(23,50,79,0.08);
}

.reaction-btn.is-active,
.reaction-btn[data-active="1"]{
  background: rgba(47,111,237,0.10);
  border-color: rgba(47,111,237,0.18);
}

.comments-block{
  background: linear-gradient(180deg, rgba(247,250,255,0.86), rgba(241,246,252,0.94));
  border: 1px solid rgba(23,50,79,0.06);
}

.comment-item{
  background: rgba(255,255,255,0.74);
  border: 1px solid rgba(23,50,79,0.06);
  border-radius: 16px;
}

.floating-badge{
  background: var(--brand-gradient);
  color: #fff;
  box-shadow: 0 20px 40px rgba(47,111,237,0.20);
}

.feed-tip{
  background: rgba(255,255,255,0.82);
  color: var(--text-soft);
  border: 1px solid rgba(23,50,79,0.08);
}

.feed-footer-bar{
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(23,50,79,0.10);
  box-shadow: 0 22px 46px rgba(23,50,79,0.10);
}

.feed-footer-link.is-active,
.feed-footer-action.is-submit-mode{
  color: #fff;
  border-color: transparent;
  background: var(--brand-gradient);
}

.notification-panel-head strong,
.notification-permission-copy strong{
  color: var(--text);
}

.notification-empty p,
.notification-permission-copy p{
  color: var(--text-soft);
}

.notification-item{
  background: rgba(255,255,255,0.82);
  border: 1px solid rgba(23,50,79,0.08);
}

.notification-permission-icon{
  background: var(--brand-gradient);
  color: #fff;
  box-shadow: 0 16px 30px rgba(47,111,237,0.18);
}

.auth-shell,
.countdown-premium{
  align-items: stretch;
}

.auth-story,
.countdown-card-side{
  background:
    linear-gradient(160deg, rgba(23,50,79,0.95), rgba(39,72,108,0.92)),
    radial-gradient(circle at top left, rgba(255,122,89,0.12), transparent 22%);
  color: #f8fbff;
  border: 1px solid rgba(255,255,255,0.08);
}

.auth-story .eyebrow,
.countdown-card-side .eyebrow{
  background: rgba(255,255,255,0.10);
  border-color: rgba(255,255,255,0.08);
  color: #f7f3eb;
}

.auth-story h1,
.countdown-card-side h1,
.countdown-card-side h2{
  color: #fff;
  font-family: "Fraunces", "Georgia", serif;
  font-weight: 700;
}

.auth-story-lead,
.countdown-card-side p{
  color: rgba(248,251,255,0.84);
}

.auth-story-card{
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.08);
}

.auth-story-card strong{
  color: #fff;
}

.auth-story-card p{
  color: rgba(248,251,255,0.76);
}

.auth-card-brand,
.countdown-card-main{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(249,245,239,0.94)),
    var(--brand-gradient-soft);
}

.brand-lockup strong{
  font-family: "Fraunces", "Georgia", serif;
  color: var(--text);
  font-size: clamp(1.8rem, 4vw, 2.6rem);
}

.brand-lockup small{
  color: var(--text-soft);
  line-height: 1.7;
}

.register-stepper-track{
  background: rgba(23,50,79,0.08);
}

.register-stepper-fill{
  background: var(--brand-gradient);
}

.selfie-preview{
  background: rgba(255,255,255,0.88);
  border: 1px dashed rgba(23,50,79,0.16);
  color: var(--text-soft);
}

.countdown-grid .countdown-item{
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(23,50,79,0.08);
  box-shadow: 0 12px 26px rgba(23,50,79,0.06);
}

.countdown-grid .countdown-item strong{
  color: var(--primary);
}

.gallery-hero-card{
  overflow: hidden;
}

.gallery-hero-title,
.legal-title,
.admin-page-title{
  font-family: "Fraunces", "Georgia", serif;
  letter-spacing: -0.03em;
}

.gallery-filter.is-active{
  background: var(--brand-gradient);
  color: #fff;
  border-color: transparent;
}

.gallery-card-media,
.gallery-story-media{
  border-radius: 22px;
  border: 1px solid rgba(23,50,79,0.08);
}

.gallery-download{
  background: rgba(255,255,255,0.82);
  border-color: rgba(23,50,79,0.08);
  color: var(--text);
}

.legal-highlight{
  background: linear-gradient(180deg, rgba(47,111,237,0.08), rgba(255,122,89,0.08));
  color: var(--text);
  border-color: rgba(23,50,79,0.08);
}

.admin-header,
.admin-live-banner{
  background:
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(249,245,239,0.94)),
    var(--brand-gradient-soft);
  border-color: rgba(23,50,79,0.08);
}

.admin-header-title,
.admin-live-banner strong{
  color: var(--text);
}

.status-pill.is-success{
  background: rgba(33,182,111,0.12);
  color: #178451;
}

.status-pill.is-warning{
  background: rgba(241,165,58,0.14);
  color: #9a5d10;
}

.status-pill.is-danger{
  background: rgba(235,91,91,0.14);
  color: #b53c3c;
}

@media (max-width: 900px){
  .feed-shell{
    padding-top: 108px;
  }

  .feed-appbar-subtitle{
    font-size: 0.84rem;
  }
}

@media (max-width: 720px){
  .app-shell,
  .admin-shell{
    padding: 12px;
  }

  .feed-shell{
    padding-top: 104px;
  }

  .feed-topbar-inner{
    padding-inline: 12px;
  }

  .feed-appbar-kicker{
    min-height: 24px;
    padding-inline: 10px;
  }

  .feed-appbar-title{
    font-size: clamp(1.2rem, 6vw, 1.55rem);
  }

  .feed-appbar-subtitle{
    font-size: 0.78rem;
  }

  .feed-promo-card,
  .composer-card,
  .feed-stage,
  .gallery-hero-card,
  .auth-card,
  .auth-story,
  .countdown-card,
  .legal-card,
  .admin-card,
  .table-wrap{
    padding: 18px;
    border-radius: 22px;
  }

  .feed-footer-bar{
    width: calc(100% - 16px);
    bottom: max(8px, env(safe-area-inset-bottom));
  }
}

/* Ajuste final solicitado */
body{
  background: var(--app-background-image) center/cover no-repeat fixed !important;
}

body::before{
  display: none !important;
}

.feed-appbar-kicker{
  display: none !important;
}

.feed-topbar-banner{
  background: rgba(255,255,255,0.94) !important;
  border-bottom: 1px solid rgba(23,50,79,0.08) !important;
  box-shadow: 0 10px 28px rgba(23,50,79,0.08) !important;
}

.feed-appbar-title{
  color: #17324f !important;
}

.feed-appbar-subtitle{
  color: #566f8d !important;
}

.feed-promo-card,
.feed-gallery-lock,
.composer-card,
.feed-stage,
.notification-panel,
.notification-permission-card,
.auth-card,
.auth-card-brand,
.countdown-card,
.gallery-hero-card,
.gallery-card,
.legal-card,
.admin-card,
.table-wrap{
  background: rgba(255,255,255,0.94) !important;
  border: 1px solid rgba(23,50,79,0.08) !important;
  box-shadow: 0 18px 40px rgba(23,50,79,0.10) !important;
}

.auth-story,
.countdown-card-side{
  background: rgba(255,255,255,0.90) !important;
  border: 1px solid rgba(23,50,79,0.08) !important;
  box-shadow: 0 18px 40px rgba(23,50,79,0.10) !important;
  color: var(--text) !important;
}

.auth-story .eyebrow,
.countdown-card-side .eyebrow{
  background: rgba(47,111,237,0.08) !important;
  color: var(--primary) !important;
  border-color: rgba(47,111,237,0.08) !important;
}

.auth-story h1,
.countdown-card-side h1,
.countdown-card-side h2,
.auth-story-card strong{
  color: #17324f !important;
}

.auth-story-lead,
.countdown-card-side p,
.auth-story-card p,
.auth-card-brand small,
.auth-card-brand .notice,
.auth-linkline{
  color: #5b6f88 !important;
}

.auth-story-card{
  background: rgba(247,250,255,0.86) !important;
  border: 1px solid rgba(23,50,79,0.08) !important;
}

.btn-primary,
.btn-publish,
.btn-create-icon,
.btn-create-post,
.btn-auth-main,
.btn-auth-create,
.btn-notification-enable{
  background: linear-gradient(135deg, #189f5f 0%, #2dcf7d 100%) !important;
  color: #ffffff !important;
  border-color: transparent !important;
  box-shadow: 0 16px 30px rgba(24,159,95,0.22) !important;
}

.btn-comment{
  background: linear-gradient(135deg, #189f5f 0%, #2dcf7d 100%) !important;
  color: #ffffff !important;
  border-color: transparent !important;
}

.feed-create-trigger{
  background: linear-gradient(135deg, #189f5f 0%, #2dcf7d 100%) !important;
  color: #ffffff !important;
  border-color: transparent !important;
  box-shadow: 0 16px 30px rgba(24,159,95,0.22) !important;
}

.feed-create-trigger.is-open{
  background: linear-gradient(135deg, #d93b3b 0%, #f26a6a 100%) !important;
  color: #ffffff !important;
  box-shadow: 0 16px 30px rgba(217,59,59,0.22) !important;
}

.feed-footer-action.is-submit-mode{
  background: linear-gradient(135deg, #189f5f 0%, #2dcf7d 100%) !important;
  color: #ffffff !important;
}

.btn-share{
  background: linear-gradient(135deg, #2f6fed 0%, #5fa8ff 100%) !important;
  color: #ffffff !important;
}

.notification-panel{
  max-height: min(68vh, 520px) !important;
  overflow: hidden !important;
}

.notification-panel-list{
  max-height: calc(min(68vh, 520px) - 72px) !important;
  overflow-y: auto !important;
  padding-right: 4px !important;
}

.notification-item.is-unread{
  border-color: rgba(47,111,237,0.18) !important;
  background: rgba(237,245,255,0.96) !important;
}

.notification-item.is-unread .notification-item-copy strong{
  color: #163d72 !important;
}

.btn-notification.has-alert .btn-notification-count{
  display: inline-flex !important;
}

.btn-notification-count{
  background: #ef4444 !important;
  color: #fff !important;
  box-shadow: none !important;
}

.feed-promo-text,
.notification-empty strong,
.notification-panel-head strong,
.notification-permission-copy strong,
.brand-lockup strong,
.legal-title,
.gallery-hero-title{
  color: #17324f !important;
}

.notification-empty p,
.notification-permission-copy p{
  color: #5b6f88 !important;
}

.feed-footer-bar{
  background: rgba(255,255,255,0.94) !important;
}

.feed-footer-link{
  color: #17324f !important;
}

.feed-footer-link.is-active{
  background: rgba(47,111,237,0.10) !important;
  color: #17324f !important;
  border-color: rgba(47,111,237,0.12) !important;
}

.auth-page .eyebrow,
.auth-page .brand-badge{
  background: linear-gradient(135deg, #d93b3b 0%, #f26a6a 100%) !important;
  color: #ffffff !important;
  border-color: transparent !important;
  box-shadow: 0 12px 24px rgba(217,59,59,0.20) !important;
  letter-spacing: 0.14em !important;
}

.auth-highlight,
.auth-highlight-selfie{
  background: rgba(245,249,255,0.92) !important;
  border: 1px solid rgba(23,50,79,0.08) !important;
}

.auth-highlight strong,
.field span,
.brand-lockup strong,
.feed-section-head strong,
.post-author-meta strong,
.comment-body strong,
.notification-item-copy strong{
  color: #17324f !important;
}

.auth-highlight p,
.field small,
.brand-lockup small,
.post-text,
.comment-body p,
.notification-item-copy small,
.notification-item time,
.feed-tip,
.feed-promo-text{
  color: #4f6987 !important;
}

.feed-section-head{
  gap: 8px !important;
}

.feed-section-head strong{
  color: #17324f !important;
  font-size: 1rem !important;
  font-weight: 900 !important;
  letter-spacing: 0.24em !important;
  text-shadow: 0 1px 0 rgba(255,255,255,0.6) !important;
}

.feed-section-head span{
  color: #189f5f !important;
  font-size: 1.4rem !important;
}

.reaction-row{
  background: rgba(255,255,255,0.88) !important;
  border: 1px solid rgba(23,50,79,0.08) !important;
}

.reaction-btn{
  background: rgba(247,250,255,0.96) !important;
  color: #17324f !important;
  border: 1px solid rgba(23,50,79,0.08) !important;
}

.reaction-btn .reaction-emoji,
.reaction-btn small{
  color: #17324f !important;
}

.reaction-btn.is-active,
.reaction-btn[data-active="1"]{
  background: linear-gradient(135deg, rgba(24,159,95,0.14), rgba(47,111,237,0.10)) !important;
  border-color: rgba(24,159,95,0.22) !important;
  box-shadow: 0 10px 22px rgba(24,159,95,0.12) !important;
}

.reaction-btn.is-active .reaction-emoji,
.reaction-btn.is-active small,
.reaction-btn[data-active="1"] .reaction-emoji,
.reaction-btn[data-active="1"] small{
  color: #126d45 !important;
  font-weight: 800 !important;
}

.countdown-card-main .eyebrow,
.countdown-card-main .brand-badge{
  background: linear-gradient(135deg, #d93b3b 0%, #f26a6a 100%) !important;
  color: #ffffff !important;
  border-color: transparent !important;
  box-shadow: 0 12px 24px rgba(217,59,59,0.20) !important;
}

.countdown-card-main h1,
.countdown-card-main h2,
.countdown-card-main .brand-lockup strong{
  color: #17324f !important;
  font-family: "Fraunces", "Georgia", serif !important;
  letter-spacing: -0.03em !important;
}

.countdown-card-main .lead,
.countdown-card-main p,
.countdown-card-main .notice,
.countdown-card-main small{
  color: #4f6987 !important;
  line-height: 1.72 !important;
}

.countdown-grid-premium{
  margin-top: 8px !important;
}

.countdown-grid .countdown-item,
.countdown-box{
  background: rgba(255,255,255,0.96) !important;
  border: 1px solid rgba(23,50,79,0.10) !important;
  box-shadow: 0 14px 28px rgba(23,50,79,0.08) !important;
}

.countdown-grid .countdown-item strong,
.countdown-box strong{
  color: #17324f !important;
  font-size: clamp(1.8rem, 6vw, 2.8rem) !important;
  font-weight: 800 !important;
}

.countdown-grid .countdown-item span,
.countdown-box span{
  color: #5d748f !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
}

.countdown-separator{
  color: #d93b3b !important;
  font-weight: 900 !important;
}

.cta-block .btn-secondary[disabled]{
  opacity: 1 !important;
  background: rgba(247,250,255,0.96) !important;
  color: #17324f !important;
  border-color: rgba(23,50,79,0.10) !important;
  box-shadow: 0 14px 26px rgba(23,50,79,0.08) !important;
}
