/* OmniPhotosBETA — burger-first navigation, anchored options, loader exit animation */
:root{--bg:#0b0b0e;--fg:#e7e7ea;--muted:#b4b4bb;--panel:#111116;--panel-2:#16161d;--line:#23232c;--accent:#e11d48;--new-bg:#2e7d32;--new-border:#3ea451}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--fg)}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:none;filter:brightness(1.06)}

.topbar{position:sticky;top:0;z-index:40;display:grid;grid-template-columns:auto auto 1fr auto;gap:10px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--line);background:color-mix(in oklab,var(--panel) 92%,transparent);backdrop-filter:blur(8px)}
.logo{display:inline-flex;align-items:center;gap:8px;font-weight:800}
.logo-badge{background:var(--accent);color:#fff;display:inline-grid;place-items:center;width:28px;height:28px;border-radius:6px}
.logo-text span{color:var(--accent)}
.icon-btn{padding:8px 10px;border-radius:10px;border:1px solid var(--line);background:var(--panel);color:var(--fg);cursor:pointer}

.searchbar{position:relative;display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;max-width:100%;width:100%;transform:translateY(3px)}
.search-input{width:100%;padding:12px 44px 12px 40px;border-radius:999px;border:1px solid var(--line);background:var(--panel-2);color:var(--fg);outline:none}
.search-icon{position:absolute;left:12px;pointer-events:none;opacity:.9}
.search-clear{border-radius:999px;border:1px solid var(--line);background:var(--panel);color:var(--fg);padding:8px 10px;cursor:pointer}
.search-submit{border-radius:999px;border:1px solid var(--line);background:var(--accent);color:#fff;padding:10px 14px;font-weight:700;cursor:pointer}

/* Options dropdown anchored below topbar */
.options-panel{position:absolute;top:100%;right:12px;margin-top:8px;min-width: min(92vw, 740px);display:none;padding:12px;border:1px solid var(--line);border-radius:12px;background:var(--panel);box-shadow:0 14px 50px rgba(0,0,0,.35);z-index:38}
.options-panel.open{display:block;animation:fadeIn .12s ease-out}
.options-panel .caret{position:absolute;top:-6px;right:70px;width:12px;height:12px;background:var(--panel);border-left:1px solid var(--line);border-top:1px solid var(--line);transform:rotate(45deg)}
.options-form{display:grid;gap:10px}
.options-form .row{display:grid;gap:6px}
.options-form .row.two{grid-template-columns:1fr 1fr;gap:10px}
.options-form label{color:var(--muted);font-size:13px}
.options-form select{padding:10px 12px;border-radius:10px;border:1px solid var(--line);background:var(--panel-2);color:var(--fg);outline:none;width:100%}
.options-form .check{display:flex;align-items:end}
.options-form .btn.ghost{background:transparent;border-color:var(--line);color:var(--fg)}
.options-form .actions{display:flex;gap:8px;justify-content:flex-end}

/* Burger menu (all breakpoints) */
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);backdrop-filter:blur(2px);display:none;z-index:39}
.backdrop.show{display:block;animation:fadeIn .12s ease-out}
.burger-menu{position:fixed;top:0;left:0;bottom:0;width:min(92vw,380px);z-index:40;background:var(--panel);border-right:1px solid var(--line);box-shadow:0 16px 40px rgba(0,0,0,.35);display:grid;gap:4px;padding:10px 10px 14px;border-top-right-radius:12px;border-bottom-right-radius:12px;transform:translateX(-100%);}
.burger-menu a{display:block;padding:12px 10px;border-radius:8px}
.burger-menu a:hover{background:var(--panel-2)}
.burger-menu.open{animation:drawerInLeft .20s ease-out forwards}
@keyframes drawerInLeft{from{transform:translateX(-100%);opacity:.6}to{transform:translateX(0);opacity:1}}to{transform:translateX(0);opacity:1}}

.user-menu{display:none} /* no top actions, user ops go in burger */

/* Layout */
.main,.watch{padding:12px}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media (min-width:640px){.grid{grid-template-columns:repeat(3,1fr)}}
@media (min-width:900px){.grid{grid-template-columns:repeat(4,1fr)}}

.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;display:grid;transform:translateY(6px);opacity:0}
.card.reveal{animation:reveal .3s both ease-out}
@keyframes reveal{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.thumb-wrap{position:relative;display:block;aspect-ratio:16/9;background:#111;overflow:hidden}
.thumb-wrap img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s ease}
.thumb-wrap:hover img{transform:scale(1.02)}
.thumb-wrap::after{content:'▶';position:absolute;inset:auto 8px 8px auto;width:24px;height:24px;display:grid;place-items:center;background:rgba(0,0,0,.55);border-radius:6px;color:#fff;font-size:12px}
.duration{position:absolute;right:8px;bottom:8px;z-index:2;background:rgba(0,0,0,.7);color:#fff;padding:3px 6px;border-radius:6px;font-size:12px;pointer-events:none}
.badge-new{position:absolute;left:8px;top:8px;z-index:2;background:var(--new-bg);border:2px solid var(--new-border);color:#fff;font-weight:700;padding:2px 8px;border-radius:8px;font-size:12px;line-height:1}

.meta{display:grid;grid-template-columns:auto 1fr auto;gap:10px;padding:10px;align-items:start}
.avatar{width:36px;height:36px;border-radius:999px;overflow:hidden;background:var(--panel-2);display:block}
.avatar img{width:100%;height:100%;object-fit:cover;display:block}
.title{margin:0;font-size:15px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.side__title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sub{color:var(--muted);font-size:13px}
.more,.share-btn{background:transparent;border:0;color:var(--muted);font-size:18px;cursor:pointer}

/* Watch layout */
.watch{display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width:1100px){.watch{grid-template-columns:2fr 1fr}}
.btn{background:var(--accent);color:#fff;border:1px solid transparent;border-radius:10px;padding:8px 12px;cursor:pointer}
.btn.small{padding:6px 10px}
.side__list{display:grid;gap:10px}
.side__item{position:relative;display:grid;grid-template-columns:160px 1fr;gap:8px;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--panel)}
.side__item img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/9;display:block}
.duration--small{position:absolute;right:6px;bottom:6px;font-size:11px;background:rgba(0,0,0,.7);color:#fff;padding:2px 5px;border-radius:6px}
.empty{grid-column:1/-1;text-align:center;color:var(--muted);padding:40px}

/* Pagination */
.pagination{display:flex;gap:8px;justify-content:center;align-items:center;margin:18px 0}
.pagination a,.pagination span{padding:8px 12px;border:1px solid var(--line);border-radius:10px;background:var(--panel)}
.pagination .current{background:var(--accent);border-color:transparent;color:#fff}

/* Forms */
.form{max-width:560px;margin:24px auto;padding:16px;border:1px solid var(--line);background:var(--panel);border-radius:12px;display:grid;gap:12px}
.form h1{margin:0 0 8px 0}
.form .row{display:grid;gap:6px}
.form input,.form select{padding:12px;border-radius:10px;border:1px solid var(--line);background:var(--panel-2);color:var(--fg);outline:none}
.form .actions{display:flex;gap:8px;justify-content:flex-end}
.form .muted{color:var(--muted);font-size:13px}
.alert{padding:10px 12px;border-radius:10px;background:#1e293b;border:1px solid #334155}
.alert.err{background:#3b1e1e;border-color:#7f1d1d}

/* Loader: visible until full load, with exit animation */
.loader{position:fixed;inset:0;background:#0b0b0ef0;backdrop-filter:blur(3px);display:grid;place-items:center;z-index:60;transition:opacity .35s ease, transform .35s ease}
.loader.leaving{opacity:0;transform:scale(1.03)}
.loader.hidden{display:none}
.spinner{width:44px;height:44px;border-radius:999px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.footer{margin-top:30px;border-top:1px solid var(--line);background:var(--panel)}
.footer__inner{max-width:1200px;margin:0 auto;padding:14px 12px;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;align-items:center}
.footer__links{display:flex;gap:12px}
.footer__links a{padding:6px 8px;border-radius:8px}
.footer__links a:hover{background:var(--panel-2)}

@keyframes fadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

.watch__meta{display:grid;grid-template-columns:auto 1fr auto auto auto;gap:12px;align-items:center;margin:10px 0}
.watch__meta .grow{display:none}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.chip{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--line);border-radius:999px;background:var(--panel-2);font-size:13px}
.chip .avatar{width:22px;height:22px;border-radius:999px;overflow:hidden}

.burger-head{display:flex;justify-content:space-between;align-items:center;padding:6px 6px 8px 6px;margin-bottom:4px;border-bottom:1px solid var(--line)}
.user-link{justify-self:end;padding:8px 12px;border:1px solid var(--line);border-radius:10px;background:var(--panel);color:var(--fg);white-space:nowrap}
.user-link:hover{background:var(--panel-2)}
.panel-close{position:absolute;top:8px;right:8px;border:1px solid var(--line);background:var(--panel-2);color:var(--fg);border-radius:8px;padding:4px 8px;cursor:pointer}
/* Mobile Up Next mirrors grid and hides sidebar */
@media (max-width:1099px){
  .watch__side{display:none}
  .up-next-mobile{display:block}
}
@media (min-width:1100px){
  .up-next-mobile{display:none}
}

.user-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px}
.user-badge{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:999px;color:#fff;font-weight:700;font-size:12px}
.user-name{max-width:32ch;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Mobile: stack search under logo, shrink controls to fit */
@media (max-width: 640px){
  .topbar{
    grid-template-columns: auto 1fr auto;
    grid-template-areas:
      "burger logo user"
      "search search search";
    row-gap: 8px;
  }
  #burgerBtn{ grid-area: burger; }
  .logo{ grid-area: logo; min-width: 0; }
  .user-link{ grid-area: user; }
  .searchbar{ grid-area: search; margin-top: 0; transform:none; }
  .logo-text{ font-size: 16px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .logo-badge{ width:24px; height:24px; }
  .search-input{ padding:10px 40px 10px 36px; font-size:14px; }
  .search-submit{ padding:8px 12px; font-size:14px; }
  .search-clear{ padding:6px 8px; }
}
@media (max-width: 380px){
  .logo-text{ font-size: 15px; }
  .search-input{ font-size:13px; padding:9px 38px 9px 34px; }
  .search-submit{ font-size:13px; padding:7px 10px; }
  .search-clear{ padding:5px 7px; }
}

/* Index: 1 card per row on small screens */
@media (max-width: 640px){
  .page-index .grid,
  .page-channels .grid,
  .page-watch .grid,
  .page-model .grid { grid-template-columns: 1fr; }
}
/* Comments: no reveal animation by default */
.comments .card{
  opacity: 1;
  transform: none;
}

.model-suggestions .chip img {
  width: 32px;                   /* Plus petit que le cadre */
  height: 32px;
  border-radius: 50%;
  object-fit: cover;
}

.model-suggestions .chip span {
  font-size: 15px;
  font-weight: 500;
  line-height: 1;        
  text-align: center;         /* Évite que le texte soit trop haut ou trop bas */
}


