@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500;1,600&family=Outfit:wght@300;400;500;600;700;800&display=swap');

:root{
  --beige:#F5EFE6;--beige2:#EDE4D8;--white:#FDFAF6;--ink:#1F1A15;--green:#153D39;--green2:#53624A;--gold:#C9A96E;--muted:#8C7B6E;--border:rgba(21,61,57,.13);--paper:#EAE0D0;--shadow:0 18px 60px rgba(31,26,21,.09);--safe-bottom:env(safe-area-inset-bottom);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;background:var(--beige)}
body{font-family:'Outfit',sans-serif;background:radial-gradient(ellipse 80% 60% at 40% 10%,rgba(201,169,110,.12) 0%,transparent 62%),radial-gradient(ellipse 60% 50% at 90% 80%,rgba(21,61,57,.07) 0%,transparent 62%),var(--beige);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100vh}
button,input,textarea,select{font:inherit}button{cursor:pointer}a{text-decoration:none;color:inherit}.hidden{display:none!important}.shell{min-height:100vh;padding-bottom:76px}

/* loading-like elegance via header */
.topbar{position:sticky;top:0;left:0;right:0;z-index:80;height:94px;padding:14px 28px;display:flex;align-items:center;justify-content:space-between;background:rgba(245,239,230,.96);backdrop-filter:blur(18px);border-bottom:1px solid var(--border);box-shadow:0 8px 30px rgba(31,26,21,.045)}
.logo img{width:76px;height:76px;object-fit:contain;display:block}.top-actions{display:flex;align-items:center;gap:10px}.round-action{width:45px;height:45px;border-radius:50%;background:var(--ink);color:var(--beige);display:flex;align-items:center;justify-content:center;font-size:18px;border:1px solid rgba(255,255,255,.12);box-shadow:0 12px 28px rgba(31,26,21,.13)}

.page{max-width:900px;margin:0 auto;padding:48px 28px 118px}.home-hero{padding:8px 0 22px}.kicker{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.28em;color:var(--gold);font-weight:700;margin-bottom:20px}.page-title{font-family:'Cormorant Garamond',serif;font-size:clamp(54px,12vw,104px);font-weight:300;line-height:.88;color:var(--ink);letter-spacing:-.04em;margin-bottom:26px}.page-title em{color:var(--green);font-style:italic;font-weight:300}.lead{font-size:18px;color:var(--muted);font-weight:300;letter-spacing:.01em;line-height:1.9;max-width:580px;margin-bottom:34px}.feed-count{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:18px}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s ease,transform .65s ease}.reveal.visible{opacity:1;transform:translateY(0)}

/* feed posts, Nysscious-style */
.feed-list{display:flex;flex-direction:column;gap:18px}.post-card{background:var(--white);border:1px solid var(--border);border-radius:28px;overflow:hidden;box-shadow:0 10px 34px rgba(31,26,21,.055)}.post-head{padding:20px 20px 14px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px}.avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(145deg,var(--ink),var(--green));color:var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:20px;font-style:italic;flex-shrink:0}.post-head strong{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--ink);font-style:italic;font-weight:400;line-height:1}.post-head small{display:block;font-size:10px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:4px}.tag{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(201,169,110,.35);padding:5px 9px;border-radius:999px;background:rgba(201,169,110,.08);white-space:nowrap}.post-card h2{font-family:'Cormorant Garamond',serif;font-size:clamp(31px,8vw,54px);font-weight:400;color:var(--ink);line-height:1.03;margin:0 20px 12px;letter-spacing:-.035em}.post-card p{padding:0 20px 20px;font-size:14px;line-height:1.85;color:var(--muted);white-space:pre-line}.post-media-grid{display:grid;gap:3px;background:var(--paper);border-top:1px solid rgba(21,61,57,.06);border-bottom:1px solid rgba(21,61,57,.06);margin-bottom:18px}.post-media-grid.count-1{grid-template-columns:1fr}.post-media-grid.count-2{grid-template-columns:repeat(2,1fr)}.post-media-grid.count-3{grid-template-columns:1.2fr .8fr;grid-template-rows:1fr 1fr}.post-media-grid.count-3 .media-tile:first-child{grid-row:1/3}.post-media-grid.count-4{grid-template-columns:repeat(2,1fr)}.media-tile{border:0;position:relative;background:var(--paper);overflow:hidden;min-height:150px;display:block;padding:0}.media-tile img,.media-tile video{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/3}.count-1 .media-tile img,.count-1 .media-tile video{aspect-ratio:16/10;max-height:520px}.media-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(31,26,21,.14);color:white;font-size:42px;text-shadow:0 4px 18px rgba(0,0,0,.25)}

/* protocols */
.protocol-grid{display:grid;gap:18px}.protocol-card{border-radius:24px;overflow:hidden;background:var(--white);border:1px solid var(--border);box-shadow:0 10px 34px rgba(31,26,21,.055);padding:12px}.protocol-hero{width:100%;height:86px;border-radius:18px;background:linear-gradient(135deg,#9CAD91,#61745A);display:flex;align-items:center;justify-content:center;font-size:34px;overflow:hidden;margin-bottom:12px}.protocol-hero img{width:100%;height:100%;object-fit:cover}.protocol-hero.is-locked{filter:saturate(.75)}.protocol-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 2px 8px}.protocol-mini{display:flex;align-items:center;gap:10px;min-width:0}.protocol-mini .avatar{width:34px;height:34px;font-size:16px}.protocol-mini small{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:19px;color:rgba(31,26,21,.68);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.protocol-card h2{font-family:'Cormorant Garamond',serif;font-size:35px;font-weight:400;line-height:1;letter-spacing:-.04em;margin:8px 2px}.protocol-card p{font-size:13px;color:var(--muted);line-height:1.65;margin:0 2px 12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.protocol-meta{display:flex;align-items:center;justify-content:space-between;margin:10px 2px 12px}.price-pill,.duration-pill{border-radius:999px;padding:7px 12px;font-size:9px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.price-pill{background:var(--green);color:var(--beige)}.duration-pill{border:1px solid rgba(201,169,110,.25);background:rgba(201,169,110,.08);color:var(--muted)}.main-cta{width:100%;border:none;border-radius:999px;padding:13px 16px;background:var(--green);color:var(--beige);font-size:10px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;text-align:center;display:block}.download-link{display:inline-flex;margin-top:12px;border-bottom:1px solid var(--gold);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--green)}

/* cards/pages */
.page-section{background:var(--white);border:1px solid var(--border);border-radius:26px;box-shadow:0 10px 34px rgba(31,26,21,.05);padding:24px;margin-bottom:18px}.page-section h2,.content-card h2,.mini-card h2,.form-card h2,.empty-card h2{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:400;line-height:1.05;margin-bottom:10px}.page-section p,.content-card p,.mini-card p,.empty-card p{font-size:14px;color:var(--muted);line-height:1.8}.mini-grid,.dashboard-grid{display:grid;gap:14px}.mini-editorial-card,.content-card,.mini-card,.form-card,.empty-card{background:var(--white);border:1px solid var(--border);border-radius:24px;padding:22px;box-shadow:0 10px 34px rgba(31,26,21,.045);margin-bottom:16px}.mini-editorial-card b,.content-card span,.mini-card b{font-size:24px}.mini-editorial-card h3{font-family:'Cormorant Garamond',serif;font-size:25px;font-weight:400;margin:8px 0}.content-list{display:grid;gap:16px}.access-gate{background:var(--white);border:1px solid var(--border);border-radius:24px;padding:22px;box-shadow:var(--shadow);margin-bottom:22px}.access-gate h2{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:400;margin-bottom:8px}.access-gate p{color:var(--muted);line-height:1.7;margin-bottom:14px}

/* forms admin */
.admin-page{max-width:980px}.admin-studio{display:grid;gap:18px}.form-card label{display:block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin:14px 0 7px}.form-card input,.form-card textarea,.form-card select{width:100%;border:1px solid var(--border);border-radius:15px;padding:13px 15px;font-size:13px;color:var(--ink);background:var(--beige);outline:none;transition:.2s ease;margin-bottom:10px}.form-card input:focus,.form-card textarea:focus,.form-card select:focus{border-color:var(--gold);background:var(--white)}.form-card button,.ghost-btn{width:100%;border:1px solid var(--green);border-radius:999px;padding:13px 16px;background:var(--green);color:var(--beige);font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;margin-top:4px}.ghost-btn{background:transparent;color:var(--green)}.admin-block>p{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:12px}.admin-list{display:flex;flex-direction:column;gap:10px}.admin-row-card{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;padding:12px;border:1px solid var(--border);border-radius:16px;background:rgba(245,239,230,.55)}.admin-row-card strong{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:400;line-height:1.05}.admin-row-card small{display:block;font-size:9px;color:var(--muted);letter-spacing:.11em;text-transform:uppercase;margin-top:4px}.admin-row-card button{border:0;border-radius:999px;padding:9px 11px;background:var(--white);color:var(--green);text-transform:uppercase;letter-spacing:.12em;font-size:8px;font-weight:800}.admin-row-card button.danger{color:#9E4B43}.admin-row-card button:disabled{opacity:.45}

/* auth */
.auth-body{background:linear-gradient(180deg,#53624A,#42543D);color:#fff}.auth-hero{min-height:100vh;padding:58px 26px 46px;max-width:720px;margin:0 auto;text-align:center}.auth-brand h1{font-family:'Cormorant Garamond',serif;font-size:clamp(72px,17vw,118px);line-height:.76;letter-spacing:-.06em;font-weight:300;margin:22px 0}.auth-brand p{color:rgba(255,255,255,.76);font-size:18px;line-height:1.75}.tagline{font-family:'Cormorant Garamond',serif!important;font-size:38px!important;line-height:1.05!important;font-style:italic!important;color:#fff!important}.pill{display:inline-flex;border:1px solid rgba(255,255,255,.28);border-radius:999px;padding:10px 14px;letter-spacing:.15em;font-size:9px;font-weight:800;text-transform:uppercase}.auth-card{background:rgba(248,244,234,.92);color:var(--ink);border:1px solid rgba(255,255,255,.55);border-radius:30px;padding:22px;margin-top:32px;text-align:left;box-shadow:0 18px 55px rgba(0,0,0,.12)}.tabs{display:flex;gap:6px;background:#E9E2D7;padding:6px;border-radius:999px;margin-bottom:24px}.tabs button{flex:1;border:0;border-radius:999px;background:transparent;color:var(--green);padding:13px 8px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:800}.tabs button.active{background:var(--white);box-shadow:0 8px 18px rgba(31,26,21,.045)}.auth-card label{display:block;color:var(--muted);font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:800;margin:14px 0 7px}.auth-card input{width:100%;border:1px solid rgba(31,26,21,.10);border-radius:16px;padding:14px 15px;background:#fff;color:var(--ink);outline:none;margin-bottom:12px}.auth-card button[type=submit]{width:100%;border:0;border-radius:999px;padding:14px;background:var(--green);color:#fff;text-transform:uppercase;letter-spacing:.16em;font-size:10px;font-weight:800}

/* nav bottom */
.navbar{position:fixed;bottom:12px;left:12px;right:12px;z-index:999;display:flex;justify-content:space-around;gap:4px;overflow-x:auto;scrollbar-width:none;background:rgba(245,239,230,.97);backdrop-filter:blur(18px);border:1px solid var(--border);border-radius:30px;padding:10px 12px calc(10px + var(--safe-bottom));box-shadow:0 10px 35px rgba(31,26,21,.10)}.navbar::-webkit-scrollbar{display:none}.navbar a{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;height:56px;padding:6px 4px;border-radius:15px;background:transparent;color:var(--muted);transition:.2s ease;text-align:center}.navbar a.active{color:var(--green);background:rgba(253,250,246,.85)}.navbar b{display:block;font-size:18px;line-height:1;height:20px;min-height:20px;margin:0}.navbar span{display:block;width:100%;font-size:7.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* modal */
.media-modal{display:none}.media-modal.open{display:block}.modal-backdrop{position:fixed;inset:0;background:rgba(31,26,21,.82);backdrop-filter:blur(10px);z-index:200}.modal-card{position:fixed;left:18px;right:18px;top:50%;transform:translateY(-50%);z-index:210;background:var(--white);border-radius:24px;overflow:hidden;max-height:86vh}.modal-card img,.modal-card video{width:100%;max-height:70vh;object-fit:contain;background:var(--paper);display:block}.modal-card h3{font-family:'Cormorant Garamond',serif;font-size:28px;padding:18px}.modal-close{position:absolute;right:12px;top:12px;width:36px;height:36px;border-radius:50%;border:0;background:rgba(31,26,21,.60);color:#fff;font-size:22px;z-index:3}

/* responsive */
@media(min-width:720px){.protocol-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid,.mini-grid{grid-template-columns:repeat(3,1fr)}.navbar{left:50%;transform:translateX(-50%);width:min(720px,100%);border-radius:28px 28px 0 0;border-left:1px solid var(--border);border-right:1px solid var(--border)}.admin-studio{grid-template-columns:1fr 1fr}.admin-block{height:max-content}}
@media(max-width:600px){.page{padding:38px 18px 100px}.topbar{height:90px;padding:12px 24px}.logo img{width:70px;height:70px}.round-action{width:44px;height:44px}.post-card{border-radius:22px}.post-head{padding:17px 16px 12px}.post-card h2{font-size:38px;margin-left:16px;margin-right:16px}.post-card p{padding-left:16px;padding-right:16px;font-size:13.5px}.media-tile{min-height:142px}.protocol-card{border-radius:22px}.admin-row-card{grid-template-columns:1fr}.admin-row-card button{width:100%}.navbar{padding:7px 8px calc(7px + var(--safe-bottom))}.navbar a{height:54px;border-radius:14px;padding:5px 3px}.navbar b{font-size:17px}.navbar span{font-size:7px}.page-title{font-size:52px}.lead{font-size:16px}}


/* V13 — Gestion admin + bibliothèque */
.library-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin:0 0 18px;
}
.library-category{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:20px;
  padding:18px;
  box-shadow:0 10px 34px rgba(31,26,21,.045);
}
.library-category b{
  font-size:24px;
  display:block;
  margin-bottom:8px;
}
.library-category h2{
  font-family:'Cormorant Garamond',serif;
  font-size:24px;
  font-weight:400;
  line-height:1;
  margin-bottom:6px;
}
.library-category p{
  color:var(--muted);
  font-size:12px;
  line-height:1.5;
}
.admin-row-card{
  grid-template-columns:1fr auto auto auto;
}
.admin-row-card button:disabled{
  opacity:.45;
}
.admin-error,.admin-empty{
  color:var(--muted);
  font-size:13px;
  line-height:1.6;
}
.content-card small{
  display:block;
  margin:8px 0 0;
  color:var(--gold);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:9px;
  font-weight:700;
}
@media(max-width:600px){
  .library-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
  }
  .library-category{
    padding:14px;
    border-radius:18px;
  }
  .library-category h2{
    font-size:21px;
  }
  .admin-row-card{
    grid-template-columns:1fr;
  }
}

/* MÉTHODE TEE V14 — Private Club Luxe */
.ambiance-layer{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}.ambiance-layer .orb{position:absolute;border-radius:999px;filter:blur(22px);opacity:.22;animation:orbFloat 14s ease-in-out infinite alternate}.orb-a{width:320px;height:320px;background:#C9A96E;top:6%;left:-110px}.orb-b{width:360px;height:360px;background:#153D39;right:-160px;bottom:8%;animation-delay:2s}.grain{position:absolute;inset:0;opacity:.14;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.28'/%3E%3C/svg%3E");mix-blend-mode:multiply}@keyframes orbFloat{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(32px,42px,0) scale(1.12)}}
.luxury-loader{position:fixed;inset:0;z-index:9999;background:rgba(245,239,230,.98);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;transition:opacity .42s ease,visibility .42s ease}.luxury-loader img{width:96px;height:96px;object-fit:contain;animation:loaderBloom .7s ease both}.luxury-loader span{text-transform:uppercase;letter-spacing:.22em;font-size:10px;color:var(--muted);font-weight:700}.luxury-loader.hide{opacity:0;visibility:hidden}@keyframes loaderBloom{from{opacity:0;transform:translateY(10px) scale(.96);filter:blur(5px)}to{opacity:1;transform:none;filter:blur(0)}}
body.page-entered{animation:pageIn .38s ease both}body.page-leaving{animation:pageOut .18s ease both}@keyframes pageIn{from{opacity:0;transform:translateY(8px);filter:blur(4px)}to{opacity:1;transform:none;filter:blur(0)}}@keyframes pageOut{to{opacity:0;transform:translateY(6px);filter:blur(3px)}}
.post-card,.protocol-card,.content-card,.mini-card,.library-category,.main-cta,.navbar a{transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.is-pressing{transform:scale(.985)!important}
.club-intro{position:relative;margin:18px 0 24px;padding:24px;border:1px solid rgba(201,169,110,.20);border-radius:28px;background:linear-gradient(145deg,rgba(253,250,246,.70),rgba(245,239,230,.38));box-shadow:0 18px 50px rgba(31,26,21,.055);overflow:hidden}.club-eyebrow{text-transform:uppercase;letter-spacing:.26em;font-size:9px;color:var(--gold);font-weight:800;margin-bottom:14px}.club-intro h2{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,9vw,58px);line-height:.95;font-weight:300;letter-spacing:-.04em;color:var(--green);margin-bottom:12px}.club-intro p{color:var(--muted);line-height:1.7;font-size:14px}.member-strip{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:18px;padding:12px;border-radius:999px;background:rgba(253,250,246,.72);border:1px solid rgba(21,61,57,.08)}.member-strip span{font-size:20px}.member-strip strong{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--green)}.member-strip em{font-size:12px;color:var(--muted);font-style:normal}
.story-rail{display:flex;gap:10px;overflow-x:auto;padding:3px 0 18px;margin-bottom:6px;scrollbar-width:none}.story-rail::-webkit-scrollbar{display:none}.story-bubble{min-width:92px;border:1px solid rgba(21,61,57,.10);border-radius:22px;background:rgba(253,250,246,.82);padding:12px 10px;text-align:left;box-shadow:0 10px 30px rgba(31,26,21,.045)}.story-bubble span{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:rgba(21,61,57,.08);margin-bottom:8px}.story-bubble b{display:block;font-size:11px;color:var(--green);line-height:1.15}.story-bubble small{display:block;margin-top:4px;font-size:8px;text-transform:uppercase;letter-spacing:.12em;color:var(--gold);font-weight:800}
.private-drops{margin:8px 0 20px}.drop-grid{display:grid;gap:10px}.drop-card{border-radius:24px;padding:18px;background:linear-gradient(145deg,#1F1A15,#153D39);color:#F5EFE6;box-shadow:0 16px 45px rgba(31,26,21,.12)}.drop-card span{font-size:24px}.drop-card h3{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:300;line-height:1;margin:10px 0}.drop-card p{font-size:13px;color:rgba(245,239,230,.72);line-height:1.6}.drop-card a{display:inline-flex;margin-top:12px;color:#C9A96E;text-transform:uppercase;letter-spacing:.14em;font-size:9px;font-weight:800}
.post-card{animation:postRise .58s ease both;animation-delay:var(--delay,0ms)}@keyframes postRise{from{opacity:0;transform:translateY(18px);filter:blur(4px)}to{opacity:1;transform:none;filter:blur(0)}}.post-actions{display:flex;gap:8px;padding:0 20px 18px}.post-actions button{border:1px solid rgba(21,61,57,.10);background:rgba(245,239,230,.54);border-radius:999px;padding:8px 11px;font-size:9px;text-transform:uppercase;letter-spacing:.12em;font-weight:800;color:var(--green)}
.toast-layer{position:fixed;left:16px;right:16px;bottom:calc(90px + env(safe-area-inset-bottom));z-index:9000;display:flex;flex-direction:column;align-items:center;pointer-events:none}.premium-toast{position:relative;display:flex;align-items:center;gap:10px;max-width:min(92vw,420px);margin-top:10px;padding:14px 16px;border-radius:20px;background:rgba(31,26,21,.92);color:#F5EFE6;box-shadow:0 18px 50px rgba(31,26,21,.22);backdrop-filter:blur(18px);opacity:0;transform:translateY(16px) scale(.98);transition:.32s ease}.premium-toast.show{opacity:1;transform:none}.premium-toast b{font-size:17px}.premium-toast span{font-size:13px;line-height:1.4}
.protocol-card.locked .protocol-hero{position:relative;overflow:hidden}.protocol-card.locked .protocol-hero:after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent,rgba(255,255,255,.22),transparent);transform:translateX(-100%);animation:shimmerLock 2.8s ease-in-out infinite}@keyframes shimmerLock{55%,100%{transform:translateX(120%)}}
.admin-block label input[type="checkbox"]{width:auto;margin-right:8px}@media(max-width:600px){.club-intro{padding:20px;border-radius:24px}.story-bubble{min-width:86px;padding:11px 9px}.story-bubble span{width:36px;height:36px}.post-actions{padding-left:16px;padding-right:16px}}

.download-link.as-button{
  border:0;
  background:transparent;
  border-bottom:1px solid var(--gold, #C9A96E);
  padding:0 0 3px;
  color:var(--green, #153D39);
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:10px;
  font-weight:800;
  cursor:pointer;
}


/* ============================================
   NAVBAR V17 — PREMIUM FINAL
   Shell = flex column 100dvh
   Navbar toujours visible, visuellement premium
   ============================================ */

html, body {
  height: 100% !important;
  overflow: hidden !important;
}

.shell {
  display: flex !important;
  flex-direction: column !important;
  height: 100dvh !important;
  min-height: 100dvh !important;
  overflow: hidden !important;
  padding-bottom: 0 !important;
}

.topbar {
  flex-shrink: 0 !important;
}

.page {
  flex: 1 1 auto !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  padding-bottom: 20px !important;
  min-height: 0 !important;
}

/* Wrapper navbar — gère le margin et le safe-area */
.navbar {
  flex-shrink: 0 !important;
  position: relative !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
  z-index: 999 !important;

  /* Pleine largeur du shell, padding interne = les marges visuelles */
  width: 100% !important;
  box-sizing: border-box !important;
  padding: 6px 5px calc(6px + env(safe-area-inset-bottom, 0px)) 5px !important;

  /* Fond transparent — c'est le inner qui a le fond arrondi */
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;

  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: space-around !important;
  gap: 0 !important;
  overflow: visible !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* Pill premium — contenu réel de la navbar */
.navbar::before {
  content: '' !important;
  position: absolute !important;
  inset: 6px 5px calc(6px + env(safe-area-inset-bottom, 0px)) 5px !important;
  border-radius: 26px !important;
  background: rgba(248,244,238,.98) !important;
  -webkit-backdrop-filter: blur(28px) saturate(1.15) !important;
  backdrop-filter: blur(28px) saturate(1.15) !important;
  border: 1px solid rgba(21,61,57,.09) !important;
  box-shadow:
    0 2px 0 rgba(255,255,255,.7) inset,
    0 8px 32px rgba(31,26,21,.10),
    0 2px 8px rgba(31,26,21,.06) !important;
  z-index: -1 !important;
}

.navbar a {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  width: auto !important;
  height: 60px !important;
  border-radius: 18px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 3px !important;
  padding: 6px 2px !important;
  text-align: center !important;
  position: relative !important;
  z-index: 1 !important;
}

.navbar b {
  font-size: 20px !important;
  height: 22px !important;
  display: block !important;
  line-height: 1 !important;
}

.navbar span {
  font-size: 7px !important;
  display: block !important;
  opacity: 1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  width: 100% !important;
  letter-spacing: .06em !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
}

.navbar a.active {
  background: rgba(255,252,248,.95) !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 6px 18px rgba(31,26,21,.08) !important;
}

.navbar a.active span {
  color: var(--green) !important;
}

/* Les modals et overlays JS gardent position fixed */
.media-modal,
.toast-layer,
[class*="modal"],
[class*="overlay"] {
  position: fixed !important;
}


/* =========================================================
   MÉTHODE TEE V18 — Club + Protocoles premium
   IMPORTANT : ne touche PAS à la navbar/topbar validées V17b.
   ========================================================= */

/* Home cards premium: même largeur luxe, sans modifier la navbar */
.club-intro,
.post-card{
  width:calc(100% - 28px) !important;
  max-width:720px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  border-radius:32px !important;
}
@media(max-width:600px){
  .club-intro,
  .post-card{width:calc(100% - 28px) !important;}
}

.club-v18-panel,
.protocol-progress-card,
.protocol-day-card,
.viewer-content-card{
  background:rgba(253,250,246,.86);
  border:1px solid rgba(21,61,57,.10);
  border-radius:28px;
  box-shadow:0 14px 42px rgba(31,26,21,.06);
}
.club-v18-panel{
  width:calc(100% - 28px);
  max-width:720px;
  margin:18px auto 20px;
  padding:18px;
}
.club-v18-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.club-v18-head h2{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:400;line-height:1;color:var(--green);letter-spacing:-.035em}
.club-v18-head p{font-size:12px;color:var(--muted);line-height:1.5;margin-top:5px}
.club-streak-pill{border:1px solid rgba(201,169,110,.28);border-radius:999px;padding:9px 12px;background:rgba(201,169,110,.08);white-space:nowrap;font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--green)}
.club-v18-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.club-v18-tile{border:1px solid rgba(21,61,57,.08);border-radius:22px;background:rgba(245,239,230,.55);padding:14px;min-height:120px;text-align:left;color:var(--green)}
.club-v18-tile b{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.75);font-size:18px;margin-bottom:10px}
.club-v18-tile strong{display:block;font-size:14px;line-height:1.1;color:var(--green)}
.club-v18-tile span{display:block;margin-top:6px;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-weight:800}
.club-v18-actions{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.club-v18-actions button{border:1px solid rgba(21,61,57,.10);background:rgba(253,250,246,.82);border-radius:999px;padding:10px 12px;color:var(--green);font-size:9px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}

.protocol-progress-card{padding:18px;margin:0 0 18px}
.protocol-progress-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:13px}
.protocol-progress-top h2{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:400;line-height:1;color:var(--green)}
.protocol-progress-top small{font-size:9px;text-transform:uppercase;letter-spacing:.14em;color:var(--gold);font-weight:800}
.progress-ring-text{font-size:10px;text-transform:uppercase;letter-spacing:.12em;font-weight:800;color:var(--green);white-space:nowrap}
.progress-bar{height:9px;border-radius:999px;background:rgba(21,61,57,.08);overflow:hidden;margin:12px 0}
.progress-bar span{display:block;height:100%;width:0;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--gold));transition:width .35s ease}
.protocol-progress-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
.protocol-progress-meta div{border:1px solid rgba(21,61,57,.08);border-radius:18px;padding:10px;background:rgba(245,239,230,.44);text-align:center}
.protocol-progress-meta b{display:block;font-size:16px;color:var(--green)}
.protocol-progress-meta span{font-size:8px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:800}
.validate-today-btn{width:100%;margin-top:13px;border:0;border-radius:999px;padding:14px 16px;background:var(--green);color:var(--beige);font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:900}
.validate-today-btn.done{background:rgba(21,61,57,.18);color:var(--green)}

.timeline-rail{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;margin:0 0 18px;padding:2px 0 10px}.timeline-rail::-webkit-scrollbar{display:none}
.timeline-day{min-width:64px;border:1px solid rgba(21,61,57,.09);background:rgba(253,250,246,.78);border-radius:18px;padding:10px 8px;text-align:center;color:var(--muted)}
.timeline-day.active{background:var(--green);color:var(--beige)}
.timeline-day.done{border-color:rgba(201,169,110,.44);color:var(--green)}
.timeline-day b{display:block;font-size:14px}.timeline-day span{display:block;font-size:8px;text-transform:uppercase;letter-spacing:.10em;font-weight:800;margin-top:3px}

.content-card.viewer-content-card{cursor:pointer;position:relative;overflow:hidden}
.content-card.viewer-content-card .content-badges{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0 0}
.content-badge{border:1px solid rgba(201,169,110,.28);border-radius:999px;padding:5px 8px;font-size:8px;text-transform:uppercase;letter-spacing:.11em;font-weight:800;color:var(--gold);background:rgba(201,169,110,.07)}
.content-open-pill{display:inline-flex;align-items:center;gap:6px;margin-top:12px;border-bottom:1px solid var(--gold);font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.14em;color:var(--green)}

.immersive-overlay{position:fixed;inset:0;background:rgba(31,26,21,.42);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:2147483100;display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity .22s ease}
.immersive-overlay.open{opacity:1;pointer-events:auto}
.immersive-sheet{width:100%;max-height:92vh;min-height:62vh;background:linear-gradient(180deg,#FDFAF6,#F5EFE6);border-radius:30px 30px 0 0;border:1px solid rgba(255,255,255,.65);box-shadow:0 -24px 70px rgba(31,26,21,.22);transform:translateY(100%);transition:transform .28s cubic-bezier(.2,.9,.2,1);overflow:hidden;display:flex;flex-direction:column}
.immersive-overlay.open .immersive-sheet{transform:translateY(0)}
.immersive-handle{width:60px;height:5px;border-radius:999px;background:rgba(31,26,21,.18);margin:10px auto 6px;flex-shrink:0}
.immersive-head{padding:12px 18px 14px;display:grid;grid-template-columns:1fr auto;gap:12px;align-items:start;border-bottom:1px solid rgba(21,61,57,.08)}
.immersive-head h2{font-family:'Cormorant Garamond',serif;font-size:31px;line-height:.96;font-weight:400;color:var(--green);letter-spacing:-.035em}.immersive-head small{display:block;margin-top:6px;color:var(--gold);font-size:9px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}
.immersive-close{width:42px;height:42px;border:0;border-radius:50%;background:rgba(31,26,21,.08);color:var(--green);font-size:20px}.immersive-body{padding:16px 18px calc(22px + env(safe-area-inset-bottom));overflow:auto;-webkit-overflow-scrolling:touch}.immersive-frame{width:100%;height:58vh;border:0;border-radius:22px;background:white;box-shadow:0 10px 30px rgba(31,26,21,.06)}.immersive-video{width:100%;aspect-ratio:16/9;border:0;border-radius:22px;background:#111}.immersive-audio-card{border-radius:24px;background:linear-gradient(145deg,var(--green),#1f1a15);color:var(--beige);padding:22px;box-shadow:0 18px 42px rgba(31,26,21,.16)}.immersive-audio-card h3{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:400;margin-bottom:14px}.immersive-audio-card audio{width:100%}.immersive-text{font-size:15px;line-height:1.85;color:var(--muted);white-space:pre-line}.immersive-text h3{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:400;color:var(--green);line-height:1;margin:10px 0}.viewer-actions{display:flex;gap:9px;flex-wrap:wrap;margin-top:16px}.viewer-actions a,.viewer-actions button{border:1px solid rgba(21,61,57,.10);background:rgba(253,250,246,.86);border-radius:999px;padding:12px 14px;color:var(--green);font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.viewer-actions .primary{background:var(--green);color:var(--beige)}
.checklist-list{display:grid;gap:10px;margin-top:12px}.checklist-item{display:flex;align-items:center;gap:11px;border:1px solid rgba(21,61,57,.08);background:rgba(253,250,246,.72);border-radius:18px;padding:13px}.checklist-item input{width:20px;height:20px;accent-color:var(--green)}.checklist-item span{font-size:14px;color:var(--green);font-weight:600}.checklist-item small{display:block;color:var(--muted);font-size:11px;font-weight:400;margin-top:3px}.certificate-card{border-radius:26px;padding:20px;background:linear-gradient(135deg,#1F1A15,#153D39);color:var(--beige);text-align:center;margin-top:16px}.certificate-card h2{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:400}.certificate-card p{color:rgba(245,239,230,.74);font-size:13px;line-height:1.7;margin-top:8px}

/* PATCH — Protocole mobile anti-débordement */
html,
body,
.shell,
.page{
  max-width:100vw !important;
}

#protocolDetail{
  width:100% !important;
  max-width:900px !important;
  margin-left:auto !important;
  margin-right:auto !important;
  box-sizing:border-box !important;
  overflow-x:hidden !important;
}

#protocolDetail *,
#protocolDetail *::before,
#protocolDetail *::after{
  box-sizing:border-box !important;
  max-width:100% !important;
}

#protocolDetail .protocol-progress-card,
#protocolDetail .content-list,
#protocolDetail .viewer-content-card,
#protocolDetail .content-card,
#protocolDetail .certificate-card{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  margin-left:0 !important;
  margin-right:0 !important;
}

#protocolDetail h1,
#protocolDetail h2,
#protocolDetail h3,
#protocolDetail p,
#protocolDetail span,
#protocolDetail b,
#protocolDetail small{
  min-width:0 !important;
  overflow-wrap:break-word !important;
}

#protocolDetail .protocol-progress-meta{
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  width:100% !important;
  overflow:hidden !important;
}

#protocolDetail .protocol-progress-meta div{
  min-width:0 !important;
  overflow:hidden !important;
}

#protocolDetail .protocol-progress-meta b,
#protocolDetail .protocol-progress-meta span{
  display:block !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
  white-space:nowrap !important;
}

#protocolDetail .timeline-rail{
  width:100% !important;
  overflow-x:auto !important;
  overflow-y:hidden !important;
  padding-left:0 !important;
  padding-right:0 !important;
}

#protocolDetail .timeline-day{
  flex:0 0 64px !important;
  max-width:64px !important;
}

@media(max-width:600px){
  #protocolDetail{
    padding-left:18px !important;
    padding-right:18px !important;
  }

  #protocolDetail .protocol-progress-card{
    padding:18px 14px !important;
    border-radius:26px !important;
  }

  #protocolDetail .protocol-progress-top h2{
    font-size:clamp(34px, 11vw, 46px) !important;
  }

  #protocolDetail .protocol-progress-meta{
    gap:7px !important;
  }

  #protocolDetail .protocol-progress-meta div{
    padding:10px 6px !important;
    border-radius:18px !important;
  }

  #protocolDetail .viewer-content-card{
    padding:22px 18px !important;
    border-radius:28px !important;
  }
}


/* =========================================================
   MÉTHODE TEE V18.3 — Audio immersif premium SAFE PATCH
   Ajout uniquement visuel/player. Ne touche pas Stripe/Supabase/navbar.
   ========================================================= */
.mt-ritual-audio{
  position:relative;
  overflow:hidden;
  border-radius:30px;
  padding:28px 22px 22px;
  background:
    radial-gradient(circle at 18% 8%, rgba(201,169,110,.22), transparent 34%),
    radial-gradient(circle at 86% 4%, rgba(253,250,246,.18), transparent 30%),
    linear-gradient(145deg, #123c35 0%, #1f1a15 100%);
  color:#FDFAF6;
  box-shadow:0 22px 60px rgba(31,26,21,.22);
  isolation:isolate;
}
.mt-ritual-audio::before{
  content:'';
  position:absolute;
  inset:-40%;
  background:linear-gradient(120deg, transparent 20%, rgba(255,255,255,.08) 48%, transparent 72%);
  transform:translateX(-45%) rotate(8deg);
  transition:transform 1.4s ease;
  z-index:-1;
}
.mt-ritual-audio.is-playing::before{transform:translateX(28%) rotate(8deg)}
.mt-audio-orb{
  width:70px;height:70px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(253,250,246,.10);
  border:1px solid rgba(201,169,110,.28);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18), 0 14px 34px rgba(0,0,0,.14);
  margin-bottom:18px;
}
.mt-audio-orb span{font-size:28px;filter:drop-shadow(0 6px 14px rgba(0,0,0,.20))}
.mt-audio-kicker{
  color:var(--gold);
  font-size:9px;
  font-weight:900;
  letter-spacing:.24em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.mt-ritual-audio h3{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(34px,9vw,48px);
  line-height:.96;
  font-weight:400;
  letter-spacing:-.045em;
  margin:0 0 12px;
  color:#FDFAF6;
}
.mt-ritual-audio p{
  color:rgba(253,250,246,.72);
  font-size:14px;
  line-height:1.7;
  margin:0 0 24px;
  white-space:pre-line;
}
.mt-audio-controls{display:flex;gap:14px;align-items:center;margin-top:8px}
.mt-audio-play{
  width:64px;height:64px;border-radius:50%;border:0;
  background:var(--gold);color:#123c35;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 34px rgba(0,0,0,.18);
  flex:0 0 auto;
}
.mt-audio-play span{font-weight:900;font-size:18px;line-height:1;transform:translateX(1px)}
.mt-ritual-audio.is-playing .mt-audio-play{background:#FDFAF6;color:#123c35}
.mt-audio-main{flex:1;min-width:0}
.mt-audio-track{
  width:100%;height:13px;border:0;border-radius:999px;
  background:rgba(253,250,246,.18);
  display:block;overflow:hidden;padding:0;position:relative;
}
.mt-audio-fill{
  position:absolute;left:0;top:0;bottom:0;width:0%;
  border-radius:999px;
  background:linear-gradient(90deg, var(--gold), #FDFAF6);
  transition:width .18s linear;
}
.mt-audio-times{display:flex;justify-content:space-between;margin-top:8px;color:rgba(253,250,246,.58);font-size:11px;font-weight:700;letter-spacing:.08em}
.mt-audio-closed-eyes{
  margin-top:20px;
  border:1px solid rgba(201,169,110,.24);
  background:rgba(253,250,246,.08);
  color:rgba(253,250,246,.78);
  border-radius:999px;
  padding:11px 13px;
  text-align:center;
  font-size:9px;
  font-weight:900;
  letter-spacing:.16em;
  text-transform:uppercase;
}
@media(max-width:600px){
  .mt-ritual-audio{padding:25px 19px 20px;border-radius:28px}
  .mt-audio-controls{gap:12px}
  .mt-audio-play{width:58px;height:58px}
}


/* V19.5 — Carte installation PWA premium */
.install-app-card{
  grid-column:1/-1;
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 12% 12%, rgba(201,169,110,.14), transparent 34%),
    linear-gradient(145deg, rgba(253,250,246,.96), rgba(245,239,230,.72));
  border:1px solid rgba(201,169,110,.22);
  border-radius:30px;
  padding:26px 24px;
  box-shadow:0 18px 44px rgba(31,26,21,.065);
}
.install-app-card:before{
  content:"";
  position:absolute;
  inset:auto -35% -45% auto;
  width:260px;
  height:260px;
  border-radius:999px;
  background:rgba(21,61,57,.055);
  filter:blur(2px);
}
.install-app-kicker{
  position:relative;
  color:#c9a96e;
  font-size:11px;
  font-weight:800;
  letter-spacing:.24em;
  text-transform:uppercase;
  margin-bottom:14px;
}
.install-app-card h2{
  position:relative;
  margin:0 0 12px;
  font-family:var(--serif);
  font-size:clamp(34px, 8vw, 58px);
  line-height:.95;
  font-weight:400;
  color:var(--ink);
}
.install-app-card p{
  position:relative;
  margin:0;
  color:var(--muted);
  font-size:15px;
  line-height:1.8;
}
.install-app-steps{
  position:relative;
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  margin:18px 0 16px;
}
.install-app-steps div{
  background:rgba(255,255,255,.52);
  border:1px solid rgba(31,26,21,.08);
  border-radius:20px;
  padding:14px 16px;
}
.install-app-steps b{
  display:block;
  color:var(--green);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:5px;
}
.install-app-steps span{
  display:block;
  color:var(--ink);
  font-size:14px;
  line-height:1.55;
}
.install-app-note{
  margin-top:4px!important;
  color:var(--green)!important;
  font-weight:600;
}

/* V19.6 — bouton téléchargement fichiers premium */
.premium-download{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-top:14px;
  padding:12px 18px;
  border-radius:999px;
  background:#123f37;
  color:#f8f1e6!important;
  text-decoration:none!important;
  font-size:11px;
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
}

/* ── Recette Premium · Méthode TEE ──────────────────── */
.imm-recipe {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.imm-recipe-desc {
  font-family: 'Cormorant Garamond', serif;
  font-size: 17px;
  font-style: italic;
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(21,61,57,.08);
}
.imm-recipe-section {}
.imm-recipe-section-title {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 10px;
}
.imm-recipe-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
/* Ingrédient */
.imm-recipe-ing {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 14px;
  line-height: 1.5;
  color: var(--ink);
}
.imm-ing-dot {
  flex-shrink: 0;
  font-size: 7px;
  color: var(--gold);
  margin-top: 5px;
}
/* Étape de préparation */
.imm-recipe-list--steps { gap: 12px; }
.imm-recipe-step {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink);
}
.imm-step-num {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--green);
  color: var(--beige);
  font-size: 10px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
}
/* Image jointe */
.imm-recipe-img {
  width: 100%;
  border-radius: 18px;
  object-fit: cover;
  max-height: 260px;
  box-shadow: 0 8px 24px rgba(31,26,21,.08);
}
/* PDF joint */
.imm-recipe-pdf-wrap { margin-top: 4px; }
/* Lien fichier générique */
.imm-recipe-file-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid rgba(21,61,57,.14);
  border-radius: 999px;
  padding: 10px 16px;
  font-size: 11px;
  font-weight: 700;
  color: var(--green);
  text-decoration: none;
}
/* Texte sous un fichier PDF/document */
.imm-below-file {
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid rgba(21,61,57,.07);
}


/* ── Modules Premium · même direction artistique que Recette/Audio ── */
.imm-editorial{display:flex;flex-direction:column;gap:20px}
.imm-editorial-file h4{font-size:9px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin:0 0 10px}
.imm-editorial-img{max-height:340px;border:1px solid rgba(201,169,110,.18)}
.imm-check-step{list-style:none}.imm-check-step label{display:flex;align-items:flex-start;gap:10px;color:var(--ink);font-size:14px;line-height:1.55}.imm-check-step input{width:20px;height:20px;accent-color:var(--green);margin-top:2px}.imm-check-step .imm-step-num{margin-top:0}
.imm-tracker-premium{display:grid;gap:10px}.imm-tracker-premium div{display:grid;grid-template-columns:42px 1fr;gap:12px;align-items:center;padding:13px 14px;border-radius:18px;background:rgba(245,239,230,.58);border:1px solid rgba(21,61,57,.07)}.imm-tracker-premium span{font-size:10px;font-weight:900;letter-spacing:.12em;color:var(--gold)}.imm-tracker-premium p{margin:0;color:var(--ink);font-size:14px;line-height:1.5}
.imm-playlist-panel{border-radius:24px;padding:18px;background:linear-gradient(145deg,var(--green),#1f1a15);box-shadow:0 18px 42px rgba(31,26,21,.12);display:grid;gap:0}.imm-playlist-panel div{display:grid;grid-template-columns:34px 1fr;gap:12px;align-items:center;padding:12px 0;border-bottom:1px solid rgba(245,239,230,.13)}.imm-playlist-panel div:last-child{border-bottom:0}.imm-playlist-panel b{width:30px;height:30px;border-radius:50%;background:rgba(245,239,230,.12);color:var(--gold);display:flex;align-items:center;justify-content:center;font-size:11px}.imm-playlist-panel span{color:var(--beige);font-size:14px;line-height:1.5}
.imm-editorial--guide .imm-ing-dot{color:#6f8b65}.imm-editorial--routine .imm-step-num,.imm-editorial--calendar .imm-step-num{background:var(--green);color:var(--beige)}

/* Android Chrome — padding bas supplémentaire uniquement
   Safari/iOS ne lit pas ce bloc (@supports not webkit) */
@supports not (-webkit-touch-callout: none) {
  .page { padding-bottom: 160px !important; }
}


/* V20 — Card profil Confiance & Confidentialité */
.trust-app-card{
  grid-column:1/-1;
  display:grid;
  grid-template-columns:58px 1fr auto;
  gap:16px;
  align-items:center;
  position:relative;
  overflow:hidden;
  margin-top:18px;
  margin-bottom:110px;
  padding:20px 19px;
  border-radius:28px;
  border:1px solid rgba(201,169,110,.24);
  background:
    radial-gradient(circle at top left, rgba(201,169,110,.16), transparent 34%),
    linear-gradient(145deg, rgba(253,250,246,.96), rgba(246,241,232,.78));
  box-shadow:0 16px 42px rgba(31,26,21,.06);
  cursor:pointer;
}
.trust-app-card:active{transform:scale(.985)}
.trust-app-icon{
  width:58px;
  height:58px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:radial-gradient(circle,#1b584c,#0f3028);
  color:#E8C77A;
  font-size:23px;
  box-shadow:0 10px 22px rgba(18,61,52,.18);
}
.trust-app-kicker{
  color:#c9a96e;
  font-size:10px;
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:5px;
}
.trust-app-card h2{
  margin:0;
  font-family:var(--serif);
  color:var(--green);
  font-size:clamp(25px,6vw,38px);
  line-height:.95;
  font-weight:400;
}
.trust-app-card p{
  margin:8px 0 0;
  color:var(--muted);
  font-size:13px;
  line-height:1.55;
}
.trust-app-arrow{
  color:var(--green);
  font-size:28px;
  font-family:var(--serif);
}
@media(max-width:430px){
  .trust-app-card{
    grid-template-columns:48px 1fr auto;
    gap:12px;
    padding:18px 16px;
    border-radius:24px;
  }
  .trust-app-icon{width:48px;height:48px;font-size:20px}
  .trust-app-card p{font-size:12px}
}

/* ─── PUSH NOTIFICATION CARD (profil dashboard) ───────────────────────────── */
.push-notif-card{
  grid-column:1/-1;
  display:grid;
  grid-template-columns:58px 1fr auto;
  gap:16px;
  align-items:center;
  margin-top:18px;
  padding:20px 19px;
  border-radius:28px;
  border:1px solid rgba(201,169,110,.24);
  background:
    radial-gradient(circle at top left,rgba(201,169,110,.10),transparent 34%),
    linear-gradient(145deg,rgba(253,250,246,.96),rgba(246,241,232,.78));
  box-shadow:0 16px 42px rgba(31,26,21,.06);
}
.push-notif-icon{
  width:58px;height:58px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  background:radial-gradient(circle,#1b584c,#0f3028);
  color:#E8C77A;font-size:23px;
  box-shadow:0 10px 22px rgba(18,61,52,.18);
}
.push-notif-kicker{
  color:#c9a96e;font-size:10px;font-weight:900;
  letter-spacing:.22em;text-transform:uppercase;margin-bottom:5px;
}
.push-notif-body h2{
  margin:0;font-family:var(--serif);color:var(--green);
  font-size:clamp(22px,5.5vw,34px);line-height:.95;font-weight:400;
}
.push-notif-body p{margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.55;}
.push-notif-btn{
  flex-shrink:0;padding:10px 18px;border-radius:50px;border:none;
  background:linear-gradient(135deg,#1b584c,#0f3028);
  color:#E8C77A;font-family:var(--sans);font-size:12px;font-weight:700;
  letter-spacing:.06em;cursor:pointer;
  transition:opacity .2s,transform .15s;white-space:nowrap;
}
.push-notif-btn.is-on{
  background:linear-gradient(135deg,#2d7a5e,#1b584c);
  opacity:.7;cursor:default;
}
.push-notif-btn:disabled{opacity:.55;cursor:default;}
.push-notif-btn:not(:disabled):active{transform:scale(.96)}
@media(max-width:430px){
  .push-notif-card{grid-template-columns:48px 1fr auto;gap:12px;padding:18px 16px;border-radius:24px;}
  .push-notif-icon{width:48px;height:48px;font-size:20px;}
  .push-notif-body p{font-size:12px;}
  .push-notif-btn{padding:9px 14px;font-size:11px;}
}
/* ─────────────────────────────────────────────────────────────────────────── */

/* V20 — Recettes marketplace safe */
.recipes-hero{display:flex;justify-content:space-between;gap:24px;align-items:flex-end;margin:34px auto 22px;padding:28px;border:1px solid rgba(21,61,57,.10);border-radius:32px;background:linear-gradient(135deg,rgba(255,255,255,.64),rgba(244,240,231,.88));box-shadow:0 22px 55px rgba(31,28,24,.08)}
.recipes-hero span{font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--sage,#53644A)}
.recipes-hero h2{font-family:var(--serif,'Cormorant Garamond',serif);font-size:clamp(32px,5vw,58px);font-weight:300;line-height:.95;margin:10px 0 12px;color:var(--deep,#153D39)}
.recipes-hero p{max-width:640px;color:rgba(30,35,30,.68);line-height:1.8}
.recipes-stats{min-width:130px;display:grid;grid-template-columns:1fr 1fr;gap:6px 12px;text-align:center;padding:18px;border-radius:24px;background:rgba(255,255,255,.66)}
.recipes-stats b{font-family:var(--serif,'Cormorant Garamond',serif);font-size:34px;font-weight:300;color:var(--deep,#153D39)}
.recipes-stats small{font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:rgba(30,35,30,.52)}
.recipe-filter-strip{display:flex;gap:10px;overflow-x:auto;padding:6px 0 18px;scrollbar-width:none}.recipe-filter-strip::-webkit-scrollbar{display:none}
.recipe-filter-strip span{white-space:nowrap;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.64);border:1px solid rgba(21,61,57,.08);font-size:12px;color:rgba(30,35,30,.72)}
.recipe-market-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;padding-bottom:120px}
.recipe-market-card{overflow:hidden;border-radius:30px;background:rgba(255,255,255,.72);border:1px solid rgba(21,61,57,.08);box-shadow:0 18px 45px rgba(31,28,24,.07)}
.recipe-img{height:210px;background:linear-gradient(135deg,#f7f1e8,#e8e1d5);display:flex;align-items:center;justify-content:center;overflow:hidden}.recipe-img img{width:100%;height:100%;object-fit:cover}.recipe-img-placeholder span{font-size:54px;filter:drop-shadow(0 10px 24px rgba(0,0,0,.12))}
.recipe-market-body{padding:22px}.recipe-market-top{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:12px}.recipe-market-top span,.recipe-market-top b{font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:rgba(30,35,30,.55)}.recipe-market-top b{color:var(--sage,#53644A)}
.recipe-market-card h2{font-family:var(--serif,'Cormorant Garamond',serif);font-size:32px;font-weight:300;line-height:1;margin:0 0 10px;color:var(--deep,#153D39)}
.recipe-market-card p{color:rgba(30,35,30,.66);line-height:1.65;margin:0 0 16px}.recipe-market-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}.recipe-market-meta span{font-size:11px;padding:8px 10px;border-radius:999px;background:rgba(244,240,231,.8);color:rgba(30,35,30,.62)}
.recipe-viewer-card{max-width:720px}.recipe-viewer-text{margin-top:18px;padding:22px;border-radius:22px;background:rgba(244,240,231,.72);line-height:1.9;color:rgba(30,35,30,.78)}
@media(max-width:760px){.recipes-hero{display:block;padding:22px}.recipes-stats{margin-top:18px}.recipe-market-grid{grid-template-columns:1fr}.recipe-img{height:180px}}



/* =========================================================
   V26 — Recette débloquée · Viewer éditorial premium
   Même esprit que les protocoles immersifs.
   ========================================================= */
.media-modal.recipe-open{
  position:fixed;
  inset:0;
  display:block;
  z-index:9999;
}
.mt-recipe-backdrop{
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at 50% 20%, rgba(201,169,110,.18), transparent 34%),
    rgba(34,29,24,.78);
  backdrop-filter:blur(14px);
  z-index:9998;
}
.mt-recipe-sheet{
  position:fixed;
  z-index:9999;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:min(92vw,720px);
  max-height:88vh;
  overflow:auto;
  border-radius:34px;
  background:
    radial-gradient(circle at top right, rgba(201,169,110,.16), transparent 34%),
    linear-gradient(180deg, #fffdf8 0%, #f8f2e8 100%);
  border:1px solid rgba(201,169,110,.22);
  box-shadow:0 28px 90px rgba(31,26,21,.28);
}
.mt-recipe-sheet::-webkit-scrollbar{width:0;height:0}
.mt-recipe-close{
  position:absolute;
  top:18px;
  right:18px;
  z-index:5;
  width:52px;
  height:52px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.26);
  background:rgba(31,26,21,.56);
  color:#fff;
  font-size:32px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  backdrop-filter:blur(8px);
}
.mt-recipe-hero-image{
  height:270px;
  border-radius:34px 34px 0 0;
  overflow:hidden;
  background:linear-gradient(145deg,#1d312c,#d8b261);
  display:flex;
  align-items:center;
  justify-content:center;
}
.mt-recipe-hero-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.mt-recipe-hero-fallback span{
  font-size:72px;
  filter:drop-shadow(0 10px 18px rgba(0,0,0,.18));
}
.mt-recipe-sheet-body{
  padding:28px 26px 34px;
}
.mt-recipe-topline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:18px;
}
.mt-recipe-topline span,
.mt-recipe-topline b,
.mt-recipe-section-kicker{
  font-size:10px;
  font-weight:900;
  letter-spacing:.24em;
  text-transform:uppercase;
}
.mt-recipe-topline span,
.mt-recipe-section-kicker{color:var(--gold)}
.mt-recipe-topline b{
  color:var(--green);
  background:rgba(21,61,57,.07);
  border:1px solid rgba(21,61,57,.09);
  border-radius:999px;
  padding:9px 12px;
  letter-spacing:.14em;
}
.mt-recipe-sheet h1{
  margin:0 0 10px;
  font-family:var(--serif);
  font-size:clamp(52px,13vw,82px);
  line-height:.86;
  letter-spacing:-.055em;
  font-weight:300;
  color:var(--ink);
}
.mt-recipe-subtitle{
  margin:0 0 22px;
  color:var(--muted);
  font-size:16px;
  line-height:1.75;
}
.mt-recipe-intro-card,
.mt-recipe-editorial-section{
  background:rgba(255,255,255,.58);
  border:1px solid rgba(21,61,57,.08);
  border-radius:28px;
  padding:22px 20px;
  margin:16px 0;
  box-shadow:0 12px 32px rgba(31,26,21,.035);
}
.mt-recipe-intro-card p{
  margin:0;
  font-family:var(--serif);
  font-style:italic;
  font-size:26px;
  line-height:1.25;
  color:var(--ink);
}
.mt-recipe-meta-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
  margin:18px 0 10px;
}
.mt-recipe-meta-grid div{
  min-width:0;
  border-radius:22px;
  padding:16px 12px;
  text-align:center;
  background:rgba(245,239,230,.68);
  border:1px solid rgba(21,61,57,.07);
}
.mt-recipe-meta-grid strong{
  display:block;
  font-family:var(--serif);
  font-size:23px;
  line-height:1;
  font-weight:400;
  color:var(--ink);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.mt-recipe-meta-grid span{
  display:block;
  margin-top:7px;
  color:var(--muted);
  font-size:9px;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
}
.mt-recipe-ingredients,
.mt-recipe-steps{
  list-style:none;
  padding:0;
  margin:16px 0 0;
  display:grid;
  gap:12px;
}
.mt-recipe-ingredient,
.mt-recipe-step{
  display:grid;
  grid-template-columns:32px 1fr;
  gap:12px;
  align-items:flex-start;
}
.mt-recipe-ingredient span,
.mt-recipe-step span{
  width:32px;
  height:32px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(21,61,57,.08);
  color:var(--green);
  font-size:12px;
  font-weight:900;
}
.mt-recipe-step span{
  background:var(--green);
  color:#fffdf8;
}
.mt-recipe-ingredient p,
.mt-recipe-step p{
  margin:4px 0 0;
  color:var(--ink);
  font-size:15px;
  line-height:1.65;
}
@media(max-width:520px){
  .mt-recipe-sheet{
    width:100vw;
    max-height:92vh;
    left:0;
    right:0;
    bottom:0;
    top:auto;
    transform:none;
    border-radius:34px 34px 0 0;
  }
  .mt-recipe-hero-image{height:230px}
  .mt-recipe-sheet-body{padding:25px 20px 112px}
  .mt-recipe-meta-grid{grid-template-columns:1fr}
  .mt-recipe-sheet h1{font-size:56px}
  .mt-recipe-intro-card p{font-size:24px}
}


/* V28 · CTA PDF plus éditorial */
.mt-recipe-download-zone {
  margin-top: 38px;
  padding: 28px;
  border-radius: 34px;
  border: 1px solid rgba(184, 146, 74, .26);
  background:
    radial-gradient(circle at top left, rgba(184,146,74,.13), transparent 42%),
    linear-gradient(135deg, rgba(255,253,247,.98), rgba(244,240,231,.88));
  box-shadow: 0 22px 52px rgba(23, 63, 53, .075);
  text-align: center;
}

.mt-recipe-download-zone:before {
  content: "FICHE ÉDITORIALE";
  display: block;
  margin-bottom: 14px;
  color: #b8924a;
  font-family: var(--font-sans, "Jost", sans-serif);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .32em;
}

.mt-recipe-download-btn {
  width: 100%;
  border: 0;
  border-radius: 999px;
  padding: 18px 20px;
  background: #173f35;
  color: #fffdf7;
  font-family: var(--font-sans, "Jost", sans-serif);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  box-shadow: 0 14px 34px rgba(23,63,53,.18);
}

.mt-recipe-download-zone small {
  display: block;
  margin-top: 14px;
  color: #8c7561;
  font-family: var(--font-sans, "Jost", sans-serif);
  font-size: .78rem;
  line-height: 1.55;
}


/* V29 · PDF mobile-safe */
.mt-recipe-download-zone small::after {
  content: " Aperçu mobile optimisé.";
}


/* V30 · Viewer PDF intégré premium */
body.mt-pdf-open {
  overflow: hidden;
}

.mt-pdf-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 99999;
}

.mt-pdf-backdrop {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 10%, rgba(184,146,74,.22), transparent 38%),
    rgba(31, 27, 23, .62);
  backdrop-filter: blur(14px);
  opacity: 0;
  transition: opacity .28s ease;
}

.mt-pdf-shell {
  position: absolute;
  left: 50%;
  bottom: 18px;
  transform: translate(-50%, 28px) scale(.985);
  width: min(92vw, 520px);
  height: min(86vh, 780px);
  border-radius: 34px;
  background: #fbf7ef;
  border: 1px solid rgba(255,255,255,.58);
  box-shadow: 0 30px 90px rgba(0,0,0,.32);
  overflow: hidden;
  opacity: 0;
  transition: transform .32s ease, opacity .32s ease;
}

.mt-pdf-modal.is-open .mt-pdf-backdrop {
  opacity: 1;
}

.mt-pdf-modal.is-open .mt-pdf-shell {
  opacity: 1;
  transform: translate(-50%, 0) scale(1);
}

.mt-pdf-topbar {
  height: 78px;
  padding: 18px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background:
    linear-gradient(180deg, rgba(255,253,247,.96), rgba(248,243,234,.88));
  border-bottom: 1px solid rgba(184,146,74,.18);
}

.mt-pdf-topbar small {
  display: block;
  color: #b8924a;
  font-size: .66rem;
  font-weight: 900;
  letter-spacing: .28em;
  margin-bottom: 5px;
}

.mt-pdf-topbar strong {
  display: block;
  color: #173f35;
  font-family: var(--font-serif, Georgia, serif);
  font-size: 1.2rem;
  font-weight: 400;
}

.mt-pdf-close {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 0;
  background: rgba(31,27,23,.62);
  color: #fffdf7;
  font-size: 1.7rem;
  line-height: 1;
}

.mt-pdf-loader {
  position: absolute;
  inset: 78px 0 84px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 18px;
  background: #fbf7ef;
  z-index: 2;
  opacity: 1;
  transition: opacity .24s ease, visibility .24s ease;
}

.mt-pdf-modal.is-ready .mt-pdf-loader {
  opacity: 0;
  visibility: hidden;
}

.mt-pdf-loader-orb {
  width: 74px;
  height: 74px;
  border-radius: 50%;
  border: 1px solid rgba(184,146,74,.32);
  background:
    radial-gradient(circle, rgba(23,63,53,.16) 0 32%, transparent 33%),
    conic-gradient(from 0deg, rgba(23,63,53,.0), rgba(23,63,53,.55), rgba(184,146,74,.18));
  animation: mtPdfSpin 1.25s linear infinite;
}

.mt-pdf-loader p {
  color: #8c7561;
  font-family: var(--font-serif, Georgia, serif);
  font-style: italic;
  font-size: 1.25rem;
}

@keyframes mtPdfSpin {
  to { transform: rotate(360deg); }
}

.mt-pdf-preview-wrap {
  height: calc(100% - 78px - 84px);
  background: #e9e1d6;
  overflow: hidden;
}

.mt-pdf-frame {
  width: 100%;
  height: 100%;
  border: 0;
  background: #f4f0e7;
}

.mt-pdf-actions {
  height: 84px;
  padding: 14px 18px 18px;
  display: grid;
  grid-template-columns: .85fr 1.15fr;
  gap: 12px;
  background:
    linear-gradient(0deg, rgba(255,253,247,.98), rgba(248,243,234,.94));
  border-top: 1px solid rgba(184,146,74,.18);
}

.mt-pdf-actions button {
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.mt-pdf-secondary {
  border: 1px solid rgba(23,63,53,.16);
  background: rgba(255,255,255,.62);
  color: #173f35;
}

.mt-pdf-primary {
  border: 0;
  background: #173f35;
  color: #fffdf7;
  box-shadow: 0 12px 28px rgba(23,63,53,.18);
}

@media (max-width: 520px) {
  .mt-pdf-shell {
    left: 10px;
    right: 10px;
    bottom: 10px;
    width: auto;
    height: calc(100vh - 32px);
    transform: translateY(28px) scale(.985);
  }

  .mt-pdf-modal.is-open .mt-pdf-shell {
    transform: translateY(0) scale(1);
  }
}


/* V31 · Fix iPhone safe bottom: boutons PDF jamais coupés */
.mt-pdf-shell {
  height: min(82dvh, 760px) !important;
  max-height: calc(100dvh - 34px - env(safe-area-inset-bottom)) !important;
  bottom: calc(16px + env(safe-area-inset-bottom)) !important;
}

.mt-pdf-preview-wrap {
  height: calc(100% - 78px - 104px) !important;
  overflow: hidden !important;
}

.mt-pdf-actions {
  height: 104px !important;
  padding: 14px 18px calc(18px + env(safe-area-inset-bottom)) !important;
  align-items: start !important;
}

@media (max-width: 520px) {
  .mt-pdf-shell {
    left: 10px !important;
    right: 10px !important;
    top: 12px !important;
    bottom: calc(12px + env(safe-area-inset-bottom)) !important;
    width: auto !important;
    height: auto !important;
    max-height: none !important;
  }

  .mt-pdf-preview-wrap {
    height: calc(100dvh - 12px - 12px - env(safe-area-inset-bottom) - 78px - 104px) !important;
    min-height: 0 !important;
  }

  .mt-pdf-actions {
    height: 104px !important;
    padding-bottom: calc(18px + env(safe-area-inset-bottom)) !important;
  }

  .mt-pdf-actions button {
    min-height: 52px !important;
  }
}


/* V32 · Barre actions PDF toujours visible */
.mt-pdf-shell {
  top: max(96px, env(safe-area-inset-top)) !important;
  bottom: max(12px, env(safe-area-inset-bottom)) !important;
  height: auto !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: column !important;
}

.mt-pdf-topbar {
  flex: 0 0 78px !important;
}

.mt-pdf-preview-wrap {
  flex: 1 1 auto !important;
  height: auto !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

.mt-pdf-actions {
  flex: 0 0 auto !important;
  height: auto !important;
  min-height: 92px !important;
  padding: 14px 18px calc(18px + env(safe-area-inset-bottom)) !important;
  position: relative !important;
  z-index: 5 !important;
}

.mt-pdf-actions button {
  height: 54px !important;
  min-height: 54px !important;
}

@media (max-width: 520px) {
  .mt-pdf-shell {
    left: 10px !important;
    right: 10px !important;
    top: 118px !important;
    bottom: 12px !important;
    width: auto !important;
    height: auto !important;
    max-height: none !important;
  }

  .mt-pdf-preview-wrap {
    height: auto !important;
    min-height: 0 !important;
  }

  .mt-pdf-actions {
    display: grid !important;
    grid-template-columns: 1fr 1.25fr !important;
    gap: 10px !important;
    min-height: 96px !important;
  }
}


/* V33 · Accueil connecté au journal : signaux courts + drawer */
.club-v18-connected .club-v18-kicker{
  display:block;
  margin-bottom:8px;
  color:var(--gold);
  font-size:9px;
  font-weight:900;
  letter-spacing:.24em;
  text-transform:uppercase;
}

.club-v18-connected .club-v18-head p{
  max-width:390px;
}

.club-v18-connected .club-v18-tile{
  position:relative;
  overflow:hidden;
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.club-v18-connected .club-v18-tile:after{
  content:"";
  position:absolute;
  inset:auto 14px 12px auto;
  width:6px;
  height:6px;
  border-radius:999px;
  background:rgba(201,169,110,.52);
}

.club-v18-connected .club-v18-tile.is-live{
  background:linear-gradient(145deg, rgba(253,250,246,.78), rgba(245,239,230,.52));
  border-color:rgba(201,169,110,.20);
}

.club-v18-connected .club-v18-tile.is-live:after{
  background:var(--gold);
  box-shadow:0 0 0 4px rgba(201,169,110,.10);
}

.club-v18-connected .club-v18-tile:active{
  transform:scale(.985);
}

.club-v18-connected .club-v18-tile span{
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* highlight du post relié */
.post-card.post-highlight{
  animation:mtPostHighlight 1.25s ease;
}

@keyframes mtPostHighlight{
  0%{box-shadow:0 0 0 0 rgba(201,169,110,.0), 0 10px 34px rgba(31,26,21,.055);}
  30%{box-shadow:0 0 0 6px rgba(201,169,110,.18), 0 20px 48px rgba(31,26,21,.10);}
  100%{box-shadow:0 0 0 0 rgba(201,169,110,.0), 0 10px 34px rgba(31,26,21,.055);}
}

/* drawer signal journal */
.ritual-signal-drawer{
  position:fixed;
  inset:0;
  z-index:2147483300;
  pointer-events:none;
}

.ritual-signal-drawer.open{
  pointer-events:auto;
}

.ritual-signal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(31,26,21,.42);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  opacity:0;
  transition:opacity .22s ease;
}

.ritual-signal-drawer.open .ritual-signal-backdrop{
  opacity:1;
}

.ritual-signal-sheet{
  position:absolute;
  left:12px;
  right:12px;
  bottom:calc(12px + env(safe-area-inset-bottom));
  max-width:540px;
  margin:0 auto;
  border-radius:34px;
  padding:18px;
  background:
    radial-gradient(circle at 12% 0%, rgba(201,169,110,.16), transparent 34%),
    linear-gradient(180deg, rgba(253,250,246,.98), rgba(245,239,230,.96));
  border:1px solid rgba(255,255,255,.62);
  box-shadow:0 28px 82px rgba(31,26,21,.28);
  transform:translateY(24px) scale(.985);
  opacity:0;
  transition:transform .28s ease, opacity .28s ease;
}

.ritual-signal-drawer.open .ritual-signal-sheet{
  transform:translateY(0) scale(1);
  opacity:1;
}

.ritual-signal-grip{
  width:48px;
  height:5px;
  border-radius:999px;
  background:rgba(21,61,57,.14);
  margin:0 auto 14px;
}

.ritual-signal-close{
  position:absolute;
  right:16px;
  top:16px;
  width:38px;
  height:38px;
  border:0;
  border-radius:999px;
  background:rgba(31,26,21,.56);
  color:var(--beige);
  font-size:24px;
  line-height:1;
}

.ritual-signal-icon{
  width:50px;
  height:50px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.72);
  margin-bottom:14px;
  font-size:24px;
}

.ritual-signal-kicker{
  color:var(--gold);
  font-size:9px;
  font-weight:900;
  letter-spacing:.24em;
  text-transform:uppercase;
  margin-bottom:8px;
}

.ritual-signal-sheet h3{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  color:var(--green);
  font-size:34px;
  line-height:1;
  letter-spacing:-.035em;
  margin:0 48px 10px 0;
}

.ritual-signal-sheet h4{
  color:var(--ink);
  font-size:16px;
  line-height:1.35;
  margin:0 0 8px;
}

.ritual-signal-sheet p{
  color:var(--muted);
  font-size:14px;
  line-height:1.7;
  margin:0;
  white-space:pre-line;
}

.ritual-signal-actions{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:10px;
  margin-top:18px;
}

.ritual-signal-actions button{
  border-radius:999px;
  min-height:48px;
  padding:12px 14px;
  font-size:10px;
  font-weight:900;
  letter-spacing:.13em;
  text-transform:uppercase;
}

.ritual-signal-secondary{
  border:1px solid rgba(21,61,57,.14);
  background:rgba(253,250,246,.72);
  color:var(--green);
}

.ritual-signal-primary{
  border:0;
  background:var(--green);
  color:var(--beige);
  box-shadow:0 12px 26px rgba(21,61,57,.17);
}

/* V35 — Favoris & routines personnels */
.post-actions button.is-saved{
  background:#123D34!important;
  color:#fff!important;
  border-color:#123D34!important;
  box-shadow:0 10px 24px rgba(18,61,52,.16);
}
.saved-profile-card{cursor:pointer;transition:transform .22s ease, box-shadow .22s ease;}
.saved-profile-card:active{transform:scale(.985);}
.saved-sheet .saved-list{display:grid;gap:12px;margin:16px 0 4px;max-height:42vh;overflow:auto;padding-right:4px;}
.saved-item{background:#FBF8F1;border:1px solid #E8DDC9;border-radius:22px;padding:16px;}
.saved-item small{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#B89554;font-weight:800;margin-bottom:6px;}
.saved-item h4{font-family:'Cormorant Garamond',serif;font-size:27px;line-height:1.02;font-weight:400;color:#173F35;margin:0 0 6px;}
.saved-item p{font-size:14px;line-height:1.65;color:#8A7E73;margin:0;}


/* V36 — Bibliothèque personnelle premium */
.saved-library-sheet{max-height:min(88vh,760px)!important;overflow:auto!important;padding-bottom:28px!important;}
.saved-library-intro{font-size:15px;line-height:1.7;color:#8A7E73;margin:2px 0 16px;}
.saved-library-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:14px 0 12px;}
.saved-library-count{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#B89554;font-weight:800;}
.saved-library-switch{display:flex;gap:8px;background:#F6F1E8;border:1px solid #E7DDCD;border-radius:999px;padding:4px;}
.saved-library-switch button{border:0;background:transparent;border-radius:999px;padding:9px 12px;font-size:12px;font-weight:900;letter-spacing:.09em;text-transform:uppercase;color:#7C7066;}
.saved-library-switch button.active{background:#fff;color:#123F35;box-shadow:0 8px 18px rgba(30,40,30,.08);}
.saved-library-tools{display:grid;grid-template-columns:1fr auto;gap:10px;margin:10px 0 12px;}
.saved-library-tools input,.saved-library-tools select{height:46px;border-radius:999px;border:1px solid #E2D8C9;background:#FBF8F1;padding:0 16px;font:600 14px 'Jost',sans-serif;color:#173F35;outline:none;}
.saved-library-tools select{padding-right:32px;}
.saved-library-filters{display:flex;gap:8px;overflow:auto;padding:2px 0 12px;margin-bottom:4px;}
.saved-library-filters button{white-space:nowrap;border:1px solid #E2D8C9;background:#FBF8F1;color:#173F35;border-radius:999px;padding:10px 14px;font-size:12px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;}
.saved-library-filters button.active{background:#123F35;color:#fff;border-color:#123F35;}
.saved-editorial-list{display:grid;gap:12px;margin-top:6px;}
.saved-editorial-card{border:1px solid #E7DDCD;background:linear-gradient(140deg,#FFFEFA,#F8F2E8);border-radius:28px;padding:18px 18px 16px;box-shadow:0 18px 45px rgba(38,46,36,.08);cursor:pointer;}
.saved-editorial-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.saved-editorial-icon{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:#EEF1EA;font-size:18px;}
.saved-editorial-top small{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#B89554;font-weight:900;}
.saved-editorial-card h4{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:30px;line-height:1.02;color:#1B2B23;margin:0 0 8px;}
.saved-editorial-card p{font-size:14px;line-height:1.7;color:#82766C;margin:0 0 12px;}
.saved-editorial-foot{display:flex;align-items:center;justify-content:space-between;border-top:1px solid #E8DDC9;padding-top:12px;color:#9A8B7D;font-size:12px;letter-spacing:.08em;text-transform:uppercase;}
.saved-editorial-foot b{color:#123F35;}
.saved-empty{border:1px dashed #E2D8C9;border-radius:26px;padding:24px;background:#FBF8F1;text-align:left;}
.saved-empty b{font-size:26px;display:block;margin-bottom:8px;}
.saved-empty h4{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:400;margin:0 0 8px;color:#173F35;}
.saved-empty p{margin:0;color:#8A7E73;line-height:1.7;}
.saved-detail-preview{position:fixed;inset:0;z-index:10000;display:grid;place-items:center;padding:22px;}
.saved-detail-backdrop{position:absolute;inset:0;background:rgba(35,31,25,.46);backdrop-filter:blur(8px);}
.saved-detail-card{position:relative;background:#FFFEFA;border:1px solid #E8DDC9;border-radius:34px;padding:30px;max-width:520px;width:100%;box-shadow:0 28px 80px rgba(0,0,0,.22);}
.saved-detail-card>button{position:absolute;right:18px;top:18px;border:0;background:#766F66;color:white;border-radius:50%;width:44px;height:44px;font-size:28px;line-height:1;}
.saved-detail-card small{display:block;color:#B89554;font-weight:900;letter-spacing:.18em;text-transform:uppercase;margin-bottom:10px;}
.saved-detail-card h3{font-family:'Cormorant Garamond',serif;font-weight:400;font-size:42px;line-height:1;margin:0 42px 14px 0;color:#173F35;}
.saved-detail-card p{font-size:16px;line-height:1.8;color:#6F665E;white-space:pre-wrap;}
.saved-detail-actions{margin-top:18px;display:flex;justify-content:flex-end;}
.saved-detail-actions button{border:1px solid #D9C8AD;background:#123F35;color:white;border-radius:999px;padding:12px 22px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;}
@media(max-width:560px){.saved-library-tools{grid-template-columns:1fr}.saved-editorial-card h4{font-size:27px}.saved-detail-card h3{font-size:34px}.saved-library-switch button{font-size:11px;padding:8px 10px}}






/* V41 · Filtres premium intelligents — style discret */
.mt-premium-filter-zone {
  margin: 22px 0 26px;
  position: relative;
}
.mt-premium-filter-zone::before {
  content: "Explorer";
  display: block;
  margin: 0 0 12px 4px;
  font-family: var(--font-sans, "Outfit", sans-serif);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: rgba(184,146,74,.92);
}
.mt-filter-inner {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 2px 4px 9px;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.mt-filter-inner::-webkit-scrollbar { display: none; }
.mt-filter-pill {
  flex: 0 0 auto;
  min-width: 108px;
  border: 1px solid rgba(23, 63, 53, .10);
  background: rgba(255, 253, 247, .78);
  color: #173F35;
  border-radius: 999px;
  padding: 11px 15px 10px;
  box-shadow: 0 12px 30px rgba(23,63,53,.055);
  text-align: left;
  transition: transform .22s ease, background .22s ease, border-color .22s ease, box-shadow .22s ease;
}
.mt-filter-pill span {
  display: block;
  font-family: var(--font-sans, "Outfit", sans-serif);
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .04em;
  line-height: 1.1;
  white-space: nowrap;
}
.mt-filter-pill small {
  display: block;
  margin-top: 4px;
  color: #8C7561;
  font-family: var(--font-sans, "Outfit", sans-serif);
  font-size: .61rem;
  font-weight: 800;
  letter-spacing: .17em;
  text-transform: uppercase;
  white-space: nowrap;
}
.mt-filter-pill.is-active {
  background: linear-gradient(135deg, #173F35, #0F2D1F);
  color: #FFFDF7;
  border-color: rgba(23,63,53,.72);
  box-shadow: 0 18px 42px rgba(23,63,53,.18);
}
.mt-filter-pill.is-active small { color: rgba(255,253,247,.72); }
.mt-filter-pill:active { transform: scale(.97); }
.mt-protocol-filter-mount,
.mt-recipes-filter-mount {
  margin: 6px 0 20px;
}
@media (max-width: 520px) {
  .mt-premium-filter-zone { margin: 20px 0 22px; }
  .mt-filter-pill { min-width: 104px; padding: 10px 14px 9px; }
  .mt-filter-pill span { font-size: .74rem; }
  .mt-filter-pill small { font-size: .59rem; }
}


/* V44 · Profil — protocoles débloqués cliquables */
.unlocked-protocol-card .saved-editorial-icon{
  font-size: 1.3rem;
}


/* V49 · Continuer mon parcours + bibliothèque intelligente */
.continue-journey-card{
  border:1px solid rgba(23,63,53,.12);
  background:linear-gradient(135deg,rgba(255,253,247,.92),rgba(246,241,232,.86));
  border-radius:34px;
  padding:30px;
  margin:0 0 24px;
  box-shadow:0 22px 60px rgba(23,63,53,.08);
}
.continue-kicker,.continue-topline span,.biblio-shelf-kicker{
  font-family:var(--font-sans,"Outfit",sans-serif);
  color:#B8924A;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.68rem;
}
.continue-topline{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:center;
  margin-bottom:12px;
}
.continue-topline em{
  color:#173F35;
  font-style:normal;
  font-weight:900;
}
.continue-journey-card h2{
  font-family:var(--font-serif,"Cormorant Garamond",serif);
  color:#173F35;
  font-size:2.45rem;
  line-height:.95;
  margin:12px 0 14px;
  font-weight:400;
}
.continue-journey-card p{
  color:#8C7561;
  line-height:1.65;
  font-size:1rem;
  margin-bottom:18px;
}
.continue-progress{
  height:7px;
  border-radius:999px;
  background:rgba(23,63,53,.10);
  overflow:hidden;
  margin:4px 0 20px;
}
.continue-progress i{
  display:block;
  height:100%;
  background:linear-gradient(90deg,#173F35,#B8924A);
  border-radius:999px;
}
.continue-journey-card button{
  border:0;
  background:#173F35;
  color:#FFFDF7;
  border-radius:999px;
  padding:14px 22px;
  font-family:var(--font-sans,"Outfit",sans-serif);
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.biblio-smart-shelf{
  margin:26px 0;
  padding:24px;
  border-radius:30px;
  background:rgba(255,253,247,.72);
  border:1px solid rgba(23,63,53,.09);
  box-shadow:0 18px 45px rgba(23,63,53,.055);
}
.biblio-smart-shelf h2{
  font-family:var(--font-serif,"Cormorant Garamond",serif);
  color:#173F35;
  font-size:2.05rem;
  line-height:1;
  font-weight:400;
  margin:10px 0 8px;
}
.biblio-smart-shelf p{
  color:#8C7561;
  line-height:1.55;
  margin:0 0 18px;
}
.biblio-shelf-row{
  display:flex;
  gap:14px;
  overflow-x:auto;
  padding-bottom:8px;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.biblio-shelf-row::-webkit-scrollbar{display:none}
.biblio-shelf-row .saved-editorial-card{
  min-width:270px;
  max-width:310px;
  flex:0 0 78%;
}
@media (max-width:520px){
  .continue-journey-card{padding:26px 22px;border-radius:30px}
  .continue-journey-card h2{font-size:2.08rem}
  .biblio-smart-shelf{padding:20px 18px}
  .biblio-shelf-row .saved-editorial-card{min-width:245px}
}


/* V52 · Identité simple dashboard */
.mt-identity-simple{
  margin:0 0 18px;
  padding:18px 20px;
  border-radius:22px;
  background:rgba(255,253,247,.62);
  border:1px solid rgba(23,63,53,.08);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  box-shadow:0 12px 28px rgba(23,63,53,.045);
}
.mt-identity-simple small{
  display:block;
  color:#B8924A;
  font-family:var(--font-sans,"Outfit",sans-serif);
  font-size:.62rem;
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
  margin-bottom:6px;
}
.mt-identity-simple h2{
  font-family:var(--font-serif,"Cormorant Garamond",serif);
  color:#173F35;
  font-size:1.72rem;
  line-height:1;
  font-weight:400;
  margin:0 0 4px;
}
.mt-identity-simple p{
  margin:0;
  color:#8C7561;
  font-size:.92rem;
  line-height:1.35;
}
.mt-identity-simple button,
.mt-identity-simple-form button{
  border:0;
  background:#173F35;
  color:#FFFDF7;
  border-radius:999px;
  padding:11px 15px;
  font-family:var(--font-sans,"Outfit",sans-serif);
  font-size:.66rem;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  flex:0 0 auto;
}
.mt-identity-simple-sheet{
  padding:34px;
}
.mt-identity-simple-form{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-top:22px;
}
.mt-identity-simple-form label{
  color:#173F35;
  font-weight:800;
}
.mt-identity-simple-form input,
.mt-identity-simple-form select{
  width:100%;
  border:1px solid rgba(23,63,53,.12);
  background:#FFFDF7;
  border-radius:18px;
  padding:16px;
  color:#173F35;
  font-size:1rem;
}
@media(max-width:560px){
  .mt-identity-simple{
    padding:16px 16px;
    border-radius:20px;
  }
  .mt-identity-simple h2{
    font-size:1.45rem;
  }
}


/* ── Post feed : aperçu tronqué ── */
.post-preview-text {
  padding: 0 20px 4px;
  font-size: 14px;
  line-height: 1.85;
  color: var(--muted);
  white-space: pre-line;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.post-read-more {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin: 2px 20px 18px;
  background: none;
  border: none;
  padding: 0;
  font-family: 'Outfit', sans-serif;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--green);
  cursor: pointer;
  opacity: .82;
  transition: opacity .18s ease, letter-spacing .18s ease;
}
.post-read-more:hover { opacity: 1; letter-spacing: .18em; }
.post-read-more:active { opacity: .6; }

/* ── Post detail drawer ── */
.mt-post-detail-drawer {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 2000;
}
.mt-post-detail-drawer.open { display: block; }
.mt-post-detail-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(31, 26, 21, .52);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  animation: mtFadeIn .28s ease both;
}
@keyframes mtFadeIn { from { opacity: 0; } to { opacity: 1; } }

.mt-post-detail-sheet {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  max-height: 92dvh;
  background: var(--white);
  border-radius: 32px 32px 0 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  padding-bottom: calc(28px + var(--safe-bottom));
  animation: mtSheetUp .34s cubic-bezier(.22,.82,.32,1) both;
  box-shadow: 0 -24px 80px rgba(31,26,21,.18);
}
@keyframes mtSheetUp {
  from { transform: translateY(100%); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
.mt-post-detail-handle {
  width: 40px; height: 4px;
  background: var(--border);
  border-radius: 999px;
  margin: 14px auto 0;
}
.mt-post-detail-head {
  padding: 18px 20px 12px;
  display: grid;
  grid-template-columns: auto minmax(0,1fr) auto auto;
  align-items: center;
  gap: 12px;
  border-bottom: 1px solid var(--border);
}
.mt-post-detail-head strong {
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px;
  color: var(--ink);
  font-style: italic;
  font-weight: 400;
  line-height: 1;
}
.mt-post-detail-head small {
  display: block;
  font-size: 10px;
  color: var(--muted);
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-top: 4px;
}
.mt-post-detail-close {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 0;
  background: rgba(31,26,21,.08);
  color: var(--ink);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: background .18s ease;
}
.mt-post-detail-close:hover { background: rgba(31,26,21,.16); }
.mt-post-detail-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(34px, 9vw, 58px);
  font-weight: 400;
  color: var(--ink);
  line-height: 1.03;
  letter-spacing: -.035em;
  margin: 20px 20px 14px;
}
.mt-post-detail-body {
  padding: 16px 20px 8px;
  font-size: 15px;
  line-height: 1.9;
  color: var(--muted);
  white-space: pre-line;
}
.mt-post-detail-sheet .post-media-grid {
  margin-bottom: 0;
}
@media (max-width: 600px) {
  .post-read-more { margin-left: 16px; font-size: 11px; }
  .mt-post-detail-title { font-size: 34px; margin: 16px 16px 12px; }
  .mt-post-detail-body { padding: 14px 16px 8px; font-size: 14px; }
  .mt-post-detail-head { padding: 16px 16px 10px; }
}
