/* =========================================================================
   Jirari — espace viewer + fiche cinématique (complète app.css)
   ====================================================================== */

.jx-espace{padding-bottom:calc(96px + env(safe-area-inset-bottom))}
.jx-espace .jx-screen{position:absolute}
.jx-espace .jx-screen.is-active{position:relative}
.jx-espace-loading{gap:14px}
.jx-espace-loading p{color:var(--ink-soft)}

/* Vues (pages) commutées par le menu de pied de page */
.jx-view{display:none}
.jx-view.is-active{display:block;animation:viewIn .5s cubic-bezier(.2,1,.3,1) both}
@keyframes viewIn{from{opacity:0;transform:translateX(32px)}to{opacity:1;transform:none}}
.jx-view-title{font-family:var(--font-fun);font-size:clamp(22px,7vw,28px);font-weight:800;text-align:center;margin:2px 0 18px;text-shadow:var(--text-shadow);animation:cardIn .5s both}

.jx-or{color:var(--ink-dim);margin:16px 0 8px;font-size:13px}

/* Mon vœu (récap) */
.jx-myvoeu{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}
.jx-myvoeu .mv-photo{width:140px;height:140px;border-radius:24px;object-fit:cover;border:3px solid var(--c-accent);box-shadow:var(--shadow)}
.jx-myvoeu .mv-nom{font-family:var(--font-fun);font-size:24px;font-weight:800;margin:0}
.jx-myvoeu .mv-order{display:inline-block;background:rgba(255,255,255,.1);border:1px solid var(--glass-brd);padding:5px 12px;border-radius:999px;font-size:13px}
.jx-myvoeu .mv-msg{color:var(--ink-soft);font-style:italic;font-size:16px}
.jx-myvoeu .mv-cine-btn{margin-top:6px}

/* Stats */
.jx-stats-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;width:100%;max-width:500px;margin:16px auto}
.jx-stat-card{background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--radius-sm);padding:20px 14px;text-align:center;backdrop-filter:blur(10px);animation:cardIn .5s both}
.jx-stats-row .jx-stat-card:nth-child(2){animation-delay:.12s}
.jx-stat-num{display:block;font-family:var(--font-fun);font-size:40px;font-weight:800;color:var(--c-accent);line-height:1}
.jx-stat-label{display:block;color:var(--ink-soft);font-size:13px;margin-top:6px}
.jx-stat-emo{font-size:38px}
.jx-stat-card--gift{background:linear-gradient(135deg,color-mix(in srgb,var(--c-primary) 25%,transparent),color-mix(in srgb,var(--c-secondary) 25%,transparent))}

/* Timeline */
.jx-timeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;text-align:left}
.jx-tl-item{display:flex;align-items:center;gap:13px;background:rgba(255,255,255,.05);border:1px solid var(--glass-brd);border-radius:16px;padding:11px 13px;animation:cardIn .4s both}
.jx-tl-avatar{flex:none;width:62px;height:62px;border-radius:14px;object-fit:cover;background:linear-gradient(135deg,var(--c-primary),var(--c-secondary));display:grid;place-items:center;font-weight:700;font-size:24px;color:#fff;box-shadow:0 4px 14px rgba(0,0,0,.35)}
.jx-tl-body{flex:1;min-width:0}
.jx-tl-nom{font-weight:700;font-size:15px}
.jx-tl-msg{color:var(--ink-dim);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.jx-tl-ago{flex:none;font-size:12px;color:var(--c-accent);background:rgba(255,210,63,.12);padding:4px 9px;border-radius:999px}

/* Galerie complète */
.jx-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.jx-gallery-item{position:relative;border-radius:14px;overflow:hidden;background:rgba(255,255,255,.06);border:1px solid var(--glass-brd);aspect-ratio:1/1;animation:cardIn .45s both}
.jx-gallery-item img{width:100%;height:100%;object-fit:cover}
.jx-gallery-cap{position:absolute;left:0;right:0;bottom:0;padding:8px;background:linear-gradient(transparent,rgba(0,0,0,.75));font-size:12px;font-weight:600}
.jx-gallery-noimg{display:grid;place-items:center;height:100%;font-size:30px}
@media (min-width:560px){.jx-gallery{grid-template-columns:repeat(3,1fr)}}

/* =================== FICHE CINÉMATIQUE =================== */
.jx-cine-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:70px 18px 40px;min-height:100vh;min-height:100dvh}
.jx-back-link{position:fixed;top:14px;left:14px;z-index:8;background:rgba(0,0,0,.4);border:1px solid var(--glass-brd);padding:8px 14px;border-radius:999px;font-size:14px;text-decoration:none;backdrop-filter:blur(8px)}
.jx-cine{position:relative;z-index:2;width:100%;max-width:520px;text-align:center;animation:cineIn 1s cubic-bezier(.2,.9,.2,1) both}
@keyframes cineIn{from{opacity:0;transform:translateY(40px) scale(.94)}to{opacity:1;transform:none}}
.jx-cine-stage{position:relative}
.jx-cine-photo{position:relative;width:230px;height:230px;margin:0 auto 18px;border-radius:30px;overflow:hidden;border:4px solid transparent;background:linear-gradient(var(--c-bg),var(--c-bg)) padding-box,linear-gradient(135deg,var(--c-primary),var(--c-accent),var(--c-secondary)) border-box;box-shadow:var(--shadow);animation:cinePhoto 1.1s .2s both}
@keyframes cinePhoto{from{opacity:0;transform:scale(.6) rotate(-8deg)}to{opacity:1;transform:none}}
.jx-cine-photo img{width:100%;height:100%;object-fit:cover}
.jx-cine-shine{position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.45) 50%,transparent 70%);transform:translateX(-120%);animation:shine 2.6s 1.2s ease-in-out infinite}
@keyframes shine{0%{transform:translateX(-120%)}60%,100%{transform:translateX(120%)}}
.jx-cine-card{background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--radius);padding:24px;backdrop-filter:blur(14px);animation:cardIn .8s .5s both}
.jx-cine-order{display:inline-block;background:rgba(255,255,255,.1);padding:5px 13px;border-radius:999px;font-size:13px;margin-bottom:8px}
.jx-cine-nom{font-family:var(--font-fun);font-size:clamp(26px,8vw,38px);font-weight:800;margin:0 0 14px;background:linear-gradient(90deg,var(--c-accent),var(--c-primary));-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 2px 6px rgba(0,0,0,.45))}
.jx-cine-msg{font-size:19px;font-style:italic;color:var(--ink);margin:0 0 16px;line-height:1.6;border:none;padding:0 6px;position:relative}
.jx-cine-msg::before{content:"“";font-size:50px;color:var(--c-accent);opacity:.5;line-height:0;vertical-align:-.2em}
.jx-cine-meta{display:flex;gap:10px;align-items:center;justify-content:center;flex-wrap:wrap;color:var(--ink-dim);font-size:13px}
.jx-chip-owner{background:var(--c-accent);color:#3a2a00;font-weight:700;padding:4px 10px;border-radius:999px}
.jx-cine--locked{background:var(--glass);border:1px solid var(--glass-brd);border-radius:var(--radius);padding:34px 24px;backdrop-filter:blur(14px)}
.jx-lock-emoji{font-size:64px;margin-bottom:10px;animation:bob 2.4s ease-in-out infinite}

/* Navigation entre vœux (carousel cinématique) */
.jx-cine-nav{display:flex;align-items:center;justify-content:center;gap:18px;margin:24px auto 0;position:relative;z-index:3;animation:cardIn .6s .6s both}
.jx-cine-arrow{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;cursor:pointer;
	background:var(--glass);border:1px solid var(--glass-brd);backdrop-filter:blur(10px);color:#fff;
	transition:transform .15s,background .2s,box-shadow .2s;box-shadow:0 6px 18px rgba(0,0,0,.3)}
.jx-cine-arrow:hover{background:rgba(255,255,255,.18)}
.jx-cine-arrow:active{transform:scale(.88)}
.jx-cine-arrow svg{width:26px;height:26px;fill:none;stroke:#fff;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.jx-cine-counter{font-family:var(--font-fun);font-weight:700;font-size:16px;color:var(--ink-soft);min-width:64px;text-align:center;text-shadow:var(--text-shadow)}

/* =================== MENU MOBILE-APP (barre premium) =================== */
.jx-tabbar{position:fixed;left:0;right:0;bottom:0;z-index:30;display:flex;align-items:flex-end;justify-content:space-around;gap:2px;
	padding:14px 10px calc(12px + env(safe-area-inset-bottom));
	background:var(--tabbar-bg);
	backdrop-filter:blur(22px) saturate(1.4);-webkit-backdrop-filter:blur(22px) saturate(1.4);
	border-top:1px solid rgba(255,255,255,.14);box-shadow:0 -14px 44px rgba(0,0,0,.55)}
.jx-tabbar[hidden]{display:none}
.jx-tabbar::before{content:"";position:absolute;left:16%;right:16%;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent)}
.jx-tab{position:relative;flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:5px;
	background:none;border:none;cursor:pointer;font-family:inherit;padding:4px 2px;
	color:var(--ink-dim);font-size:10.5px;font-weight:600;transition:color .25s,transform .14s}
.jx-tab-lbl{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.jx-tab-ic{position:relative;width:28px;height:28px;display:grid;place-items:center;transition:transform .32s cubic-bezier(.2,1.7,.4,1)}
.jx-tab-ic svg{width:25px;height:25px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;transition:stroke .25s,filter .25s}
.jx-tab:active{transform:scale(.9)}
.jx-tab.is-active{color:var(--tab-active-ink)}
.jx-tab.is-active .jx-tab-ic{transform:translateY(-3px)}
.jx-tab.is-active .jx-tab-ic::before{content:"";position:absolute;inset:-9px;border-radius:50%;z-index:-1;
	background:radial-gradient(closest-side,color-mix(in srgb,var(--c-accent) 60%,transparent),transparent);animation:tabGlow .35s ease both}
.jx-tab.is-active .jx-tab-ic svg{stroke:var(--c-accent);filter:drop-shadow(0 2px 7px color-mix(in srgb,var(--c-accent) 75%,transparent))}
@keyframes tabGlow{from{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}
/* Bouton d'action central surélevé (FAB) */
.jx-tab--fab{justify-content:flex-end}
.jx-fab{position:relative;display:grid;place-items:center;width:60px;height:60px;margin-top:-32px;border-radius:50%;
	background:linear-gradient(135deg,var(--c-primary),var(--c-accent));
	box-shadow:0 12px 28px color-mix(in srgb,var(--c-primary) 60%,transparent),0 0 0 6px rgba(10,5,24,.94);
	transition:transform .25s cubic-bezier(.2,1.8,.4,1)}
.jx-fab::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:2px solid color-mix(in srgb,var(--c-accent) 55%,transparent);animation:fabPulse 2.4s ease-out infinite}
@keyframes fabPulse{0%{transform:scale(.85);opacity:.7}100%{transform:scale(1.4);opacity:0}}
.jx-fab svg{width:28px;height:28px;fill:none;stroke:#fff;stroke-width:2.6;stroke-linecap:round}
.jx-tab--fab:active .jx-fab{transform:scale(.9) rotate(90deg)}

.jx-sheet-ic{width:66px;height:66px;margin:0 auto 8px;border-radius:20px;display:grid;place-items:center;
	background:linear-gradient(135deg,var(--c-primary),var(--c-secondary));box-shadow:var(--shadow)}
.jx-sheet-ic svg{width:32px;height:32px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* =================== FEUILLE (bottom sheet) =================== */
.jx-sheet{position:fixed;inset:0;z-index:60;display:flex;align-items:flex-end;justify-content:center}
.jx-sheet[hidden]{display:none}
.jx-sheet-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6);opacity:0;transition:opacity .25s}
.jx-sheet.is-open .jx-sheet-backdrop{opacity:1}
.jx-sheet-card{position:relative;z-index:1;width:100%;max-width:480px;background:var(--glass);border:1px solid var(--glass-brd);
	border-radius:26px 26px 0 0;padding:28px 22px calc(26px + env(safe-area-inset-bottom));backdrop-filter:blur(18px);
	box-shadow:var(--shadow);transform:translateY(105%);transition:transform .32s cubic-bezier(.2,.9,.2,1)}
.jx-sheet.is-open .jx-sheet-card{transform:none}
.jx-sheet-close{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;border:1px solid var(--glass-brd);
	background:rgba(255,255,255,.1);color:#fff;cursor:pointer;font-size:15px;line-height:1}
.jx-sheet-card .jx-input{margin-top:6px}
.jx-sheet-card .jx-btn{margin-top:14px}
@media (min-width:560px){.jx-sheet{align-items:center}.jx-sheet-card{border-radius:26px}}

/* =================== FLASH =================== */
.jx-flash{position:fixed;left:50%;bottom:calc(98px + env(safe-area-inset-bottom));transform:translateX(-50%) translateY(10px);z-index:70;
	background:#fff;color:#16182e;padding:11px 18px;border-radius:999px;font-weight:600;font-size:14px;
	box-shadow:var(--shadow);opacity:0;transition:.3s;pointer-events:none;max-width:90vw;text-align:center}
.jx-flash.is-shown{opacity:1;transform:translateX(-50%) translateY(0)}
