
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F7F3EE;--surface:#FFFFFF;--primary:#7A2035;--primary-dark:#5a1526;
  --accent:#C4813A;--accent-light:#E8A355;--text:#1A2E35;--text-muted:#7A8C92;
  --border:#E5DDD5;--green:#4A8C6F;--green-bg:#EBF5EF;--maroon:#6B1A2A;
}
html{-webkit-tap-highlight-color:transparent}
body{font-family:'Inter',-apple-system,sans-serif;background:#3d0f1a;min-height:100vh;
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:20px 16px}
.desktop-note{color:rgba(255,255,255,.5);font-size:11px;text-align:center;margin-bottom:14px;letter-spacing:.3px}
.desktop-note strong{color:rgba(255,255,255,.8);font-weight:600}
@media(max-width:430px){body{background:var(--bg);padding:0}.desktop-note{display:none}
  .phone{position:fixed!important;inset:0!important;width:100%!important;height:100%!important;border-radius:0!important;box-shadow:none!important}}
.phone{width:390px;height:820px;background:var(--bg);border-radius:40px;overflow:hidden;
  display:flex;flex-direction:column;box-shadow:0 40px 100px rgba(0,0,0,.5),inset 0 0 0 1px rgba(255,255,255,.08);position:relative}
.status-bar{background:var(--primary);color:white;padding:14px 20px 10px;
  display:flex;justify-content:space-between;align-items:center;font-size:12px;font-weight:600;flex-shrink:0}
.status-logo{display:flex;align-items:center;gap:6px}
.status-logo-text{font-family:'Playfair Display',Georgia,serif;font-size:13px;font-weight:600;letter-spacing:2px;color:white}
.screens{flex:1;overflow:hidden;position:relative}
.screen{position:absolute;inset:0;overflow-y:auto;display:none;background:var(--bg);scrollbar-width:none}
.screen::-webkit-scrollbar{display:none}
.screen.active{display:block}
.bottom-nav{background:var(--surface);border-top:1px solid var(--border);display:flex;padding:8px 0 16px;flex-shrink:0}
.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 0;
  cursor:pointer;background:none;border:none;transition:transform .15s}
.nav-btn:active{transform:scale(.92)}
.nav-btn svg{width:22px;height:22px;stroke:var(--text-muted);transition:stroke .2s;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.nav-btn span{font-size:10px;color:var(--text-muted);font-weight:500;transition:color .2s}
.bottom-nav:has(.nav-btn:nth-child(6)) .nav-btn span{font-size:9px}
.nav-btn.active svg{stroke:var(--accent)}.nav-btn.active span{color:var(--accent)}
.toast{position:absolute;bottom:12px;left:20px;right:20px;background:var(--text);color:white;
  font-size:13px;padding:12px 16px;border-radius:12px;text-align:center;opacity:0;
  transform:translateY(8px);transition:all .3s;z-index:999;pointer-events:none}
.toast.visible{opacity:1;transform:translateY(0)}
.screen-hdr{background:var(--primary);color:white;padding:20px 20px 24px}
.screen-hdr h1{font-size:22px;font-weight:700;margin-bottom:4px;letter-spacing:-.3px}
.screen-hdr p{font-size:12px;opacity:.65}
#back-btn{position:fixed;top:12px;left:12px;z-index:50;background:rgba(255,255,255,0.18);border:none;color:white;width:34px;height:34px;border-radius:50%;font-size:18px;cursor:pointer;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px);line-height:1}
#back-btn.visible{display:flex}
.section-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin:12px 0 8px}
.content{padding:16px}
.btn-primary{background:var(--accent);color:white;border:none;border-radius:14px;padding:15px 24px;
  font-size:15px;font-weight:600;width:100%;cursor:pointer;font-family:'Inter',sans-serif;transition:all .2s}
.btn-primary:active{transform:scale(.97);background:#b5722d}
.btn-secondary{background:transparent;color:var(--primary);border:1.5px solid var(--primary);
  border-radius:14px;padding:13px 24px;font-size:14px;font-weight:500;width:100%;
  cursor:pointer;font-family:'Inter',sans-serif;transition:all .2s;margin-top:10px}
.btn-secondary:active{transform:scale(.97)}
.chip{background:var(--surface);border:1.5px solid var(--border);border-radius:20px;padding:6px 14px;
  font-size:12px;font-weight:500;color:var(--text-muted);white-space:nowrap;cursor:pointer;flex-shrink:0;transition:all .2s}
.chip.active{background:var(--primary);border-color:var(--primary);color:white}
.inicio-hero{background:linear-gradient(160deg,var(--primary) 0%,var(--primary-dark) 100%);color:white;padding:20px 20px 28px}
.app-logo-row{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.12)}
.app-name-block .app-name{font-family:'Playfair Display',Georgia,serif;font-size:22px;font-weight:600;letter-spacing:3px;color:white;line-height:1}
.app-name-block .app-tagline{font-size:10px;color:rgba(255,255,255,.55);letter-spacing:2.5px;text-transform:uppercase;margin-top:4px}
.inicio-greeting{font-size:13px;opacity:.65;margin-bottom:4px}
.inicio-name{font-family:'Playfair Display',Georgia,serif;font-size:28px;font-weight:400;margin-bottom:4px}
.inicio-date{font-size:12px;opacity:.55}
.streak-row{margin-top:14px;background:rgba(255,255,255,.12);border-radius:12px;padding:10px 14px;
  display:inline-flex;align-items:center;gap:8px;font-size:13px}
.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.quick-card{background:var(--surface);border-radius:16px;padding:16px;cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.05);transition:transform .15s}
.quick-card:active{transform:scale(.96)}
.qc-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:10px}
.qc-icon.teal{background:#E5F0F3}.qc-icon.amber{background:#FDF3E5}.qc-icon.sage{background:var(--green-bg)}.qc-icon.slate{background:#EAECF4}.qc-icon.violet{background:#F0EAFA}
.recurso-section{margin-bottom:24px}
.recurso-cat-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-secondary);padding:0 16px 8px;margin-top:4px}
.recurso-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;margin:0 16px 10px;padding:14px;display:flex;align-items:center;gap:12px}
.recurso-icon{font-size:22px;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#F5F5F7;border-radius:9px}
.recurso-body{flex:1;min-width:0}
.recurso-titulo{font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.3;margin-bottom:3px}
.recurso-desc{font-size:12px;color:var(--text-secondary);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.recurso-btn{flex-shrink:0;background:var(--primary);color:white;border:none;border-radius:8px;padding:7px 12px;font-size:12px;font-weight:600;cursor:pointer;text-decoration:none;white-space:nowrap}
.recurso-empty{text-align:center;padding:48px 24px;color:var(--text-secondary)}
.recurso-tipo-hdr{font-size:14px;font-weight:700;color:var(--text);padding:16px 16px 8px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border);margin:0 16px 2px}
.quick-card h3{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}
.quick-card p{font-size:11px;color:var(--text-muted);line-height:1.4}
.info-card{background:var(--surface);border-radius:16px;padding:16px;box-shadow:0 2px 8px rgba(0,0,0,.05);margin-bottom:10px}
.info-card-hdr{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.info-card h3{font-size:14px;font-weight:600;color:var(--text)}
.badge{font-size:10px;font-weight:600;background:var(--green-bg);color:var(--green);padding:3px 8px;border-radius:20px}
.info-card p{font-size:13px;color:var(--text-muted);line-height:1.5}
.progress-bar-row{display:flex;gap:6px;padding:16px 20px 4px}
.pb-seg{flex:1;height:4px;background:var(--border);border-radius:2px;transition:background .4s}
.pb-seg.done{background:var(--accent)}.pb-seg.current{background:var(--accent-light)}
.examen-body{padding:16px 20px}
.step-view{display:none}.step-view.active{display:block}
.step-eyebrow{font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:6px}
.step-title{font-size:22px;font-weight:700;color:var(--text);margin-bottom:10px;line-height:1.25;letter-spacing:-.2px}
.step-desc{font-size:14px;color:var(--text-muted);line-height:1.65;margin-bottom:16px}
.prompt-box{background:var(--green-bg);border-left:3px solid var(--green);border-radius:0 12px 12px 0;padding:14px 16px;margin-bottom:20px}
.prompt-box p{font-style:italic;font-size:14px;color:var(--text);line-height:1.55}
.silence-hint{text-align:center;font-size:12px;color:var(--text-muted);margin-bottom:20px}
.diary-label{font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px}
.diary-area{width:100%;border:1.5px solid var(--border);border-radius:12px;padding:14px;font-size:14px;
  font-family:'Inter',sans-serif;color:var(--text);resize:none;height:110px;background:var(--surface);
  outline:none;margin-bottom:14px;line-height:1.5}
.diary-area:focus{border-color:var(--accent)}
.diary-area::placeholder{color:var(--text-muted)}
.complete-wrap{text-align:center;padding:24px 16px}
.complete-icon{font-size:52px;margin-bottom:12px}
.complete-title{font-size:22px;font-weight:700;color:var(--text);margin-bottom:8px}
.complete-text{font-size:14px;color:var(--text-muted);line-height:1.6;margin-bottom:20px}
.lectura-body{padding:16px}
.gospel-ref{font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:6px}
.gospel-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:14px;letter-spacing:-.2px}
.gospel-card{background:var(--surface);border-radius:16px;padding:18px;margin-bottom:14px;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.gospel-text{font-size:14px;color:var(--text);line-height:1.8}
.gospel-text p{margin-bottom:12px}.gospel-text p:last-child{margin-bottom:0}
.ai-card{background:linear-gradient(135deg,var(--primary-dark),var(--primary));color:white;border-radius:16px;padding:18px;margin-bottom:14px}
.ai-label{font-size:9px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;opacity:.6;margin-bottom:10px}
.ai-question{font-size:17px;font-style:italic;font-weight:500;line-height:1.5;color:rgba(255,255,255,.95)}
.ai-loading{opacity:.6;font-size:14px;display:flex;align-items:center;gap:8px}
.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:white;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.no-key-notice{background:rgba(255,255,255,.1);border-radius:10px;padding:12px;font-size:13px;opacity:.8;line-height:1.5}
.source-note{font-size:11px;color:var(--text-muted);text-align:center;margin-bottom:14px}
.liturgical-info{background:var(--surface);border-radius:12px;padding:12px 14px;margin-bottom:14px;
  display:flex;align-items:center;gap:10px;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.litur-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.litur-text{font-size:12px;color:var(--text-muted);line-height:1.3}
.search-box{margin:14px 16px 0;display:flex;align-items:center;background:var(--surface);
  border-radius:12px;padding:10px 14px;gap:8px;border:1.5px solid var(--border)}
.search-box svg{width:16px;height:16px;stroke:var(--text-muted);flex-shrink:0;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.search-box input{border:none;outline:none;font-size:14px;color:var(--text);background:transparent;width:100%;font-family:'Inter',sans-serif}
.search-box input::placeholder{color:var(--text-muted)}
.filter-row{display:flex;gap:8px;padding:12px 16px 4px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}
.filter-row::-webkit-scrollbar{display:none}
.center-card{background:var(--surface);border-radius:16px;padding:16px;margin:10px 16px 0;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.center-card.hidden{display:none}
.center-name{font-size:15px;font-weight:600;color:var(--text);margin-bottom:2px}
.center-loc{font-size:12px;color:var(--accent);margin-bottom:8px;display:flex;align-items:center;gap:4px}
.center-desc{font-size:13px;color:var(--text-muted);line-height:1.5;margin-bottom:12px}
.center-actions{display:flex;gap:8px}
.ca-btn{flex:1;background:#F2F6F8;border:none;border-radius:8px;padding:9px 6px;font-size:11px;font-weight:500;color:var(--primary);cursor:pointer;text-align:center;transition:background .2s}
.ca-btn:active{background:#dae3e7}
.tag{display:inline-block;font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;margin-bottom:8px}
.tag.priority{background:#FDF3E5;color:var(--accent)}.tag.regular{background:var(--green-bg);color:var(--green)}
.event-card{background:var(--surface);border-radius:16px;padding:14px;margin:10px 16px 0;
  box-shadow:0 2px 8px rgba(0,0,0,.05);display:flex;gap:12px}
.event-card.hidden{display:none}
.date-box{background:var(--primary);color:white;border-radius:10px;width:50px;height:58px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0}
.date-day{font-size:24px;font-weight:700;line-height:1}
.date-mon{font-size:10px;text-transform:uppercase;opacity:.8;letter-spacing:.5px}
.event-content{flex:1;min-width:0}
.event-type{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--accent);margin-bottom:2px}
.event-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:3px}
.event-info{margin-top:6px;display:flex;flex-direction:column;gap:4px}
.event-info-row{font-size:12px;color:var(--text-muted);line-height:1.4;display:flex;align-items:flex-start;gap:5px}
.event-info-row .ei-icon{flex-shrink:0;font-size:13px;line-height:1.3}
.event-info-row .ei-text{flex:1;min-width:0}
.event-price{font-size:11px;font-weight:600;color:var(--green);margin-top:2px}
.event-inscribirse{background:transparent;border:1px solid var(--border);border-radius:8px;
  font-size:11px;font-weight:500;color:var(--primary);padding:4px 10px;cursor:pointer;margin-top:6px;font-family:'Inter',sans-serif}
.event-inscribirse:active{background:var(--border)}
.month-sep{padding:16px 16px 6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted)}
.month-sep.hidden{display:none}
.perfil-hdr{background:var(--primary);color:white;padding:24px 20px 28px;text-align:center}
.perfil-avatar{width:72px;height:72px;background:rgba(255,255,255,.15);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 12px}
.perfil-hdr h1{font-size:20px;font-weight:700}
.perfil-hdr p{font-size:12px;opacity:.65;margin-top:2px}
.stat-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:12px}
.stat-card{background:var(--surface);border-radius:14px;padding:14px 10px;text-align:center}
.stat-num{font-size:26px;font-weight:700;color:var(--primary);margin-bottom:2px}
.stat-label{font-size:11px;color:var(--text-muted);line-height:1.3}
.perfil-section{background:var(--surface);border-radius:16px;overflow:hidden;margin-bottom:12px}
.perfil-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;
  border-bottom:1px solid var(--border);cursor:pointer}
.perfil-row:last-child{border-bottom:none}
.perfil-row-left{display:flex;align-items:center;gap:12px}
.perfil-row-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px}
.perfil-row-icon.teal{background:#E5F0F3}.perfil-row-icon.amber{background:#FDF3E5}
.perfil-row-icon.sage{background:var(--green-bg)}.perfil-row-icon.slate{background:#EAECF4}
.perfil-row h3{font-size:14px;font-weight:500;color:var(--text)}
.perfil-row p{font-size:12px;color:var(--text-muted)}
.chevron{color:var(--text-muted);font-size:14px}
.diary-entry-card{background:var(--surface);border-radius:14px;padding:14px;margin-bottom:10px}
.diary-date{font-size:11px;color:var(--accent);font-weight:600;margin-bottom:5px}
.diary-text{font-size:13px;color:var(--text-muted);line-height:1.5}
.diary-type-badge{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;
  padding:2px 6px;border-radius:10px;margin-left:6px;background:var(--green-bg);color:var(--green)}
.diary-type-badge.lectura{background:#FDF3E5;color:var(--accent)}
.empty-state{text-align:center;padding:32px 16px;color:var(--text-muted)}
.empty-state .icon{font-size:40px;margin-bottom:10px}
.empty-state p{font-size:13px;line-height:1.5}
.modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:flex-end;
  z-index:500;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-overlay.visible{opacity:1;pointer-events:all}
.modal-sheet{background:var(--surface);border-radius:20px 20px 0 0;padding:20px;width:100%;
  transform:translateY(30px);transition:transform .3s;position:relative;max-height:85%;overflow-y:auto}
.modal-overlay.visible .modal-sheet{transform:translateY(0)}
.modal-sheet h2{font-size:18px;font-weight:600;color:var(--text);margin-bottom:6px}
.modal-sheet .sub{font-size:13px;color:var(--text-muted);line-height:1.5;margin-bottom:16px}
.form-field{margin-bottom:12px}
.form-label{font-size:12px;font-weight:600;color:var(--text);margin-bottom:5px;display:block}
.form-input{width:100%;border:1.5px solid var(--border);border-radius:10px;padding:11px 14px;
  font-size:14px;font-family:'Inter',sans-serif;color:var(--text);outline:none;background:var(--bg)}
.form-input:focus{border-color:var(--accent)}
.form-select{width:100%;border:1.5px solid var(--border);border-radius:10px;padding:11px 14px;
  font-size:14px;font-family:'Inter',sans-serif;color:var(--text);outline:none;background:var(--bg);appearance:none;cursor:pointer}
.modal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:22px;cursor:pointer;color:var(--text-muted)}

/* REGISTRO */
#registro-overlay{position:fixed;inset:0;z-index:9999;background:var(--primary);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:32px 24px;overflow-y:auto;box-sizing:border-box}
#registro-overlay.hidden{display:none!important}
.reg-logo{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:32px}
.reg-logo-icon{width:64px;height:64px;background:rgba(255,255,255,.12);border-radius:20px;
  display:flex;align-items:center;justify-content:center}
.reg-logo-title{font-family:'Playfair Display',Georgia,serif;font-size:28px;font-weight:600;
  letter-spacing:4px;color:white}
.reg-logo-sub{font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:rgba(255,255,255,.5);margin-top:2px}
.reg-card{background:white;border-radius:24px;padding:24px;width:100%;max-width:360px}
.reg-card h2{font-size:20px;font-weight:700;color:var(--text);
  margin-bottom:4px}
.reg-card .reg-intro{font-size:13px;color:var(--text-muted);margin-bottom:20px;line-height:1.5}
.reg-field{margin-bottom:14px}
.reg-label{display:block;font-size:11px;font-weight:700;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.reg-input,.reg-select{width:100%;border:1.5px solid var(--border);border-radius:12px;
  padding:12px 14px;font-size:14px;font-family:'Inter',sans-serif;color:var(--text);
  background:var(--bg);outline:none;transition:border-color .2s;-webkit-appearance:none;
  box-sizing:border-box}
.reg-input:focus,.reg-select:focus{border-color:var(--primary)}
.reg-input.error,.reg-select.error{border-color:#e53e3e}
.reg-error{font-size:11px;color:#e53e3e;margin-top:4px;display:none}
.reg-error.visible{display:block}
.reg-btn{width:100%;background:var(--accent);color:white;border:none;border-radius:14px;
  padding:15px;font-size:15px;font-weight:600;font-family:'Inter',sans-serif;
  cursor:pointer;margin-top:8px;transition:all .2s}
.reg-btn:active{transform:scale(.97);background:#b5722d}
.reg-privacy{font-size:11px;color:var(--text-muted);text-align:center;margin-top:12px;line-height:1.5}


/* FLYER EN EVENTO */
.event-flyer{width:100%;border-radius:10px 10px 0 0;object-fit:cover;max-height:160px;display:block;cursor:pointer}
.event-flyer-wrap{overflow:hidden;border-radius:10px 10px 0 0;margin:-1px -1px 0}



#pwa-banner{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(120px);
  width:calc(100% - 40px);max-width:370px;background:white;border-radius:18px;
  box-shadow:0 8px 32px rgba(122,32,53,0.25);padding:16px 18px;
  display:flex;align-items:center;gap:14px;z-index:9998;
  transition:transform .35s cubic-bezier(.34,1.56,.64,1);pointer-events:none;opacity:0}
#pwa-banner.visible{transform:translateX(-50%) translateY(0);pointer-events:all;opacity:1}
.pwa-icon{width:48px;height:48px;background:#7A2035;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center}
.pwa-text{flex:1;min-width:0}
.pwa-text strong{display:block;font-size:13px;font-weight:600;color:#1A2E35;margin-bottom:2px}
.pwa-text span{font-size:11px;color:#7A8C92;line-height:1.4}
.pwa-btn{background:#7A2035;color:white;border:none;border-radius:10px;
  padding:8px 14px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0}
.pwa-close{background:none;border:none;color:#7A8C92;font-size:18px;cursor:pointer;
  padding:0 0 0 6px;flex-shrink:0;line-height:1}

/* ── Skeleton loaders ─────────────────────────────────── */
@keyframes sk-shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
.sk-list{display:flex;flex-direction:column;gap:12px;padding:12px 16px 0}
.sk-card{background:var(--surface);border-radius:14px;padding:16px;
  border:1px solid var(--border);display:flex;flex-direction:column;gap:10px}
.sk-line{border-radius:6px;height:12px;
  background:linear-gradient(90deg,#e8e0d8 25%,#f2ede8 50%,#e8e0d8 75%);
  background-size:200% 100%;
  animation:sk-shimmer 1.4s infinite}
.sk-title{height:15px;width:65%}
.sk-label{height:10px;width:30%}
.sk-sub{width:90%}
.sk-short{width:50%}
.sk-row{display:flex;gap:8px;margin-top:4px}
.sk-btn{height:30px;width:80px;border-radius:8px;
  background:linear-gradient(90deg,#e8e0d8 25%,#f2ede8 50%,#e8e0d8 75%);
  background-size:200% 100%;
  animation:sk-shimmer 1.4s infinite}
