/* ── DESIGN TOKENS — Thème Nuit ────────────────────────────────────── */
:root {
  --bg:         #14110d;
  --surface:    #1d1a14;
  --surface-2:  #28231c;
  --surface-3:  #332d23;
  --hairline:        rgba(240,232,216,0.08);
  --hairline-strong: rgba(240,232,216,0.16);
  --text:       #f0e8d8;
  --text-dim:   #a59c8c;
  --text-faint: #6a6258;
  --accent:        #d4a574;
  --accent-bright: #e6bf8d;
  --accent-deep:   #b48656;
  --accent-bg:        rgba(212,165,116,0.13);
  --accent-bg-strong: rgba(212,165,116,0.22);
  --danger:  #d97a6e;
  --success: #8fb583;
  --serif: "Source Serif 4","Spectral",Georgia,serif;
  --sans:  "Inter",system-ui,-apple-system,sans-serif;
  --shadow-lg: 0 24px 60px rgba(0,0,0,0.5);
  --shadow-md: 0 8px 24px rgba(0,0,0,0.4);
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.3);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100dvh}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit;color:inherit}
img{display:block;max-width:100%}

/* ── SCROLL UTILS ── */
.scroll{overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.scroll::-webkit-scrollbar{display:none}
.h-scroll{overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}
.h-scroll::-webkit-scrollbar{display:none;height:0;width:0}

/* ── TYPE ── */
.serif{font-family:var(--serif)}
.serif-it{font-family:var(--serif);font-style:italic;font-weight:400}
.eyebrow{font-family:var(--sans);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-dim);font-weight:500}
.muted{color:var(--text-dim)}
.faint{color:var(--text-faint)}
.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.text-2line{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ── LAYOUT UTILS ── */
.row{display:flex;align-items:center}
.row.gap-8{gap:8px}.row.gap-12{gap:12px}.row.gap-14{gap:14px}.row.gap-16{gap:16px}
.col{display:flex;flex-direction:column}
.flex1{flex:1;min-width:0}
.hidden{display:none!important}

/* ── PROGRESS BAR ── */
.progress{height:4px;background:var(--hairline-strong);border-radius:999px;position:relative;overflow:hidden}
.progress>i{position:absolute;inset:0 auto 0 0;background:var(--accent);border-radius:999px;display:block}
.progress.thick{height:6px}

/* ── COVER ── */
.cover-frame{position:relative;border-radius:8px;overflow:hidden;background:var(--surface-2);flex-shrink:0;box-shadow:var(--shadow-sm)}
.cover-frame img{width:100%;height:100%;object-fit:contain;display:block;background:var(--surface-2)}
.cover-frame.lg{box-shadow:var(--shadow-lg);border-radius:10px}
.cover-badge{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;background:rgba(20,17,13,0.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:grid;place-items:center;font-size:11px;font-weight:600}
.cover-badge.accent{background:var(--accent);color:#1a1410}
.cover-badge.success{background:var(--success);color:#14110d}

/* ── BUTTONS ── */
.btn{font-family:var(--sans);font-size:15px;font-weight:500;border-radius:999px;padding:14px 20px;border:1px solid transparent;background:var(--surface-2);color:var(--text);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:transform .12s,background .12s;white-space:nowrap}
.btn:active{transform:scale(0.97)}
.btn-primary{background:var(--accent);color:#1a1410;font-weight:600}
.btn-primary:hover{background:var(--accent-bright)}
.btn-ghost{background:transparent;border-color:var(--hairline-strong);color:var(--text)}
.btn-block{width:100%}

/* ── ICON BUTTONS ── */
.icon-btn{width:40px;height:40px;border-radius:50%;background:transparent;border:1px solid var(--hairline-strong);color:var(--text);display:grid;place-items:center;cursor:pointer;transition:background .12s,transform .12s;flex-shrink:0}
.icon-btn:active{transform:scale(0.94)}
.icon-btn:hover{background:var(--surface-2)}
.icon-btn.bare{border:none}
.icon-btn.small{width:34px;height:34px}
.icon-btn.large{width:56px;height:56px}

/* ── CHIPS ── */
.chip{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:999px;font-size:12px;font-weight:500;border:1px solid var(--hairline-strong);background:transparent;color:var(--text-dim);white-space:nowrap;font-family:var(--sans);cursor:pointer;transition:background .12s,color .12s,border-color .12s}
.chip:hover{color:var(--text)}
.chip.active{background:var(--text);color:var(--bg);border-color:var(--text)}

/* ── STATUS BADGE ── */
.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:500;font-family:var(--sans)}
.status-badge.in-progress{background:var(--accent-bg);color:var(--accent);border:1px solid rgba(212,165,116,0.3)}
.status-badge.done{background:rgba(143,181,131,0.13);color:var(--success);border:1px solid rgba(143,181,131,0.3)}
.status-badge.wishlist{background:transparent;color:var(--text-dim);border:1px solid var(--hairline-strong)}

/* ── SECTION HEAD ── */
.section-head{display:flex;align-items:baseline;justify-content:space-between;padding:20px 20px 12px}
.section-head h2{font-family:var(--serif);font-weight:600;font-style:italic;font-size:22px;letter-spacing:-0.01em;color:var(--text)}
.section-head .more{font-size:12px;color:var(--accent);cursor:pointer;font-weight:500;flex-shrink:0}

/* ── INPUT ── */
.input{background:var(--surface-2);border:1px solid var(--hairline);border-radius:12px;padding:12px 14px;font-family:var(--sans);font-size:14px;color:var(--text);width:100%;outline:none;transition:border-color .12s}
.input:focus{border-color:var(--accent)}
.input::placeholder{color:var(--text-faint)}
.search-wrap{position:relative;padding:0 20px}
.search-wrap svg{position:absolute;left:34px;top:50%;transform:translateY(-50%);color:var(--text-faint);pointer-events:none}
.search-wrap input{background:var(--surface-2);border:1px solid var(--hairline);border-radius:999px;padding:11px 14px 11px 40px;font-family:var(--sans);font-size:14px;color:var(--text);width:100%;outline:none;transition:border-color .12s}
.search-wrap input::placeholder{color:var(--text-faint)}
.search-wrap input:focus{border-color:var(--hairline-strong)}

/* ── TOPBAR ── */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 8px;flex-shrink:0;position:sticky;top:0;z-index:50;background:rgba(20,17,13,0.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}

/* ── AVATAR ── */
.avatar{display:grid;place-items:center;border-radius:50%;flex-shrink:0}

/* ── CARD ── */
.card{background:var(--surface);border-radius:18px;padding:16px}
.card.elevated{background:var(--surface-2);box-shadow:var(--shadow-md)}

/* ── TAB BAR ── */
.tabbar{display:flex;background:rgba(20,17,13,0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--hairline);padding:10px 10px max(14px,env(safe-area-inset-bottom));flex-shrink:0;position:sticky;bottom:0;z-index:50}
.tabbar .tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 0;color:var(--text-faint);font-size:10px;font-weight:500;cursor:pointer;transition:color .12s;background:none;border:none;font-family:var(--sans)}
.tabbar .tab.active{color:var(--accent)}
.tabbar .tab svg{width:22px;height:22px}

/* ── MINI PLAYER ── */
.mini-player{display:flex;align-items:center;gap:12px;padding:10px 16px;background:rgba(28,23,17,0.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--hairline);cursor:pointer;flex-shrink:0}
.mini-player:active{opacity:.85}
.mini-player-cover{width:44px;height:44px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--surface-2)}
.mini-player-cover img{width:100%;height:100%;object-fit:cover}
.mini-player-info{flex:1;min-width:0}
.mini-player-title{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-player-author{font-size:11px;color:var(--text-dim);margin-top:1px}
.mini-player-progress{height:2px;background:var(--hairline-strong);border-radius:999px;margin-top:5px}
.mini-player-progress>i{display:block;height:100%;background:var(--accent);border-radius:999px}
.mini-player-play{width:40px;height:40px;border-radius:50%;background:var(--text);color:var(--bg);display:grid;place-items:center;flex-shrink:0}

/* ── PROFILES PAGE ── */
.profiles-page{min-height:100dvh;background:var(--bg);padding:64px 24px 32px}
.profiles-header{text-align:center;margin-bottom:36px}
.profiles-header .eyebrow{display:block;margin-bottom:12px}
.profiles-title{font-family:var(--serif);font-style:italic;font-weight:600;font-size:36px;letter-spacing:-0.015em;color:var(--text);line-height:1;margin-bottom:6px}
.profiles-subtitle{font-size:14px;color:var(--text-dim)}
.profiles-list{display:flex;flex-direction:column;gap:14px}
.profile-card{appearance:none;border:1px solid var(--hairline);background:var(--surface);border-radius:20px;padding:16px;text-align:left;display:flex;align-items:center;gap:14px;cursor:pointer;transition:transform .12s,border-color .12s;font-family:inherit;color:inherit;width:100%}
.profile-card:active{transform:scale(0.985)}
.profile-card:hover{border-color:var(--hairline-strong)}
.profile-card-name{font-family:var(--serif);font-size:19px;font-weight:600;letter-spacing:-0.005em}
.profile-card-meta{font-size:11px;color:var(--text-faint);margin-top:2px;letter-spacing:0.04em}
.profile-card-inprogress{display:flex;align-items:center;gap:8px;margin-top:10px}
.profile-card-miniprogress{margin-top:4px}
.profile-add-btn{margin-top:24px;background:transparent;border:1px dashed var(--hairline-strong);border-radius:16px;padding:14px;color:var(--text-dim);font-size:13px;display:flex;align-items:center;justify-content:center;gap:8px;width:100%;cursor:pointer;font-family:inherit;transition:border-color .12s,color .12s}
.profile-add-btn:hover{color:var(--text);border-color:var(--hairline)}
.profiles-manage{text-align:center;margin-top:32px;font-size:11px;color:var(--text-faint)}

/* ── LIBRARY PAGE ── */
.library-page{display:flex;flex-direction:column;min-height:100dvh}
.library-topbar-profile{display:flex;align-items:center;gap:10px;cursor:pointer}
.library-topbar-eyebrow{font-size:10px;color:var(--text-faint);letter-spacing:0.08em;text-transform:uppercase}
.library-topbar-name{font-family:var(--serif);font-style:italic;font-size:16px;font-weight:600;line-height:1.1}

/* Hero "Tu reprends" */
.hero-card{margin:8px 20px;border-radius:22px;overflow:hidden;background:var(--surface-2);cursor:pointer;box-shadow:var(--shadow-md);position:relative}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:blur(30px) saturate(1.3);transform:scale(1.2);opacity:0.7}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(20,17,13,0.55) 0%,rgba(20,17,13,0.78) 100%)}
.hero-content{position:relative;padding:14px;display:flex;gap:14px;align-items:center}
.hero-cover{width:70px;height:102px;border-radius:6px;overflow:hidden;flex-shrink:0;box-shadow:var(--shadow-sm)}
.hero-cover img{width:100%;height:100%;object-fit:cover}
.hero-info{flex:1;min-width:0}
.hero-eyebrow{font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:rgba(240,232,216,0.7);font-weight:500;margin-bottom:4px}
.hero-title{font-family:var(--serif);font-style:italic;font-size:18px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}
.hero-author{font-size:12px;color:rgba(240,232,216,0.7);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hero-meta{font-size:11px;color:rgba(240,232,216,0.65);margin-top:5px}
.hero-play{width:48px;height:48px;border-radius:50%;background:var(--accent);border:none;color:#1a1410;display:grid;place-items:center;flex-shrink:0;transition:transform .12s}
.hero-play:active{transform:scale(0.94)}

/* Carousel */
.carousel-section{margin-bottom:4px}
.carousel-list{display:flex;gap:14px;padding:0 20px 12px}
.carousel-item{min-width:108px;cursor:pointer;flex-shrink:0}
.carousel-cover{width:108px;height:156px;border-radius:8px;overflow:hidden;background:var(--surface-2);box-shadow:var(--shadow-sm);position:relative}
.carousel-cover img{width:100%;height:100%;object-fit:contain;background:var(--surface-2)}
.carousel-title{font-size:12px;font-weight:500;margin-top:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:108px}
.carousel-author{font-size:11px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:108px}

/* Grid (all books) */
.books-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:12px 20px 20px}
.grid-item{cursor:pointer}
.grid-cover{width:100%;aspect-ratio:2/3;border-radius:8px;overflow:hidden;background:var(--surface-2);box-shadow:var(--shadow-sm);position:relative}
.grid-cover img{width:100%;height:100%;object-fit:contain;background:var(--surface-2)}
.grid-title{font-size:11px;font-weight:500;margin-top:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}
.grid-author{font-size:10px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.grid-badge{position:absolute;top:6px;right:6px;padding:3px 7px;border-radius:999px;font-size:10px;font-weight:700;font-family:var(--sans)}
.grid-badge.in-progress{background:var(--accent);color:#1a1410}
.grid-badge.done{background:var(--success);color:#14110d}

/* Author chips */
.author-chips{display:flex;gap:8px;padding:0 20px 4px;margin-top:10px}

/* Search tab */
.search-tab{padding:0 0 20px}
.search-empty{text-align:center;color:var(--text-dim);padding:40px 20px;font-size:14px}

/* Wishlist tab */
.wishlist-list{padding:0 20px}
.wishlist-row{display:flex;gap:14px;align-items:center;padding:12px 0;border-bottom:1px solid var(--hairline)}
.wishlist-cover{width:64px;height:93px;border-radius:6px;overflow:hidden;background:var(--surface-2);flex-shrink:0}
.wishlist-cover img{width:100%;height:100%;object-fit:contain;background:var(--surface-2)}
.wishlist-info{flex:1;min-width:0}
.wishlist-title{font-family:var(--serif);font-style:italic;font-size:15px;font-weight:600;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.wishlist-author{font-size:12px;color:var(--text-dim);margin-top:3px}
.wishlist-dur{font-size:11px;color:var(--text-faint);margin-top:4px}
.wishlist-empty{text-align:center;padding:60px 20px;color:var(--text-dim)}
.wishlist-empty svg{margin:0 auto 16px;opacity:.4}

/* Me tab */
.me-tab{padding:32px 20px 20px;display:flex;flex-direction:column;align-items:center}
.me-avatar{width:80px;height:80px;border-radius:50%;display:grid;place-items:center;font-size:36px;margin-bottom:14px}
.me-name{font-family:var(--serif);font-style:italic;font-size:28px;font-weight:600;letter-spacing:-0.01em;margin-bottom:4px}
.me-count{font-size:13px;color:var(--text-dim);margin-bottom:28px}
.me-stats{display:flex;gap:20px;margin-bottom:32px}
.me-stat{text-align:center}
.me-stat-val{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--accent);font-variant-numeric:tabular-nums}
.me-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-faint);margin-top:2px}
.me-actions{width:100%;display:flex;flex-direction:column;gap:2px}
.me-action{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid var(--hairline);font-size:14px;cursor:pointer;background:none;border-left:none;border-right:none;border-top:none;color:var(--text);font-family:inherit;width:100%;text-align:left}
.me-action:last-child{border-bottom:none}

/* ── BOOK DETAIL ── */
.book-detail-scroll{padding:8px 24px 80px}
.book-detail-header{margin-bottom:24px}
.book-detail-title{font-family:var(--serif);font-style:italic;font-weight:600;font-size:38px;letter-spacing:-0.015em;line-height:1.02;margin:14px 0 8px;text-wrap:balance}
.book-detail-subtitle{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--text-dim);line-height:1.15;margin-bottom:10px}
.book-detail-author{font-size:14px;color:var(--text-dim)}
.book-detail-author strong{color:var(--text);font-weight:500}
.book-detail-meta{display:flex;gap:18px;margin-top:24px;align-items:flex-end}
.book-detail-meta-item{margin-bottom:4px}
.book-meta-label{font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--text-faint);font-weight:500;margin-bottom:3px}
.book-meta-value{font-family:var(--serif);font-size:18px;font-weight:500}
.book-meta-value.accent{color:var(--accent)}
.book-actions{margin-top:22px;display:flex;flex-direction:column;gap:10px}
.book-actions-row{display:flex;gap:10px}
.book-summary{margin-top:32px}
.book-summary h3{font-family:var(--serif);font-style:italic;font-size:22px;font-weight:600;margin-bottom:12px;letter-spacing:-0.01em}
.book-summary-text{font-family:var(--serif);font-size:15.5px;line-height:1.65;color:var(--text);text-wrap:pretty}
.book-summary-dropcap{font-family:var(--serif);float:left;font-size:44px;line-height:0.9;margin-right:6px;margin-top:6px;color:var(--accent);font-style:italic;font-weight:600}
.book-same-author{margin-top:36px}
.book-same-author-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}
.book-same-author-head h3{font-family:var(--serif);font-style:italic;font-size:22px;font-weight:600;letter-spacing:-0.01em}
.book-footer{margin-top:36px;padding:14px 0;border-top:1px solid var(--hairline);display:flex;justify-content:space-between;color:var(--text-faint);font-size:11px}

/* ── PLAYER ── */
.player-screen{position:fixed;inset:0;display:flex;flex-direction:column;overflow:hidden;z-index:100;background:var(--bg)}
.player-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center top;filter:blur(56px) saturate(1.4);transform:scale(1.3);opacity:.65}
.player-overlay{position:absolute;inset:0;z-index:0;background:radial-gradient(120% 65% at 50% 18%,rgba(20,17,13,.10) 0%,rgba(20,17,13,.55) 50%,rgba(20,17,13,.92) 100%),linear-gradient(to bottom,rgba(20,17,13,0) 0%,rgba(20,17,13,.4) 60%,rgba(20,17,13,.95) 100%)}
.player-content{position:relative;z-index:1;display:flex;flex-direction:column;flex:1;overflow:hidden}
.player-topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px 8px}
.player-cover-wrap{padding:6px 24px 0}
.player-cover{width:100%;aspect-ratio:1/1.45;object-fit:cover;border-radius:10px;box-shadow:var(--shadow-lg);display:block;max-height:320px}
.player-title-block{padding:20px 24px 0}
.player-title{font-family:var(--serif);font-style:italic;font-size:26px;font-weight:600;letter-spacing:-0.01em;line-height:1.05;text-wrap:pretty;margin-bottom:4px}
.player-subtitle{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--text-dim);margin-bottom:4px}
.player-author{font-size:13px;color:var(--text-dim)}
.player-controls{padding:0 24px max(30px,env(safe-area-inset-bottom))}
.player-progress-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px}
.player-time{font-size:12px;color:var(--text-dim);font-variant-numeric:tabular-nums}
.player-pct{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--accent);font-variant-numeric:tabular-nums}
/* Scrubber */
.scrubber{height:28px;display:flex;align-items:center;cursor:pointer;position:relative;margin:0 -4px;padding:0 4px}
.scrubber-track{position:relative;width:100%;height:8px;border-radius:999px;background:rgba(240,232,216,.12);overflow:visible}
.scrubber-fill{position:absolute;left:0;top:0;bottom:0;background:var(--accent);border-radius:999px}
.scrubber-handle{position:absolute;top:50%;transform:translate(-50%,-50%);width:18px;height:18px;border-radius:50%;background:var(--accent);box-shadow:0 2px 8px rgba(0,0,0,.4),0 0 0 4px rgba(212,165,116,.18);transition:width .12s,height .12s}
.scrubber-handle.dragging{width:22px;height:22px}
/* Main controls */
.player-main-controls{display:flex;justify-content:space-between;align-items:center;margin-top:26px}
.player-play-btn{width:64px;height:64px;border-radius:50%;background:var(--text);color:var(--bg);display:grid;place-items:center;box-shadow:0 4px 14px rgba(212,165,116,.25);transition:transform .12s}
.player-play-btn:active{transform:scale(0.94)}
.player-skip-btns{display:flex;align-items:center;gap:24px}
/* Speed chip */
.speed-chip{background:transparent;border:1px solid var(--hairline-strong);border-radius:999px;padding:7px 14px;font-size:12px;font-weight:500;color:var(--text-dim);min-width:56px;text-align:center;cursor:pointer;font-variant-numeric:tabular-nums;font-family:var(--sans);transition:border-color .12s,color .12s}
.speed-chip:hover{color:var(--text)}
/* Sleep timer card */
.sleep-card{margin-top:18px;width:100%;border:1px solid rgba(212,165,116,.3);background:rgba(212,165,116,.10);border-radius:14px;padding:12px 14px;display:flex;align-items:center;gap:12px;cursor:pointer;color:var(--text);font-family:inherit;text-align:left;transition:background .12s}
.sleep-card:active{background:rgba(212,165,116,.16)}
.sleep-icon{width:36px;height:36px;border-radius:12px;background:rgba(212,165,116,.20);display:grid;place-items:center;color:var(--accent);flex-shrink:0}
.sleep-label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;font-weight:500}
.sleep-label.active{color:var(--accent)}
.sleep-label.inactive{color:var(--text-dim)}
.sleep-value{font-family:var(--serif);font-size:14px;font-weight:500;margin-top:1px;font-variant-numeric:tabular-nums}
/* Speed picker modal */
.speed-modal-backdrop{position:fixed;inset:0;background:rgba(10,8,6,.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:200;display:flex;align-items:flex-end}
.speed-modal-sheet{width:100%;background:var(--surface-2);border-radius:24px 24px 0 0;padding:8px 0 max(24px,env(safe-area-inset-bottom))}
.speed-modal-grip{width:36px;height:4px;border-radius:4px;background:var(--text-faint);margin:0 auto 16px}
.speed-modal-title{text-align:center;font-family:var(--serif);font-style:italic;font-size:18px;font-weight:600;margin-bottom:16px;padding:0 20px}
.speed-options{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:0 20px}
.speed-option{padding:14px;border-radius:12px;border:1px solid var(--hairline-strong);background:transparent;color:var(--text-dim);font-size:14px;font-family:var(--sans);font-variant-numeric:tabular-nums;cursor:pointer;transition:all .12s}
.speed-option.active{background:var(--accent-bg);border-color:rgba(212,165,116,.4);color:var(--accent);font-weight:600}
/* Sleep picker modal */
.sleep-options{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:0 20px}
.sleep-option{padding:14px;border-radius:12px;border:1px solid var(--hairline-strong);background:transparent;color:var(--text-dim);font-size:13px;font-family:var(--sans);cursor:pointer;transition:all .12s}
.sleep-option.active{background:var(--accent-bg);border-color:rgba(212,165,116,.4);color:var(--accent)}
.sleep-cancel{display:block;margin:16px 20px 0;width:calc(100% - 40px);background:transparent;border:1px solid var(--hairline-strong);border-radius:999px;padding:12px;color:var(--text-dim);font-family:var(--sans);font-size:14px;cursor:pointer}

/* ── ADMIN ── */
.admin-page{max-width:680px;margin:0 auto;padding:16px 16px 80px}
.admin-title{font-family:var(--serif);font-style:italic;font-size:26px;font-weight:600;letter-spacing:-0.01em}
.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.admin-tabs{display:flex;background:var(--surface);border-radius:999px;padding:4px;margin-bottom:20px;gap:2px}
.admin-tab{flex:1;padding:9px;border-radius:999px;font-size:13px;font-weight:500;font-family:var(--sans);cursor:pointer;border:none;background:transparent;color:var(--text-dim);transition:all .15s;text-align:center}
.admin-tab.active{background:var(--accent);color:#1a1410;font-weight:600}
.admin-book-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--hairline)}
.admin-book-cover{width:42px;height:60px;border-radius:5px;object-fit:cover;background:var(--surface-2)}
.admin-book-info{flex:1;min-width:0}
.admin-book-title{font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-book-sub{font-size:.75rem;color:var(--text-dim)}
.admin-book-actions{display:flex;gap:6px;flex-shrink:0}
.admin-profile-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--hairline)}
.admin-profile-form{display:flex;gap:8px;flex:1;align-items:center}
.admin-search{margin-bottom:12px}
.back-link{font-size:.85rem;color:var(--text-faint);display:inline-flex;align-items:center;gap:4px}
.back-link:hover{color:var(--text-dim)}

/* ── FORM ── */
.book-form{background:var(--surface);border:1px solid var(--hairline);border-radius:18px;padding:24px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.form-full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim)}
.admin-input{background:var(--surface-2);border:1px solid var(--hairline);border-radius:10px;padding:10px 12px;color:var(--text);font-family:var(--sans);font-size:.9rem;width:100%;outline:none;transition:border-color .15s}
.admin-input:focus{border-color:var(--accent)}
.admin-textarea{resize:vertical;min-height:100px}
.form-hint{font-size:.7rem;color:var(--text-faint)}
.form-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}
.btn-primary-small{background:var(--accent);color:#1a1410;border-radius:999px;padding:8px 16px;font-size:.82rem;font-weight:600;border:none;cursor:pointer;transition:background .15s}
.btn-cancel-small{background:var(--surface-2);color:var(--text-dim);border:1px solid var(--hairline);border-radius:999px;padding:8px 16px;font-size:.82rem;cursor:pointer}
.btn-save-sm{background:var(--accent);color:#1a1410;padding:6px 12px;border-radius:999px;font-size:.8rem;font-weight:600;border:none;cursor:pointer;white-space:nowrap}
.btn-edit-sm{font-size:.75rem;color:var(--text-dim);border:1px solid var(--hairline);border-radius:6px;padding:5px 10px;background:var(--surface-2);cursor:pointer}
.btn-delete-sm{font-size:.75rem;color:var(--danger);border:1px solid rgba(217,122,110,.3);border-radius:6px;padding:5px 10px;background:transparent;cursor:pointer}

/* Edit book form */
.edit-book-layout{display:flex;gap:24px;align-items:flex-start}
.edit-cover-col{flex-shrink:0;width:160px;display:flex;flex-direction:column;gap:10px}
.edit-cover-img{width:160px;height:220px;object-fit:cover;border-radius:10px;background:var(--surface-2);box-shadow:var(--shadow-md)}
.edit-cover-actions{display:flex;flex-direction:column;gap:6px}
.edit-info-col{flex:1;display:flex;flex-direction:column;gap:12px}

/* Import / bulk */
.import-card{background:var(--surface);border:1px solid var(--hairline);border-radius:18px;padding:22px;margin-bottom:18px}
.import-step-title{font-family:var(--serif);font-size:1.1rem;display:flex;align-items:center;gap:10px;margin-bottom:8px}
.step-num{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#1a1410;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0}
.import-hint{font-size:.82rem;color:var(--text-dim);margin-bottom:14px}
.mp3-selector{display:flex;gap:10px}
.mp3-selector select{flex:1}
.import-status{font-size:.8rem;color:var(--text-dim);margin-top:8px;min-height:20px}
.import-error{font-size:.82rem;color:var(--danger);margin-top:10px;padding:10px;background:rgba(217,122,110,.08);border-radius:8px}
.search-query-row{margin-top:12px;display:flex;flex-direction:column;gap:6px}
.search-query-input-wrap{display:flex;gap:10px}
.search-query-input-wrap input{flex:1}
.search-results-grid{display:flex;flex-direction:column;gap:10px}
.result-card{display:flex;gap:14px;align-items:flex-start;padding:12px;border-radius:10px;border:2px solid var(--hairline);cursor:pointer;transition:border-color .2s,background .2s}
.result-card:hover{border-color:var(--accent);background:var(--accent-bg)}
.result-thumb{width:52px;height:72px;object-fit:cover;border-radius:4px;flex-shrink:0;background:var(--surface-2)}
.result-info{flex:1;min-width:0}
.result-title{font-family:var(--serif);font-size:.95rem}
.result-author{font-size:.78rem;color:var(--text-dim);margin:2px 0}
.result-desc{font-size:.75rem;color:var(--text-faint);margin-top:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.result-select-btn{flex-shrink:0;align-self:center;padding:6px 12px;border-radius:999px;border:1px solid var(--accent);color:var(--accent);font-size:.75rem;font-weight:700;background:transparent;cursor:pointer}
.import-or{margin-top:14px;text-align:center}
.btn-manual{font-size:.8rem;color:var(--text-faint);text-decoration:underline;background:none;border:none;cursor:pointer}
.confirm-layout{display:flex;gap:20px}
.confirm-cover-wrap{flex-shrink:0;width:110px}
.confirm-cover{width:110px;height:155px;object-fit:cover;border-radius:10px;background:var(--surface-2)}
.confirm-cover-status{font-size:.68rem;color:var(--text-faint);margin-top:4px;text-align:center}
.cover-replace-wrap{margin-top:8px;display:flex;flex-direction:column;gap:4px}
.confirm-form{flex:1;display:flex;flex-direction:column;gap:10px}

/* Bulk import */
.scan-progress{margin-top:16px}
.scan-bar-wrap{height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden;margin-bottom:8px}
.scan-bar-fill{height:100%;background:var(--accent);border-radius:3px;width:0%;transition:width .4s}
.scan-label{font-size:.82rem;color:var(--text-dim)}
.bulk-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:16px}
.bulk-actions{display:flex;gap:8px;flex-wrap:wrap}
.bulk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:12px;margin-bottom:40px}
.bulk-card{background:var(--surface);border:2px solid var(--hairline);border-radius:14px;padding:14px;display:flex;gap:12px;cursor:pointer;position:relative;transition:border-color .2s}
.bulk-card.selected{border-color:var(--accent)}
.bulk-cover{width:56px;height:80px;object-fit:cover;border-radius:6px;flex-shrink:0;background:var(--surface-2)}
.bulk-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.bulk-title{font-family:var(--serif);font-size:.88rem;line-height:1.3}
.bulk-author{font-size:.74rem;color:var(--text-dim)}
.bulk-dur{font-size:.7rem;color:var(--text-faint)}
.bulk-file{font-size:.64rem;color:var(--text-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bulk-status{font-size:.68rem;font-weight:700;letter-spacing:.06em;margin-top:2px}
.bulk-status.ok{color:var(--success)}
.bulk-status.searching{color:var(--accent)}
.bulk-status.err{color:var(--danger)}
.bulk-retry{font-size:.7rem;color:var(--accent);text-decoration:underline;background:none;border:none;cursor:pointer;padding:0;margin-top:2px;text-align:left}
.bulk-check{position:absolute;top:10px;right:10px;width:20px;height:20px;border-radius:50%;border:2px solid var(--hairline);background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-size:.7rem;transition:all .2s}
.bulk-card.selected .bulk-check{background:var(--accent);border-color:var(--accent);color:#1a1410}

/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(10,8,6,.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:200;display:flex;align-items:flex-end}
.modal-box{background:var(--surface-2);border-radius:24px 24px 0 0;width:100%;padding:8px 0 max(24px,env(safe-area-inset-bottom));max-height:85dvh;display:flex;flex-direction:column}
.modal-grip{width:36px;height:4px;border-radius:4px;background:var(--text-faint);margin:0 auto 16px}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px 12px}
.modal-title-text{font-family:var(--serif);font-style:italic;font-size:18px;font-weight:600}
.modal-close{font-size:1.4rem;color:var(--text-faint);background:none;border:none;cursor:pointer;line-height:1;padding:4px 8px}
.modal-file{font-size:.72rem;color:var(--text-faint);padding:0 20px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.modal-search-row{display:flex;gap:10px;padding:0 20px 14px}
.modal-search-row input{flex:1}
.modal-status{font-size:.8rem;color:var(--text-dim);padding:0 20px 8px;min-height:20px}
.modal-results{flex:1;overflow-y:auto;padding:0 20px;display:flex;flex-direction:column;gap:10px}
.modal-result-card{display:flex;gap:12px;padding:12px;border-radius:10px;border:2px solid var(--hairline);cursor:pointer;transition:border-color .15s,background .15s}
.modal-result-card:hover{border-color:var(--accent);background:var(--accent-bg)}
.modal-result-thumb{width:48px;height:68px;object-fit:cover;border-radius:4px;flex-shrink:0;background:var(--surface-2)}
.modal-result-info{flex:1;min-width:0}
.modal-result-title{font-family:var(--serif);font-size:.92rem}
.modal-result-author{font-size:.76rem;color:var(--text-dim);margin:2px 0}
.modal-result-desc{font-size:.72rem;color:var(--text-faint);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.modal-footer{padding:14px 20px;border-top:1px solid var(--hairline)}

/* Empty state */
.empty-state{text-align:center;padding:40px 20px;color:var(--text-faint);display:flex;flex-direction:column;align-items:center;gap:16px}

/* No results */
.no-results{text-align:center;color:var(--text-faint);padding:24px;font-size:.88rem}

/* Author filter bar */
.author-filter-bar{display:flex;align-items:center;gap:10px;background:var(--accent-bg);border:1px solid rgba(212,165,116,.3);border-radius:20px;padding:6px 14px;margin:0 20px 10px;font-size:.82rem;color:var(--accent)}
.clear-author{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.8rem;text-decoration:underline}

@media(max-width:400px){.form-grid{grid-template-columns:1fr}.edit-book-layout{flex-direction:column}.confirm-layout{flex-direction:column}.books-grid{grid-template-columns:repeat(2,1fr)}.speed-options,.sleep-options{grid-template-columns:repeat(2,1fr)}}
