/*
 * Igreja Community — Stylesheet
 * TODAS as regras escopadas em .ic-app para não conflitar com o tema WordPress
 */

/* ── Variáveis escopadas (não vazam para o tema) ────────────────── */
.ic-app {
  --ic-navy:        #0f1f3d;
  --ic-navy-mid:    #1a3360;
  --ic-navy-soft:   #243876;
  --ic-gold:        #b8831a;
  --ic-gold-light:  #d4a843;
  --ic-gold-pale:   #fdf6e8;
  --ic-ivory:       #faf8f4;
  --ic-ivory-dark:  #f0ece3;
  --ic-bordeaux:    #7c1f3a;
  --ic-text:        #1a1a2e;
  --ic-text-mid:    #4a4a6a;
  --ic-text-muted:  #8a8aaa;
  --ic-white:       #ffffff;
  --ic-border:      rgba(15,31,61,0.1);
  --ic-border-gold: rgba(184,131,26,0.3);
  --ic-shadow-sm:   0 2px 12px rgba(15,31,61,0.08);
  --ic-shadow-md:   0 8px 32px rgba(15,31,61,0.14);
  --ic-shadow-gold: 0 4px 20px rgba(184,131,26,0.2);
  --ic-r:           14px;
  --ic-r-sm:        8px;
  --ic-r-lg:        20px;
  --ic-serif:       'Cormorant Garamond', Georgia, serif;
  --ic-sans:        'Outfit', system-ui, sans-serif;
  --ic-ease:        0.22s cubic-bezier(0.4,0,0.2,1);
}

/* ── Reset SOMENTE dentro do plugin ────────────────────────────── */
.ic-app, .ic-app * { box-sizing: border-box; }
.ic-app { font-family: var(--ic-sans); color: var(--ic-text); }

/* ── Portal layout ──────────────────────────────────────────────── */
.ic-app .ic-portal { display:flex; min-height:100vh; background:var(--ic-ivory); }

/* SIDEBAR */
.ic-app .ic-sidebar {
  width:260px; background:var(--ic-navy);
  display:flex; flex-direction:column;
  position:fixed; top:0; left:0; bottom:0;
  z-index:1000; transition:transform var(--ic-ease); overflow-y:auto;
}
.ic-app .ic-sidebar-logo { padding:28px 24px 20px; border-bottom:1px solid rgba(255,255,255,0.07); }
.ic-app .ic-sidebar-logo-img { margin-bottom:10px; }
.ic-app .ic-sidebar-logo-img img { max-height:52px; max-width:180px; object-fit:contain; display:block; filter:brightness(0) invert(1); opacity:.9; }
.ic-app .ic-cross { width:32px; height:32px; background:var(--ic-gold); border-radius:6px; display:flex; align-items:center; justify-content:center; font-size:18px; color:white; margin-bottom:10px; }
.ic-app .ic-sidebar-logo h2 { font-family:var(--ic-serif); font-size:1.2rem; color:white; font-weight:500; line-height:1.2; margin:0; }
.ic-app .ic-sidebar-logo p  { font-size:.68rem; color:rgba(255,255,255,.4); margin:2px 0 0; letter-spacing:.06em; text-transform:uppercase; }
.ic-app .ic-verse-side { margin:14px; padding:12px 14px; background:rgba(184,131,26,.12); border:1px solid rgba(184,131,26,.25); border-radius:var(--ic-r-sm); }
.ic-app .ic-verse-side p { font-family:var(--ic-serif); font-style:italic; font-size:.78rem; color:rgba(255,255,255,.75); line-height:1.6; margin:0; }
.ic-app .ic-verse-side cite { font-size:.63rem; color:var(--ic-gold-light); display:block; margin-top:5px; font-style:normal; }
.ic-app .ic-nav { padding:6px 0; flex:1; }
.ic-app .ic-nav-section { padding:14px 20px 5px; font-size:.6rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.28); }
.ic-app .ic-nav-item { display:flex; align-items:center; gap:11px; padding:10px 20px; cursor:pointer; transition:all var(--ic-ease); border-left:3px solid transparent; font-size:.86rem; color:rgba(255,255,255,.6); font-weight:400; user-select:none; text-decoration:none; }
.ic-app .ic-nav-item:hover { background:rgba(255,255,255,.05); color:rgba(255,255,255,.9); text-decoration:none; }
.ic-app .ic-nav-item.active { background:rgba(184,131,26,.15); border-left-color:var(--ic-gold); color:var(--ic-gold-light); font-weight:500; }
.ic-app .ic-nav-icon { width:32px; height:32px; border-radius:7px; display:flex; align-items:center; justify-content:center; font-size:14px; background:rgba(255,255,255,.05); flex-shrink:0; transition:background var(--ic-ease); }
.ic-app .ic-nav-item.active .ic-nav-icon { background:rgba(184,131,26,.2); }
.ic-app .ic-nav-item:hover .ic-nav-icon  { background:rgba(255,255,255,.1); }
.ic-app .ic-sidebar-user { margin:10px; padding:11px; background:rgba(255,255,255,.04); border-radius:var(--ic-r-sm); border:1px solid rgba(255,255,255,.06); display:flex; align-items:center; gap:9px; cursor:pointer; }
.ic-app .ic-user-avatar { width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg,var(--ic-gold) 0%,var(--ic-bordeaux) 100%); display:flex; align-items:center; justify-content:center; font-family:var(--ic-serif); font-size:.9rem; color:white; font-weight:600; flex-shrink:0; }
.ic-app .ic-user-info { flex:1; min-width:0; }
.ic-app .ic-user-info strong { display:block; font-size:.78rem; color:white; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ic-app .ic-user-info span { font-size:.62rem; color:rgba(255,255,255,.4); }

/* MAIN */
.ic-app .ic-main { margin-left:260px; flex:1; display:flex; flex-direction:column; min-height:100vh; }
.ic-app .ic-topbar { background:var(--ic-white); border-bottom:1px solid var(--ic-border); padding:0 28px; height:62px; display:flex; align-items:center; justify-content:space-between; position:sticky; top:0; z-index:50; }
.ic-app .ic-topbar-title { font-family:var(--ic-serif); font-size:1.25rem; color:var(--ic-navy); font-weight:500; }
.ic-app .ic-menu-btn { display:none; width:34px; height:34px; border-radius:var(--ic-r-sm); background:none; border:1px solid var(--ic-border); cursor:pointer; font-size:15px; color:var(--ic-text-mid); align-items:center; justify-content:center; }
.ic-app .ic-content { padding:28px; flex:1; }

/* PAGES */
.ic-app .ic-page { display:none; }
.ic-app .ic-page.active { display:block; animation:ic-fade .28s ease; }
@keyframes ic-fade { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:none} }

/* ── Cards ───────────────────────────────────────────────────────── */
.ic-app .ic-card { background:var(--ic-white); border:1px solid var(--ic-border); border-radius:var(--ic-r); box-shadow:var(--ic-shadow-sm); padding:22px; }
.ic-app .ic-card--navy { background:var(--ic-navy); border-color:transparent; color:white; }
.ic-app .ic-card--gold { background:var(--ic-gold-pale); border-color:var(--ic-border-gold); }
.ic-app .ic-g2 { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.ic-app .ic-g3 { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }

/* ── Typography ─────────────────────────────────────────────────── */
.ic-app .ic-page-title { font-family:var(--ic-serif); font-size:1.9rem; color:var(--ic-navy); font-weight:500; margin:0 0 4px; }
.ic-app .ic-page-sub   { font-size:.87rem; color:var(--ic-text-muted); margin:0 0 24px; }
.ic-app .ic-section-label { font-size:.68rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--ic-text-muted); margin-bottom:10px; display:block; }
.ic-app .ic-card-title { font-family:var(--ic-serif); font-size:1.05rem; color:var(--ic-navy); font-weight:500; }

/* ── Stat cards ──────────────────────────────────────────────────── */
.ic-app .ic-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:13px; margin-bottom:26px; }
.ic-app .ic-stat-card { background:var(--ic-white); border:1px solid var(--ic-border); border-radius:var(--ic-r); padding:18px; position:relative; overflow:hidden; transition:transform var(--ic-ease),box-shadow var(--ic-ease); }
.ic-app .ic-stat-card:hover { transform:translateY(-2px); box-shadow:var(--ic-shadow-md); }
.ic-app .ic-stat-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; }
.ic-app .ic-stat-card.gold::before   { background:linear-gradient(90deg,var(--ic-gold),var(--ic-gold-light)); }
.ic-app .ic-stat-card.navy::before   { background:linear-gradient(90deg,var(--ic-navy),var(--ic-navy-soft)); }
.ic-app .ic-stat-card.bord::before   { background:linear-gradient(90deg,var(--ic-bordeaux),#c44a6e); }
.ic-app .ic-stat-card.green::before  { background:linear-gradient(90deg,#1a7a4a,#2ea86a); }
.ic-app .ic-stat-icon { width:38px; height:38px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:17px; margin-bottom:10px; }
.ic-app .ic-stat-val   { font-family:var(--ic-serif); font-size:1.9rem; font-weight:600; color:var(--ic-navy); line-height:1; }
.ic-app .ic-stat-label { font-size:.72rem; color:var(--ic-text-muted); margin-top:3px; }
.ic-app .ic-stat-note  { font-size:.68rem; margin-top:6px; color:#1a7a4a; }

/* ── Progress bar ───────────────────────────────────────────────── */
.ic-app .ic-progress-track { background:var(--ic-ivory-dark,#f0ece3); border-radius:100px; height:7px; overflow:hidden; }
.ic-app .ic-progress-fill  { height:100%; border-radius:100px; background:linear-gradient(90deg,var(--ic-gold),var(--ic-gold-light)); transition:width .8s cubic-bezier(.4,0,.2,1); }

/* ── Buttons ────────────────────────────────────────────────────── */
.ic-app .ic-btn { display:inline-flex; align-items:center; justify-content:center; gap:7px; padding:10px 20px; border-radius:var(--ic-r-sm); border:none; font-family:var(--ic-sans); font-size:.875rem; font-weight:500; cursor:pointer; transition:all var(--ic-ease); text-decoration:none !important; white-space:nowrap; line-height:1; }
.ic-app .ic-btn-primary { background:var(--ic-navy); color:white !important; }
.ic-app .ic-btn-primary:hover { background:var(--ic-navy-soft); transform:translateY(-1px); }
.ic-app .ic-btn-gold    { background:var(--ic-gold); color:white !important; }
.ic-app .ic-btn-gold:hover { background:var(--ic-gold-light); transform:translateY(-1px); }
.ic-app .ic-btn-outline { background:transparent; border:1px solid var(--ic-border); color:var(--ic-text-mid) !important; }
.ic-app .ic-btn-outline:hover { border-color:var(--ic-navy); color:var(--ic-navy) !important; }
.ic-app .ic-btn-uber    { background:#000; color:white !important; padding:15px 28px; border-radius:var(--ic-r); font-size:.98rem; font-weight:500; width:100%; }
.ic-app .ic-btn-uber:hover { background:#1a1a1a; transform:translateY(-2px); }
.ic-app .ic-btn-full    { width:100%; }
.ic-app .ic-btn-lg      { padding:13px 28px; font-size:1rem; border-radius:var(--ic-r); }
.ic-app .ic-btn-sm      { padding:5px 13px; font-size:.76rem; }

/* ── Forms ──────────────────────────────────────────────────────── */
.ic-app .ic-form-group { margin-bottom:14px; }
.ic-app .ic-form-label { display:block; font-size:.77rem; font-weight:500; color:var(--ic-text-mid); margin-bottom:5px; }
.ic-app .ic-form-input { width:100%; padding:10px 13px; border:1px solid var(--ic-border); border-radius:var(--ic-r-sm); font-family:var(--ic-sans); font-size:.88rem; color:var(--ic-text); background:var(--ic-white); outline:none; transition:border-color var(--ic-ease),box-shadow var(--ic-ease); }
.ic-app .ic-form-input:focus { border-color:var(--ic-gold); box-shadow:0 0 0 3px rgba(184,131,26,.1); }
.ic-app .ic-form-input::placeholder { color:var(--ic-text-muted); }
.ic-app textarea.ic-form-input { resize:vertical; min-height:78px; }
.ic-app .ic-form-select { width:100%; padding:10px 13px; border:1px solid var(--ic-border); border-radius:var(--ic-r-sm); font-family:var(--ic-sans); font-size:.88rem; color:var(--ic-text); background:var(--ic-white); outline:none; cursor:pointer; appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238a8aaa' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 11px center; background-size:11px; padding-right:34px; }
.ic-app .ic-form-select:focus { border-color:var(--ic-gold); box-shadow:0 0 0 3px rgba(184,131,26,.1); }
.ic-app .ic-alert { padding:11px 15px; border-radius:var(--ic-r-sm); font-size:.83rem; margin-top:8px; display:none; }
.ic-app .ic-alert-success { background:#d4edda; color:#155724; border:1px solid #c3e6cb; display:block; }
.ic-app .ic-alert-error   { background:#f8d7da; color:#721c24; border:1px solid #f5c6cb; display:block; }

/* ── Tabs ───────────────────────────────────────────────────────── */
.ic-app .ic-tabs { display:flex; border-bottom:1px solid var(--ic-border); margin-bottom:22px; flex-wrap:wrap; }
.ic-app .ic-tab-btn { padding:11px 18px; border:none; background:none; font-family:var(--ic-sans); font-size:.86rem; color:var(--ic-text-muted); cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-1px; transition:all var(--ic-ease); font-weight:400; }
.ic-app .ic-tab-btn:hover { color:var(--ic-navy); }
.ic-app .ic-tab-btn.active { color:var(--ic-navy); border-bottom-color:var(--ic-gold); font-weight:500; }
.ic-app .ic-tab-panel { display:none; }
.ic-app .ic-tab-panel.active { display:block; animation:ic-fade .2s ease; }

/* ── Badges ─────────────────────────────────────────────────────── */
.ic-app .ic-badge { display:inline-flex; align-items:center; padding:3px 10px; border-radius:20px; font-size:.66rem; font-weight:600; letter-spacing:.04em; }
.ic-app .ic-badge-gold  { background:rgba(184,131,26,.15); color:var(--ic-gold); border:1px solid var(--ic-border-gold); }
.ic-app .ic-badge-navy  { background:rgba(15,31,61,.1); color:var(--ic-navy); }
.ic-app .ic-badge-green { background:#d4edda; color:#155724; }
.ic-app .ic-badge-red   { background:#f8d7da; color:#721c24; }

/* ── Welcome banner ─────────────────────────────────────────────── */
.ic-app .ic-welcome { background:linear-gradient(135deg,var(--ic-navy) 0%,var(--ic-navy-soft) 60%,#2d4a9e 100%); border-radius:var(--ic-r-lg,20px); padding:30px 34px; color:white; margin-bottom:26px; position:relative; overflow:hidden; }
.ic-app .ic-welcome::before { content:'✝'; position:absolute; right:28px; top:50%; transform:translateY(-50%); font-size:5.5rem; opacity:.05; color:white; pointer-events:none; font-family:var(--ic-serif); }
.ic-app .ic-welcome-date { font-size:.7rem; color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:.08em; margin-bottom:5px; }
.ic-app .ic-welcome-name { font-family:var(--ic-serif); font-size:1.8rem; font-weight:500; line-height:1.2; margin-bottom:5px; }
.ic-app .ic-welcome-sub  { font-size:.83rem; color:rgba(255,255,255,.6); margin-bottom:18px; }
.ic-app .ic-welcome-verse { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); border-radius:var(--ic-r-sm); padding:13px 15px; max-width:500px; }
.ic-app .ic-welcome-verse p { font-family:var(--ic-serif); font-style:italic; font-size:.9rem; color:rgba(255,255,255,.85); line-height:1.65; margin:0; }
.ic-app .ic-welcome-verse cite { font-size:.68rem; color:#f0c040; display:block; margin-top:4px; font-style:normal; }

/* ── Quick actions ──────────────────────────────────────────────── */
.ic-app .ic-qa-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:11px; margin-bottom:26px; }
.ic-app .ic-qa-card { background:var(--ic-white); border:1px solid var(--ic-border); border-radius:var(--ic-r); padding:16px 14px; text-align:center; cursor:pointer; transition:all var(--ic-ease); text-decoration:none !important; color:inherit; display:flex; flex-direction:column; align-items:center; gap:8px; }
.ic-app .ic-qa-card:hover { border-color:var(--ic-gold); transform:translateY(-3px); box-shadow:var(--ic-shadow-gold); }
.ic-app .ic-qa-icon { width:46px; height:46px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:20px; transition:transform var(--ic-ease); }
.ic-app .ic-qa-card:hover .ic-qa-icon { transform:scale(1.1); }
.ic-app .ic-qa-name { font-size:.8rem; font-weight:500; color:var(--ic-navy); }
.ic-app .ic-qa-desc { font-size:.68rem; color:var(--ic-text-muted); line-height:1.3; }

/* ── Reading widget ─────────────────────────────────────────────── */
.ic-app .ic-rw { background:var(--ic-gold-pale); border:1px solid var(--ic-border-gold); border-radius:var(--ic-r); padding:18px; }
.ic-app .ic-rw-hdr { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:12px; }
.ic-app .ic-rw-plan { font-family:var(--ic-serif); font-size:.98rem; color:var(--ic-navy); }
.ic-app .ic-rw-sub  { font-size:.7rem; color:var(--ic-text-muted); margin-top:2px; }
.ic-app .ic-rw-badge { background:var(--ic-navy); color:white; font-size:.66rem; padding:4px 11px; border-radius:20px; white-space:nowrap; }
.ic-app .ic-rw-passage { background:var(--ic-white); border-radius:10px; padding:11px 13px; display:flex; align-items:center; justify-content:space-between; margin-top:12px; gap:10px; }
.ic-app .ic-check-btn { width:32px; height:32px; border-radius:50%; border:2px solid var(--ic-gold); background:transparent; color:var(--ic-gold); font-size:13px; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all var(--ic-ease); font-weight:700; }
.ic-app .ic-check-btn:hover,.ic-app .ic-check-btn.done { background:var(--ic-gold); color:white; border-color:var(--ic-gold); }

/* ── Next event ─────────────────────────────────────────────────── */
.ic-app .ic-next-event { background:var(--ic-navy); border-radius:var(--ic-r); padding:18px; color:white; display:flex; align-items:center; gap:14px; }
.ic-app .ic-event-date { background:var(--ic-gold); border-radius:10px; padding:9px 13px; text-align:center; flex-shrink:0; }
.ic-app .ic-event-day   { font-family:var(--ic-serif); font-size:1.7rem; color:white; line-height:1; font-weight:600; }
.ic-app .ic-event-month { font-size:.63rem; color:rgba(255,255,255,.85); text-transform:uppercase; letter-spacing:.06em; margin-top:1px; }
.ic-app .ic-event-info h3 { font-size:.96rem; font-weight:500; margin:0 0 3px; }
.ic-app .ic-event-info p  { font-size:.76rem; color:rgba(255,255,255,.55); margin:0; }
.ic-app .ic-live-pill { display:inline-flex; align-items:center; gap:5px; background:rgba(220,50,50,.2); border:1px solid rgba(220,50,50,.35); color:#ff8a80; font-size:.63rem; padding:3px 9px; border-radius:20px; margin-top:5px; }
.ic-app .ic-live-dot { width:5px; height:5px; border-radius:50%; background:#ff5252; animation:ic-pulse 1.8s ease-in-out infinite; }
@keyframes ic-pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.7)} }

/* ── Bible ──────────────────────────────────────────────────────── */
.ic-app .ic-bible-controls { display:flex; gap:9px; margin-bottom:18px; flex-wrap:wrap; }
.ic-app .ic-bible-search-box { flex:1; min-width:180px; position:relative; }
.ic-app .ic-bible-search-box .ic-form-input { padding-right:40px; }
.ic-app .ic-bible-search-icon { position:absolute; right:11px; top:50%; transform:translateY(-50%); color:var(--ic-text-muted); font-size:13px; pointer-events:none; }
.ic-app .ic-bible-viewer { background:var(--ic-white); border:1px solid var(--ic-border); border-radius:var(--ic-r); }
.ic-app .ic-bible-viewer-hdr { padding:14px 18px; border-bottom:1px solid var(--ic-border); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:7px; }
.ic-app .ic-bible-ref  { font-family:var(--ic-serif); font-size:1.05rem; color:var(--ic-navy); font-weight:500; }
.ic-app .ic-bible-text { padding:22px; font-family:var(--ic-serif); font-size:1.03rem; line-height:1.9; color:var(--ic-text); }
.ic-app .ic-bible-text.night { background:#0d1b2a; color:#c8d8e8; border-radius:0 0 var(--ic-r) var(--ic-r); }
.ic-app .ic-verse-num  { font-size:.58rem; font-weight:700; color:var(--ic-gold); vertical-align:super; margin-right:2px; font-family:var(--ic-sans); }
.ic-app .ic-bible-results { display:flex; flex-direction:column; gap:9px; padding:14px; }
.ic-app .ic-search-result { border-left:3px solid var(--ic-gold); padding:9px 13px; border-radius:0 var(--ic-r-sm) var(--ic-r-sm) 0; background:var(--ic-ivory); cursor:pointer; transition:background var(--ic-ease); }
.ic-app .ic-search-result:hover { background:var(--ic-ivory-dark,#f0ece3); }
.ic-app .ic-search-result-ref  { font-size:.7rem; color:var(--ic-gold); font-weight:600; margin-bottom:3px; }
.ic-app .ic-search-result-text { font-family:var(--ic-serif); font-size:.93rem; line-height:1.6; }
.ic-app .ic-night-btn { background:none; border:1px solid var(--ic-border); border-radius:6px; padding:5px 11px; font-size:.73rem; cursor:pointer; color:var(--ic-text-mid); transition:all var(--ic-ease); font-family:var(--ic-sans); }

/* ── PIX ────────────────────────────────────────────────────────── */
.ic-app .ic-pix-wrap { max-width:500px; margin:0 auto; }
.ic-app .ic-pix-toggle { display:flex; background:var(--ic-ivory-dark,#f0ece3); border-radius:12px; padding:4px; gap:4px; margin-bottom:22px; }
.ic-app .ic-pix-toggle-btn { flex:1; padding:11px; border:none; border-radius:9px; font-family:var(--ic-sans); font-size:.88rem; font-weight:500; cursor:pointer; transition:all var(--ic-ease); color:var(--ic-text-muted); background:none; display:flex; align-items:center; justify-content:center; gap:7px; }
.ic-app .ic-pix-toggle-btn.active { background:var(--ic-white); color:var(--ic-navy); box-shadow:var(--ic-shadow-sm); }
.ic-app .ic-pix-panel { display:none; }
.ic-app .ic-pix-panel.active { display:block; animation:ic-fade .25s ease; }
.ic-app .ic-pix-card { border-radius:var(--ic-r); padding:26px; border:1px solid; }
.ic-app .ic-pix-desc { text-align:center; font-size:.81rem; color:var(--ic-text-muted); margin-bottom:18px; line-height:1.5; }
.ic-app .ic-pix-qr-frame { background:white; border-radius:var(--ic-r); padding:18px; display:flex; justify-content:center; align-items:center; margin-bottom:14px; box-shadow:var(--ic-shadow-sm); min-height:180px; }
.ic-app .ic-pix-key-row { background:white; border-radius:10px; padding:11px 15px; display:flex; align-items:center; justify-content:space-between; gap:9px; box-shadow:var(--ic-shadow-sm); margin-bottom:10px; }
.ic-app .ic-pix-key-info small { display:block; font-size:.63rem; color:var(--ic-text-muted); margin-bottom:1px; }
.ic-app .ic-pix-key-info span  { font-size:.86rem; font-weight:500; color:var(--ic-navy); }
.ic-app .ic-copy-btn { background:var(--ic-ivory-dark,#f0ece3); border:none; border-radius:6px; padding:7px 13px; font-size:.73rem; font-family:var(--ic-sans); cursor:pointer; transition:all var(--ic-ease); color:var(--ic-text-mid); white-space:nowrap; font-weight:500; }
.ic-app .ic-copy-btn:hover { background:var(--ic-navy); color:white; }
.ic-app .ic-copy-btn.copied { background:#d4edda; color:#155724; }
.ic-app .ic-copy-pix-btn { display:inline-flex !important; align-items:center; gap:7px; padding:9px 16px !important; background:var(--ic-navy) !important; color:white !important; border:none !important; border-radius:var(--ic-r-sm) !important; font-size:.8rem !important; font-weight:600 !important; cursor:pointer; transition:all var(--ic-ease) !important; white-space:nowrap; font-family:var(--ic-sans); }
.ic-app .ic-copy-pix-btn:hover { background:var(--ic-navy-soft) !important; transform:translateY(-1px); }
.ic-app .ic-copy-pix-btn.copied { background:#1a7a4a !important; }
.ic-app .ic-pix-steps { display:flex; flex-direction:column; gap:7px; margin:12px 0; background:rgba(255,255,255,.65); border-radius:var(--ic-r-sm); padding:12px 14px; }
.ic-app .ic-pix-step { display:flex; align-items:center; gap:10px; font-size:.77rem; color:var(--ic-text-mid); }
.ic-app .ic-pix-step-num { width:22px; height:22px; border-radius:50%; background:var(--ic-navy); color:#fff; display:flex; align-items:center; justify-content:center; font-size:.67rem; font-weight:700; flex-shrink:0; }
.ic-app .ic-pix-copy-confirm { background:#d4edda; border:1px solid #c3e6cb; color:#155724; border-radius:var(--ic-r-sm); padding:10px 14px; font-size:.82rem; font-weight:500; text-align:center; margin-top:10px; animation:ic-fade .3s ease; }
.ic-app .ic-pix-note { text-align:center; font-size:.7rem; color:var(--ic-text-muted); line-height:1.5; }

/* ── Uber ───────────────────────────────────────────────────────── */
.ic-app .ic-uber-wrap { max-width:460px; margin:0 auto; }
.ic-app .ic-church-preview { background:linear-gradient(135deg,#1a3360 0%,#0f1f3d 100%); border-radius:var(--ic-r-lg,20px); padding:36px; text-align:center; margin-bottom:22px; }
.ic-app .ic-church-preview::before { content:'📍'; font-size:3.5rem; display:block; margin-bottom:7px; animation:ic-bounce 2s ease-in-out infinite; }
@keyframes ic-bounce { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-6px)} }
.ic-app .ic-church-preview h3 { font-family:var(--ic-serif); font-size:1.25rem; color:white; margin-bottom:3px; }
.ic-app .ic-church-preview p  { font-size:.8rem; color:rgba(255,255,255,.55); margin:0; }
.ic-app .ic-addr-card { background:var(--ic-white); border:1px solid var(--ic-border); border-radius:var(--ic-r); padding:14px 18px; display:flex; align-items:center; gap:13px; margin-bottom:14px; }
.ic-app .ic-addr-icon { font-size:1.4rem; flex-shrink:0; }
.ic-app .ic-addr-info strong { font-size:.88rem; color:var(--ic-navy); display:block; }
.ic-app .ic-addr-info span   { font-size:.76rem; color:var(--ic-text-muted); }
.ic-app .ic-transport-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:9px; margin-top:18px; }
.ic-app .ic-transport-card { background:var(--ic-white); border:1px solid var(--ic-border); border-radius:var(--ic-r-sm); padding:13px 9px; text-align:center; cursor:pointer; transition:all var(--ic-ease); font-size:.76rem; color:var(--ic-text-mid); }
.ic-app .ic-transport-card:hover { border-color:var(--ic-gold); color:var(--ic-navy); transform:translateY(-1px); }
.ic-app .ic-transport-icon { font-size:1.3rem; display:block; margin-bottom:5px; }

/* ── Reading plans ──────────────────────────────────────────────── */
.ic-app .ic-plans-list { display:flex; flex-direction:column; gap:14px; }
.ic-app .ic-plan-card { background:var(--ic-white); border:1px solid var(--ic-border); border-radius:var(--ic-r); padding:18px 22px; transition:all var(--ic-ease); }
.ic-app .ic-plan-card:hover { box-shadow:var(--ic-shadow-md); }
.ic-app .ic-plan-hdr { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:12px; }
.ic-app .ic-plan-title { font-family:var(--ic-serif); font-size:1.05rem; color:var(--ic-navy); }
.ic-app .ic-plan-desc  { font-size:.76rem; color:var(--ic-text-muted); margin-top:1px; }
.ic-app .ic-plan-badge { background:var(--ic-navy); color:white; font-size:.65rem; padding:4px 11px; border-radius:20px; white-space:nowrap; flex-shrink:0; }
.ic-app .ic-plan-meta  { display:flex; justify-content:space-between; font-size:.68rem; color:var(--ic-text-muted); margin-bottom:5px; }
.ic-app .ic-plan-passage { background:var(--ic-ivory); border-radius:9px; padding:10px 13px; display:flex; align-items:center; justify-content:space-between; margin-top:12px; gap:9px; }
.ic-app .ic-week-grid  { display:grid; grid-template-columns:repeat(7,1fr); gap:6px; margin-top:14px; }
.ic-app .ic-day-pill   { aspect-ratio:1; border-radius:7px; display:flex; flex-direction:column; align-items:center; justify-content:center; font-size:.6rem; font-weight:500; cursor:pointer; transition:all var(--ic-ease); border:1px solid var(--ic-border); background:var(--ic-white); color:var(--ic-text-muted); gap:1px; }
.ic-app .ic-day-pill .dp-d { font-size:.55rem; color:var(--ic-text-muted); }
.ic-app .ic-day-pill.done  { background:var(--ic-navy); color:white; border-color:var(--ic-navy); }
.ic-app .ic-day-pill.done .dp-d { color:rgba(255,255,255,.6); }
.ic-app .ic-day-pill.today { border-color:var(--ic-gold); color:var(--ic-gold); }

/* ── Media gallery ──────────────────────────────────────────────── */
.ic-app .ic-media-filters { display:flex; gap:7px; flex-wrap:wrap; margin-bottom:18px; }
.ic-app .ic-filter-pill { padding:5px 15px; border-radius:20px; border:1px solid var(--ic-border); background:var(--ic-white); font-size:.76rem; cursor:pointer; transition:all var(--ic-ease); color:var(--ic-text-mid); font-weight:500; }
.ic-app .ic-filter-pill:hover { border-color:var(--ic-navy); color:var(--ic-navy); }
.ic-app .ic-filter-pill.active { background:var(--ic-navy); color:white; border-color:var(--ic-navy); }
.ic-app .ic-media-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:11px; }
.ic-app .ic-media-item { border-radius:var(--ic-r-sm); overflow:hidden; aspect-ratio:4/3; position:relative; cursor:pointer; background:var(--ic-ivory-dark,#f0ece3); }
.ic-app .ic-media-thumb { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:2.4rem; transition:transform .3s ease; object-fit:cover; }
.ic-app .ic-media-item:hover .ic-media-thumb { transform:scale(1.06); }
.ic-app .ic-media-overlay { position:absolute; bottom:0; left:0; right:0; padding:7px 9px; background:linear-gradient(transparent,rgba(0,0,0,.6)); color:white; font-size:.7rem; font-weight:500; opacity:0; transition:opacity var(--ic-ease); }
.ic-app .ic-media-item:hover .ic-media-overlay { opacity:1; }
.ic-app .ic-media-badge { position:absolute; top:7px; right:7px; background:rgba(0,0,0,.65); color:white; font-size:.6rem; padding:2px 7px; border-radius:4px; }

/* ── Streaming ──────────────────────────────────────────────────── */
.ic-app .ic-stream-player { background:#000; border-radius:var(--ic-r-lg,20px); overflow:hidden; aspect-ratio:16/9; position:relative; margin-bottom:18px; }
.ic-app .ic-stream-placeholder { width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:11px; background:linear-gradient(135deg,#0a1628 0%,#1a3360 100%); color:white; }
.ic-app .ic-play-btn { width:60px; height:60px; border-radius:50%; background:rgba(255,255,255,.15); border:2px solid rgba(255,255,255,.3); display:flex; align-items:center; justify-content:center; font-size:20px; cursor:pointer; transition:all var(--ic-ease); }
.ic-app .ic-play-btn:hover { background:rgba(255,255,255,.25); transform:scale(1.1); }
.ic-app .ic-schedule-item { background:var(--ic-white); border:1px solid var(--ic-border); border-radius:var(--ic-r-sm); padding:13px 17px; display:flex; align-items:center; gap:13px; cursor:pointer; transition:all var(--ic-ease); margin-bottom:8px; }
.ic-app .ic-schedule-item:hover { border-color:var(--ic-gold); }
.ic-app .ic-schedule-day { background:var(--ic-navy); color:white; border-radius:6px; padding:5px 9px; font-size:.68rem; font-weight:600; text-align:center; min-width:46px; flex-shrink:0; }
.ic-app .ic-schedule-info strong { font-size:.88rem; color:var(--ic-navy); display:block; }
.ic-app .ic-schedule-info span   { font-size:.73rem; color:var(--ic-text-muted); }

/* ── Check-in ───────────────────────────────────────────────────── */
.ic-app .ic-checkin-card { background:var(--ic-white); border:1px solid var(--ic-border); border-radius:var(--ic-r-lg,20px); padding:36px 28px; text-align:center; box-shadow:var(--ic-shadow-md); max-width:420px; margin:0 auto; }
.ic-app .ic-checkin-done { background:#d4edda; border:1px solid #c3e6cb; border-radius:var(--ic-r-sm); padding:13px; color:#155724; font-size:.88rem; display:none; margin-bottom:14px; }
.ic-app .ic-checkin-done.show { display:block; }

/* ── Profile ────────────────────────────────────────────────────── */
.ic-app .ic-profile-header { background:linear-gradient(135deg,var(--ic-navy) 0%,#2d3f7c 100%); border-radius:var(--ic-r-lg,20px); padding:30px; display:flex; align-items:center; gap:22px; margin-bottom:22px; color:white; flex-wrap:wrap; }
.ic-app .ic-profile-photo-wrap { display:flex; flex-direction:column; align-items:center; gap:5px; }
.ic-app .ic-profile-photo { width:110px; height:110px; border-radius:50%; position:relative; overflow:hidden; border:3px solid rgba(255,255,255,.25); cursor:pointer; flex-shrink:0; }
.ic-app .ic-profile-photo img { width:100%; height:100%; object-fit:cover; display:block; }
.ic-app .ic-profile-photo-initials { width:100%; height:100%; background:linear-gradient(135deg,var(--ic-gold) 0%,var(--ic-bordeaux) 100%); display:flex; align-items:center; justify-content:center; font-family:var(--ic-serif); font-size:2.2rem; color:white; font-weight:600; }
.ic-app .ic-photo-edit-overlay { position:absolute; inset:0; background:rgba(0,0,0,.45); display:flex; flex-direction:column; align-items:center; justify-content:center; color:white; cursor:pointer; opacity:0; transition:opacity .22s; }
.ic-app .ic-profile-photo:hover .ic-photo-edit-overlay { opacity:1; }
.ic-app .ic-spinner { width:14px; height:14px; border-radius:50%; border:2px solid rgba(255,255,255,.3); border-top-color:white; animation:ic-spin .7s linear infinite; display:inline-block; }
@keyframes ic-spin { to{transform:rotate(360deg)} }
.ic-app .ic-profile-info h2 { font-family:var(--ic-serif); font-size:1.45rem; font-weight:500; margin:0 0 3px; }
.ic-app .ic-profile-info p  { font-size:.8rem; color:rgba(255,255,255,.55); margin:0 0 9px; }
.ic-app .ic-profile-stats { display:flex; gap:16px; flex-wrap:wrap; margin-top:12px; }
.ic-app .ic-ps-item { text-align:center; }
.ic-app .ic-ps-num   { font-family:var(--ic-serif); font-size:1.25rem; color:var(--ic-gold-light,#d4a843); }
.ic-app .ic-ps-label { font-size:.62rem; color:rgba(255,255,255,.4); }
/* Profile tabs */
.ic-app .ic-ptab { display:none; padding:20px 0 0; }
.ic-app .ic-ptab.active { display:block; animation:ic-fade .22s ease; }
/* Profile form grid */
.ic-app .ic-profile-form-grid { display:grid; grid-template-columns:1fr 1fr; gap:0 16px; }
.ic-app .ic-profile-form-grid .ic-col-2 { grid-column:1/-1; }
/* Timeline */
.ic-app .ic-timeline { display:flex; flex-direction:column; position:relative; }
.ic-app .ic-timeline::before { content:''; position:absolute; left:10px; top:12px; bottom:12px; width:2px; background:var(--ic-border); }
.ic-app .ic-timeline-item { display:flex; align-items:flex-start; gap:16px; padding:8px 0; }
.ic-app .ic-timeline-dot { width:22px; height:22px; border-radius:50%; flex-shrink:0; position:relative; z-index:1; border:2px solid white; box-shadow:0 0 0 2px var(--ic-border); }
.ic-app .ic-tdot-navy  { background:var(--ic-navy); }
.ic-app .ic-tdot-gold  { background:var(--ic-gold); }
.ic-app .ic-tdot-green { background:#1a7a4a; }
.ic-app .ic-timeline-content { flex:1; padding-bottom:14px; }
.ic-app .ic-tl-date  { font-size:.7rem; color:var(--ic-text-muted); margin-bottom:2px; }
.ic-app .ic-tl-title { font-size:.9rem; font-weight:500; color:var(--ic-navy); }
.ic-app .ic-tl-sub   { font-size:.75rem; color:var(--ic-text-muted); }

/* ── Auth ───────────────────────────────────────────────────────── */
.ic-app .ic-auth-wrap { max-width:410px; margin:0 auto; }
.ic-app .ic-auth-logo { text-align:center; margin-bottom:28px; }
.ic-app .ic-auth-logo .ic-auth-cross { width:52px; height:52px; background:var(--ic-navy); border-radius:13px; display:flex; align-items:center; justify-content:center; font-size:22px; color:var(--ic-gold-light,#d4a843); margin:0 auto 10px; }
.ic-app .ic-auth-logo h2 { font-family:var(--ic-serif); font-size:1.55rem; color:var(--ic-navy); margin:0; }
.ic-app .ic-auth-logo p  { font-size:.8rem; color:var(--ic-text-muted); margin:3px 0 0; }
.ic-app .ic-auth-card { background:var(--ic-white); border:1px solid var(--ic-border); border-radius:var(--ic-r-lg,20px); padding:30px; box-shadow:var(--ic-shadow-md); }

/* ── Donations table ────────────────────────────────────────────── */
.ic-app .ic-dt { width:100%; border-collapse:collapse; font-size:.83rem; }
.ic-app .ic-dt th { padding:11px 15px; text-align:left; font-size:.68rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--ic-text-muted); border-bottom:1px solid var(--ic-border); }
.ic-app .ic-dt td { padding:11px 15px; border-bottom:1px solid var(--ic-border); color:var(--ic-text-mid); }
.ic-app .ic-dt tr:last-child td { border-bottom:none; }
.ic-app .ic-dt tr:hover td { background:var(--ic-ivory); }

/* ── Overlay / mobile ───────────────────────────────────────────── */
.ic-app .ic-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:999; }
.ic-app .ic-overlay.show { display:block; }

/* ── Cultos (inline styles migrated here, scoped) ───────────────── */
.ic-app .ic-cultos-logo { text-align:center; margin-bottom:20px; }
.ic-app .ic-cultos-logo img { max-height:65px; max-width:200px; object-fit:contain; }
.ic-app .ic-cultos-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:16px; }
.ic-app .ic-culto-day-col { display:flex; flex-direction:column; gap:12px; }
.ic-app .ic-culto-day-header { background:var(--ic-navy); color:white; text-align:center; padding:8px 12px; border-radius:var(--ic-r-sm); font-size:.78rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; }
.ic-app .ic-culto-card { background:var(--ic-white); border:1px solid var(--ic-border); border-radius:var(--ic-r); overflow:hidden; box-shadow:var(--ic-shadow-sm); transition:transform .2s,box-shadow .2s; }
.ic-app .ic-culto-card:hover { transform:translateY(-2px); box-shadow:var(--ic-shadow-md); }
.ic-app .ic-culto-foto { position:relative; aspect-ratio:16/9; overflow:hidden; }
.ic-app .ic-culto-foto img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.ic-app .ic-culto-card:hover .ic-culto-foto img { transform:scale(1.04); }
.ic-app .ic-culto-foto-overlay { position:absolute; bottom:0; left:0; right:0; padding:6px 10px; background:linear-gradient(transparent,rgba(0,0,0,.6)); }
.ic-app .ic-culto-horario-badge,.ic-app .ic-culto-horario-badge-alt { background:var(--ic-gold); color:white; font-size:.72rem; font-weight:600; padding:3px 10px; border-radius:20px; }
.ic-app .ic-culto-sem-foto { background:var(--ic-navy); padding:14px 12px; display:flex; align-items:center; justify-content:center; aspect-ratio:16/9; }
.ic-app .ic-culto-info { padding:12px 14px; }
.ic-app .ic-culto-info h3 { font-family:var(--ic-serif); font-size:1rem; color:var(--ic-navy); margin:0 0 6px; font-weight:500; }
.ic-app .ic-culto-meta { display:flex; flex-direction:column; gap:3px; font-size:.75rem; color:var(--ic-text-muted); }
.ic-app .ic-culto-desc { font-size:.76rem; color:var(--ic-text-muted); margin:6px 0 0; line-height:1.5; }

/* ── Células (inline styles migrated here, scoped) ──────────────── */
.ic-app .ic-cel-filters { display:flex; flex-wrap:wrap; gap:7px; margin-bottom:20px; }
.ic-app .ic-cel-filter { padding:5px 15px; border-radius:20px; border:1px solid var(--ic-border); background:var(--ic-white); font-size:.76rem; cursor:pointer; transition:all .2s; color:var(--ic-text-mid); font-weight:500; font-family:var(--ic-sans); }
.ic-app .ic-cel-filter:hover { border-color:var(--ic-navy); color:var(--ic-navy); }
.ic-app .ic-cel-filter.active { background:var(--ic-navy); color:#fff; border-color:var(--ic-navy); }
.ic-app .ic-celulas-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px; }
.ic-app .ic-cel-card { background:#fff; border:1px solid var(--ic-border); border-radius:var(--ic-r); overflow:hidden; box-shadow:var(--ic-shadow-sm); transition:transform .2s,box-shadow .2s; display:flex; flex-direction:column; }
.ic-app .ic-cel-card:hover { transform:translateY(-3px); box-shadow:var(--ic-shadow-md); }
.ic-app .ic-cel-foto { position:relative; aspect-ratio:16/9; overflow:hidden; }
.ic-app .ic-cel-foto img { width:100%; height:100%; object-fit:cover; transition:transform .35s; }
.ic-app .ic-cel-card:hover .ic-cel-foto img { transform:scale(1.05); }
.ic-app .ic-cel-foto-placeholder { aspect-ratio:16/9; background:linear-gradient(135deg,var(--ic-navy) 0%,#2d4a9e 100%); display:flex; align-items:center; justify-content:center; font-size:2.5rem; position:relative; }
.ic-app .ic-cel-bairro-badge { position:absolute; bottom:9px; left:10px; background:rgba(0,0,0,.6); color:#fff; font-size:.68rem; padding:3px 10px; border-radius:20px; }
.ic-app .ic-cel-body { padding:16px; flex:1; display:flex; flex-direction:column; gap:8px; }
.ic-app .ic-cel-nome { font-family:var(--ic-serif); font-size:1.05rem; color:var(--ic-navy); margin:0; font-weight:500; line-height:1.3; }
.ic-app .ic-cel-info-row { display:flex; align-items:flex-start; gap:7px; font-size:.8rem; color:var(--ic-text-mid); line-height:1.4; }
.ic-app .ic-cel-lider { display:flex; align-items:center; gap:10px; padding:9px 11px; background:var(--ic-ivory); border-radius:var(--ic-r-sm); margin-top:4px; }
.ic-app .ic-cel-lider-avatar { width:32px; height:32px; border-radius:50%; background:linear-gradient(135deg,var(--ic-gold),var(--ic-bordeaux)); display:flex; align-items:center; justify-content:center; font-size:.85rem; color:#fff; font-weight:600; flex-shrink:0; }
.ic-app .ic-cel-desc { font-size:.76rem; color:var(--ic-text-muted); margin:0; line-height:1.5; }
.ic-app .ic-cel-actions { display:flex; gap:8px; margin-top:auto; padding-top:10px; flex-wrap:wrap; }
.ic-app .ic-cel-btn { flex:1; min-width:120px; display:inline-flex; align-items:center; justify-content:center; gap:6px; padding:9px 14px; border-radius:var(--ic-r-sm); font-size:.78rem; font-weight:600; text-decoration:none !important; transition:all .2s; cursor:pointer; font-family:var(--ic-sans); border:none; }
.ic-app .ic-cel-btn-map { background:var(--ic-navy); color:#fff !important; }
.ic-app .ic-cel-btn-map:hover { background:var(--ic-navy-soft); transform:translateY(-1px); }
.ic-app .ic-cel-btn-wa  { background:#25d366; color:#fff !important; }
.ic-app .ic-cel-btn-wa:hover { background:#1da855; transform:translateY(-1px); }
.ic-app .ic-cel-hidden { display:none !important; }

/* ── Verse shortcodes (standalone) ─────────────────────────────── */
.ic-verse-banner-sc { background:var(--ic-navy-soft,#243876); color:rgba(255,255,255,.85); font-family:'Cormorant Garamond',Georgia,serif; font-style:italic; font-size:.95rem; line-height:1.7; padding:1rem 1.5rem; border-radius:14px; }
.ic-verse-banner-sc cite { display:block; font-style:normal; font-size:.68rem; color:#d4a843; margin-top:5px; }
.ic-verse-card-sc { background:#fdf6e8; border:1px solid rgba(184,131,26,.3); border-radius:14px; padding:1.5rem; text-align:center; }
.ic-verse-card-sc p { font-family:'Cormorant Garamond',Georgia,serif; font-style:italic; font-size:1.02rem; line-height:1.7; margin:0 0 .5rem; }
.ic-verse-card-sc cite { font-size:.73rem; color:#b8831a; font-weight:600; font-style:normal; }

/* ── Toast ──────────────────────────────────────────────────────── */
#ic-toast { position:fixed; bottom:22px; left:50%; transform:translateX(-50%) translateY(10px); background:#0f1f3d; color:white; padding:11px 22px; border-radius:100px; font-family:Outfit,system-ui,sans-serif; font-size:.81rem; font-weight:500; box-shadow:0 8px 24px rgba(0,0,0,.2); z-index:99999; opacity:0; transition:opacity .28s,transform .28s; white-space:nowrap; pointer-events:none; }

/* ── Responsive ─────────────────────────────────────────────────── */
@media(max-width:900px){
  .ic-app .ic-stats    { grid-template-columns:repeat(2,1fr); }
  .ic-app .ic-qa-grid  { grid-template-columns:repeat(2,1fr); }
  .ic-app .ic-g2,.ic-app .ic-g3 { grid-template-columns:1fr; }
}
@media(max-width:768px){
  .ic-app .ic-sidebar { transform:translateX(-100%); }
  .ic-app .ic-sidebar.open { transform:translateX(0); }
  .ic-app .ic-main { margin-left:0; }
  .ic-app .ic-menu-btn { display:flex; }
  .ic-app .ic-content { padding:18px 14px; }
  .ic-app .ic-topbar  { padding:0 14px; }
  .ic-app .ic-welcome { padding:22px 18px; }
  .ic-app .ic-welcome-name { font-size:1.45rem; }
  .ic-app .ic-stats    { grid-template-columns:repeat(2,1fr); gap:9px; }
  .ic-app .ic-qa-grid  { grid-template-columns:repeat(2,1fr); gap:9px; }
  .ic-app .ic-profile-header { flex-direction:column; text-align:center; }
  .ic-app .ic-media-grid { grid-template-columns:repeat(2,1fr); }
  .ic-app .ic-profile-form-grid { grid-template-columns:1fr; }
  .ic-app .ic-profile-form-grid .ic-col-2 { grid-column:1; }
}
@media(max-width:480px){
  .ic-app .ic-stats { grid-template-columns:1fr 1fr; }
  .ic-app .ic-transport-grid { grid-template-columns:repeat(3,1fr); }
  .ic-app .ic-cultos-grid { grid-template-columns:1fr 1fr; }
  .ic-app .ic-celulas-grid { grid-template-columns:1fr; }
  .ic-app .ic-cel-actions { flex-direction:column; }
  .ic-app .ic-cel-btn { flex:none; width:100%; }
}

/* Standalone shortcodes: show .ic-page directly (not portal navigation) */
.ic-app.ic-standalone .ic-page { display: block !important; }
