:root{
  --bg:#0E1622; --bg-2:#16202E; --bg-3:#1B2738; --line:#26344a;
  --txt:#E8EDF3; --muted:#94a3b8; --brand:#36CBC6; --brand-2:#0C7E7C;
  --green:#27c08a; --red:#E0664A; --amber:#d29922; --radius:12px;
  --shadow:0 18px 44px -22px rgba(0,0,0,.6);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--bg);color:var(--txt);font:15px/1.55 'Nunito',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--muted)}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}

/* layout shell */
.shell{display:flex;min-height:100vh}
.sidebar{width:230px;background:var(--bg-2);border-right:1px solid var(--line);padding:20px 14px;position:sticky;top:0;height:100vh;flex-shrink:0}
.sidebar .logo{font-weight:700;font-size:18px;padding:6px 10px 18px;display:flex;align-items:center;gap:8px}
.sidebar .logo .dot{width:10px;height:10px;border-radius:50%;background:var(--brand)}
.nav a{display:block;padding:9px 12px;border-radius:9px;color:var(--muted);margin-bottom:2px;font-weight:500}
.nav a:hover{background:var(--bg-3);color:var(--txt);text-decoration:none}
.nav a.active{background:var(--brand-2);color:#fff}
.nav .sep{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#5a6678;padding:14px 12px 6px}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 26px;border-bottom:1px solid var(--line);background:var(--bg-2)}
.topbar .who{font-size:13px;color:var(--muted)}
.content{padding:26px;max-width:1100px;width:100%}
h1{font-size:22px;margin:0 0 4px}
h2{font-size:17px;margin:26px 0 12px}
.sub{color:var(--muted);margin:0 0 22px}

/* auth pages */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.auth-card{width:100%;max-width:400px;background:var(--bg-2);border:1px solid var(--line);border-radius:16px;padding:30px;box-shadow:var(--shadow)}
.auth-card h1{text-align:center;margin-bottom:6px}
.auth-card .sub{text-align:center}
.auth-foot{text-align:center;margin-top:16px;font-size:14px;color:var(--muted)}

/* cards & grid */
.grid{display:grid;gap:16px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:860px){.grid.cols-3,.grid.cols-4,.grid.cols-2{grid-template-columns:1fr}}
.card{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.stat{padding:18px}
.stat .k{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.stat .v{font-size:28px;font-weight:700;margin-top:6px}

/* forms */
.field{margin-bottom:14px}
label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}
input,textarea,select{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:9px;color:var(--txt);padding:10px 12px;font-size:14px;font-family:inherit}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--brand)}
textarea{resize:vertical;min-height:70px}
.row{display:flex;gap:12px}
.row>*{flex:1}
.btn{display:inline-block;background:var(--brand-2);color:#fff;border:none;border-radius:9px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer}
.btn:hover{background:#0a6e6c;text-decoration:none}
.btn.full{width:100%}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--txt)}
.btn.ghost:hover{background:var(--bg-3)}
.btn.danger{background:transparent;border:1px solid var(--red);color:var(--red)}
.btn.danger:hover{background:rgba(248,81,73,.12)}
.btn.sm{padding:6px 10px;font-size:13px}
.hint{font-size:12px;margin-top:5px;min-height:16px}
.hint.ok{color:var(--green)} .hint.bad{color:var(--red)}

/* table */
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line)}
th{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}
tr:hover td{background:var(--bg-3)}
.tag{display:inline-block;font-size:11px;padding:2px 8px;border-radius:20px;background:var(--bg-3);color:var(--muted)}
.tag.green{background:rgba(63,185,80,.15);color:var(--green)}
.tag.red{background:rgba(248,81,73,.15);color:var(--red)}
.tag.blue{background:rgba(31,182,178,.16);color:var(--brand)}

/* flash */
.flash{padding:11px 16px;border-radius:9px;margin-bottom:14px;font-size:14px}
.flash.error{background:rgba(224,102,74,.12);border:1px solid rgba(224,102,74,.5);color:var(--txt)}
.flash.success{background:rgba(31,182,178,.14);border:1px solid var(--brand);color:var(--txt)}

/* bar chart (sparkline) */
.bars{display:flex;align-items:flex-end;gap:3px;height:90px;margin-top:8px}
.bars .bar{flex:1;background:var(--brand-2);border-radius:3px 3px 0 0;min-height:2px;opacity:.85}
.bars .bar:hover{opacity:1}

/* inline copy */
.copyrow{display:flex;gap:8px;align-items:center}
.copyrow input{font-family:ui-monospace,monospace}

/* public profile */
.profile-hero{text-align:center;padding:40px 20px 10px}
.avatar{width:84px;height:84px;border-radius:50%;background:var(--brand-2);display:inline-flex;align-items:center;justify-content:center;font-size:34px;font-weight:700;color:#fff;margin-bottom:14px}
.linklist{max-width:560px;margin:20px auto;padding:0 16px}
.linklist a.linkitem{display:block;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:12px;color:var(--txt);font-weight:600;transition:.15s}
.linklist a.linkitem:hover{border-color:var(--brand);text-decoration:none;transform:translateY(-1px)}
.flex-between{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.actions{display:flex;gap:6px;flex-wrap:wrap}
details.inline-edit{margin-top:0}
details.inline-edit summary{cursor:pointer;list-style:none}
details.inline-edit[open] .editbox{margin-top:10px}

/* ===== Fonctionnalités avancées (v1.1) ===== */
/* blocs repliables dans le formulaire de création */
details.block{border:1px solid var(--line);border-radius:10px;margin-bottom:14px;background:var(--bg)}
details.block summary{cursor:pointer;list-style:none;padding:10px 14px;font-size:13px;font-weight:600;color:var(--txt)}
details.block summary::-webkit-details-marker{display:none}
details.block summary::before{content:"▸ ";color:var(--muted)}
details.block[open] summary::before{content:"▾ "}
details.block .block-body{padding:4px 14px 14px}

/* barre de recherche + chips de tags */
.searchbar{display:flex;gap:8px;align-items:center}
.searchbar input{width:200px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.chip{display:inline-block;padding:5px 12px;border-radius:20px;border:1px solid var(--line);color:var(--muted);font-size:13px}
.chip:hover{background:var(--bg-3);text-decoration:none;color:var(--txt)}
.chip.on{background:var(--brand-2);border-color:var(--brand-2);color:#fff}

/* courbe SVG */
.linechart{width:100%;height:auto;display:block;margin-top:8px}
.lc-axis{stroke:var(--line);stroke-width:1}
.lc-lbl{fill:var(--muted);font-size:10px;font-family:ui-monospace,monospace}
.lc-area{fill:rgba(31,182,178,.15);stroke:none}
.lc-line{fill:none;stroke:var(--brand);stroke-width:2;stroke-linejoin:round;stroke-linecap:round}
.lc-dot{fill:var(--brand)}

/* barres horizontales (devices, pays) */
.hbars{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.hbar{display:grid;grid-template-columns:90px 1fr 40px;align-items:center;gap:10px;font-size:13px}
.hbar-l{color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hbar-track{background:var(--bg-3);border-radius:6px;height:10px;overflow:hidden}
.hbar-fill{display:block;height:100%;background:var(--brand-2);border-radius:6px}
.hbar-fill.green{background:var(--green)}
.hbar-v{text-align:right;color:var(--txt)}

/* ===== Modal ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:flex-start;justify-content:center;padding:60px 16px;z-index:50;overflow:auto}
.modal-overlay[hidden]{display:none}
.modal{width:100%;max-width:540px;box-shadow:var(--shadow)}

/* ===== Page profil Bento (public) ===== */
.bento-page{max-width:760px;margin:0 auto;padding:40px 18px 60px}
.bento-hero{text-align:center;margin-bottom:26px}
.bento-avatar{width:92px;height:92px;border-radius:50%;object-fit:cover;display:inline-block;border:2px solid var(--accent)}
.bento-avatar.initial{display:inline-flex;align-items:center;justify-content:center;font-size:38px;font-weight:700;color:#fff;background:var(--accent)}
.bento-bio{max-width:480px;margin:10px auto 0;color:var(--txt)}
.bento-foot{text-align:center;margin:36px 0 0;font-size:12px;color:var(--muted)}
.bento{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;grid-auto-rows:120px;grid-auto-flow:dense}
.bento .b{grid-column:span 1;grid-row:span 1;border-radius:16px;border:1px solid var(--line);background:var(--bg-2);padding:16px;overflow:hidden;position:relative;text-decoration:none;color:var(--txt);transition:.15s;display:flex;flex-direction:column}
.bento a.b:hover{border-color:var(--accent);transform:translateY(-2px);text-decoration:none}
.bento .b.w{grid-column:span 2}
.bento .b.t{grid-row:span 2}
.bento .b.l{grid-column:span 2;grid-row:span 2}
.bento .b-title{font-weight:600;font-size:15px}
.bento .b-sub{color:var(--muted);font-size:13px;margin-top:4px}
.bento .b-link-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.bento .b-arrow{color:var(--accent);font-size:18px}
.bento .b-text{justify-content:center;background:var(--bg-3)}
.bento .b-image{padding:0;background-size:cover;background-position:center;justify-content:flex-end}
.bento .b-image .b-caption{background:linear-gradient(transparent,rgba(0,0,0,.7));color:#fff;padding:10px 12px;font-size:13px;font-weight:600}
.bento .b-social{align-items:flex-start}
.bento .b-badge{width:36px;height:36px;border-radius:10px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:8px}
@media(max-width:640px){.bento{grid-template-columns:repeat(2,1fr)}.bento .b.w,.bento .b.l{grid-column:span 2}}

/* ===== Éditeur Bento (portail) ===== */
.block-list{list-style:none;padding:0;margin:12px 0 0;display:flex;flex-direction:column;gap:10px}
.block-row{padding:12px 14px}
.block-row.dragging{opacity:.4}
.block-row.over{border-color:var(--brand)}
.brow-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.brow-head .drag{cursor:grab;color:var(--muted);font-size:18px}
.editbox{margin-top:12px;border-top:1px solid var(--line);padding-top:12px}

/* ===== Éditeur Bento visuel ===== */
.bento-page.editor{background:var(--bg-2);border:1px solid var(--line);border-radius:16px;margin-top:16px;padding:28px 20px}
.bento-empty{text-align:center;padding:40px;border:1px dashed var(--line);border-radius:14px}
.bento.editable .b{cursor:default;position:relative}
.bento.editable .b[draggable]{cursor:grab}
.bento.editable .b.dragging{opacity:.4}
.bento.editable .b:hover{border-color:var(--accent)}
.bento.editable .b.is-hidden{opacity:.45;border-style:dashed}
.bento .b-content{display:flex;flex-direction:column;height:100%;min-height:0}
.b-ctrls{position:absolute;top:6px;right:6px;display:flex;gap:4px;opacity:0;transition:.12s}
.bento.editable .b:hover .b-ctrls{opacity:1}
.b-ctrl{width:26px;height:26px;border:none;border-radius:7px;background:rgba(0,0,0,.55);color:#fff;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}
.b-ctrl:hover{background:rgba(0,0,0,.8)}
.b-ctrl.drag{cursor:grab}
.b-sizes{position:absolute;bottom:6px;left:6px;display:flex;gap:3px;opacity:0;transition:.12s}
.bento.editable .b:hover .b-sizes{opacity:1}
.b-sz{width:24px;height:22px;border:1px solid var(--line);background:rgba(0,0,0,.55);color:#fff;border-radius:6px;font-size:11px;cursor:pointer;padding:0}
.b-sz.on{background:var(--accent);border-color:var(--accent)}

/* ===== Bento v2 : favicon, fond, thème clair, picker ===== */
/* page pleine largeur pour que le fond/thème couvre tout l'écran (public) */
.bento-page{max-width:none;width:100%;min-height:100vh}
.bento-page .bento-hero,.bento-page .bento,.bento-page .linklist{max-width:760px;margin-left:auto;margin-right:auto}
.bento-page.editor{min-height:0}

/* thème clair (scopé à la page profil) */
.bento-page[data-theme="light"]{--bg-2:#ffffff;--bg-3:#eef1f5;--line:#e2e6ea;--txt:#161b22;--muted:#5a6573;background:var(--page-bg,#f5f7fa);color:#161b22}
.bento-page[data-theme="light"] .bento-foot{color:#5a6573}

/* favicon dans les cartes */
.b-favicon{width:22px;height:22px;border-radius:6px;flex:0 0 auto;object-fit:cover}
.b-link .b-link-top{display:flex;align-items:center;gap:8px}
.b-social .b-favicon{width:34px;height:34px;border-radius:9px;margin-bottom:8px}

/* carte avec image de fond : lisibilité du texte */
.b.has-bg{background-size:cover;background-position:center}
.b.has-bg .b-content{height:100%;justify-content:flex-end;background:linear-gradient(transparent,rgba(0,0,0,.6));margin:-16px;padding:16px;border-radius:16px}
.b.has-bg .b-title,.b.has-bg .b-sub{color:#fff}

/* sélecteur de taille (4×4) sur la carte */
.b-picker{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:rgba(8,12,18,.82);border-radius:16px;opacity:0;transform:scale(.96);pointer-events:none;transition:opacity .14s ease,transform .14s ease;z-index:3}
.b.picking .b-picker{opacity:1;transform:scale(1);pointer-events:auto}
.b-picker-grid{display:grid;grid-template-columns:repeat(4,16px);grid-template-rows:repeat(4,16px);gap:3px}
.b-cell{width:16px;height:16px;border:1px solid rgba(255,255,255,.3);border-radius:3px;background:transparent;cursor:pointer;padding:0;transition:.1s}
.b-cell:hover{background:rgba(255,255,255,.25)}
.b-cell.on{background:var(--accent,#4f8cff);border-color:var(--accent,#4f8cff)}
.b-picker-lbl{font-size:11px;color:#cfd6e0}

/* ===== Uploader ===== */
.uploader{display:flex;align-items:center;gap:10px;margin-top:6px}
.img-prev{max-width:100%;max-height:140px;border-radius:10px;margin-top:8px;border:1px solid var(--line)}

/* ===== Poignée de redimensionnement souris ===== */
.b-resize{position:absolute;right:3px;bottom:3px;width:16px;height:16px;cursor:nwse-resize;opacity:0;transition:opacity .12s;z-index:4;
  background:linear-gradient(135deg,transparent 50%,var(--accent,#4f8cff) 50%);border-bottom-right-radius:14px}
.bento.editable .b:hover .b-resize{opacity:.9}
.bento.editable .b.resizing{outline:2px solid var(--accent,#4f8cff);outline-offset:1px}
.bento.editable .b.resizing .b-resize{opacity:1}
.secondary-url{margin-top:8px;font-size:13px;opacity:.85}

/* image affichée sous le texte d'une carte */
.b-img-below{width:100%;border-radius:10px;margin-top:10px;object-fit:cover;flex:1 1 auto;min-height:0;max-height:100%}

/* favicon à côté du titre : le titre occupe l'espace, la flèche reste à droite */
.b-link-top .b-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.b-link-top{width:100%}

/* ===== Thème clair de l'application ===== */
html[data-theme="light"]{
  --bg:#eef1f6; --bg-2:#ffffff; --bg-3:#f3f6fa; --line:#e2e8f0;
  --txt:#16202E; --muted:#5f7186; --brand:#109490; --brand-2:#0C7E7C;
  --green:#0f9d6a; --red:#d4583a;
  --shadow:0 18px 44px -26px rgba(20,40,70,.28);
}

/* ===== Logo & titres ===== */
.logo-img{height:26px;width:auto;border-radius:6px;display:inline-block}
.logo-img.sm{height:22px}
.logo .logo-txt{font-weight:700}
.topbar-title{font-weight:600}

/* ===== Header à icônes ===== */
.topbar{gap:12px}
.topbar .who{margin-right:auto}
.topbar-actions{display:flex;gap:8px;align-items:center}
.topbar-center{display:none}
.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:transparent;color:var(--txt);font-size:16px;line-height:1;cursor:pointer;text-decoration:none}
.iconbtn:hover{background:var(--bg-3);text-decoration:none}
.hamburger{display:none}

/* ===== Menu mobile coulissant (droite → gauche) ===== */
.drawer-overlay{display:none}
@media(max-width:760px){
  .sidebar{position:fixed;top:0;right:0;left:auto;height:100vh;width:260px;transform:translateX(100%);transition:transform .25s ease;z-index:60;border-left:1px solid var(--line);border-right:none}
  .shell.drawer-open .sidebar{transform:translateX(0)}
  .drawer-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:55;opacity:0;visibility:hidden;transition:opacity .2s}
  .shell.drawer-open .drawer-overlay{opacity:1;visibility:visible}
  .hamburger{display:inline-flex}
  .topbar .who{display:none}
  .topbar-center{display:flex;align-items:center;gap:8px;margin:0 auto}
  .content{padding:18px}
}

/* ===== Impression de la page profil ===== */
.print-btn{position:fixed;top:14px;right:14px;z-index:10}
@media print{
  .print-btn{display:none}
  .bento-page{min-height:auto}
  .b{break-inside:avoid}
}

/* ===== Onglets de période (stats) ===== */
.period-tabs{display:inline-flex;gap:6px;flex-wrap:wrap}
.period-tab{padding:5px 12px;border-radius:8px;border:1px solid var(--line);color:var(--muted);text-decoration:none;font-size:13px;line-height:1.6}
.period-tab:hover{background:var(--bg-3);text-decoration:none}
.period-tab.active{background:var(--brand-2);border-color:var(--brand-2);color:#fff}

/* ===== Topbar backoffice/portail (layout EoKin) ===== */
.admin-topbar{position:sticky;top:0;z-index:50;background:var(--bg-2);border-bottom:1px solid var(--line);backdrop-filter:blur(8px)}
.admin-topbar__inner{max-width:1180px;margin:0 auto;padding:11px 22px;display:flex;align-items:center;gap:18px}
.admin-brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:18px;color:var(--txt)!important;text-decoration:none!important;flex-shrink:0}
.admin-brand .dot{width:18px;height:18px;border-radius:6px;background:var(--brand-2);display:inline-block}
.admin-brand img{height:24px;border-radius:6px}
.admin-nav{display:flex;gap:4px;flex-wrap:wrap;flex:1}
.admin-nav a{color:var(--muted)!important;text-decoration:none!important;padding:7px 12px;border-radius:999px;font-weight:600;font-size:14px}
.admin-nav a:hover{color:var(--txt)!important;background:var(--bg-3)}
.admin-nav a.active{color:#fff!important;background:var(--brand-2)}
.admin-topbar__right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.admin-topbar__right .who{font-size:13px;color:var(--muted)}
.admin-main{padding:26px 22px 60px}
.admin-container{max-width:1180px;margin:0 auto;width:100%}
@media(max-width:820px){
  .admin-topbar__inner{flex-wrap:wrap}
  .admin-nav{order:3;width:100%}
  .admin-topbar__right .who{display:none}
}

/* ===== Sélecteur de langue (topbar portail/backoffice) ===== */
.admin-topbar .lang-switch{position:relative}
.admin-topbar .lang-switch>summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid rgba(120,120,120,.28);border-radius:999px;background:transparent;font-size:13px;font-weight:600;color:inherit;user-select:none}
.admin-topbar .lang-switch>summary::-webkit-details-marker{display:none}
.admin-topbar .lang-switch>summary::marker{content:''}
.admin-topbar .lang-flag{font-size:15px;line-height:1}
.admin-topbar .lang-code{font-size:12px;letter-spacing:.02em}
.admin-topbar .lang-menu{position:absolute;right:0;top:calc(100% + 8px);background:#fff;color:#1b1a17;border:1px solid #e2dcd2;border-radius:12px;box-shadow:0 18px 40px -22px rgba(0,0,0,.45);padding:6px;min-width:182px;z-index:120;display:flex;flex-direction:column;gap:2px}
.admin-topbar .lang-menu a{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;color:#1b1a17!important;text-decoration:none!important;font-size:14px}
.admin-topbar .lang-menu a:hover{background:#f1ede4}
.admin-topbar .lang-menu a.is-cur{background:rgba(47,59,208,.08);color:#2f3bd0!important}
