:root{
  --brand:#e15e01;--brand-2:#f2771f;--ink:#1c1814;--ink-soft:#7a716b;--ink-faint:#aaa19b;
  --cream:#f3dbc6;--surface:#ffffff;--line:rgba(0,0,0,.07);--dark:#1f1b18;
  --r-lg:26px;--r-md:20px;--r-sm:14px;
  --shadow-soft:0 10px 30px rgba(30,20,12,.10);--shadow-card:0 14px 36px rgba(30,20,12,.16);
}
html[data-theme="light"]{
  --app-bg:#f5f3f1;--head:#1c1814;--sub:#7a716b;
  --chip-bg:#fff;--chip-border:transparent;--chip-color:#7a716b;
  --chip-active-bg:#1f1b18;--chip-active-color:#fff;--accent-link:#e15e01;
  --avatar-bg:linear-gradient(135deg,#e15e01,#f2771f);--avatar-color:#fff;--avatar-border:#fff;
  --icon-btn-bg:#fff;--icon-btn-border:transparent;--icon-btn-color:#1c1814;
  --note:#aaa19b;--body-bg:#e9e6e3;
}
html[data-theme="warm"]{
  --app-bg:radial-gradient(125% 58% at 50% -10%, rgba(255,255,255,.24), rgba(255,255,255,0) 56%), linear-gradient(168deg,#f5871f 0%,#e15e01 48%,#c64d00 100%);
  --head:#fff;--sub:rgba(255,255,255,.86);
  --chip-bg:rgba(255,255,255,.16);--chip-border:rgba(255,255,255,.30);--chip-color:#fff;
  --chip-active-bg:#fff;--chip-active-color:#e15e01;--accent-link:#fff;
  --avatar-bg:#fff;--avatar-color:#e15e01;--avatar-border:rgba(255,255,255,.7);
  --icon-btn-bg:rgba(255,255,255,.18);--icon-btn-border:rgba(255,255,255,.32);--icon-btn-color:#fff;
  --note:rgba(255,255,255,.82);--body-bg:#d9cfc8;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{font-family:'Raleway',system-ui,sans-serif;background:var(--body-bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.45;transition:background .4s}
a{color:inherit;text-decoration:none}
.app{max-width:460px;margin:0 auto;min-height:100vh;background:var(--app-bg);position:relative;padding:0 18px 110px;box-shadow:0 0 80px rgba(0,0,0,.06);transition:background .4s}
@media (min-width:480px){body{padding:24px 0}.app{min-height:calc(100vh - 48px);border-radius:34px;overflow:hidden;padding-bottom:110px}}
.top{display:flex;align-items:center;justify-content:space-between;padding:26px 4px 18px;gap:12px}
.hello{font-family:'Montserrat',sans-serif;font-weight:800;font-size:23px;letter-spacing:-.3px;margin:0;color:var(--head)}
.hello-sub{font-size:13px;color:var(--sub);margin:2px 0 0}
.top-actions{display:flex;align-items:center;gap:10px}
.icon-btn{width:46px;height:46px;border-radius:50%;flex-shrink:0;cursor:pointer;background:var(--icon-btn-bg);border:1px solid var(--icon-btn-border);color:var(--icon-btn-color);display:flex;align-items:center;justify-content:center;transition:.2s}
html[data-theme="light"] .icon-btn{box-shadow:var(--shadow-soft)}
.icon-btn:active{transform:scale(.92)}
.icon-btn svg{width:21px;height:21px}
.avatar{width:48px;height:48px;border-radius:50%;flex-shrink:0;background:var(--avatar-bg);color:var(--avatar-color);font-family:'Montserrat',sans-serif;font-weight:800;font-size:17px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid var(--avatar-border);transition:.3s}
.search-row{display:flex;gap:11px;margin-bottom:24px}
.search{flex:1;display:flex;align-items:center;gap:10px;background:var(--surface);border-radius:999px;padding:0 18px;height:54px;box-shadow:var(--shadow-soft)}
.search svg{width:19px;height:19px;color:var(--ink-faint);flex-shrink:0}
.search input{border:0;outline:0;background:transparent;width:100%;font-family:'Raleway',sans-serif;font-size:15px;color:var(--ink)}
.search input::placeholder{color:var(--ink-faint)}
.filter-btn{width:54px;height:54px;border-radius:999px;flex-shrink:0;border:0;cursor:pointer;background:var(--dark);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px rgba(31,27,24,.3);transition:transform .15s}
.filter-btn:active{transform:scale(.92)}
.filter-btn svg{width:20px;height:20px}
.sec-title{font-family:'Montserrat',sans-serif;font-weight:800;font-size:19px;letter-spacing:-.3px;margin:0 0 14px;color:var(--head)}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin:30px 0 14px}
.sec-head .sec-title{margin:0}
.see-all{font-size:13px;font-weight:700;color:var(--accent-link);font-family:'Montserrat',sans-serif}
.chips{display:flex;gap:9px;overflow-x:auto;padding:2px 18px 8px;margin:0 -18px 4px;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex-shrink:0;border:1px solid var(--chip-border);cursor:pointer;background:var(--chip-bg);color:var(--chip-color);font-family:'Montserrat',sans-serif;font-weight:700;font-size:13.5px;padding:10px 18px;border-radius:999px;transition:all .18s;white-space:nowrap;backdrop-filter:blur(4px)}
.chip.active{background:var(--chip-active-bg);color:var(--chip-active-color);border-color:transparent;box-shadow:0 8px 18px rgba(0,0,0,.18)}
.hero{position:relative;border-radius:var(--r-lg);overflow:hidden;height:340px;box-shadow:var(--shadow-card);cursor:pointer;margin-bottom:6px}
.hero .ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero .scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,10,6,.82) 4%,rgba(15,10,6,.15) 46%,rgba(15,10,6,0) 70%)}
.hero .heart{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.22);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:3}
.hero .heart svg{width:20px;height:20px;color:#fff;fill:none;transition:.2s}
.hero .heart.on svg{fill:#fff}
.badge{display:inline-flex;align-items:center;gap:6px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:11px;letter-spacing:.4px;text-transform:uppercase;padding:6px 12px;border-radius:999px;color:#fff;backdrop-filter:blur(6px)}
.badge.video{background:rgba(225,94,1,.92)}
.badge.article{background:rgba(31,27,24,.7)}
.badge.doc{background:rgba(46,125,50,.85)}
.badge.interview{background:rgba(124,58,237,.82)}
.hero .body{position:absolute;left:20px;right:20px;bottom:20px;z-index:2;color:#fff}
.hero .body h3{font-family:'Montserrat',sans-serif;font-weight:800;font-size:23px;line-height:1.18;margin:12px 0 8px;letter-spacing:-.4px}
.hero .meta{display:flex;align-items:center;gap:14px;font-size:13px;color:rgba(255,255,255,.88);font-weight:600}
.hero .meta .star{color:#ffc24b}
.hero .go{position:absolute;bottom:20px;right:20px;width:50px;height:50px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;z-index:3;box-shadow:0 8px 20px rgba(0,0,0,.3)}
.hero .go svg{width:22px;height:22px;color:var(--dark)}
.scroller{display:flex;gap:14px;overflow-x:auto;margin:0 -18px;padding:4px 18px 12px;scrollbar-width:none}
.scroller::-webkit-scrollbar{display:none}
.mini{flex-shrink:0;width:215px;background:var(--surface);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-soft);cursor:pointer;transition:transform .18s}
.mini:active{transform:scale(.98)}
.mini .thumb{position:relative;height:128px;overflow:hidden}
.mini .thumb img{width:100%;height:100%;object-fit:cover}
.mini .thumb .badge{position:absolute;top:10px;left:10px;font-size:9.5px;padding:5px 9px}
.mini .thumb .h{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;cursor:pointer;border:0}
.mini .thumb .h svg{width:15px;height:15px;color:var(--ink);fill:none}
.mini .thumb .h.on svg{fill:var(--brand);color:var(--brand)}
.mini .b{padding:13px 14px 15px}
.mini .b h4{font-family:'Montserrat',sans-serif;font-weight:700;font-size:14px;line-height:1.32;margin:0 0 8px;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:37px}
.mini .b .m{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-soft);font-weight:600}
.mini .b .m .dot{width:3px;height:3px;border-radius:50%;background:var(--ink-faint)}
.feed{display:flex;flex-direction:column;gap:14px;margin-top:6px}
.row-card{display:flex;gap:14px;background:var(--surface);border-radius:var(--r-md);padding:12px;box-shadow:var(--shadow-soft);cursor:pointer;align-items:center;transition:transform .15s}
.row-card:active{transform:scale(.99)}
.row-card .thumb{position:relative;width:104px;height:88px;border-radius:var(--r-sm);overflow:hidden;flex-shrink:0}
.row-card .thumb img{width:100%;height:100%;object-fit:cover}
.row-card .info{flex:1;min-width:0}
.row-card .info .badge{font-size:9.5px;padding:4px 9px;margin-bottom:7px}
.row-card .info h4{font-family:'Montserrat',sans-serif;font-weight:700;font-size:14.5px;line-height:1.3;margin:0 0 7px;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.row-card .info .m{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-soft);font-weight:600}
.row-card .info .m .dot{width:3px;height:3px;border-radius:50%;background:var(--ink-faint)}
.empty{text-align:center;color:var(--note);padding:40px 20px;font-size:14px}
.reveal{opacity:0;transform:translateY(14px);animation:up .5s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes up{to{opacity:1;transform:none}}
.tabbar{position:fixed;left:50%;transform:translateX(-50%);bottom:18px;z-index:40;width:min(420px,calc(100% - 36px));background:var(--dark);border-radius:999px;display:flex;justify-content:space-around;align-items:center;padding:11px 10px;box-shadow:0 14px 40px rgba(31,27,24,.45)}
.tab{background:none;border:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;color:rgba(255,255,255,.55);font-family:'Montserrat',sans-serif;font-size:9.5px;font-weight:700;padding:6px 14px;border-radius:999px;transition:.2s}
.tab svg{width:22px;height:22px}
.tab.active{color:var(--dark);background:#fff;flex-direction:row;padding:9px 16px;gap:7px}
.tab.active svg{color:var(--dark)}
/* preview sheet */
.sheet-overlay{position:fixed;inset:0;background:rgba(15,10,6,.5);backdrop-filter:blur(3px);z-index:60;opacity:0;pointer-events:none;transition:opacity .28s}
.sheet-overlay.open{opacity:1;pointer-events:auto}
.sheet{position:fixed;left:50%;transform:translateX(-50%) translateY(100%);bottom:0;z-index:61;width:min(460px,100%);max-height:92vh;overflow-y:auto;background:#f5f3f1;border-radius:28px 28px 0 0;transition:transform .34s cubic-bezier(.2,.8,.2,1)}
.sheet.open{transform:translateX(-50%) translateY(0)}
.sheet .grip{width:42px;height:5px;border-radius:99px;background:rgba(0,0,0,.18);margin:11px auto 0}
.sheet .media{position:relative;height:240px;margin:14px 14px 0;border-radius:var(--r-md);overflow:hidden;background:#000}
.sheet .media img,.sheet .media iframe{width:100%;height:100%;border:0;object-fit:cover;display:block}
.sheet .media .play{position:absolute;inset:0;margin:auto;width:66px;height:66px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(0,0,0,.35);cursor:pointer}
.sheet .media .play svg{width:26px;height:26px;color:var(--brand);margin-left:3px}
.sheet .media .close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);border:0;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1;z-index:4}
.sheet .sbody{padding:20px 22px 30px}
.sheet .sbody .badge{font-size:10px;padding:5px 11px;margin-bottom:12px}
.sheet .sbody h2{font-family:'Montserrat',sans-serif;font-weight:800;font-size:22px;line-height:1.22;margin:0 0 10px;letter-spacing:-.4px;color:var(--ink)}
.sheet .sbody .m{display:flex;align-items:center;gap:13px;font-size:13px;color:var(--ink-soft);font-weight:600;margin-bottom:16px}
.sheet .sbody .m .star{color:#f0a500}
.sheet .sbody p{font-size:14.5px;color:#544c47;margin:0 0 22px}
.cta{display:block;width:100%;text-align:center;border:0;cursor:pointer;background:var(--brand);color:#fff;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;padding:17px;border-radius:999px;box-shadow:0 10px 26px rgba(225,94,1,.35);margin-bottom:16px}
.comments-link{display:block;text-align:center;font-family:'Montserrat',sans-serif;font-weight:700;font-size:13.5px;color:var(--brand);padding:6px}
.comments-teaser{background:var(--cream);border-radius:var(--r-md);padding:18px;text-align:center}
.comments-teaser p{margin:0 0 12px;font-size:13.5px;color:#6b4a2e;font-weight:600}
.comments-teaser a{display:inline-block;background:var(--dark);color:#fff;font-family:'Montserrat',sans-serif;font-weight:700;font-size:13.5px;padding:11px 22px;border-radius:999px}
.placeholder-note{font-size:11px;color:var(--note);text-align:center;padding:14px 0 0;font-style:italic}
/* ---- formulaires (auth, compte, admin) ---- */
.card-panel{background:var(--surface);border-radius:var(--r-md);padding:24px;box-shadow:var(--shadow-soft);margin-top:8px}
.page-title{font-family:'Montserrat',sans-serif;font-weight:800;font-size:26px;color:var(--head);margin:8px 0 18px;letter-spacing:-.4px}
label.fld{display:block;font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px;color:var(--ink);margin:14px 0 6px}
.input,select.input,textarea.input{width:100%;padding:13px 15px;border:1px solid #e5e0db;border-radius:12px;font-family:'Raleway',sans-serif;font-size:15px;color:var(--ink);background:#fff;outline:none}
.input:focus{border-color:var(--brand)}
textarea.input{min-height:120px;resize:vertical}
.btn{display:inline-block;width:100%;text-align:center;border:0;cursor:pointer;background:var(--brand);color:#fff;font-family:'Montserrat',sans-serif;font-weight:700;font-size:15px;padding:15px;border-radius:12px;margin-top:20px}
.btn.dark{background:var(--dark)}
.btn.ghost{background:transparent;color:var(--brand);box-shadow:none}
.alert{padding:13px 15px;border-radius:11px;font-size:14px;margin-bottom:14px}
.alert.err{background:#fdecea;color:#b71c1c}
.alert.ok{background:#e8f5e9;color:#1b5e20}
.muted-link{display:block;text-align:center;color:var(--accent-link);font-size:14px;margin-top:16px;font-weight:600}
/* ---- resource page ---- */
.res-hero{position:relative;border-radius:var(--r-lg);overflow:hidden;margin:6px 0 18px;background:#000}
.res-hero img,.res-hero iframe{width:100%;display:block;border:0}
.res-hero img{aspect-ratio:16/9;object-fit:cover}
.res-hero iframe{aspect-ratio:16/9;height:auto}
.res-body{font-size:15.5px;color:#3f3833;line-height:1.7}
.res-body p{margin:0 0 14px}
.back-btn{display:inline-flex;align-items:center;gap:7px;color:var(--head);font-weight:700;font-family:'Montserrat',sans-serif;font-size:14px;padding:20px 0 4px}
.back-btn svg{width:18px;height:18px}
.comment{background:var(--surface);border-radius:var(--r-sm);padding:14px 16px;box-shadow:var(--shadow-soft);margin-bottom:10px}
.comment .who{font-weight:700;font-family:'Montserrat',sans-serif;font-size:13px;color:var(--ink)}
.comment .when{font-size:11px;color:var(--ink-faint);margin-left:8px;font-weight:500}
.comment p{margin:7px 0 0;font-size:14.5px;color:#4a423d}
/* ---- admin ---- */
.admin-row{display:flex;align-items:center;gap:12px;background:var(--surface);border-radius:var(--r-sm);padding:10px 12px;box-shadow:var(--shadow-soft);margin-bottom:9px}
.admin-row img{width:60px;height:46px;border-radius:9px;object-fit:cover;flex-shrink:0}
.admin-row .at{flex:1;min-width:0}
.admin-row .at b{font-family:'Montserrat',sans-serif;font-size:14px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.admin-row .at span{font-size:11.5px;color:var(--ink-soft)}
.admin-row a{font-size:12px;font-weight:700;color:var(--brand);font-family:'Montserrat',sans-serif}
.admin-row a.del{color:#c62828}
.pill-link{display:inline-block;background:var(--dark);color:#fff;padding:11px 18px;border-radius:999px;font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px}

/* ---- Nouveaux types + offres payantes ---- */
.badge.pack{background:rgba(198,124,0,.92)}
.badge.formation{background:rgba(79,70,229,.90)}
.badge.marketplace{background:rgba(29,78,216,.90)}
.price-tag{display:inline-flex;align-items:center;font-family:'Montserrat',sans-serif;font-weight:800;font-size:11px;color:#fff;background:var(--brand);padding:4px 9px;border-radius:7px;line-height:1}
.mini .thumb .price-tag,.row-card .thumb .price-tag{position:absolute;bottom:8px;left:8px;box-shadow:0 4px 10px rgba(0,0,0,.28);z-index:2}
.hero .meta .price-tag{background:rgba(225,94,1,.96);font-size:12px}
.sheet .sprice{display:inline-flex;align-items:baseline;gap:8px;font-family:'Montserrat',sans-serif;margin:0 0 14px}
.sheet .sprice b{font-size:26px;font-weight:900;color:var(--brand);letter-spacing:-.5px}
.sheet .sprice span{font-size:12.5px;color:var(--ink-soft);font-weight:600}

/* ---- Photo de profil ---- */
.avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block}
.avatar-lg{width:74px;height:74px;font-size:24px}
.comment .head{display:flex;align-items:center;gap:9px}
.comment .cav{width:30px;height:30px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,#e15e01,#f2771f);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-weight:800;font-size:12px;overflow:hidden}
.comment .cav img{width:100%;height:100%;object-fit:cover}
