/* Logo + layout additions for CMS */
.logo-text{background:var(--red);color:#fff;font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:22px;letter-spacing:.06em;padding:8px 14px;border-radius:4px;display:inline-block}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(19,21,25,.35) 0%,rgba(19,21,25,.85) 100%)}
.hero-content{position:relative;z-index:2;padding:120px 0 80px;width:100%}
.hero-kicker{text-transform:uppercase;font-size:12px;letter-spacing:.14em;color:var(--mut2);margin-bottom:12px}
.hero h1{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:clamp(2rem,5vw,3.4rem);text-transform:uppercase;line-height:1.05;margin-bottom:14px}
.hero-sub{font-size:1.1rem;color:var(--mut2);margin-bottom:8px}
.hero-slogan{font-size:1rem;color:var(--mut);margin-bottom:28px;max-width:560px}
.hero-cta{display:inline-block}
.section{padding:72px 0}
.section-title{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:1.8rem;text-transform:uppercase;margin-bottom:32px}
.families-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}
.family-card{background:var(--surf);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s cubic-bezier(.4,0,.2,1),border-color .25s ease}
.family-card:hover{transform:translateY(-2px);border-color:var(--line2);box-shadow:0 12px 28px -18px rgba(0,0,0,.55)}
.family-card img{aspect-ratio:16/10;object-fit:cover;width:100%}
.family-card-body{padding:18px 20px;display:flex;align-items:center;justify-content:space-between}
.family-card h3{font-family:'Saira',sans-serif;font-weight:600;font-size:1rem}
.family-card .arrow{color:var(--red);transition:transform .25s cubic-bezier(.4,0,.2,1)}
.family-card:hover .arrow{transform:translateX(3px)}
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.product-card{background:var(--surf);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:opacity .25s ease,transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s cubic-bezier(.4,0,.2,1),border-color .25s ease}
.product-card:hover{transform:translateY(-2px);border-color:var(--line2);box-shadow:0 12px 28px -18px rgba(0,0,0,.55)}
.product-img{aspect-ratio:4/3;background:var(--surf2);overflow:hidden}
.product-img img{width:100%;height:100%;object-fit:cover}
.product-placeholder{height:100%;min-height:140px;background:var(--line)}
.product-body{padding:16px}
.product-body h3{font-size:.95rem;font-weight:600;margin-bottom:6px}
.price{color:var(--red);font-weight:600;font-size:.9rem}
.section-cta{margin-top:36px;text-align:center}
.about-box{background:var(--surf);border:1px solid var(--line);border-radius:16px;padding:32px;line-height:1.7}
.contact-band{background:var(--surf)}
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px}
.page-head{padding-top:120px;padding-bottom:40px}
.search-form{display:flex;gap:12px;margin-top:20px;max-width:520px}
.search-form input{flex:1;background:var(--surf);border:1px solid var(--line);border-radius:8px;padding:12px 14px;color:var(--txt)}
.product-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding-top:100px}
.product-gallery-main{margin-bottom:0}
.product-main-img{border-radius:16px;width:100%;display:block;aspect-ratio:4/3;object-fit:cover;background:var(--surf2)}
.product-gallery-thumbs{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.product-gallery-thumb{padding:0;border:2px solid var(--line);border-radius:8px;background:var(--surf2);cursor:pointer;overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease;line-height:0}
.product-gallery-thumb img{width:72px;height:72px;object-fit:cover;display:block}
.product-gallery-thumb:hover{border-color:var(--line2)}
.product-gallery-thumb.is-active{border-color:var(--red);box-shadow:0 0 0 1px var(--red)}
.product-thumbs{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.product-thumbs img{width:72px;height:72px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.price-lg{font-size:1.5rem;color:var(--red);font-weight:700;margin:16px 0}
.product-desc{color:var(--mut2);margin-bottom:24px;line-height:1.7}
.product-duration{font-size:.95rem;margin:-8px 0 16px}
.product-specs{margin-bottom:28px}
.specs-title{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:1.1rem;text-transform:uppercase;margin-bottom:12px;color:var(--mut2)}
.specs-table{width:100%;border-collapse:collapse;font-size:.92rem}
.specs-table th,.specs-table td{border-bottom:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top}
.specs-table th{color:var(--mut);font-weight:500;width:42%}
.specs-table td{color:var(--txt)}
.site-footer{border-top:1px solid var(--line);padding:48px 0 32px;margin-top:40px}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-bottom:24px}
.footer-copy{font-size:.85rem}
.mut{color:var(--mut)}
.resa-form{max-width:560px;display:grid;gap:16px}
.resa-form label{display:grid;gap:6px;font-size:.9rem}
.resa-form input:not([type="radio"]),.resa-form textarea,.resa-form select{background:var(--surf);border:1px solid var(--line);border-radius:8px;padding:12px;color:var(--txt)}
.resa-form select{cursor:pointer}
.input-readonly{opacity:.85;cursor:default}
.resa-type-fieldset{border:1px solid var(--line);border-radius:8px;padding:14px 16px;display:grid;gap:10px;margin:0}
.resa-type-fieldset legend{padding:0 6px;font-size:.85rem;color:var(--mut)}
.resa-form label.resa-type-option{display:flex;flex-direction:row;align-items:center;gap:8px;font-size:.9rem;cursor:pointer}
.resa-form input[type="radio"]{width:auto;margin:0;padding:0;border:none;background:transparent;flex-shrink:0;cursor:pointer}
.admin-product-ref{display:block;font-size:.8rem;margin-top:2px}
.hp{position:absolute;left:-9999px;height:0;width:0;opacity:0}
@media(max-width:880px){.product-layout{grid-template-columns:1fr}}

/* Admin bar (session active) */
:root{--admin-bar-height:40px}
.admin-bar{position:fixed;top:0;left:0;right:0;z-index:300;height:var(--admin-bar-height);background:#111317;border-bottom:2px solid var(--red);box-shadow:0 4px 16px rgba(0,0,0,.35)}
.admin-bar-inner{display:flex;align-items:center;gap:12px;height:100%;max-width:100%;padding:0 12px 0 16px}
.admin-bar-brand{flex-shrink:0;font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:var(--red);padding:4px 10px;border-radius:4px;line-height:1.2}
.admin-bar-nav{display:flex;align-items:center;gap:2px;flex:1;min-width:0;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.admin-bar-nav::-webkit-scrollbar{display:none}
.admin-bar-link{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:6px;font-size:.78rem;font-weight:500;color:rgba(255,255,255,.78);text-decoration:none;white-space:nowrap;transition:color .15s,background .15s}
.admin-bar-link:hover{color:#fff;background:rgba(255,255,255,.08)}
.admin-bar-link.is-active{color:#fff;background:rgba(221,51,51,.22)}
.admin-bar-link--public{color:rgba(255,255,255,.92)}
.admin-bar-link--logout{color:rgba(255,255,255,.65)}
.admin-bar-link--logout:hover{color:#fff;background:rgba(221,51,51,.18)}
.admin-bar-sep{flex-shrink:0;width:1px;height:18px;background:rgba(255,255,255,.18);margin:0 6px}
.admin-bar-badge{min-width:18px;height:18px;padding:0 5px;font-size:.68rem}
.admin-bar-toggle{display:none;flex-shrink:0;margin-left:auto;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:6px;width:34px;height:28px;padding:0;cursor:pointer;color:#fff}
.admin-bar-toggle svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;display:block;margin:0 auto}
body.admin-logged-in .site-header{top:var(--admin-bar-height)}
body.admin-logged-in .hero-content{padding-top:calc(120px + var(--admin-bar-height))}
body.admin-logged-in .page-head{padding-top:calc(120px + var(--admin-bar-height))}
body.admin-logged-in .product-layout{padding-top:calc(100px + var(--admin-bar-height))}
body.admin-logged-in.is-admin-page main{padding-top:calc(var(--admin-bar-height) + 88px)}
@media(max-width:880px){
  body.admin-logged-in .mobnav{top:var(--admin-bar-height)}
}
@media(max-width:720px){
  .admin-bar-inner{padding-right:8px}
  .admin-bar-toggle{display:inline-flex;align-items:center;justify-content:center}
  .admin-bar-nav{display:none;position:absolute;top:var(--admin-bar-height);left:0;right:0;flex-direction:column;align-items:stretch;gap:0;padding:8px;background:#111317;border-bottom:2px solid var(--red);box-shadow:0 8px 24px rgba(0,0,0,.45);max-height:min(70vh,calc(100vh - var(--admin-bar-height)));overflow-y:auto}
  .admin-bar-nav.is-open{display:flex}
  .admin-bar-link{padding:10px 14px;border-radius:0;border-bottom:1px solid rgba(255,255,255,.06)}
  .admin-bar-sep{display:none}
}
@media(max-width:720px){.admin-bar-link--public,.admin-bar-link--logout{border-top:1px solid rgba(255,255,255,.1);margin-top:4px}}

/* Admin (legacy nav retirée — barre fixe ci-dessus) */
.admin-nav{display:none}
.admin-wrap{max-width:1100px;margin:0 auto;padding:1.5rem 1.25rem;width:100%;box-sizing:border-box}
.admin-page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:8px}
.admin-page-head h1,.admin-wrap>h1{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:1.8rem;text-transform:uppercase;margin:0}
.admin-page-meta{margin:8px 0 24px}
.admin-btn-link,.admin-head-cta{font-size:.9rem;padding:8px 14px;border:1px solid var(--line);border-radius:8px;text-decoration:none;color:var(--txt);background:var(--surf)}
.admin-btn-link:hover,.admin-head-cta:hover{border-color:var(--red);color:var(--red)}
.admin-head-cta{background:var(--red);border-color:var(--red);color:#fff}
.admin-head-cta:hover{background:#c42a2a;color:#fff}
.admin-form{display:grid;gap:16px;max-width:400px;width:100%;margin-top:24px}
.admin-form label{display:grid;gap:6px}
.admin-form input{background:var(--surf);border:1px solid var(--line);border-radius:8px;padding:12px;color:var(--txt)}
.admin-table{width:100%;border-collapse:collapse;margin-top:16px;font-size:.9rem;table-layout:auto}
@media(max-width:768px){
  .admin-wrap > .admin-table,.admin-section .admin-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}
  .admin-wrap > .admin-table thead,.admin-wrap > .admin-table tbody,.admin-section .admin-table thead,.admin-section .admin-table tbody{display:table;width:100%;min-width:640px;table-layout:fixed}
}
.admin-table th,.admin-table td{border:1px solid var(--line);padding:10px;text-align:left;vertical-align:top}
.admin-table input.inline-input{background:transparent;border:1px solid transparent;padding:6px;color:var(--txt);width:100%}
.admin-table input.inline-input:focus{border-color:var(--red);background:var(--surf2)}
.admin-table input.wide{min-width:240px}
.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin:24px 0}
.stat-card{background:var(--surf);border:1px solid var(--line);border-radius:12px;padding:24px 20px;text-align:center}
.stat-card strong{display:block;font-size:2rem;color:var(--red);line-height:1.1}
.stat-card span{display:block;margin-top:8px;color:var(--mut);font-size:.9rem}
.stat-sub{font-size:.8rem;color:var(--mut2)}
.stat-card-alert{border-color:var(--red)}
.admin-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:var(--red);color:#fff;font-size:.75rem;font-weight:700}
.admin-section{margin-top:32px;padding-top:24px;border-top:1px solid var(--line)}
.admin-section-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.admin-section-head h2{font-size:1.1rem;margin:0;flex:1}
.admin-filters{display:flex;gap:8px;flex-wrap:wrap;margin:16px 0}
.admin-filter{font-size:.85rem;padding:6px 12px;border:1px solid var(--line);border-radius:999px;text-decoration:none;color:var(--mut)}
.admin-filter.is-active,.admin-filter:hover{border-color:var(--red);color:var(--red)}
.admin-status{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.75rem;font-weight:600}
.admin-status.status-new{background:rgba(221,51,51,.15);color:var(--red)}
.admin-status.status-treated{background:rgba(80,160,80,.15);color:#6fcf6f}
.admin-status.status-missed{background:rgba(200,160,60,.15);color:#d4a843}
.row-unread td:first-child{box-shadow:inset 3px 0 0 var(--red)}
.col-message{max-width:240px;word-break:break-word}
.col-actions{white-space:nowrap}
.admin-type-tag{display:block;font-size:.75rem;margin-top:4px}
.btn-mark-treated,.btn-copy{background:transparent;border:1px solid var(--line);color:var(--mut);padding:4px 10px;border-radius:6px;cursor:pointer;font-size:.8rem;margin-right:4px}
.btn-mark-treated:hover,.btn-copy:hover{border-color:var(--red);color:var(--red)}
.req-status-select{background:var(--surf);border:1px solid var(--line);border-radius:6px;padding:4px 8px;color:var(--txt);font-size:.85rem}
.admin-settings-form{display:grid;gap:16px;width:100%;max-width:none;margin-top:24px}
.admin-settings-section{border:1px solid var(--line);border-radius:8px;padding:16px;display:grid;gap:12px;margin:0}
.admin-settings-section legend{font-weight:600;padding:0 4px}
.admin-mail-warn{display:inline-block;font-size:.75rem;margin-left:6px;color:var(--warn,#c90)}
.admin-checkbox{display:flex;align-items:center;gap:10px}
.admin-hint{font-size:.85rem}
.admin-smtp-dl{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;font-size:.9rem;margin:0}
.admin-smtp-dl dt{font-weight:600;color:var(--ink)}
.admin-smtp-dl dd{margin:0}
.admin-smtp-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px;margin:12px 0}
.admin-smtp-grid label{display:flex;flex-direction:column;gap:4px;font-size:.9rem}
.admin-smtp-grid input,.admin-smtp-grid select{width:100%;padding:8px 10px;border:1px solid var(--line);border-radius:4px;font:inherit}
@media(max-width:640px){.admin-smtp-grid{grid-template-columns:1fr}}
.admin-save-status{font-size:.9rem;color:var(--mut);margin-left:12px}
.contact-flash{padding:14px 16px;border-radius:8px;margin-bottom:20px;border:1px solid var(--line)}
.contact-flash-success{background:rgba(80,160,80,.12);border-color:#6fcf6f}
.contact-flash-error{background:rgba(221,51,51,.12);border-color:var(--red)}
.error{color:var(--red);margin-top:12px}
.block-edit{margin-bottom:24px;padding:20px;background:var(--surf);border-radius:12px;border:1px solid var(--line)}
.block-textarea{width:100%;background:var(--surf2);border:1px solid var(--line);border-radius:8px;padding:12px;color:var(--txt);margin:8px 0 12px}
.btn-del,.btn-rollback{background:transparent;border:1px solid var(--line);color:var(--mut);padding:4px 10px;border-radius:6px;cursor:pointer;font-size:.8rem}
.btn-del:hover,.btn-rollback:hover{border-color:var(--red);color:var(--red)}

.admin-head-cta{white-space:nowrap;flex-shrink:0}
.admin-table-products .col-thumb{width:72px}
.admin-table-products .col-price{width:130px;white-space:nowrap}
.admin-table-products .col-available{width:110px;text-align:center}
.admin-table-products .col-order{width:70px;text-align:center}
.admin-table-products .col-actions{width:200px;white-space:nowrap}
.admin-table-categories .col-slug{width:140px}
.admin-table-categories .col-products{width:72px;text-align:center}
.admin-table-categories .col-order{width:72px;text-align:center}
.admin-table-categories .col-available{width:110px;text-align:center}
.admin-table-categories .col-image{min-width:200px}
.admin-table-categories .col-actions{width:90px;white-space:nowrap}
.admin-table-categories td:first-child .status-unavailable{display:block;margin-top:4px;margin-left:0}
.catalogue-filters{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 24px}
.catalogue-filter{font-size:.85rem;padding:6px 14px;border:1px solid var(--line);border-radius:999px;text-decoration:none;color:var(--mut)}
.catalogue-filter:hover,.catalogue-filter.is-active{border-color:var(--red);color:var(--red)}
.catalogue-filter-sub{font-size:.8rem;padding:4px 12px}
.admin-table-filters th{background:var(--surf2);padding:6px 8px!important}
.admin-filter-input{width:100%;background:var(--surf);border:1px solid var(--line);border-radius:6px;padding:6px 8px;color:var(--txt);font-size:.8rem}
.admin-filter-input:focus{border-color:var(--red);outline:none}
.admin-price-filters{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.admin-filter-price{min-width:0}
.admin-avail-toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:.85rem}
.admin-avail-toggle input{cursor:pointer}
.admin-status.status-unavailable{background:rgba(140,140,140,.2);color:var(--mut);margin-left:8px}
.row-unavailable{opacity:.65}
.row-unavailable td{background:var(--surf2)}
.admin-thumb{width:56px;height:56px;object-fit:cover;border-radius:8px;border:1px solid var(--line);display:block}
.admin-thumb-placeholder{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--surf2);border-radius:8px;color:var(--mut);font-size:.85rem}
.admin-btn-edit,.admin-btn-link{display:inline-block;font-size:.85rem;padding:4px 10px;border-radius:6px;border:1px solid var(--line);margin-right:6px;color:var(--txt);text-decoration:none}
.admin-btn-edit:hover,.admin-btn-link:hover{border-color:var(--red);color:var(--red)}
.admin-product-form{display:grid;gap:20px;margin-top:24px;width:100%;max-width:none}
.admin-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.admin-form-full{grid-column:1/-1}
.admin-sort-order{display:grid;gap:8px;font-size:.9rem;max-width:10rem}
.admin-sort-order input{text-align:center}
.admin-product-form label,.admin-product-form fieldset{display:grid;gap:8px;font-size:.9rem}
.admin-product-form input,.admin-product-form textarea,.admin-product-form select{background:var(--surf);border:1px solid var(--line);border-radius:8px;padding:12px;color:var(--txt);font:inherit}
.admin-categories-select{min-height:120px}
.admin-checkbox{display:flex!important;flex-direction:row;align-items:center;gap:10px}
.admin-form-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:8px}
.price-unit-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
.price-unit-row select{min-width:8.5rem}

/* CMS product edit panel */
.cms-edit-bar{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:900;display:flex;align-items:center;gap:12px;background:var(--surf);border:1px solid var(--line2);border-radius:12px;padding:10px 16px;box-shadow:0 8px 32px rgba(0,0,0,.45)}
.cms-edit-badge{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--red);font-weight:600}
.cms-edit-toggle{background:var(--red);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-weight:600;cursor:pointer;font-size:.9rem}
.cms-edit-toggle:hover{opacity:.9}
.cms-edit-link{font-size:.85rem;color:var(--mut2);text-decoration:none}
.cms-edit-link:hover{color:var(--red)}
.cms-edit-panel{position:fixed;top:0;right:0;width:min(420px,100vw);height:100vh;z-index:950;background:var(--surf);border-left:1px solid var(--line2);display:flex;flex-direction:column;box-shadow:-8px 0 32px rgba(0,0,0,.35)}
.cms-edit-panel[hidden]{display:none!important}
.cms-edit-panel-head{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 12px;border-bottom:1px solid var(--line)}
.cms-edit-panel-head h2{font-family:'Saira Condensed',sans-serif;font-size:1.2rem;text-transform:uppercase;margin:0}
.cms-edit-close{background:transparent;border:none;color:var(--mut);font-size:1.6rem;cursor:pointer;line-height:1;padding:4px 8px}
.cms-edit-form{padding:16px 20px 32px;overflow-y:auto;display:grid;gap:16px;flex:1}
.cms-edit-form label,.cms-specs-fieldset{display:grid;gap:6px;font-size:.88rem}
.cms-edit-form input,.cms-edit-form textarea,.cms-spec-row input{background:var(--surf2);border:1px solid var(--line);border-radius:8px;padding:10px 12px;color:var(--txt);font:inherit;width:100%}
.cms-specs-fieldset{border:1px solid var(--line);border-radius:10px;padding:12px;margin:0}
.cms-specs-fieldset legend{padding:0 6px;color:var(--mut2);font-size:.85rem}
.cms-specs-list{display:grid;gap:8px}
.cms-spec-row{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:center}
.cms-spec-del{background:transparent;border:1px solid var(--line);color:var(--mut);width:32px;height:32px;border-radius:6px;cursor:pointer;font-size:1.1rem;line-height:1}
.cms-spec-del:hover{border-color:var(--red);color:var(--red)}
.cms-spec-add{background:transparent;border:1px dashed var(--line2);color:var(--mut2);padding:8px;border-radius:8px;cursor:pointer;font-size:.85rem;margin-top:4px}
.cms-spec-add:hover{border-color:var(--red);color:var(--red)}
.product-gallery-fieldset{border:1px solid var(--line);border-radius:10px;padding:12px;margin:0;display:grid;gap:10px}
.product-gallery-fieldset legend{padding:0 6px;color:var(--mut2);font-size:.85rem}
.gallery-repeater-list{display:grid;gap:10px}
.gallery-row{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:start;padding:10px;background:var(--surf2);border:1px solid var(--line);border-radius:10px}
.gallery-main-label{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--mut2);white-space:nowrap;padding-top:10px;cursor:pointer}
.gallery-main-label input{margin:0;accent-color:var(--red)}
.gallery-row .media-picker-label{gap:0;margin:0}
.gallery-row .media-picker-row{flex-wrap:wrap}
.gallery-row-del{background:transparent;border:1px solid var(--line);color:var(--mut);width:32px;height:32px;border-radius:6px;cursor:pointer;font-size:1.1rem;line-height:1;margin-top:10px}
.gallery-row-del:hover{border-color:var(--red);color:var(--red)}
.cms-edit-actions{display:flex;align-items:center;gap:12px;padding-top:8px}
.cms-save-status{font-size:.85rem;color:var(--mut2)}
.hero-admin-section{margin-bottom:48px;padding:24px;background:var(--surf);border:1px solid var(--line);border-radius:16px}
.hero-admin-section h2{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:1.4rem;text-transform:uppercase;margin-bottom:8px}
.cms-hero-preview{border-radius:12px;overflow:hidden;border:1px solid var(--line);aspect-ratio:21/9;background:var(--surf2);margin-bottom:8px}
.cms-hero-preview img{width:100%;height:100%;object-fit:cover;display:block}
body.cms-panel-open{overflow:hidden}
@media(max-width:600px){.cms-edit-bar{left:12px;right:12px;transform:none;flex-wrap:wrap;justify-content:center}}

/* Inline edit mode (blocs accueil) */
[data-editable]{outline:1px dashed rgba(221,51,51,.4);outline-offset:4px;cursor:text;border-radius:4px}
[data-editable]:hover{outline-color:var(--red)}
[data-editing=true]{outline:2px solid var(--red)!important}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* Médiathèque & media picker */
.media-picker-label{display:grid;gap:6px}
.media-picker-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.media-picker-preview{width:56px;height:56px;object-fit:cover;border-radius:8px;border:1px solid var(--line);flex-shrink:0;background:var(--surf2)}
.media-picker-preview--empty{width:56px;height:56px;border-radius:8px;border:1px dashed var(--line);background:var(--surf2)}
.media-picker-input{flex:1;min-width:160px}
.media-picker--compact{display:flex;gap:6px;align-items:center}
.media-picker--compact .media-picker-preview,.media-picker--compact .media-picker-preview--empty{display:none}
.media-picker-open,.chrome-btn{background:var(--surf2);border:1px solid var(--line);border-radius:8px;padding:8px 12px;color:var(--txt);cursor:pointer;font-size:.85rem;white-space:nowrap}
.media-picker-open:hover,.chrome-btn:hover{border-color:var(--line2)}
body.media-picker-open{overflow:hidden}
.media-picker-modal{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;padding:16px}
.media-picker-modal[hidden]{display:none!important}
.media-picker-dialog{background:var(--surf);border:1px solid var(--line2);border-radius:16px;width:min(720px,100%);max-height:90vh;display:flex;flex-direction:column;box-shadow:0 16px 48px rgba(0,0,0,.45)}
.media-picker-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}
.media-picker-head h2{margin:0;font-family:'Saira Condensed',sans-serif;font-size:1.2rem;text-transform:uppercase}
.media-picker-close{background:transparent;border:none;color:var(--mut);font-size:1.6rem;cursor:pointer;line-height:1}
.media-picker-tabs{display:flex;gap:8px;padding:12px 20px 0;border-bottom:1px solid var(--line)}
.media-picker-tab{background:transparent;border:none;color:var(--mut2);padding:8px 12px;cursor:pointer;border-bottom:2px solid transparent;font-size:.9rem}
.media-picker-tab.is-active{color:var(--txt);border-bottom-color:var(--red)}
.media-picker-panel{padding:16px 20px 20px;overflow-y:auto;flex:1}
.media-picker-panel label{display:grid;gap:8px;font-size:.9rem}
.media-picker-panel input[type=url],.media-picker-panel input[type=search],.media-picker-search{width:100%;background:var(--surf2);border:1px solid var(--line);border-radius:8px;padding:10px 12px;color:var(--txt);margin-bottom:12px}
.media-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;max-height:360px;overflow-y:auto}
.media-picker-item{display:grid;gap:4px;padding:6px;background:var(--surf2);border:1px solid var(--line);border-radius:8px;cursor:pointer;text-align:center;font-size:.75rem;color:var(--mut2)}
.media-picker-item:hover{border-color:var(--red)}
.media-picker-item img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;display:block}
.media-upload-drop{display:block;border:2px dashed var(--line2);border-radius:12px;padding:32px;text-align:center;cursor:pointer}
.media-upload-drop input{display:none}
.media-upload-hint{font-size:.85rem;margin-top:8px}
.admin-media-page .media-toolbar{display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between;margin:24px 0}
.media-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.media-search-input,.media-filters select{background:var(--surf);border:1px solid var(--line);border-radius:8px;padding:8px 12px;color:var(--txt)}
.media-upload-btn{cursor:pointer;display:inline-flex;align-items:center}
.media-upload-btn input{display:none}
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.media-card{background:var(--surf);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.media-card-thumb{position:relative;aspect-ratio:4/3;background:var(--surf2)}
.media-card-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.media-source-badge{position:absolute;top:8px;left:8px;font-size:.65rem;text-transform:uppercase;padding:2px 6px;border-radius:4px;background:rgba(0,0,0,.6);color:#fff}
.media-source-upload{background:rgba(34,139,34,.85)}
.media-source-import{background:rgba(70,130,180,.85)}
.media-source-external{background:rgba(128,128,128,.85)}
.media-card-body{padding:12px;display:grid;gap:8px}
.media-title-input,.media-alt-input{background:var(--surf2);border:1px solid var(--line);border-radius:6px;padding:6px 8px;color:var(--txt);font-size:.85rem;width:100%}
.media-url{font-size:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin:0}
.media-card-actions{display:flex;gap:8px;flex-wrap:wrap}
.media-empty{grid-column:1/-1}

.admin-dialog{border:1px solid var(--line);border-radius:12px;padding:0;background:var(--surf);color:var(--txt);max-width:480px;width:calc(100% - 32px)}
.admin-dialog::backdrop{background:rgba(0,0,0,.55)}
.admin-dialog form{padding:20px 24px 24px}
.admin-dialog h3{margin:0 0 16px;font-family:var(--font-head)}
.admin-dialog-actions{display:flex;gap:12px;align-items:center;margin-top:8px}
.admin-save-status.is-error{color:var(--red)}
.admin-table .row-self td{background:rgba(255,255,255,.03)}

