/*
Theme Name: La Faute aux Ours
Template: spoon
Theme URI: https://lafauteauxours.fr
Author: David (FAO)
Description: Thème enfant de Spoon pour La Faute aux Ours (bar d'apéro et de copains, Lyon 7). Hérite de tout le back-office de Spoon (carte, réglages, fonctions) et n'écrase que le design : mobile-first, thème clair/sombre auto, modules Privateaser / Google Maps / Dailyn.
Version: 2.4
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GPL-2.0-or-later
Text Domain: fao
*/

/* Le thème parent Spoon masque le body (anti-FOUC) puis le révèle via son JS,
   qui ne tourne pas avec nos templates. On force l'affichage. */
html, body { display: block !important; visibility: visible !important; opacity: 1 !important; }

/* ===== THEME AUTO : sombre par défaut, clair selon réglage de l'appareil ===== */
:root{
  --bg:#0E0E10; --surface:#17171B; --surface2:#1F1F25;
  --text:#F6F2EA; --muted:#A6A199; --faint:#6E6A63;
  --line:rgba(255,255,255,.09); --line2:rgba(255,255,255,.16);
  --header-bg:rgba(14,14,16,.86); --tab-bg:rgba(20,20,24,.94);
  --ghost-bg:rgba(255,255,255,.08);
  --chip-on-bg:#F6F2EA; --chip-on-text:#15110d;
  --accent:#FF3D8B; --gold:#E9B44C;
  --maxw:1100px; --radius:14px; --safe-b:env(safe-area-inset-bottom,0px);
  --disp:'Bricolage Grotesque',sans-serif; --sans:'Inter',system-ui,sans-serif;
}
@media (prefers-color-scheme: light){
  :root{
    --bg:#FBF8F2; --surface:#FFFFFF; --surface2:#F4EEE4;
    --text:#1A1512; --muted:#7A756D; --faint:#A59F95;
    --line:rgba(0,0,0,.10); --line2:rgba(0,0,0,.16);
    --header-bg:rgba(251,248,242,.9); --tab-bg:rgba(255,255,255,.94);
    --ghost-bg:#FFFFFF;
    --chip-on-bg:#1A1512; --chip-on-text:#FFFFFF;
    --accent:#E6147A; --gold:#C8881A;
  }
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.5;
  -webkit-font-smoothing:antialiased;padding-bottom:calc(74px + var(--safe-b))}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 18px}
.disp{font-family:var(--disp);font-weight:800;letter-spacing:-.01em}

header{position:sticky;top:0;z-index:50;background:var(--header-bg);
  backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid var(--line)}
.topbar{display:flex;align-items:center;justify-content:space-between;height:58px}
.logo{font-family:var(--disp);font-weight:800;letter-spacing:1px;font-size:22px;color:var(--accent)}
.logo small{display:block;font-size:8px;letter-spacing:3px;color:var(--muted);font-weight:600;margin-top:-3px}
.logo-img{height:42px;width:auto;display:block}
footer .logo-img{height:60px;margin:0 auto 8px}
.topnav{display:none;gap:24px}
.topnav a{font-size:14px;color:var(--muted);font-weight:500}
.topnav a.active,.topnav a:hover{color:var(--text)}
.top-cta{display:none}
.pill-cta{background:var(--accent);color:#fff;padding:9px 16px;border-radius:999px;font-size:13px;font-weight:600}

.page{display:none;animation:fade .25s ease}
.page.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ===== HERO : photo cadrée + texte sur fond uni (lisible) ===== */
.herowrap{display:grid;gap:18px;padding-top:18px}
.hero-photo{height:220px;border-radius:18px;background:#241019 url('img/hero.jpg') center/cover}
.eyebrow{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:10px}
.hero-body h1{font-family:var(--disp);font-size:clamp(32px,8vw,56px);line-height:1;font-weight:800}
.hero-body p{color:var(--muted);margin-top:12px;max-width:38ch;font-size:15px}
.btn{padding:13px 20px;border-radius:12px;font-weight:600;font-size:15px;display:inline-flex;align-items:center;gap:8px}
.btn-primary{background:var(--accent);color:#fff}
.btn-ghost{background:var(--ghost-bg);color:var(--text);border:1px solid var(--line2)}
.status{display:inline-flex;align-items:center;gap:8px;margin:16px 0 18px;
  background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:7px 13px;font-size:13px;color:var(--muted)}
.dot{width:8px;height:8px;border-radius:50%;background:#39D98A;box-shadow:0 0 0 4px rgba(57,217,138,.18)}
.dot.closed{background:#C8553D;box-shadow:0 0 0 4px rgba(200,85,61,.18)}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap}
@media(min-width:980px){
  .herowrap{grid-template-columns:1fr 1fr;align-items:center;padding-top:36px}
  .hero-photo{height:400px}
}

section{padding:30px 0}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:16px}
.sec-head h2{font-family:var(--disp);font-size:24px;font-weight:800}
.sec-head a{font-size:13px;color:var(--accent);font-weight:600}

.week{display:grid;grid-template-columns:1fr;gap:10px}
.wcard{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px}
.wcard .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:20px;flex:none;background:var(--surface2)}
.wcard b{font-size:15px;font-weight:600}
.wcard span{display:block;font-size:13px;color:var(--muted)}
.matchlist{display:grid;grid-template-columns:1fr;gap:10px}
.match{display:flex;align-items:center;gap:13px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:13px 16px}
.match-em{font-size:20px;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;flex:none;background:var(--surface2)}
.match-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.match-main b{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.match-main span{font-size:12.5px;color:var(--muted)}
.match-offer{color:var(--gold)!important;font-weight:600}
.match-when{flex:none;text-align:right;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--gold)}
@media(min-width:680px){.matchlist{grid-template-columns:1fr 1fr}}
.wcard .day{margin-left:auto;font-size:12px;color:var(--gold);font-weight:700;letter-spacing:.5px;white-space:nowrap}

.band{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;text-align:center}
.band h3{font-family:var(--disp);font-size:21px;font-weight:800}
.band p{color:var(--muted);font-size:14px;margin:8px auto 16px;max-width:46ch}

.fgrid{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:680px){.fgrid{grid-template-columns:repeat(3,1fr)}}
.fcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column}
.fcard .fname{font-family:var(--disp);font-weight:800;font-size:18px}
.fcard .fprice{color:var(--gold);font-weight:700;font-size:14px;margin:5px 0 2px}
.fcard .fmeta{font-size:12px;color:var(--faint);margin-bottom:12px}
.fcard ul{list-style:none;font-size:13px;color:var(--muted);display:flex;flex-direction:column;gap:6px;flex:1}
.fcard li{padding-left:15px;position:relative}
.fcard li::before{content:"\2022";position:absolute;left:0;color:var(--accent)}
.fcard .btn{margin-top:16px;justify-content:center}

/* ===== CARTE : cartes catégories ===== */
.menu-title{font-family:var(--disp);font-size:26px;font-weight:800;padding:24px 0 6px}
.catgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding-bottom:10px}
@media(min-width:680px){.catgrid{grid-template-columns:repeat(3,1fr)}}
.catcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 14px;text-align:left;display:flex;flex-direction:column;gap:6px;transition:.15s}
.catcard:hover{border-color:var(--line2)}
.catcard .em{font-size:26px}
.catcard b{font-size:15px}
.catcard span{font-size:12px;color:var(--muted)}
.catview{display:none;padding-bottom:10px}
.catview.active{display:block}
.back{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:13px;font-weight:600;padding:20px 0 6px}
.catview .cv{font-family:var(--disp);font-size:24px;font-weight:800;margin-bottom:2px}
.subh{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--faint);font-weight:700;margin:22px 0 2px}
.subdesc{font-size:12px;color:var(--muted);margin:2px 0 4px}
/* Carte en 2 colonnes sur tablette / ordinateur (comme un menu papier) */
@media(min-width:720px){
  .catview{column-count:2;column-gap:44px}
  .catview .back,.catview .cv{column-span:all}
  .catview .item,.catview .subh,.catview .subdesc{break-inside:avoid}
}
.item{display:flex;gap:14px;justify-content:space-between;padding:12px 0;border-top:1px solid var(--line)}
.item h4{font-size:15px;font-weight:600;text-transform:uppercase}
.item p{font-size:12.5px;color:var(--muted);margin-top:3px;max-width:46ch}
.price{font-family:var(--disp);font-weight:800;font-size:14px;color:var(--gold);text-align:right;flex:0 0 auto;max-width:50%;line-height:1.35}
.note{font-size:12px;color:var(--faint);margin:14px 0 0}
.badge{display:inline-block;font-size:9px;font-weight:700;letter-spacing:.5px;background:var(--surface2);color:var(--accent);border-radius:5px;padding:3px 7px;margin-left:8px;vertical-align:middle}

.prog-grid{display:grid;grid-template-columns:1fr;gap:12px}
.pcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.pcard .ph{padding:16px 18px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line)}
.pcard .ph .em{font-size:24px}.pcard .ph b{font-size:15px}
.pcard .ph .day{margin-left:auto;background:var(--surface2);color:var(--gold);font-size:11px;font-weight:700;letter-spacing:.5px;padding:5px 10px;border-radius:999px}
.pcard .pb{padding:14px 18px;font-size:13.5px;color:var(--muted)}

.info-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:8px}
.irow{display:flex;gap:12px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:15px 16px}
.irow .em{font-size:20px}.irow b{font-size:14px}
.irow span{display:block;font-size:13px;color:var(--muted);margin-top:2px}
.map iframe{width:100%;height:300px;border:0;border-radius:var(--radius);margin-top:12px}
.cform{display:grid;gap:12px;max-width:600px;margin-top:14px}
.cform .frow{display:grid;gap:12px}
@media(min-width:560px){.cform .frow{grid-template-columns:1fr 1fr}}
.cform label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px;font-weight:600}
.cform input,.cform textarea{width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:10px;background:var(--surface);font-family:inherit;font-size:15px;color:var(--text)}
.cform input::placeholder,.cform textarea::placeholder{color:var(--faint)}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--accent)}
.cform textarea{min-height:120px;resize:vertical}
.cform .consent{display:flex;gap:9px;align-items:flex-start;font-size:12px;color:var(--muted)}
.cform .consent input{width:auto;margin-top:2px;accent-color:var(--accent)}
.cform .sent{display:none;font-size:14px;color:#39D98A;font-weight:600}
.cform .sent.on{display:block}
.embed{background:#fff;border-radius:var(--radius);overflow:hidden;margin-top:6px}
.embed iframe{display:block;width:100%;border:0}

footer{padding:30px 0 40px;border-top:1px solid var(--line);margin-top:20px;text-align:center;background:var(--surface2)}
footer .logo{font-size:20px;margin-bottom:8px}
footer p{font-size:12.5px;color:var(--faint);margin-top:4px}
footer p a{color:var(--muted);text-decoration:underline;text-underline-offset:2px}
svg.ti{width:1em;height:1em;flex:none;display:inline-block;vertical-align:-.125em;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.socials{display:flex;gap:16px;justify-content:center;margin:14px 0}
.socials a{width:40px;height:40px;border-radius:50%;background:var(--surface);border:1px solid var(--line);display:grid;place-items:center;font-size:18px}

.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:60;background:var(--tab-bg);
  backdrop-filter:blur(14px);border-top:1px solid var(--line2);display:flex;padding-bottom:var(--safe-b)}
.tabbar button{flex:1;padding:9px 0 8px;display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--faint);font-size:10.5px;font-weight:600}
.tabbar button .ti{font-size:22px}
.tabbar button.active{color:var(--text)}
.tabbar button.active .ti{color:var(--accent)}

.modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal__bg{position:absolute;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(3px)}
.modal__box{position:relative;z-index:2;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);max-width:380px;width:100%;overflow:hidden;text-align:left}
.modal__head{background:var(--accent);color:#fff;padding:15px 48px 15px 18px;font-family:var(--disp);font-weight:800;font-size:15px;line-height:1.25;position:relative}
.modal__body{padding:20px 18px 22px;text-align:center}
.modal__body p{color:var(--muted);font-size:14px;margin-bottom:6px}
.modal__close{position:absolute;top:13px;right:14px;font-size:20px;color:#fff;background:none;border:none;cursor:pointer;line-height:1}

@media(min-width:680px){.week{grid-template-columns:repeat(2,1fr)}.prog-grid{grid-template-columns:repeat(2,1fr)}.info-grid{grid-template-columns:repeat(2,1fr)}.resa-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}}
@media(min-width:980px){body{padding-bottom:0}.topnav{display:flex}.top-cta{display:block}.tabbar{display:none}.carte-wrap{max-width:860px;margin:0 auto}}

/* ===== Formulaire Contact Form 7 (stylé comme le reste) ===== */
.cform .wpcf7-form p{margin:0 0 12px}
.cform .wpcf7-form label{display:block;font-size:13px;color:var(--text);font-weight:500}
.cform .wpcf7-submit{width:auto;background:var(--accent);color:#fff;border:none;border-radius:12px;padding:13px 26px;font-weight:600;font-size:15px;cursor:pointer}
.cform .wpcf7-submit:hover{filter:brightness(.95)}
.cform .wpcf7-spinner{margin:0 0 0 10px}
.cform .wpcf7-response-output{border-radius:10px;font-size:13px;margin:10px 0 0 !important;padding:10px 13px !important}
.cform .wpcf7-not-valid-tip{color:var(--accent);font-size:12px;margin-top:4px}
.cform .acceptance-text,.cform .wpcf7-acceptance .wpcf7-list-item-label{font-size:12px;color:var(--muted);font-weight:400}
