*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#fff;--surface:#fff;--surface2:#f7f6f4;--surface3:#f1f0ee;--border:rgba(0,0,0,.04);--border2:rgba(0,0,0,.07);--text:#18171a;--text2:#7a766f;--text3:#bfbab4;--accent:#c0654a;--green:#3d7e5e;--red:#c25550;--blue:#4e7faa;--gold:#b48f48;--radius:18px}
body{font-family:'Inter',-apple-system,sans-serif;background:var(--bg);color:var(--text);overflow:hidden;height:100dvh;-webkit-font-smoothing:antialiased}

#view-board{display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative}
#view-detail{display:none;height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--surface)}
#view-detail.slide-in{animation:detailSlideIn .3s cubic-bezier(.25,.46,.45,.94) forwards}
@keyframes detailSlideIn{from{opacity:0}to{opacity:1}}

/* Header — minimal */
.header{padding:18px 20px 10px;flex-shrink:0}
.header-top{display:flex;align-items:baseline;justify-content:space-between}
.header h1{font-size:.95em;font-weight:600;color:var(--accent);letter-spacing:-.02em}

.view-title{font-size:1.4em;font-weight:700;color:var(--text);padding:28px 20px 8px;letter-spacing:-.03em}
.view-stats{font-size:.75em;color:var(--text);padding:0 20px 16px;border-bottom:1px solid var(--border2)}
/* Sort bar */
.filter-bar{display:flex;gap:8px;padding:8px 20px 12px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-shrink:0;align-items:center}
.filter-bar::-webkit-scrollbar{display:none}
.filter-bar:empty{display:none}
.filter-chip{display:inline-flex;align-items:center;gap:4px;padding:7px 14px;border-radius:999px;background:var(--surface3);border:1.5px solid transparent;color:var(--text2);font-size:.74em;font-weight:500;white-space:nowrap;cursor:pointer;transition:all .2s;flex-shrink:0;-webkit-tap-highlight-color:transparent;font-family:inherit}
.filter-chip:active{transform:scale(.96)}
.filter-chip.active{background:rgba(192,101,74,.1);border-color:rgba(192,101,74,.3);color:var(--accent);font-weight:600}
.filter-chip svg{width:14px;height:14px;flex-shrink:0}
.filter-clear{color:var(--accent);font-size:.72em;font-weight:600;white-space:nowrap;cursor:pointer;padding:7px 10px;flex-shrink:0;border:none;background:none;font-family:inherit;-webkit-tap-highlight-color:transparent}
.filter-clear:active{opacity:.6}
.filter-dropdown-overlay{position:fixed;inset:0;z-index:149;background:transparent}
.filter-dropdown{position:fixed;z-index:150;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border2);box-shadow:0 8px 32px rgba(0,0,0,.12),0 2px 8px rgba(0,0,0,.06);padding:14px;min-width:220px;max-width:calc(100vw - 40px);max-height:60vh;overflow-y:auto;animation:ddIn .2s ease}
@keyframes ddIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.filter-dd-title{font-size:.72em;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
.filter-sort-option{display:flex;align-items:center;justify-content:space-between;padding:11px 12px;border-radius:10px;cursor:pointer;transition:background .15s;-webkit-tap-highlight-color:transparent}
.filter-sort-option:active{background:var(--surface3)}
.filter-sort-option.selected{background:rgba(192,101,74,.06)}
.filter-sort-label{font-size:.84em;color:var(--text);font-weight:500}
.filter-sort-option.selected .filter-sort-label{color:var(--accent);font-weight:600}
.filter-sort-check{width:18px;height:18px;color:var(--accent);opacity:0;transition:opacity .15s}
.filter-sort-option.selected .filter-sort-check{opacity:1}

/* Bottom nav */
.column-tabs{display:flex;background:var(--surface);border-top:1px solid var(--border2);flex-shrink:0}
.column-tabs button{flex:1;padding:8px 0 6px;background:none;border:none;color:#6b6660;cursor:pointer;transition:color .2s;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;overflow:visible;transform:translateZ(0);-webkit-tap-highlight-color:transparent}
.column-tabs button.active{color:var(--accent)}
.column-tabs button.active::before{content:'';position:absolute;top:-1px;left:20%;right:20%;height:2.5px;background:var(--accent);border-radius:0 0 2px 2px}
.column-tabs button svg{width:26px;height:26px;transition:transform .35s cubic-bezier(.34,1.56,.64,1),color .18s ease,filter .18s ease,stroke-width .18s ease;stroke-width:1.6}
.tab-label,.column-tabs .count{display:inline-block;transition:transform .35s cubic-bezier(.34,1.56,.64,1),color .18s ease,opacity .18s ease}
.column-tabs button.active svg{transform:scale(1.12);stroke-width:2.2}
.column-tabs button.pop svg{animation:navShrink .4s cubic-bezier(.4,0,.2,1)}
.column-tabs button.pop .tab-label,.column-tabs button.pop .count{animation:navShrinkLabel .4s cubic-bezier(.4,0,.2,1)}
.column-tabs button.fx-top svg{color:var(--green);filter:drop-shadow(0 0 8px rgba(61,126,94,.26))}
.column-tabs button.fx-visit svg{color:var(--gold);filter:drop-shadow(0 0 8px rgba(180,143,72,.28))}
.column-tabs button.fx-trash svg{color:var(--red);filter:drop-shadow(0 0 8px rgba(194,85,80,.24))}
.column-tabs button.fx-top .tab-label,.column-tabs button.fx-top .count{color:var(--green);opacity:1}
.column-tabs button.fx-visit .tab-label,.column-tabs button.fx-visit .count{color:var(--gold);opacity:1}
.column-tabs button.fx-trash .tab-label,.column-tabs button.fx-trash .count{color:var(--red);opacity:1}
@keyframes navShrink{0%{transform:scale(1)}30%{transform:scale(.7)}100%{transform:scale(1.12)}}
@keyframes navShrinkLabel{0%{transform:scale(1)}30%{transform:scale(.75)}100%{transform:scale(1)}}
.tab-label{font-size:.82em;font-weight:500;letter-spacing:.02em}
.column-tabs button.active .tab-label{font-weight:700}
.column-tabs .count{font-size:.9em;opacity:.75;font-weight:700}

/* Board */
.board{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:1fr;gap:10px;padding:0 10px 10px;flex:1;overflow:hidden;min-height:0}
.column{display:flex;flex-direction:column;background:var(--surface2);border-radius:var(--radius);overflow:hidden;min-height:0}
.column-header{padding:14px 16px;font-weight:500;font-size:.7em;background:transparent;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;text-transform:uppercase;letter-spacing:.05em;color:var(--text3)}
.column-header .col-count{opacity:.4;font-weight:400}
.column-cards{flex:1;overflow-y:auto;padding:52px 10px 10px;display:flex;flex-direction:column;gap:44px;position:relative}
.ptr-indicator{position:absolute;top:-44px;left:50%;transform:translateX(-50%);width:36px;height:36px;border-radius:50%;background:var(--surface);box-shadow:0 2px 8px rgba(0,0,0,.12);display:flex;align-items:center;justify-content:center;z-index:1;opacity:0;transition:opacity .2s}
.ptr-indicator.visible{opacity:1}
.ptr-indicator svg{width:20px;height:20px;stroke:var(--text3);fill:none;stroke-width:2;stroke-linecap:round;transition:transform .2s}
.ptr-indicator.ready svg{stroke:var(--accent)}
.ptr-indicator .ptr-spinner{width:20px;height:20px;border:2.5px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:ptrSpin .6s linear infinite}
@keyframes ptrSpin{to{transform:rotate(360deg)}}
.col-nouvelles .column-header{color:var(--blue)}
.col-top .column-header{color:var(--green)}
.col-visiter .column-header{color:var(--gold)}
.col-corbeille .column-header{color:var(--text3)}
.col-corbeille{background:var(--bg)}

/* ── Cards — image-led, magazine feel ── */
.card{background:var(--surface);border-radius:var(--radius);border:1.5px solid rgba(0,0,0,.1);overflow:hidden;transition:transform .25s ease,box-shadow .3s ease;cursor:pointer;flex-shrink:0;position:relative;box-shadow:0 2px 6px rgba(0,0,0,.15);-webkit-tap-highlight-color:transparent}
.card.pulse-like{animation:pulseLike .5s cubic-bezier(.22,.61,.36,1)}
.card.pulse-dislike{animation:pulseDislike .5s cubic-bezier(.22,.61,.36,1)}
@keyframes pulseLike{0%{transform:scale(1)}25%{transform:scale(1.015);box-shadow:0 0 0 3px rgba(61,126,94,.3)}100%{transform:scale(1);box-shadow:0 2px 6px rgba(0,0,0,.15)}}
@keyframes pulseDislike{0%{transform:scale(1)}25%{transform:scale(1.015);box-shadow:0 0 0 3px rgba(194,85,80,.3)}100%{transform:scale(1);box-shadow:0 2px 6px rgba(0,0,0,.15)}}
.col-top{background:var(--bg)}
.col-visiter{background:var(--bg)}
.stripe-top,.stripe-visit{padding-top:5px}
.stripe-top::before,.stripe-visit::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;z-index:2}
.stripe-top::before{background:var(--green)}
.stripe-visit::before{background:var(--gold)}
.card-img-placeholder{width:100%;height:150px;display:flex;align-items:center;justify-content:center;background:var(--surface2)}
.card-img{width:100%;height:150px;object-fit:cover;display:block;background:var(--surface3)}
.card-gallery{position:relative;overflow:hidden;height:150px;background:var(--surface3)}
.card-gallery-track{display:flex;height:100%;transition:transform .35s cubic-bezier(.25,.46,.45,.94);will-change:transform}
.card-gallery-track.dragging{transition:none}
.card-gallery-track img{width:100%;height:100%;object-fit:cover;flex-shrink:0}
.card-gallery-dots{position:absolute;bottom:6px;left:50%;transform:translateX(-50%);display:flex;gap:4px}
.card-gallery-dots span{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.4)}
.card-gallery-dots span.active{background:#fff}
.card-body{padding:14px 16px 6px}
.card:not(.seen){padding-top:5px}
.card:not(.seen)::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;z-index:2;background:var(--accent)}
.card-price-row{display:flex;align-items:baseline;gap:6px;margin-bottom:2px}
.card-price{font-size:1.1em;font-weight:700;color:var(--text);letter-spacing:-.02em}
.card-old-price{font-size:.72em;color:var(--text3);text-decoration:line-through;font-weight:400}
.card-title{font-size:.8em;font-weight:400;color:var(--text2);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;margin-bottom:4px}
.card-loc{font-size:.72em;color:var(--text3);margin-bottom:14px}
.card-chips{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:18px}
.card-pubdate{font-size:.64em;color:var(--text3);margin-bottom:16px}
.chip{padding:3px 8px;border-radius:8px;font-size:.66em;font-weight:500;background:var(--surface3);color:var(--text2)}
.badge{padding:3px 8px;border-radius:8px;font-size:.66em;font-weight:500}
.src-seloger{background:#fef3e2;color:#9a6b28}.src-leboncoin{background:#fef8e2;color:#8a7530}.src-bienici{background:#e8f5ec;color:#3d7e5e}
.dpe-A{background:#e8f5ec;color:#2e7d46}.dpe-B{background:#ecf5e8;color:#4a8a3a}.dpe-C{background:#f2f5e2;color:#6a8a2a}
.dpe-D{background:#fef8e2;color:#8a7a2a}.dpe-E{background:#fef0e2;color:#9a6a2a}.dpe-F{background:#fee8de;color:#a85a30}.dpe-G{background:#fce4e2;color:#a84a48}
.card-delete-x{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;border:none;background:rgba(0,0,0,.45);color:#fff;cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center;transition:background .15s;backdrop-filter:blur(4px);padding:0}
.card-delete-x:active{background:rgba(0,0,0,.7)}
.badge-new{position:absolute;top:10px;left:10px;background:var(--accent);color:#fff;padding:4px 10px;border-radius:8px;font-size:.66em;font-weight:600;letter-spacing:.03em;z-index:2}
.card-removed-overlay{position:absolute;top:-1.5px;left:-1.5px;right:-1.5px;bottom:-1.5px;background:rgba(0,0,0,.55);z-index:4;display:flex;align-items:center;justify-content:center;pointer-events:none;border-radius:var(--radius)}
.card-removed-overlay span{color:#fff;font-size:.9em;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:6px 16px;border-radius:8px;background:rgba(0,0,0,.35)}
.card-republished{color:#e67e22;font-weight:600}
.card-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px 14px 14px}
.card-id{font-size:.6em;color:var(--text3);font-family:'Inter',sans-serif;opacity:.5}
.card-meta{display:flex;align-items:center;gap:8px;min-width:0}
.card-actions{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}
.card-actions button{height:32px;min-width:32px;border-radius:10px;border:1px solid rgba(0,0,0,.08);background:var(--surface);font-size:.85em;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--text2);padding:0 8px}
.card-actions button:active{transform:scale(.92)}
.btn-like-count{gap:4px;padding:0 10px!important;color:var(--text2)!important;background:var(--surface)!important;border:1px solid rgba(0,0,0,.08)!important}
.btn-like-count.liked{color:var(--green)!important;background:rgba(61,126,94,.08)!important}
.btn-like-count.disliked{color:var(--red)!important;background:rgba(194,85,80,.08)!important}
.btn-like-count .like-num,.btn-like-count .comment-num{font-size:.75em;font-weight:600}
.btn-comment.has-comments{color:var(--blue)!important;background:rgba(78,127,170,.08)!important;border-color:rgba(78,127,170,.16)!important}
.btn-pill{padding:0 12px!important;font-size:.7em!important;font-weight:600;white-space:nowrap;color:var(--text)}
.card-vote-ro{display:flex;align-items:center;gap:3px;font-size:.72em;color:var(--text3);opacity:.5}
/* Header avatar */
.header-avatar{position:absolute;top:28px;right:62px;z-index:50;width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;font-size:.82em;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s;-webkit-tap-highlight-color:transparent}
.header-avatar:active{opacity:.7}
/* Profil panel */
.profil-panel{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:380px;background:var(--bg);z-index:200;box-shadow:-4px 0 20px rgba(0,0,0,.12);flex-direction:column;animation:notifSlideIn .25s ease;border-radius:var(--radius) 0 0 var(--radius);overflow-y:auto}
.profil-panel-head{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border2)}
.profil-panel-body{padding:0}
.profil-panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,.2);z-index:199}
/* Profil */
.profil{padding:28px 20px 80px}
.profil-head{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.profil-avatar{width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2em;font-weight:700;flex-shrink:0}
.profil-name{font-size:1.1em;font-weight:600;color:var(--text)}
.profil-metrics{display:flex;gap:10px;margin-bottom:28px}
.profil-metric{flex:1;background:var(--surface);border-radius:14px;padding:14px;text-align:center;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.profil-metric-num{font-size:1.3em;font-weight:700;color:var(--text)}
.profil-metric-label{font-size:.68em;color:var(--text3);margin-top:2px}
.profil-section-title{font-size:.7em;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}
.profil-activity{display:flex;flex-direction:column;gap:1px;background:var(--surface);border-radius:14px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.profil-act{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer;transition:background .15s}
.profil-act:active{background:var(--surface3)}
.profil-act-icon{flex-shrink:0;color:var(--text3)}
.profil-act-icon.act-like{color:var(--green)}
.profil-act-icon.act-dislike{color:var(--red)}
.profil-act-icon.act-comment{color:var(--blue)}
.profil-act-text{flex:1;min-width:0;font-size:.82em;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.profil-act-time{font-size:.68em;color:var(--text3);flex-shrink:0}

/* Comments */
.detail-comments-section{margin-top:8px}
.detail-comments-section .feed-reactions-log{padding:0 0 0 48px;margin:0 0 12px;background:none;border:none;border-radius:0;gap:6px}
.comments-section-head{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:16px}
.comments-summary{display:inline-block;background:var(--surface3);color:var(--text2);padding:2px 8px;border-radius:999px;font-size:.65em;font-weight:600;vertical-align:middle;margin-left:6px;text-transform:none;letter-spacing:0;line-height:1.4}
.comments-shell{display:flex;flex-direction:column;gap:16px}
.comments-panel:empty{display:none}
.comments-inline-note{margin-bottom:10px;padding:11px 13px;border-radius:14px;background:rgba(78,127,170,.08);color:var(--blue);font-size:.76em;line-height:1.5}
.comments-state{padding:18px 18px 16px;border-radius:18px;background:var(--surface3);color:var(--text2)}
.comments-state-title{font-size:.86em;font-weight:600;color:var(--text);margin-bottom:4px}
.comments-state-copy{font-size:.78em;line-height:1.6;color:var(--text3)}
.comments-skeleton{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}
.comment-skeleton-row{height:11px;border-radius:999px;background:linear-gradient(90deg,rgba(0,0,0,.04) 25%,rgba(0,0,0,.08) 50%,rgba(0,0,0,.04) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}
.comment-skeleton-row.short{width:62%}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.comment-delete{background:none;border:none;color:var(--text3);cursor:pointer;padding:2px 4px;border-radius:6px;opacity:.4;transition:color .15s,opacity .15s,background .15s;display:flex;align-items:center;margin-left:auto;flex-shrink:0}
.comment-delete:hover,.comment-delete:active{color:var(--red);opacity:1;background:rgba(194,85,80,.08)}
.comment-delete svg{width:14px;height:14px}
.comments{display:flex;flex-direction:column;gap:10px}
.comment{display:flex;gap:12px;align-items:flex-start;padding:14px;border-radius:18px;background:var(--surface);border:none;box-shadow:none}
.comment-own{background:#fdf8f4;border-color:rgba(192,101,74,.14)}
.comment-pending{opacity:.72}
.comment-avatar{width:36px;height:36px;border-radius:14px;background:var(--surface3);color:var(--text2);display:flex;align-items:center;justify-content:center;font-size:.78em;font-weight:700;letter-spacing:.02em;flex-shrink:0}
.comment-avatar-self{background:var(--accent);color:#fff}
.comment-body{flex:1;min-width:0}
.comment-head{display:flex;align-items:center;flex-wrap:wrap;gap:6px 8px;margin-bottom:6px}
.comment-user{font-size:.8em;font-weight:600;color:var(--text)}
.comment-badge{padding:2px 8px;border-radius:999px;background:rgba(192,101,74,.12);color:var(--accent);font-size:.64em;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.comment-time{font-size:.68em;color:var(--text3)}
.comment-status{padding:2px 8px;border-radius:999px;background:rgba(78,127,170,.08);color:var(--blue);font-size:.64em;font-weight:700;letter-spacing:.03em}
.comment-text{font-size:.84em;color:var(--text2);line-height:1.72;word-break:break-word}
.comment-composer-slot{position:relative}
.comment-composer-card{padding:0;border-radius:0;background:none;border:none;box-shadow:none}
.comment-composer-field{border:1px solid var(--border2);border-radius:14px;background:var(--surface);padding:11px 13px;transition:border-color .2s ease,box-shadow .2s ease}
.comment-composer-field:focus-within{border-color:rgba(192,101,74,.38);box-shadow:0 0 0 4px rgba(192,101,74,.08)}
.comment-composer-field textarea{width:100%;min-height:28px;max-height:180px;resize:none;border:none;background:transparent;font-size:.84em;line-height:1.65;color:var(--text);font-family:inherit;outline:none}
.comment-composer-field textarea::placeholder{color:var(--text3)}
.comment-form-error{margin-top:9px;font-size:.75em;color:var(--red);line-height:1.5}
.comment-composer-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}
.comment-composer-actions-simple{justify-content:flex-end}
.comment-composer-hint{font-size:.72em;color:var(--text3);line-height:1.4}
.comment-composer-actions button{padding:10px 14px;border:none;border-radius:12px;background:var(--accent);color:#fff;font-size:.78em;font-weight:700;cursor:pointer;font-family:inherit;flex-shrink:0;transition:transform .15s ease,opacity .15s ease}
.comment-composer-actions button:active{transform:scale(.97)}
.comment-composer-actions button:disabled{opacity:.45;cursor:default}

.card-seg{padding:8px 16px 36px;display:flex;justify-content:center}
.seg-ctrl{display:inline-flex;border-radius:10px;overflow:hidden;background:var(--surface3);font-size:.64em;flex-shrink:0}
.seg-ctrl span{padding:6px 12px 6px 16px;cursor:pointer;color:var(--text2);transition:all .2s;white-space:nowrap;font-weight:500;text-align:center;position:relative;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 50%,calc(100% - 8px) 100%,0 100%,8px 50%)}
.seg-ctrl span:first-child{clip-path:polygon(0 0,calc(100% - 8px) 0,100% 50%,calc(100% - 8px) 100%,0 100%);padding-left:12px;border-radius:10px 0 0 10px}
.seg-ctrl span:last-child{clip-path:polygon(0 0,100% 0,100% 100%,0 100%,8px 50%);padding-right:12px;border-radius:0 10px 10px 0}
.seg-ctrl span.seg-active{background:var(--gold);color:#fff;font-weight:600}
.card.fadeout{animation:fadeOut .52s cubic-bezier(.24,.78,.22,1) forwards}
@keyframes fadeOut{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:translateY(-4px) scale(.94)}}
.card.departing{position:relative;z-index:2}
.card.reflowing{transition:transform .94s cubic-bezier(.22,.61,.36,1),box-shadow .3s ease;will-change:transform}
.card.just-moved-1{animation:hl-green 2s ease-out}
.card.just-moved-2{animation:hl-gold 2s ease-out}
.card.just-moved-3{animation:hl-red 2s ease-out}
.card.just-moved-0{animation:hl-neutral 2s ease-out}
@keyframes hl-green{0%{box-shadow:0 0 0 2px rgba(61,126,94,.3)}100%{box-shadow:0 1px 2px rgba(0,0,0,.04)}}
@keyframes hl-gold{0%{box-shadow:0 0 0 2px rgba(180,143,72,.3)}100%{box-shadow:0 1px 2px rgba(0,0,0,.04)}}
@keyframes hl-red{0%{box-shadow:0 0 0 2px rgba(194,85,80,.3)}100%{box-shadow:0 1px 2px rgba(0,0,0,.04)}}
@keyframes hl-neutral{0%{box-shadow:0 0 0 2px rgba(0,0,0,.08)}100%{box-shadow:0 1px 2px rgba(0,0,0,.04)}}
.no-results{text-align:center;padding:60px 20px;color:#000;font-size:.82em}

/* Toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;padding:14px 18px;border-radius:14px;display:none;z-index:300;font-size:.82em;gap:12px;align-items:center;justify-content:space-between;box-shadow:0 6px 20px rgba(0,0,0,.15);overflow:hidden;white-space:nowrap;width:auto;max-width:calc(100% - 40px)}
.toast.show{display:flex}
.toast-progress{position:absolute;bottom:0;left:0;height:3px;background:rgba(255,255,255,.35);border-radius:0 0 14px 14px;animation:toastCountdown 4s linear forwards}
@keyframes toastCountdown{from{width:0%}to{width:100%}}
.toast button{background:rgba(255,255,255,.2);border:none;color:#fff;padding:6px 14px;border-radius:8px;cursor:pointer;font-size:.8em;font-weight:500}

/* Carousel */
.carousel{position:relative;background:#1a1a1e;overflow:hidden;touch-action:pan-y;-webkit-user-select:none;user-select:none;border-radius:0 0 var(--radius) var(--radius)}
.carousel-track{display:flex;transition:transform .35s cubic-bezier(.25,.46,.45,.94)}
.carousel-track.dragging{transition:none}
.carousel-track img{width:100%;object-fit:contain;flex-shrink:0;pointer-events:none}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:none;color:#fff;font-size:1.2em;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;transition:background .2s}
.carousel-btn:active{background:rgba(255,255,255,.3)}
.carousel-btn.prev{left:12px}
.carousel-btn.next{right:12px}
.carousel-counter{position:absolute;bottom:28px;right:14px;background:rgba(0,0,0,.4);backdrop-filter:blur(6px);color:rgba(255,255,255,.85);padding:4px 10px;border-radius:20px;font-size:.68em;z-index:5;font-weight:500}
.carousel-dots{display:flex;justify-content:center;gap:5px;padding:14px 0;background:var(--bg)}
.carousel-dots span{width:6px;height:6px;border-radius:50%;background:var(--surface3);cursor:pointer;transition:all .3s ease}
.carousel-dots span.active{background:var(--accent);width:20px;border-radius:3px}

/* ── Lightbox ── */
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:200;flex-direction:column;align-items:center;justify-content:center}
.lightbox.open{display:flex}
.lightbox-track{display:flex;height:100%;width:100%;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.lightbox-track::-webkit-scrollbar{display:none}
.lightbox-slide{width:100%;height:100%;flex-shrink:0;scroll-snap-align:center;overflow:hidden;display:flex;align-items:center;justify-content:center}
.lightbox-slide.zoomed{touch-action:none}
.lightbox-slide img{max-width:100%;max-height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;transform-origin:0 0;will-change:transform}
.lightbox-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:none;background:rgba(255,255,255,.15);color:#fff;font-size:1.2em;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:201;backdrop-filter:blur(8px)}
.lightbox-close:active{background:rgba(255,255,255,.3)}
.lightbox-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.4);backdrop-filter:blur(6px);color:rgba(255,255,255,.85);padding:4px 14px;border-radius:20px;font-size:.75em;z-index:201;font-weight:500}
.lightbox-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:none;color:#fff;font-size:1.3em;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:201}
.lightbox-btn:active{background:rgba(255,255,255,.25)}
.lightbox-btn.prev{left:12px}
.lightbox-btn.next{right:12px}

/* ── Detail page — editorial ── */
.detail-sticky-ctx{position:sticky;top:0;z-index:10;height:48px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 16px;padding-top:env(safe-area-inset-top,0px);background:rgba(255,255,255,.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.detail-sticky-right{display:flex;align-items:center;gap:10px}
.detail-back{background:none;border:none;color:var(--accent);padding:6px 0;cursor:pointer;font-size:.85em;display:flex;align-items:center;gap:4px;font-weight:500}
.detail-back:active{opacity:.7}
.detail-sticky-badge{font-size:.68em;font-weight:600;padding:3px 10px;border-radius:20px;white-space:nowrap}
.detail-sticky-badge.stb-trier{background:rgba(0,0,0,.06);color:var(--text2)}
.detail-sticky-badge.stb-top{background:rgba(180,143,72,.15);color:var(--gold)}
.detail-sticky-badge.stb-visiter{background:rgba(61,126,94,.12);color:var(--green)}
.detail-sticky-badge.stb-corbeille{background:rgba(194,85,80,.1);color:var(--red)}
.detail-placeholder{width:100%;height:200px;display:flex;align-items:center;justify-content:center;background:var(--surface2)}
.detail-carousel{margin:0}
.detail-carousel .carousel{border-radius:0}
.detail-carousel .carousel-track img{height:44vh}
.detail-content{padding:24px 20px 120px;max-width:640px;margin:0 auto;border-radius:18px 18px 0 0;margin-top:-16px;position:relative;background:var(--bg)}
.detail-title{font-size:1.05em;font-weight:400;color:var(--text2);line-height:1.5;margin-bottom:8px;text-align:center}
.detail-price{font-size:1.6em;font-weight:700;color:var(--text);letter-spacing:-.03em;margin-bottom:2px;text-align:center}
.detail-location{font-size:.82em;color:var(--text3);margin-bottom:20px;text-align:center}
.detail-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:24px}
.detail-section{margin-bottom:36px}
.detail-section h3{margin:0 0 16px;color:var(--text);font-size:.88em;font-weight:700;text-transform:uppercase;letter-spacing:.08em;text-align:center;padding-top:20px;border-top:1px solid var(--border2)}
.detail-section a{color:var(--blue);text-decoration:none}
.detail-desc{font-size:.84em;color:var(--text2);line-height:1.85;white-space:pre-wrap}
.char-group{margin-bottom:24px}
.char-group:last-child{margin-bottom:0}
.char-group-title{font-size:.72em;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;padding:0 4px 10px;text-align:center}
.char-group-card{background:var(--surface2);border-radius:14px;overflow:hidden;border:1px solid var(--border)}
.char-row{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--border)}
.char-row:last-child{border-bottom:none}
.char-lbl{font-size:.84em;color:var(--text2);font-weight:500}
.char-val{font-size:.84em;font-weight:600;color:var(--text);text-align:right;display:flex;align-items:center;gap:6px}
.char-val a{color:var(--blue);text-decoration:none}
.char-val .badge{font-size:.88em;padding:2px 9px;border-radius:6px;font-weight:700;letter-spacing:.02em}
.char-val-sub{font-weight:500;color:var(--text2);font-size:.92em}
.detail-equips{display:flex;flex-wrap:wrap;gap:6px;padding:10px 4px 0}
.detail-equip{display:inline-flex;align-items:center;padding:5px 12px;background:var(--surface2);border-radius:20px;font-size:.74em;color:var(--text2);font-weight:500;border:1px solid var(--border2)}
.detail-feed-entries{gap:12px}
.detail-feed-entries .feed-avatar{width:34px;height:34px;font-size:.76em}
.detail-feed-entries .feed-content{padding:6px 14px}
.detail-feed-entries .feed-text{font-size:.82em}
.detail-composer{margin-top:12px}
.comments-panel:empty+.comment-composer-slot .detail-composer{margin-top:0}
.detail-composer .feed-composer-avatar{width:34px;height:34px;font-size:.76em}
.detail-actions{position:fixed;bottom:0;left:0;right:0;display:flex;flex-direction:column;gap:8px;padding:10px 16px calc(16px + env(safe-area-inset-bottom,0px));background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid var(--border);z-index:10}
.detail-bar-reactions{display:flex;align-items:center;gap:4px}
.detail-bar-reactions .bubble-sep{width:1px;height:18px;background:var(--border2);margin:0 2px;flex-shrink:0}
.detail-bar-reactions .feed-react-delete{margin-left:auto;color:var(--text3)}
.detail-bar-reactions .feed-react-delete:active{color:var(--red)}
.visit-status-badge{flex:1;justify-content:center;background:var(--gold);border:none;border-radius:8px;padding:6px 10px;font-size:.75em;font-weight:600;color:#fff;cursor:pointer;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;font-family:inherit}
.visit-status-badge:active{transform:scale(.95)}
.visit-status-menu{position:fixed;background:var(--surface);border:1px solid var(--border2);border-radius:10px;box-shadow:0 4px 16px rgba(0,0,0,.12);z-index:100;overflow:hidden}
.visit-status-menu button{display:block;width:100%;padding:10px 20px;border:none;background:none;font-size:.78em;font-weight:500;color:var(--text2);cursor:pointer;text-align:left;white-space:nowrap;font-family:inherit}
.visit-status-menu button:active{background:var(--surface3)}
.visit-status-menu button.active{color:var(--gold);font-weight:600}
.detail-bar-actions{display:flex;align-items:center;gap:8px}
.detail-cta{padding:10px 16px;border-radius:10px;border:none;background:var(--accent);color:#fff;font-size:.78em;font-weight:600;cursor:pointer;text-decoration:none;transition:transform .15s;white-space:nowrap;display:flex;align-items:center;justify-content:center;flex:1}
.detail-cta:active{transform:scale(.96)}
.detail-cta-call{background:var(--green);gap:6px}

/* Fly-to ghost */
.fly-ghost{position:fixed;z-index:200;overflow:hidden;border-radius:var(--radius);background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(245,241,236,.92));border:1px solid rgba(255,255,255,.72);box-shadow:0 16px 30px rgba(24,23,26,.12),0 6px 14px rgba(192,101,74,.1);pointer-events:none;transform-origin:center center;will-change:transform,opacity;contain:paint;backface-visibility:hidden;transform:translateZ(0)}
.fly-ghost::before{content:'';position:absolute;inset:0;background:linear-gradient(140deg,rgba(255,255,255,.24),rgba(255,255,255,0) 36%,rgba(255,255,255,.12) 100%);pointer-events:none}
.fly-ghost::after{content:'';position:absolute;inset:-18%;background:radial-gradient(circle at top left,rgba(255,255,255,.22),rgba(255,255,255,0) 44%);opacity:.45;pointer-events:none}
.fly-ghost img,.fly-ghost-fill{width:100%;height:100%;display:block}
.fly-ghost img{object-fit:cover;transform:scale(1.03)}
.fly-ghost-fill{background:linear-gradient(135deg,rgba(192,101,74,.24),rgba(61,126,94,.16))}
.count.count-bump{animation:countBump .42s cubic-bezier(.22,1,.36,1)}
@keyframes countBump{0%{transform:scale(1)}35%{transform:translateY(-2px) scale(1.38)}100%{transform:scale(1)}}

/* Card Feed */
.card-feed{border-top:none;padding:0 20px;background:transparent;border-radius:0 0 16px 16px}
.feed-toolbar{display:flex;align-items:center;justify-content:flex-start;gap:8px;padding:8px 20px;margin:0 -20px;background:none;border-radius:0 0 16px 16px;border-top:1px solid rgba(192,101,74,.2);border-bottom:1px solid rgba(192,101,74,.2)}
.feed-toolbar:has(~ .feed-reactions-log),.feed-toolbar:has(~ .feed-comments.open){border-radius:0}
.feed-actions{display:flex;gap:4px;margin-left:auto}
.feed-action-btn{background:var(--accent);border:none;border-radius:10px;color:#fff;cursor:pointer;padding:4px 8px;display:flex;flex-direction:column;align-items:center;gap:2px;transition:all .15s;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.feed-action-btn span{font-size:.6em;font-weight:600;font-family:inherit;line-height:1}
.feed-action-btn:active{transform:scale(.95);box-shadow:none}
.feed-action-btn svg{width:18px;height:18px;stroke:#fff}
.feed-action-visit{background:var(--gold)}
.visit-check{display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none;-webkit-tap-highlight-color:transparent}
.visit-check input{display:none}
.visit-check-box{width:36px;height:20px;border-radius:999px;background:rgba(180,143,72,.35);position:relative;transition:background .2s ease;flex-shrink:0}
.visit-check-box::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.15);transition:transform .2s ease}
.visit-check input:checked~.visit-check-box{background:var(--gold)}
.visit-check input:checked~.visit-check-box::after{transform:translateX(16px)}
.visit-check-label{font-size:.72em;font-weight:600;color:var(--gold);white-space:nowrap}
.visit-check input:checked~.visit-check-label{color:var(--gold)}
.feed-reactions{display:flex;gap:4px}
.feed-react{background:none;border:1.5px solid transparent;border-radius:10px;padding:4px 10px;font-size:.92em;font-weight:600;cursor:pointer;color:var(--text3);font-family:inherit;transition:all .15s;min-height:36px;display:inline-flex;align-items:center;gap:4px}
.thumb-icon{width:16px;height:16px;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.thumb-up{stroke:rgba(61,126,94,.75)}
.thumb-down{stroke:rgba(194,85,80,.75)}
.feed-react:has(.thumb-up){color:rgba(61,126,94,.75)}
.feed-react:has(.thumb-down){color:rgba(194,85,80,.75)}
.feed-react.liked .thumb-up{stroke:var(--green);fill:rgba(61,126,94,.15)}
.feed-react.disliked .thumb-down{stroke:var(--red);fill:rgba(194,85,80,.15)}
.feed-react:active{transform:scale(.94)}
.feed-react.liked{color:var(--green);background:rgba(61,126,94,.08);border-radius:10px;padding:4px 10px;border:1.5px solid rgba(61,126,94,.3)}
.feed-react.disliked{color:var(--red);background:rgba(194,85,80,.08);border-radius:10px;padding:4px 10px;border:1.5px solid rgba(194,85,80,.3)}
.feed-reactions-log{display:flex;flex-direction:column;gap:0;padding:2px 20px 4px;margin:0 -20px;background:none}
.feed-reactions-log:has(~ .feed-comments.open){padding-bottom:4px}
.feed-reaction-like{color:#a09a93}
.feed-reaction-dislike{color:#a09a93}
.feed-reaction-like .reaction-log-icon{width:11px;height:11px;fill:none;stroke:var(--green);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;vertical-align:-2px;margin-right:4px}
.feed-reaction-dislike .reaction-log-icon{width:11px;height:11px;fill:none;stroke:var(--red);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;vertical-align:-2px;margin-right:4px}
.feed-comments{display:none}
.feed-comments.open{display:block;padding-bottom:20px;padding-top:10px;border-top:none;margin:0 -20px;padding-left:20px;padding-right:20px}
.feed-comment-btn svg{vertical-align:middle;width:18px;height:18px;stroke:rgba(78,127,170,.5)}
.feed-comment-btn.has-comments{color:rgba(40,100,160,1)}
.feed-comment-btn.has-comments svg{stroke:rgba(40,100,160,1)}
.feed-comment-btn.comments-open{color:var(--blue)!important;background:rgba(78,127,170,.08)!important;border-radius:10px!important;padding:6px 12px!important;border:1.5px solid rgba(78,127,170,.3)!important}
.feed-entries{display:flex;flex-direction:column;gap:14px;margin-top:10px}
.feed-entry{display:flex;align-items:flex-start;gap:6px}
.feed-avatar{width:30px;height:30px;border-radius:50%;background:var(--surface3);color:var(--text2);display:flex;align-items:center;justify-content:center;font-size:.72em;font-weight:700;flex-shrink:0;position:relative}
.feed-avatar-like{background:rgba(61,126,94,.12);color:var(--green)}
.feed-avatar-dislike{background:rgba(194,85,80,.12);color:var(--red)}
.feed-avatar-icon{position:absolute;bottom:-3px;right:-3px;font-size:.55em;line-height:1;background:var(--surface);border-radius:50%;width:14px;height:14px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border2);box-shadow:none}
.feed-content{flex:1;min-width:0;background:rgba(192,101,74,.05);border-radius:14px;padding:5px 12px;border:.5px solid rgba(192,101,74,.15)}
.feed-entry-head{display:flex;align-items:baseline;gap:6px;margin-bottom:1px}
.feed-user{font-size:.76em;font-weight:600;color:var(--text)}
.feed-sep{color:var(--text3);font-size:.9em;font-weight:700}
.feed-time{font-size:.68em;color:var(--text3);flex-shrink:0}
.feed-text{font-size:.78em;color:var(--text);line-height:1.5;word-break:break-word}
.feed-entry-reaction{align-items:center}
.feed-content-reaction{background:none!important;padding:1px 0!important;border:none!important}
.feed-reaction-line{font-size:.78em;color:#a09a93;line-height:1.4}
.feed-reaction-line .feed-user{font-style:normal;font-weight:400;font-size:1em;color:#a09a93}
.feed-see-more{display:block;font-size:.68em;color:var(--blue);font-weight:500;cursor:pointer;padding:3px 0;background:none;border:none;font-family:inherit;text-align:left}
.feed-composer{display:flex;flex-direction:row;align-items:flex-start;gap:8px;margin-top:14px}
.feed-composer-avatar{width:30px;height:30px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.72em;font-weight:700;flex-shrink:0;margin-top:2px}
.feed-composer-field{flex:1;border:1px solid var(--border2);border-radius:10px;padding:0 10px;transition:border-color .2s;background:#fff;display:flex;align-items:center}
.feed-composer-field:focus-within{border-color:rgba(192,101,74,.38)}
.feed-composer-field textarea{width:100%;min-height:30px;max-height:80px;resize:none;border:none;background:transparent;font-size:.74em;line-height:1.4;color:var(--text);font-family:inherit;outline:none;padding:6px 0;overflow-y:auto}
.feed-submit{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:8px 14px;font-size:.72em;font-weight:600;cursor:pointer;font-family:inherit;align-self:flex-end;transition:transform .15s}
.feed-submit:active{transform:scale(.94)}
.feed-submit:disabled{opacity:.4;cursor:default}

/* Mobile */
@media(max-width:768px){
  .column-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border2);z-index:100;padding:2px 0 env(safe-area-inset-bottom,2px)}
  .board{display:flex;flex-direction:column;padding:0;gap:0}
  .column{display:none;border-radius:0;flex:1;background:var(--bg)}
  .column.active{display:flex}
  .col-top.active{background:var(--bg);background:var(--bg)}
  .col-visiter.active{background:var(--bg)}
  .col-corbeille.active{background:var(--bg)}
  .column-header{display:none}
  .column-cards{padding:52px 20px 110px;gap:48px}
  .card-img-placeholder{height:180px}
  .card-img{height:180px}
  .card-gallery{height:180px}
  .detail-carousel .carousel-track img{height:36vh}
  .detail-content{padding:20px 18px 120px}
  .comments-section-head{flex-direction:column;align-items:flex-start}
  .comments-summary{align-self:flex-start}
  .comment{padding:13px}
  .comment-composer-card{padding:14px}
  .comment-composer-actions{flex-direction:column;align-items:stretch}
  .comment-composer-actions button{width:100%}
  .toast{bottom:90px;left:50%;transform:translateX(-50%)}
}
@media(min-width:769px){
  .column-tabs{display:none}
}

/* Notification bell */
.notif-bell{position:absolute;top:28px;right:20px;z-index:50;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .15s;color:var(--text2)}
.notif-bell:active{background:var(--surface3)}
.notif-badge{position:absolute;top:2px;right:2px;background:var(--red);color:#fff;font-size:.58em;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}

/* Notification panel */
.notif-panel{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:380px;background:var(--bg);z-index:200;box-shadow:-4px 0 20px rgba(0,0,0,.12);flex-direction:column;animation:notifSlideIn .25s ease;border-radius:var(--radius) 0 0 var(--radius)}
@keyframes notifSlideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
.notif-panel-head{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border2)}
.notif-panel-title{font-size:1em;font-weight:700;color:var(--text)}
.notif-mark-all{background:none;border:none;color:var(--accent);font-size:.78em;font-weight:500;cursor:pointer}
.notif-panel-list{flex:1;overflow-y:auto;padding:0}
.notif-item{display:flex;align-items:center;gap:10px;padding:14px 20px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border);position:relative}
.notif-item:active{background:var(--surface3)}
.notif-item.unread{background:rgba(192,101,74,.08);transition:background .4s ease}
.notif-item.unread::before{content:'';position:absolute;left:7px;top:50%;transform:translateY(-50%);width:6px;height:6px;border-radius:50%;background:var(--accent)}
.notif-item-icon{flex-shrink:0;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9em}
.notif-item-icon.notif-new{background:rgba(78,127,170,.12);color:var(--blue)}
.notif-item-icon.notif-like{background:rgba(61,126,94,.12);color:var(--green)}
.notif-item-icon.notif-dislike{background:rgba(194,85,80,.12);color:var(--red)}
.notif-item-icon.notif-comment{background:rgba(78,127,170,.12);color:var(--blue)}
.notif-item-icon.notif-visit_status{background:rgba(180,143,72,.12);color:var(--gold)}
.notif-item-body{flex:1;min-width:0}
.notif-item-text{font-size:.82em;color:var(--text);line-height:1.35}
.notif-item-annonce{font-size:.72em;color:var(--text2);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.notif-item-time{font-size:.68em;color:var(--text3);margin-top:2px}
.notif-pinned{background:rgba(130,90,180,.07);border:1px solid rgba(130,90,180,.20);border-radius:12px;margin:10px 12px;padding:14px 16px !important}
.notif-pinned .notif-item-icon{background:rgba(130,90,180,.12);color:#7b5ea7}
.notif-pinned .notif-item-text{font-weight:600;color:#7b5ea7}
.notif-pinned .notif-item-time{color:#7b5ea7;opacity:.7}
.notif-pinned.unread{background:rgba(130,90,180,.10)}
.notif-pinned.unread::before{display:none}
.notif-kebab{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text3);cursor:pointer;padding:6px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s}
.notif-kebab:hover{background:var(--surface3);color:var(--text)}
.notif-ctx-menu{position:absolute;right:8px;top:calc(50% + 16px);background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 16px rgba(0,0,0,.15);z-index:10;overflow:hidden}
.notif-ctx-menu button{display:block;width:100%;padding:10px 20px;border:none;background:none;font-size:.8em;color:var(--red);cursor:pointer;text-align:left;white-space:nowrap}
.notif-ctx-menu button:hover{background:var(--surface3)}
.notif-empty{padding:40px 20px;text-align:center;color:var(--text3);font-size:.85em}
.notif-panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,.2);z-index:199}

/* Home page */
#view-home{height:100dvh;overflow-y:auto;background:var(--bg)}
.home-wrap{max-width:640px;margin:0 auto;padding:24px 20px 120px}
.home-back{background:none;border:none;color:var(--accent);padding:6px 0;cursor:pointer;font-size:.85em;display:flex;align-items:center;gap:4px;font-weight:500;margin-bottom:16px;font-family:inherit}
.home-back:active{opacity:.7}
.home-title{font-size:1.5em;font-weight:300;color:var(--text);letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px}
.home-title .brand-light{font-weight:600}
.home-intro{font-size:.88em;color:var(--text2);line-height:1.7;margin-bottom:32px}
.home-section{margin-bottom:40px}
.home-section-title{font-size:.72em;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}
.home-carousel{position:relative;overflow:hidden;margin:0 -20px}
.home-carousel-track{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:12px;padding:0 20px}
.home-carousel-track::-webkit-scrollbar{display:none}
.home-col{flex:0 0 42%;scroll-snap-align:start;background:var(--surface2);border-radius:14px;padding:24px 18px;font-size:.82em;line-height:1.6;min-height:180px;display:flex;flex-direction:column;justify-content:center}
.home-col strong{display:block;margin-bottom:6px;color:var(--text);font-weight:700;font-size:1.05em}
.home-col p{color:var(--text2);font-size:.88em;margin:0}
.home-carousel-dots{display:flex;justify-content:center;gap:6px;padding:14px 0 4px}
.home-carousel-dots span{width:7px;height:7px;border-radius:50%;background:var(--border2);transition:background .2s,transform .2s}
.home-carousel-dots span.active{background:var(--text2);transform:scale(1.2)}
.home-actions{display:flex;flex-direction:column;gap:10px}
.home-action{background:var(--surface2);border-radius:14px;padding:14px 16px;font-size:.82em;color:var(--text2);line-height:1.5}
.home-action strong{color:var(--text);font-weight:600}
.home-action-icon{margin-right:4px;position:relative;display:inline-flex;vertical-align:middle}
.home-notif-icon{position:relative}
.home-notif-dot{position:absolute;top:0;right:-2px;width:8px;height:8px;border-radius:50%;background:var(--red)}
.home-criteria{background:var(--surface2);border-radius:14px;overflow:hidden}
.home-crit-row{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--border)}
.home-crit-row:last-child{border-bottom:none}
.home-crit-label{font-size:.82em;color:var(--text2);font-weight:500}
.home-crit-value{font-size:.82em;font-weight:600;color:var(--text);text-align:right}
.home-sites{display:flex;gap:8px;flex-wrap:wrap}
.home-sites .badge{font-size:.78em;padding:5px 12px}
.home-site-off{background:var(--surface3);color:var(--text3)}
.home-cta{width:100%;padding:14px;border:none;border-radius:12px;background:var(--accent);color:#fff;font-size:.9em;font-weight:600;cursor:pointer;font-family:inherit;margin-top:16px}
.home-cta:active{opacity:.85}
