/* ====================================
   ENT MDL — Style global
   Palette orange (#E8541C) + bleu nuit (#13315C)
   ==================================== */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..900;1,9..144,300..900&family=Outfit:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  --paper:#F4F0E8; --paper-2:#E8E4D9; --cream:#FBF8F1;
  --ink:#13315C; --ink-soft:#2E4D6D; --ink-mute:#6B7585;
  --rule:#CFC9BB;
  --terra:#E8541C; --terra-deep:#B83F12;
  --ochre:#FF9D52;
  --navy:#13315C; --navy-deep:#0B2240;
  --sky:#4F87B9; --sky-pale:#E2EAF3;
  --forest:#4D7A4D; --plum:#6B3E5E;
  --shadow: 0 1px 0 rgba(19,49,92,.04), 0 2px 6px rgba(19,49,92,.06), 0 20px 40px -24px rgba(19,49,92,.18);
  --shadow-lg: 0 10px 30px -12px rgba(19,49,92,.22), 0 30px 80px -30px rgba(19,49,92,.28);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Outfit', system-ui, sans-serif;
  background:var(--paper); color:var(--ink);
  font-size:15px; line-height:1.55;
  background-image:
    radial-gradient(circle at 15% 10%, rgba(232,84,28,.06), transparent 40%),
    radial-gradient(circle at 85% 80%, rgba(19,49,92,.05), transparent 45%);
}
.serif{font-family:'Fraunces',serif}
.mono{font-family:'JetBrains Mono',monospace}

/* ===== AUTH ===== */
.auth-screen{display:grid;grid-template-columns:1.05fr .95fr;min-height:100vh}
@media (max-width:900px){.auth-screen{grid-template-columns:1fr}.auth-brand{display:none}}

.auth-brand{
  position:relative;padding:48px 56px;
  background:radial-gradient(ellipse at 25% 20%,rgba(255,157,82,.18),transparent 50%),radial-gradient(ellipse at 80% 90%,rgba(232,84,28,.12),transparent 45%),linear-gradient(140deg,#1B3A5F 0%,#13315C 55%,#0B2240 100%);
  color:#FBF8F1;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;
}
.brand-top{display:flex;align-items:center;gap:16px}
.brand-mark{width:54px;height:54px;flex-shrink:0;display:block}
.brand-mark svg{width:100%;height:100%;display:block;filter:drop-shadow(0 4px 14px rgba(232,84,28,.28))}
.brand-mark.mob{width:38px;height:38px}
.brand-block{display:flex;flex-direction:column;gap:5px}
.brand-name{font-family:'Fraunces',serif;font-weight:500;font-size:26px;letter-spacing:.06em;line-height:1}
.brand-name em{font-style:italic;font-weight:400;color:#FF9D52;margin-right:1px}
.brand-sub{font-family:'JetBrains Mono',monospace;font-size:9.5px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:rgba(251,248,241,.55);display:flex;align-items:center;gap:8px}
.brand-sub::before{content:"";width:14px;height:1px;background:linear-gradient(90deg,transparent,#FF9D52 50%,transparent)}

.auth-hero{max-width:520px}
.auth-hero .eyebrow{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#FF9D52;margin-bottom:24px}
.auth-hero h1{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(40px,5vw,64px);line-height:1.05;letter-spacing:-.02em;margin-bottom:22px}
.auth-hero h1 em{font-style:italic;color:#FF9D52;font-weight:400}
.auth-hero p{color:rgba(251,248,241,.75);font-size:16px;max-width:460px}
.auth-footline{display:flex;gap:32px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(251,248,241,.5);flex-wrap:wrap}
.auth-footline span b{color:#FBF8F1;font-weight:500;display:block;margin-top:2px;font-family:'Outfit';letter-spacing:0;text-transform:none;font-size:13px}

.auth-panel{padding:56px 64px;display:flex;flex-direction:column;justify-content:center}
@media (max-width:900px){.auth-panel{padding:40px 28px}}
.auth-form{max-width:420px;width:100%;margin:auto}
.auth-title{font-family:'Fraunces',serif;font-weight:400;font-size:34px;line-height:1.1;margin-bottom:6px}
.auth-title em{font-style:italic;color:var(--terra)}
.auth-sub{color:var(--ink-mute);font-size:14px;margin-bottom:28px}

.field{margin-bottom:18px}
.field label{display:block;font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:8px;font-family:'JetBrains Mono',monospace}
.field input,.field select,.field textarea{
  width:100%;padding:12px 14px;background:var(--cream);border:1px solid var(--rule);border-radius:8px;
  font-family:inherit;font-size:15px;color:var(--ink);transition:all .2s
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--terra);background:#fff;box-shadow:0 0 0 4px rgba(232,84,28,.12)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 22px;border-radius:999px;border:0;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s;text-decoration:none;color:inherit}
.btn-primary{background:var(--ink);color:var(--cream);box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--terra);transform:translateY(-1px)}
.btn-primary.full{width:100%}
.btn-ghost{background:transparent;color:var(--ink-soft);padding:8px 14px}
.btn-ghost:hover{color:var(--terra)}
.btn-sm{padding:8px 14px;font-size:13px}
.btn-outline{background:transparent;color:var(--ink);border:1px solid var(--rule)}
.btn-outline:hover{border-color:var(--ink);background:var(--cream)}
.btn-terra{background:var(--terra);color:#fff}
.btn-terra:hover{background:var(--terra-deep)}
.btn-icon{padding:8px;width:36px;height:36px;border-radius:8px;border:1px solid var(--rule);background:var(--cream);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-soft)}
.btn-icon:hover{border-color:var(--ink);color:var(--ink)}
.btn-icon svg{width:16px;height:16px;stroke-width:1.8}

.alert{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:16px;background:#FCE4D5;color:var(--terra-deep);border:1px solid #F4BD9B;display:none}
.alert.show{display:block}
.alert.success{background:#DDE9F4;color:#13315C;border-color:#A6C0DA}
.flash{padding:12px 18px;border-radius:8px;margin-bottom:18px;font-size:14px;background:#DDE9F4;color:#13315C;border:1px solid #A6C0DA}
.flash.error{background:#FCE4D5;color:var(--terra-deep);border-color:#F4BD9B}

/* ===== APP SHELL ===== */
.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
@media (max-width:900px){.app-shell{grid-template-columns:1fr}}

.sidebar{background:var(--ink);color:var(--cream);padding:28px 22px;display:flex;flex-direction:column;gap:24px;position:sticky;top:0;height:100vh;overflow-y:auto}
@media (max-width:900px){
  .sidebar{position:fixed;top:0;bottom:0;left:-300px;width:280px;z-index:90;transition:left .3s cubic-bezier(.2,.8,.2,1)}
  .sidebar.open{left:0;box-shadow:var(--shadow-lg)}
}

.sidebar-brand{display:flex;align-items:center;gap:14px;padding-bottom:22px;border-bottom:1px solid rgba(251,248,241,.1)}
.sidebar .brand-mark{width:46px;height:46px}
.nav-section{display:flex;flex-direction:column;gap:2px}
.nav-label{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:rgba(251,248,241,.4);margin-bottom:10px;padding:0 10px}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;color:rgba(251,248,241,.75);cursor:pointer;font-size:14px;background:transparent;text-decoration:none}
.nav-item:hover{background:rgba(251,248,241,.06);color:var(--cream)}
.nav-item.active{background:rgba(255,157,82,.18);color:var(--ochre)}
.nav-item svg{width:18px;height:18px;flex-shrink:0}
.nav-item .count{margin-left:auto;background:rgba(251,248,241,.1);padding:2px 8px;border-radius:999px;font-size:11px;font-family:'JetBrains Mono',monospace}
.nav-item.active .count{background:var(--terra);color:var(--cream)}
.sidebar-user{margin-top:auto;padding-top:20px;border-top:1px solid rgba(251,248,241,.1)}
.user-card{display:flex;align-items:center;gap:12px;padding:10px;border-radius:10px;background:rgba(251,248,241,.04)}
.user-name{font-size:14px;font-weight:500;color:var(--cream);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:11px;color:rgba(251,248,241,.5);font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.15em}

.avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:500;font-size:16px;background:linear-gradient(135deg,var(--ochre),var(--terra));color:#fff;flex-shrink:0;overflow:hidden;position:relative}
.avatar img{width:100%;height:100%;object-fit:cover;display:block}
.avatar.lg{width:64px;height:64px;font-size:26px}
.avatar.xl{width:96px;height:96px;font-size:38px}
.avatar.sm{width:28px;height:28px;font-size:12px}

.main{padding:36px 48px 80px;max-width:1400px;width:100%}
@media (max-width:900px){.main{padding:0 18px 80px;padding-top:74px}}

/* ===== Mobile topbar ===== */
.mobile-topbar{display:none}
@media (max-width:900px){
  .mobile-topbar{display:flex;position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(244,240,232,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--rule);padding:10px 14px;align-items:center;gap:12px}
}
.menu-btn{width:42px;height:42px;border-radius:10px;background:var(--navy);color:var(--cream);border:0;display:flex;align-items:center;justify-content:center;cursor:pointer}
.mobile-brand{font-family:'Fraunces',serif;font-size:20px;font-weight:500;letter-spacing:.06em;line-height:1}
.mobile-brand em{font-style:italic;color:var(--terra)}
.mobile-brand-sub{font-family:'JetBrains Mono',monospace;font-size:8.5px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-mute);margin-top:3px}

.sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(19,49,92,.5);z-index:85}
.sidebar-backdrop.show{display:block}

/* ===== Topbar (page header) ===== */
.topbar{display:flex;align-items:center;justify-content:space-between;padding-bottom:28px;margin-bottom:32px;border-bottom:1px solid var(--rule);gap:20px;flex-wrap:wrap}
.topbar-left{display:flex;align-items:baseline;gap:18px;flex-wrap:wrap}
.breadcrumb{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute)}
.topbar h1{font-family:'Fraunces',serif;font-weight:400;font-size:34px;letter-spacing:-.01em;line-height:1}
.topbar h1 em{font-style:italic;color:var(--terra)}
.topbar-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.date-pill{padding:8px 14px;background:var(--cream);border:1px solid var(--rule);border-radius:999px;font-size:13px;display:flex;align-items:center;gap:8px}
.date-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--terra);box-shadow:0 0 0 3px rgba(232,84,28,.2)}
@media (max-width:600px){.date-pill{display:none}.topbar h1{font-size:26px}}

.card{background:var(--cream);border:1px solid var(--rule);border-radius:14px;padding:22px}
.card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px;gap:10px}
.card-title{font-family:'Fraunces',serif;font-weight:500;font-size:19px}
.card-title em{font-style:italic;color:var(--terra);font-weight:400}
.card-meta{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute)}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:1100px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:700px){.grid-2,.grid-3{grid-template-columns:1fr}}

.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:40px 0 18px;gap:16px}
.section-head h2{font-family:'Fraunces',serif;font-weight:400;font-size:26px}
.section-head h2 em{font-style:italic;color:var(--terra)}
.section-head .rule{flex:1;height:1px;background:var(--rule);margin:0 16px}

.empty{padding:32px;text-align:center;color:var(--ink-mute);font-size:14px;border:1px dashed var(--rule);border-radius:12px}
.empty em{font-family:'Fraunces',serif;font-style:italic;font-size:18px;color:var(--ink-soft);display:block;margin-bottom:6px}

/* ===== HERO ===== */
.hero-greet{padding:34px;border-radius:18px;background:radial-gradient(ellipse at 80% 20%,rgba(255,157,82,.28),transparent 50%),linear-gradient(135deg,#1B4378 0%,#13315C 55%,#0B2240 100%);color:#FBF8F1;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;min-height:220px;margin-bottom:22px}
.hero-greet .kicker{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#FF9D52;margin-bottom:14px}
.hero-greet h2{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(30px,4vw,42px);line-height:1.08;letter-spacing:-.02em}
.hero-greet h2 em{font-style:italic;color:#FF9D52;font-weight:400}
.hero-greet p{color:rgba(251,248,241,.7);max-width:480px;margin-top:14px}
.hero-stats{display:flex;gap:28px;margin-top:22px;flex-wrap:wrap}
.hero-stat{border-left:2px solid #FF9D52;padding-left:12px}
.hero-stat b{display:block;font-family:'Fraunces',serif;font-size:28px;font-weight:400}
.hero-stat span{font-size:11px;color:rgba(251,248,241,.6);font-family:'JetBrains Mono',monospace;letter-spacing:.18em;text-transform:uppercase}

/* ===== TASKS ===== */
.task-list{display:flex;flex-direction:column;gap:8px}
.task{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--paper-2);border-radius:10px}
.task.done{opacity:.5}
.task.done .task-title{text-decoration:line-through}
.task-check{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--ink-mute);cursor:pointer;flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;background:var(--cream)}
.task.done .task-check{background:var(--terra);border-color:var(--terra)}
.task.done .task-check::after{content:"✓";color:#fff;font-weight:bold}
.task-body{flex:1;min-width:0}
.task-title{font-size:14px;font-weight:500}
.task-meta{font-size:12px;color:var(--ink-mute);margin-top:2px;display:flex;gap:10px;flex-wrap:wrap}
.tag{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:2px 8px;border-radius:999px;background:var(--cream);border:1px solid var(--rule)}
.tag.terra{background:#FCE4D5;border-color:#F4BD9B;color:var(--terra-deep)}
.tag.sky{background:#DDE9F4;border-color:#A6C0DA;color:#13315C}
.tag.ochre{background:#FFE7CE;border-color:#FFC891;color:#A14908}

/* ===== AGENDA MULTI-COL ===== */
.agenda-layout{display:grid;grid-template-columns:240px 1fr;gap:18px;align-items:flex-start}
@media (max-width:1100px){.agenda-layout{grid-template-columns:200px 1fr}}
@media (max-width:900px){.agenda-layout{grid-template-columns:1fr}.cal-sidebar{order:2}}
.cal-sidebar{display:flex;flex-direction:column;gap:18px;background:var(--cream);border:1px solid var(--rule);border-radius:14px;padding:16px}
.cal-side-title{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:8px}
.cal-toggle{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--ink-soft)}
.cal-toggle:hover{background:var(--paper-2)}
.cal-toggle input{display:none}
.cal-toggle .cal-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0;opacity:.3}
.cal-toggle.on{color:var(--ink)}
.cal-toggle.on .cal-dot{opacity:1}
.cal-week-grid{display:grid;grid-template-columns:60px repeat(4,1fr);background:var(--cream);border:1px solid var(--rule);border-radius:14px;overflow:hidden}
.cal-hour-label{height:48px;display:flex;align-items:flex-start;justify-content:flex-end;padding:2px 8px 0 0;font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--ink-mute)}
.cal-day-col{border-right:1px solid var(--rule);min-width:0}
.cal-day-col:last-child{border-right:0}
.cal-day-head{padding:12px;text-align:center;border-bottom:1px solid var(--rule);background:var(--paper-2)}
.cal-day-head.today{background:linear-gradient(180deg,rgba(232,84,28,.12),transparent);position:relative}
.cal-day-head.today::after{content:"";position:absolute;left:50%;bottom:-1px;transform:translateX(-50%);width:30px;height:2px;background:var(--terra);border-radius:1px}
.cal-day-name{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:2px}
.cal-day-num{font-family:'Fraunces',serif;font-size:22px;font-weight:500}
.cal-day-body{position:relative}
.cal-hour-line{position:absolute;left:0;right:0;height:1px;background:var(--rule);opacity:.5;pointer-events:none}
.cal-event{position:absolute;left:4px;right:4px;border-radius:6px;padding:4px 6px;color:#fff;font-size:11px;line-height:1.25;cursor:pointer;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,.15);text-decoration:none}
.cal-event:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(0,0,0,.2)}
.cal-event-time{font-family:'JetBrains Mono',monospace;font-size:9px;opacity:.85}
.cal-event-title{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-nav-row{display:flex;align-items:center;gap:8px;margin-bottom:14px}
.cal-nav-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--rule);background:var(--cream);cursor:pointer;color:var(--ink-soft);font-size:14px}
.cal-week-label{font-family:'Fraunces',serif;font-size:18px;font-weight:500;margin-left:8px;text-transform:capitalize}

/* ===== NEWS ===== */
.news-feed{display:flex;flex-direction:column;gap:14px;max-width:760px}
.news-card{background:var(--cream);border:1px solid var(--rule);border-radius:14px;padding:22px}
.news-card.pinned{border-color:var(--terra);position:relative}
.news-card.pinned::before{content:"épinglé";position:absolute;top:14px;right:18px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--terra);background:rgba(232,84,28,.1);padding:2px 8px;border-radius:999px}
.news-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.news-author{font-size:14px;font-weight:500}
.news-date{font-size:12px;color:var(--ink-mute);font-family:'JetBrains Mono',monospace}
.news-title{font-family:'Fraunces',serif;font-size:20px;font-weight:500;line-height:1.25;margin-bottom:8px}
.news-body{font-size:14px;line-height:1.6;color:var(--ink-soft);margin-bottom:14px;white-space:pre-wrap}
.news-actions{display:flex;gap:14px;padding-top:12px;border-top:1px dashed var(--rule);font-size:13px;color:var(--ink-mute)}
.news-action{display:inline-flex;align-items:center;gap:6px;cursor:pointer;background:transparent;border:0;color:inherit;font-family:inherit;font-size:13px;padding:0;text-decoration:none}
.news-action:hover{color:var(--terra)}
.news-action.liked{color:var(--terra)}

/* ===== MAIL ===== */
.mail-layout{display:grid;grid-template-columns:280px 1fr;gap:0;height:calc(100vh - 220px);min-height:500px;background:var(--cream);border:1px solid var(--rule);border-radius:14px;overflow:hidden}
@media (max-width:700px){.mail-layout{grid-template-columns:1fr}}
.mail-list-col{border-right:1px solid var(--rule);overflow-y:auto}
.mail-item{padding:14px 18px;border-bottom:1px solid var(--rule);cursor:pointer;display:block;text-decoration:none;color:inherit}
.mail-item:hover{background:var(--paper-2)}
.mail-item.active{background:var(--paper-2);border-left:3px solid var(--terra);padding-left:15px}
.mail-item.unread{font-weight:600}
.mail-from{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mail-time{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-mute);float:right}
.mail-subject{font-size:13px;margin-top:2px;color:var(--ink)}
.mail-preview{font-size:12px;color:var(--ink-mute);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mail-view-col{display:flex;flex-direction:column;overflow:hidden}
.mail-view-header{padding:22px 26px;border-bottom:1px solid var(--rule)}
.mail-view-subject{font-family:'Fraunces',serif;font-size:24px;font-weight:400;line-height:1.2;margin-bottom:14px}
.mail-view-body{padding:26px;overflow-y:auto;flex:1;font-size:15px;line-height:1.7;color:var(--ink-soft);white-space:pre-wrap}
.mail-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--ink-mute);text-align:center;padding:40px}

/* ===== FORUM ===== */
.forum-list{display:flex;flex-direction:column;gap:12px}
.forum-thread{background:var(--cream);border:1px solid var(--rule);border-radius:12px;padding:18px;cursor:pointer;display:block;text-decoration:none;color:inherit}
.forum-thread:hover{border-color:var(--ink-mute);box-shadow:var(--shadow)}
.forum-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.forum-cat{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--terra);background:rgba(232,84,28,.1);padding:3px 10px;border-radius:999px}
.forum-author{font-size:13px;color:var(--ink-soft)}
.forum-date{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-mute);margin-left:auto}
.forum-title{font-family:'Fraunces',serif;font-size:18px;font-weight:500;margin-bottom:6px}
.forum-snippet{font-size:13px;color:var(--ink-mute);line-height:1.5}
.forum-detail{background:var(--cream);border:1px solid var(--rule);border-radius:14px;padding:26px}
.forum-replies{margin-top:24px;display:flex;flex-direction:column;gap:14px}
.forum-reply{padding:14px;background:var(--paper-2);border-radius:10px;display:flex;gap:12px}
.forum-reply-body{flex:1}
.forum-reply-head{display:flex;justify-content:space-between;font-size:12px;color:var(--ink-mute);margin-bottom:6px}
.forum-reply-text{font-size:14px;line-height:1.55;white-space:pre-wrap}

/* ===== POLLS ===== */
.poll-card{background:var(--cream);border:1px solid var(--rule);border-radius:14px;padding:22px;margin-bottom:14px}
.poll-question{font-family:'Fraunces',serif;font-size:20px;font-weight:500;margin-bottom:6px}
.poll-meta{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-mute);letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px}
.poll-options{display:flex;flex-direction:column;gap:10px}
.poll-option{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--rule);border-radius:10px;cursor:pointer;background:var(--paper-2);position:relative;overflow:hidden;text-align:left;font-family:inherit;color:inherit;font-size:14px}
.poll-option:hover{border-color:var(--terra)}
.poll-option.voted{border-color:var(--terra);background:rgba(232,84,28,.08)}
.poll-bar{position:absolute;top:0;left:0;bottom:0;background:rgba(232,84,28,.12);transition:width .5s;pointer-events:none}
.poll-label{flex:1;position:relative;z-index:1}
.poll-pct{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:600;color:var(--terra);position:relative;z-index:1}

/* ===== FILES ===== */
.share-folders{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.share-folder-chip{padding:6px 14px;border-radius:999px;border:1px solid var(--rule);background:var(--cream);font-size:13px;cursor:pointer;color:var(--ink-soft);text-decoration:none}
.share-folder-chip.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.doc-list{display:flex;flex-direction:column;gap:6px}
.doc{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px}
.doc:hover{background:var(--paper-2)}
.doc-icon{width:38px;height:46px;border-radius:4px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:6px;font-family:'JetBrains Mono',monospace;font-size:9px;font-weight:600;color:#fff;background:var(--ink)}
.doc-icon.pdf{background:var(--terra)}
.doc-icon.doc{background:var(--sky)}
.doc-icon.xls{background:var(--forest)}
.doc-icon.ppt{background:var(--plum)}
.doc-icon.img{background:var(--ochre)}
.doc-name{font-size:14px;font-weight:500}
.doc-meta{font-size:12px;color:var(--ink-mute)}
.doc-body{flex:1;min-width:0}

/* ===== CONTACTS ===== */
.contacts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.contact-card{padding:20px;background:var(--cream);border:1px solid var(--rule);border-radius:14px;text-decoration:none;color:inherit;display:block}
.contact-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.contact-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.contact-name{font-family:'Fraunces',serif;font-size:18px;font-weight:500}
.contact-role{font-size:12px;color:var(--ink-mute);margin-top:2px}
.contact-detail{font-size:13px;color:var(--ink-soft);padding:3px 0}

/* ===== PROFILE ===== */
.photo-upload{display:flex;align-items:center;gap:18px;padding:16px;background:var(--paper-2);border-radius:14px;border:1px dashed var(--rule);margin-bottom:24px}

.modal-backdrop{position:fixed;inset:0;background:rgba(19,49,92,.4);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}
.modal-backdrop.show{display:flex}
.modal{background:var(--cream);border-radius:16px;max-width:500px;width:100%;padding:28px;max-height:90vh;overflow-y:auto}
.modal h3{font-family:'Fraunces',serif;font-weight:500;font-size:22px;margin-bottom:16px}

.lightbox{position:fixed;inset:0;background:rgba(19,49,92,.9);display:none;align-items:center;justify-content:center;z-index:300;padding:40px;cursor:zoom-out}
.lightbox.show{display:flex}
.lightbox img{max-width:100%;max-height:100%;border-radius:10px}

.two-col-form{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:600px){.two-col-form{grid-template-columns:1fr}}

/* ===== FORMS INLINE ===== */
.add-inline{display:flex;gap:8px;margin-top:12px;padding:10px;border:1px dashed var(--rule);border-radius:10px}
.add-inline input{flex:1;border:0;background:transparent;font-family:inherit;font-size:14px;outline:none}
.add-inline button{padding:6px 14px;border:0;background:var(--ink);color:var(--cream);border-radius:999px;cursor:pointer;font-family:inherit;font-size:13px}

/* ===== SCANS — Scan de courrier papier ===== */
.scan-toolbar{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap;padding:14px 18px;background:var(--cream);border:1px solid var(--rule);border-radius:12px}
.scan-breadcrumb{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px}
.scan-breadcrumb a{color:var(--ink-soft);text-decoration:none;display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;transition:background .15s}
.scan-breadcrumb a:hover{background:var(--paper-2);color:var(--ink)}
.scan-breadcrumb a.active{color:var(--terra);font-weight:500}
.scan-breadcrumb .sep{color:var(--ink-mute);font-size:14px}
.scan-toolbar-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

.scan-folder-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;margin-bottom:24px}
.scan-folder{background:var(--cream);border:1px solid var(--rule);border-radius:12px;padding:18px 14px;text-align:center;text-decoration:none;color:inherit;transition:all .15s;display:block}
.scan-folder:hover{border-color:var(--terra);transform:translateY(-2px);box-shadow:var(--shadow);background:linear-gradient(180deg, #FCE4D5 0%, var(--cream) 100%)}
.scan-folder-icon{color:var(--terra);width:54px;height:54px;margin:0 auto 10px}
.scan-folder-icon svg{width:100%;height:100%}
.scan-folder-name{font-family:'Fraunces',serif;font-size:15px;font-weight:500;margin-bottom:4px;line-height:1.2;word-wrap:break-word}
.scan-folder-count{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;color:var(--ink-mute);text-transform:uppercase}

.scan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.scan-card{background:var(--cream);border:1px solid var(--rule);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;display:block;transition:all .15s}
.scan-card:hover{border-color:var(--terra);transform:translateY(-2px);box-shadow:var(--shadow)}
.scan-thumb{aspect-ratio:3/4;background:var(--paper-2);display:flex;align-items:center;justify-content:center;overflow:hidden;border-bottom:1px solid var(--rule)}
.scan-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.scan-pdf{display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--terra);height:100%;width:100%;background:linear-gradient(180deg, var(--cream), var(--paper-2));gap:8px}
.scan-pdf svg{width:48px;height:48px}
.scan-pdf span{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.2em;font-weight:600}
.scan-meta{padding:10px 12px}
.scan-title{font-family:'Fraunces',serif;font-size:14px;font-weight:500;margin-bottom:3px;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.scan-sub{font-size:11px;color:var(--ink-mute);font-family:'JetBrains Mono',monospace;letter-spacing:.05em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.scan-mode-tabs{display:flex;gap:4px;background:var(--paper-2);border-radius:8px;padding:4px;margin-bottom:18px}
.scan-mode-tab{flex:1;padding:8px 12px;border:0;background:transparent;border-radius:6px;cursor:pointer;font-family:inherit;font-size:13px;color:var(--ink-soft);transition:all .15s}
.scan-mode-tab.active{background:var(--cream);color:var(--ink);font-weight:500;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.scan-mode-tab:hover:not(.active){background:rgba(255,255,255,.5)}

.scan-capture-modal{max-height:92vh}
.scan-view-modal{max-height:92vh}
.scan-preview{background:var(--paper-2);border-radius:8px;padding:10px;text-align:center;max-height:60vh;overflow:auto}

/* ===== EDITOR — Éditeur de texte type Works ===== */
.editor-layout{display:grid;grid-template-columns:260px 1fr;gap:14px;align-items:flex-start;height:calc(100vh - 200px);min-height:500px}
@media (max-width:900px){.editor-layout{grid-template-columns:1fr;height:auto}}

.editor-sidebar{background:var(--cream);border:1px solid var(--rule);border-radius:12px;padding:14px;overflow-y:auto;height:100%}
@media (max-width:900px){.editor-sidebar{height:auto;max-height:300px}}
.editor-sidebar-section{margin-bottom:18px}
.editor-folder{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:6px;cursor:pointer;font-size:13px;color:var(--ink-soft);text-decoration:none;margin-bottom:2px}
.editor-folder:hover{background:var(--paper-2);color:var(--ink)}
.editor-folder.active{background:var(--paper-2);color:var(--terra);font-weight:500}
.editor-folder span{font-size:14px}
.editor-doc-item{display:block;padding:10px;border-radius:8px;cursor:pointer;text-decoration:none;color:inherit;margin-bottom:4px;border:1px solid transparent;transition:all .15s}
.editor-doc-item:hover{background:var(--paper-2)}
.editor-doc-item.active{background:rgba(232,84,28,.08);border-color:rgba(232,84,28,.2)}
.editor-doc-title{font-size:13px;font-weight:500;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}
.editor-doc-meta{font-size:11px;color:var(--ink-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.editor-main{background:var(--cream);border:1px solid var(--rule);border-radius:12px;display:flex;flex-direction:column;height:100%;overflow:hidden}
@media (max-width:900px){.editor-main{height:auto;min-height:600px}}

.editor-titlebar{display:flex;gap:8px;padding:14px 16px;border-bottom:1px solid var(--rule);background:var(--paper-2);flex-wrap:wrap;align-items:center}
.editor-titlebar #doc-title{flex:1;min-width:200px;font-family:'Fraunces',serif;font-size:18px;font-weight:500;border:1px solid transparent;background:transparent;padding:6px 10px;border-radius:6px;outline:none;color:var(--ink)}
.editor-titlebar #doc-title:focus{border-color:var(--terra);background:var(--cream)}
.editor-titlebar #doc-folder{font-size:13px;border:1px solid var(--rule);background:var(--cream);padding:6px 10px;border-radius:6px;outline:none;width:160px}
.editor-titlebar #doc-folder:focus{border-color:var(--terra)}

.editor-toolbar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:10px 16px;border-bottom:1px solid var(--rule);background:linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%)}
.tb-group{display:flex;gap:2px;align-items:center}
.tb-sep{width:1px;height:22px;background:var(--rule);margin:0 4px}
.tb-btn{min-width:30px;height:30px;border:1px solid transparent;background:transparent;border-radius:5px;cursor:pointer;font-family:inherit;font-size:14px;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;padding:0 6px}
.tb-btn:hover{background:var(--cream);border-color:var(--rule)}
.tb-btn:active{background:var(--paper-2);transform:scale(0.97)}
.editor-toolbar select{padding:5px 8px;border:1px solid var(--rule);background:var(--cream);border-radius:5px;font-family:inherit;font-size:12px;color:var(--ink-soft);cursor:pointer;height:30px}
.editor-toolbar select:hover{border-color:var(--ink-mute)}
.tb-color{width:30px;height:30px;border:1px solid var(--rule);border-radius:5px;background:transparent;padding:2px;cursor:pointer}

.editor-area{flex:1;padding:30px 50px;overflow-y:auto;min-height:300px;outline:none;font-size:15px;line-height:1.7;color:var(--ink);background:#fff;font-family:'Outfit',sans-serif}
.editor-area:focus{background:#fff}
.editor-area p{margin:0 0 14px}
.editor-area h1{font-family:'Fraunces',serif;font-size:32px;font-weight:500;margin:24px 0 12px;line-height:1.15}
.editor-area h2{font-family:'Fraunces',serif;font-size:24px;font-weight:500;margin:20px 0 10px;line-height:1.2}
.editor-area h3{font-family:'Fraunces',serif;font-size:19px;font-weight:500;margin:18px 0 8px;line-height:1.25}
.editor-area ul, .editor-area ol{margin:0 0 14px;padding-left:28px}
.editor-area li{margin-bottom:4px}
.editor-area blockquote{margin:14px 0;padding:10px 18px;border-left:3px solid var(--terra);background:var(--paper-2);font-style:italic;color:var(--ink-soft)}
.editor-area pre{background:#1B2436;color:#FBF8F1;padding:14px;border-radius:6px;font-family:'JetBrains Mono',monospace;font-size:13px;overflow-x:auto;margin:14px 0}
.editor-area code{background:var(--paper-2);padding:1px 5px;border-radius:3px;font-family:'JetBrains Mono',monospace;font-size:.9em}
.editor-area table{border-collapse:collapse;width:100%;margin:14px 0}
.editor-area table td, .editor-area table th{border:1px solid var(--rule);padding:8px 10px}
.editor-area table th{background:var(--paper-2);font-weight:600;text-align:left}
.editor-area hr{border:0;border-top:1px solid var(--rule);margin:18px 0}
.editor-area a{color:var(--terra);text-decoration:underline}
.editor-area img{max-width:100%;height:auto;border-radius:4px}

@media (max-width:900px){.editor-area{padding:18px 22px}}

.editor-footer{padding:10px 16px;border-top:1px solid var(--rule);background:var(--paper-2);display:flex;align-items:center;gap:8px}

.editor-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:40px 20px;color:var(--ink-soft)}
.editor-welcome em{font-style:italic}

/* =====================================================
   MODULE SCAN — Capture caméra et archivage
   ===================================================== */
.scan-capture{max-width:900px;margin:0 auto}
.scan-tabs{display:flex;gap:6px;background:var(--paper-2);padding:5px;border-radius:10px;margin-bottom:18px;width:fit-content}
.scan-tab{padding:8px 18px;border:0;background:transparent;border-radius:7px;cursor:pointer;font-family:inherit;font-size:13px;color:var(--ink-soft);font-weight:500;transition:all .15s}
.scan-tab.active{background:var(--cream);color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.05)}

.scan-stage{position:relative;background:var(--ink);border-radius:14px;overflow:hidden;min-height:320px;display:flex;align-items:center;justify-content:center;color:#fff}
.scan-stage video, .scan-stage img, .scan-stage canvas{display:block;max-width:100%;max-height:70vh;width:auto;height:auto}

.cam-empty{padding:60px 30px;text-align:center;color:#fff}
.cam-empty svg{color:rgba(255,255,255,.5);margin-bottom:8px}

.scan-controls{display:flex;align-items:center;justify-content:center;gap:18px;padding:16px;background:rgba(19,49,92,.06);border-radius:14px;margin-top:14px}

.btn-capture{width:64px;height:64px;border-radius:50%;border:0;background:var(--terra);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(232,84,28,.4);transition:all .15s;position:relative}
.btn-capture:hover{transform:scale(1.05)}
.btn-capture:active{transform:scale(0.95)}
.capture-ring{position:absolute;inset:6px;border:3px solid #fff;border-radius:50%}

.scan-filters{margin-top:16px;padding:14px;background:var(--cream);border:1px solid var(--rule);border-radius:12px}
.filter-chip{padding:8px 14px;border:1px solid var(--rule);background:var(--paper-2);border-radius:8px;cursor:pointer;font-family:inherit;font-size:13px;color:var(--ink-soft);transition:all .15s;text-align:center}
.filter-chip:hover{border-color:var(--ink-mute)}
.filter-chip.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}

.upload-zone{border:2px dashed var(--rule);border-radius:14px;padding:40px;text-align:center;background:var(--cream);transition:all .15s;cursor:pointer}
.upload-zone:hover, .upload-zone.dragging{border-color:var(--terra);background:#FCE4D5}
.upload-zone svg{color:var(--ink-mute);margin-bottom:8px}

.folder-tile{position:relative;background:var(--cream);border:1px solid var(--rule);border-radius:12px;padding:18px 14px;text-align:center;text-decoration:none;color:inherit;transition:all .15s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:120px;cursor:pointer;font-family:inherit}
.folder-tile:hover{border-color:var(--terra);transform:translateY(-2px);box-shadow:var(--shadow);background:linear-gradient(180deg,#FCE4D5 0%,var(--cream) 100%)}
.folder-tile svg{color:var(--terra)}
.folder-tile-name{font-family:'Fraunces',serif;font-size:15px;font-weight:500;line-height:1.2}
.folder-tile-count{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.15em;color:var(--ink-mute);text-transform:uppercase}
.folder-tile.new-folder-tile{border-style:dashed;background:transparent}
.folder-tile.new-folder-tile:hover{background:var(--cream)}
.folder-tile.new-folder-tile svg{color:var(--ink-mute)}
.folder-del{width:24px;height:24px;border-radius:50%;border:0;background:rgba(19,49,92,.1);cursor:pointer;color:var(--ink-mute);display:none;align-items:center;justify-content:center;font-size:14px;line-height:1}
.folder-tile:hover .folder-del{display:inline-flex}
.folder-del:hover{background:var(--terra);color:#fff}

.scans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.scan-card{background:var(--cream);border:1px solid var(--rule);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;transition:all .15s;display:block}
.scan-card:hover{border-color:var(--terra);transform:translateY(-2px);box-shadow:var(--shadow)}
.scan-thumb{aspect-ratio:3/4;background:var(--paper-2);overflow:hidden;position:relative}
.scan-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.scan-type-badge{position:absolute;top:8px;right:8px;padding:3px 8px;background:var(--terra);color:#fff;border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;letter-spacing:.05em}
.scan-info{padding:12px}
.scan-title{font-family:'Fraunces',serif;font-size:14px;font-weight:500;line-height:1.25;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.scan-meta{font-size:11px;color:var(--ink-mute);font-family:'JetBrains Mono',monospace;letter-spacing:.05em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.scan-tags{display:flex;gap:4px;margin-top:8px;flex-wrap:wrap}
.scan-tag{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.05em;padding:2px 6px;background:var(--paper-2);border-radius:4px;color:var(--ink-soft)}

/* Print pour l'éditeur */
@media print {
  .sidebar,.mobile-topbar,.editor-topbar,.editor-toolbar,.editor-stats,.editor-titlebar,.editor-sidebar,.flash{display:none !important}
  .main{padding:0 !important;max-width:none !important}
  .editor-page-wrap,.editor-app{background:#fff !important;padding:0 !important}
  .editor-page,.editor-area{box-shadow:none !important;border:none !important;margin:0 !important;padding:20mm !important;max-width:none !important;background:#fff !important}
}

/* Documents grid pour la liste éditeur */
.docs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px;margin-bottom:24px}
.doc-card{background:transparent;text-decoration:none;color:inherit;display:block;transition:all .15s}
.doc-card:hover{transform:translateY(-3px)}
.doc-card-page{background:#fff;border:1px solid var(--rule);border-radius:6px;aspect-ratio:1/1.41;padding:12px 14px;font-size:8px;line-height:1.3;color:var(--ink-mute);overflow:hidden;box-shadow:0 2px 6px rgba(19,49,92,.06);transition:all .15s}
.doc-card:hover .doc-card-page{box-shadow:0 6px 16px rgba(19,49,92,.12);border-color:var(--terra)}
.doc-card-content{display:-webkit-box;-webkit-line-clamp:14;-webkit-box-orient:vertical;overflow:hidden}
.doc-card-info{padding:10px 4px}
.doc-card-title{font-size:14px;font-weight:500;margin-bottom:2px}
.doc-card-meta{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;color:var(--ink-mute);text-transform:uppercase}

/* =====================================================
   MODULE MUSIQUE — bibliothèque, lecteur, playlists
   ===================================================== */
.music-layout{display:grid;grid-template-columns:240px 1fr;gap:18px;align-items:flex-start;margin-bottom:120px}
@media (max-width:900px){.music-layout{grid-template-columns:1fr}}
.music-sidebar{background:var(--cream);border:1px solid var(--rule);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:4px;position:sticky;top:18px}
.music-nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;color:var(--ink-soft);text-decoration:none;font-size:13px;transition:background .15s}
.music-nav-item:hover{background:var(--paper-2);color:var(--ink)}
.music-nav-item.active{background:rgba(232,84,28,.1);color:var(--terra);font-weight:500}
.music-nav-item svg{flex-shrink:0;color:inherit}
.count-pill{font-family:'JetBrains Mono',monospace;font-size:10px;background:var(--paper-2);padding:2px 7px;border-radius:999px;color:var(--ink-mute);letter-spacing:.05em}
.music-nav-item.active .count-pill{background:var(--terra);color:#fff}

.music-main{min-width:0}

/* Header playlist */
.playlist-header{display:flex;gap:22px;align-items:flex-end;padding:24px;background:linear-gradient(135deg,rgba(232,84,28,.1),rgba(19,49,92,.05));border-radius:14px;margin-bottom:22px}
@media (max-width:600px){.playlist-header{flex-direction:column;align-items:flex-start}}
.playlist-cover-stack{width:160px;height:160px;border-radius:12px;overflow:hidden;flex-shrink:0;box-shadow:0 6px 20px rgba(19,49,92,.15);background:var(--ink)}
.cv-grid{display:grid;grid-template-columns:1fr 1fr;width:100%;height:100%;gap:0}
.cv-grid img,.cv-grid div{width:100%;height:100%;object-fit:cover;display:block}

/* Liste de morceaux */
.track-list{background:var(--cream);border:1px solid var(--rule);border-radius:12px;overflow:hidden}
.track-list-head{display:grid;grid-template-columns:42px 1fr 200px 80px 60px 40px;gap:12px;padding:10px 14px;border-bottom:1px solid var(--rule);background:var(--paper-2);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);align-items:center}
.track-row{display:grid;grid-template-columns:42px 1fr 200px 80px 60px 40px;gap:12px;padding:8px 14px;border-bottom:1px solid var(--rule);align-items:center;transition:background .12s}
.track-row:last-child{border-bottom:0}
.track-row:hover{background:var(--paper-2)}
.track-row.playing{background:rgba(232,84,28,.08)}
.track-row.playing .track-title-text{color:var(--terra)}
@media (max-width:700px){
  .track-list-head,.track-row{grid-template-columns:42px 1fr 60px 40px}
  .hide-mobile{display:none}
}
.track-num{position:relative;width:32px;height:32px;display:flex;align-items:center;justify-content:center}
.num-text{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--ink-mute)}
.track-play-btn{display:none;position:absolute;inset:0;border:0;background:var(--terra);color:#fff;border-radius:50%;width:28px;height:28px;margin:auto;cursor:pointer;font-size:11px;padding-left:2px}
.track-row:hover .num-text{display:none}
.track-row:hover .track-play-btn{display:flex;align-items:center;justify-content:center}
.track-row.playing .num-text{color:var(--terra);font-weight:600}
.track-title-cell{display:flex;align-items:center;gap:12px;min-width:0}
.track-cover{width:36px;height:36px;border-radius:4px;object-fit:cover;background:var(--ink);flex-shrink:0}
.track-title-text{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.track-artist-text{font-size:12px;color:var(--ink-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.track-album-text{font-size:13px;color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.track-menu-wrap{position:relative;display:inline-block}
.track-menu-btn{width:30px;height:30px;border:0;background:transparent;border-radius:50%;cursor:pointer;color:var(--ink-mute);font-size:16px;line-height:1}
.track-menu-btn:hover{background:var(--paper);color:var(--ink)}
.track-menu{display:none;position:absolute;right:0;top:100%;margin-top:4px;background:var(--cream);border:1px solid var(--rule);border-radius:10px;box-shadow:var(--shadow-lg);min-width:200px;padding:6px;z-index:50;flex-direction:column}
.track-menu.show{display:flex}
.track-menu a,.menu-add-btn{display:block;padding:8px 12px;border-radius:6px;text-decoration:none;color:var(--ink);font-size:13px;background:transparent;border:0;text-align:left;width:100%;font-family:inherit;cursor:pointer}
.track-menu a:hover,.menu-add-btn:hover{background:var(--paper-2)}
.track-menu-sep{padding:6px 12px 4px;font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);border-top:1px solid var(--rule);margin-top:4px}
.track-menu-sep:first-child{border-top:0;margin-top:0}

/* LECTEUR (barre fixe en bas) */
.player-bar{position:fixed;bottom:0;left:260px;right:0;background:var(--cream);border-top:1px solid var(--rule);box-shadow:0 -4px 20px rgba(19,49,92,.08);padding:10px 20px;display:grid;grid-template-columns:1fr 2fr 1fr;gap:18px;align-items:center;z-index:80}
@media (max-width:900px){.player-bar{left:0;grid-template-columns:1fr;padding:10px 14px}.player-volume{display:none}}
.player-now{display:flex;align-items:center;gap:12px;min-width:0}
#player-cover{width:48px;height:48px;border-radius:6px;object-fit:cover;background:var(--ink);flex-shrink:0}
.player-info{flex:1;min-width:0}
.player-title{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.player-artist{font-size:12px;color:var(--ink-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.player-controls{display:flex;flex-direction:column;align-items:center;gap:6px}
.player-buttons{display:flex;gap:6px;align-items:center}
.btn-play{width:38px;height:38px;border-radius:50%;border:0;background:var(--terra);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;box-shadow:0 2px 8px rgba(232,84,28,.3)}
.btn-play:hover{background:var(--terra-deep);transform:scale(1.05)}
.player-buttons .btn-icon{width:30px;height:30px;border:0;background:transparent;border-radius:50%}
.player-buttons .btn-icon:hover{background:var(--paper-2)}
.player-buttons .btn-icon.on{color:var(--terra)}
.player-progress{display:flex;align-items:center;gap:10px;width:100%;max-width:520px}
.player-time{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--ink-mute);min-width:36px;text-align:center}
.progress-track{flex:1;height:4px;background:var(--paper-2);border-radius:2px;cursor:pointer;position:relative;transition:height .15s}
.progress-track:hover{height:6px}
.progress-fill{position:absolute;top:0;left:0;bottom:0;background:var(--terra);border-radius:2px;width:0;transition:width .1s linear}
.progress-thumb{position:absolute;top:50%;left:0;width:12px;height:12px;border-radius:50%;background:var(--terra);transform:translate(-50%,-50%) scale(0);transition:transform .15s}
.progress-track:hover .progress-thumb{transform:translate(-50%,-50%) scale(1)}
.player-volume{display:flex;align-items:center;gap:8px;justify-content:flex-end}
.player-volume input[type=range]{width:90px;height:4px;-webkit-appearance:none;background:var(--paper-2);border-radius:2px;outline:none}
.player-volume input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:var(--terra);border-radius:50%;cursor:pointer}
.player-volume input[type=range]::-moz-range-thumb{width:12px;height:12px;background:var(--terra);border-radius:50%;cursor:pointer;border:0}

/* =====================================================
   MODULE EMAILING — onglets, statuts, listes
   ===================================================== */
.email-tabs{display:flex;gap:4px;background:var(--cream);border:1px solid var(--rule);border-radius:12px;padding:5px;margin-bottom:22px;overflow-x:auto;flex-wrap:wrap}
.email-tab{padding:9px 16px;border-radius:8px;text-decoration:none;color:var(--ink-soft);font-size:13px;font-weight:500;white-space:nowrap;transition:all .15s}
.email-tab:hover{background:var(--paper-2);color:var(--ink)}
.email-tab.active{background:var(--ink);color:var(--cream)}

.email-status{display:inline-block;padding:3px 10px;border-radius:999px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;background:var(--paper-2);color:var(--ink-soft)}
.email-status.status-brouillon{background:var(--paper-2);color:var(--ink-soft)}
.email-status.status-programmee,.email-status.status-en_cours{background:#FFE7CE;color:#A14908}
.email-status.status-envoye{background:#DDE9F4;color:#13315C}
.email-status.status-pending{background:#FFE7CE;color:#A14908}
.email-status.status-sent{background:#DDE9F4;color:#13315C}
.email-status.status-failed{background:#FCE4D5;color:var(--terra-deep)}

/* ===== NOTIFICATIONS — cloche topbar ===== */
.notif-bell-wrap{position:relative;}
.notif-bell{position:relative;width:38px;height:38px;border-radius:8px;border:1px solid var(--rule);background:var(--cream);color:var(--ink-soft);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s;}
.notif-bell:hover{color:var(--ink);border-color:var(--ink);}
.notif-bell svg{width:17px;height:17px;}
.notif-dot{position:absolute;top:-4px;right:-4px;background:var(--terra);color:#fff;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:500;padding:1px 5px;border-radius:999px;min-width:16px;text-align:center;line-height:1.4;}
.notif-pop{position:absolute;top:46px;right:0;width:340px;background:var(--cream);border:1px solid var(--rule);border-radius:12px;box-shadow:var(--shadow-lg);max-height:0;overflow:hidden;opacity:0;transition:all .2s;z-index:80;}
.notif-pop.open{max-height:500px;opacity:1;}
.notif-pop-head{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--rule);font-family:'Fraunces',serif;font-size:14px;color:var(--ink);font-weight:500;}
.notif-mark-read{background:transparent;border:0;color:var(--terra);font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;}
.notif-mark-read:hover{color:var(--terra-deep);}
.notif-list{max-height:420px;overflow-y:auto;}
.notif-item{display:block;padding:11px 16px;border-bottom:1px solid var(--rule);text-decoration:none;color:inherit;transition:background .15s;}
.notif-item:hover{background:var(--paper-2);}
.notif-item:last-child{border-bottom:0;}
.notif-item.unread{background:rgba(232,84,28,.04);border-left:3px solid var(--terra);padding-left:13px;}
.notif-title{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:3px;}
.notif-body{font-size:12px;color:var(--ink-soft);line-height:1.4;margin-bottom:4px;}
.notif-time{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--ink-mute);letter-spacing:.05em;}
.notif-empty{padding:30px 18px;text-align:center;color:var(--ink-mute);font-style:italic;font-size:13px;}

/* ===== POPUP D'APPEL ENTRANT (RING) ===== */
.ring-popup{position:fixed;top:80px;right:24px;z-index:9999;display:none;animation:ringSlide .35s cubic-bezier(.2,.8,.2,1);}
.ring-popup.show{display:block;}
@keyframes ringSlide{from{opacity:0;transform:translateX(60px) scale(.92);}to{opacity:1;transform:translateX(0) scale(1);}}
.ring-card{background:linear-gradient(140deg,#1B3A5F 0%,#13315C 55%,#0B2240 100%);color:#FBF8F1;border-radius:18px;padding:22px 24px;width:340px;box-shadow:0 18px 50px -10px rgba(11,34,64,.5),0 0 0 1px rgba(255,157,82,.18);position:relative;overflow:hidden;}
.ring-pulse{position:absolute;top:-30px;right:-30px;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle,rgba(232,84,28,.35),transparent 70%);animation:ringPulse 1.6s ease-in-out infinite;}
@keyframes ringPulse{0%,100%{transform:scale(1);opacity:.7;}50%{transform:scale(1.3);opacity:.3;}}
.ring-avatar{width:60px;height:60px;border-radius:50%;background:#E8541C;color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-weight:500;font-size:22px;margin-bottom:14px;overflow:hidden;position:relative;z-index:2;border:3px solid rgba(255,157,82,.3);}
.ring-avatar img{width:100%;height:100%;object-fit:cover;}
.ring-meta{position:relative;z-index:2;margin-bottom:18px;}
.ring-type{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:#FF9D52;margin-bottom:6px;}
.ring-name{font-family:'Fraunces',serif;font-size:22px;font-weight:500;line-height:1.15;}
.ring-actions{display:flex;gap:14px;justify-content:center;position:relative;z-index:2;}
.ring-btn{width:54px;height:54px;border-radius:50%;border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;}
.ring-btn svg{width:22px;height:22px;}
.ring-reject{background:#E8541C;color:#fff;}
.ring-reject:hover{background:#B83F12;transform:scale(1.05);}
.ring-accept{background:#4D7A4D;color:#fff;animation:ringAccept 1.4s ease-in-out infinite;}
.ring-accept:hover{background:#3a5d3a;transform:scale(1.05);animation:none;}
@keyframes ringAccept{0%,100%{box-shadow:0 0 0 0 rgba(77,122,77,.5);}50%{box-shadow:0 0 0 12px rgba(77,122,77,0);}}
@media (max-width:600px){.ring-popup{top:auto;bottom:24px;right:12px;left:12px;}.ring-card{width:auto;}}

/* ===== SOFTPHONE SIP ===== */
.softphone-card{background:linear-gradient(170deg,#FBF8F1 0%,#F4F0E8 100%);}
.sp-status{display:flex;align-items:center;gap:8px;padding:9px 14px;border-radius:8px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;}
.sp-status-dot{width:8px;height:8px;border-radius:50%;background:var(--ink-mute);flex-shrink:0;}
.sp-status-disconnected,.sp-status-connecting{background:#FFE7CE;color:#A14908;}
.sp-status-disconnected .sp-status-dot,.sp-status-connecting .sp-status-dot{background:#E8541C;animation:spPulse 1.4s ease-in-out infinite;}
.sp-status-connected{background:#E0F0E5;color:#3a5d3a;}
.sp-status-connected .sp-status-dot{background:#4D7A4D;}
.sp-status-error{background:#FCE4D5;color:var(--terra-deep);}
.sp-status-error .sp-status-dot{background:var(--terra-deep);}
@keyframes spPulse{0%,100%{opacity:.4;}50%{opacity:1;}}

.sp-display{background:var(--ink);color:#FBF8F1;padding:18px 20px;border-radius:12px;text-align:center;margin-bottom:14px;min-height:90px;display:flex;flex-direction:column;justify-content:center;}
.sp-display-name{font-family:'Fraunces',serif;font-size:20px;font-weight:500;line-height:1.2;}
.sp-display-num{font-family:'JetBrains Mono',monospace;font-size:13px;color:rgba(251,248,241,.6);margin-top:4px;letter-spacing:.05em;}
.sp-display-time{font-family:'JetBrains Mono',monospace;font-size:11px;color:#FF9D52;margin-top:6px;letter-spacing:.15em;}

.sp-input{width:100%;padding:12px 14px;background:#fff;border:1px solid var(--rule);border-radius:8px;font-family:'JetBrains Mono',monospace;font-size:18px;text-align:center;color:var(--ink);margin-bottom:14px;letter-spacing:.05em;}
.sp-input:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 4px rgba(232,84,28,.12);}

.sp-dialpad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px;}
.sp-key{background:#fff;border:1px solid var(--rule);border-radius:10px;padding:10px 0;cursor:pointer;text-align:center;transition:all .12s;font-family:inherit;}
.sp-key:hover{background:var(--paper-2);border-color:var(--ink);transform:translateY(-1px);}
.sp-key:active{transform:translateY(0) scale(.98);}
.sp-key b{display:block;font-family:'Fraunces',serif;font-size:22px;color:var(--ink);font-weight:500;}
.sp-key span{display:block;font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--ink-mute);letter-spacing:.18em;text-transform:uppercase;margin-top:1px;min-height:11px;}

.sp-actions{display:flex;gap:10px;justify-content:center;margin-bottom:14px;}
.sp-btn{width:54px;height:54px;border-radius:50%;border:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;color:#fff;}
.sp-btn svg{width:22px;height:22px;}
.sp-btn:disabled{opacity:.35;cursor:not-allowed;}
.sp-call{background:#4D7A4D;}
.sp-call:hover:not(:disabled){background:#3a5d3a;transform:scale(1.05);}
.sp-hangup{background:#E8541C;}
.sp-hangup:hover:not(:disabled){background:#B83F12;transform:scale(1.05);}
.sp-secondary{background:var(--paper-2);color:var(--ink-soft);}
.sp-secondary:hover:not(:disabled){background:var(--ink-soft);color:#fff;}
.sp-secondary.active{background:var(--terra);color:#fff;}

.sp-toggles{display:flex;gap:18px;justify-content:center;font-size:12px;color:var(--ink-soft);padding-top:10px;border-top:1px solid var(--rule);}
.sp-toggles label{display:flex;align-items:center;gap:6px;cursor:pointer;}
.sp-toggles input{width:auto;}

.sp-speed-btn{background:var(--paper-2);border:0;border-radius:8px;padding:10px 12px;cursor:pointer;text-align:left;transition:all .12s;font-family:inherit;}
.sp-speed-btn:hover{background:var(--ink);}
.sp-speed-btn:hover>div{color:#fff !important;}

.sp-transcript{background:var(--paper-2);border-radius:8px;padding:14px 16px;min-height:140px;max-height:220px;overflow-y:auto;font-size:13px;line-height:1.55;color:var(--ink);}
.sp-transcript-empty{color:var(--ink-mute);font-style:italic;text-align:center;padding:30px 10px;font-size:12px;}
.sp-transcript>div{padding:3px 0;}

/* ===== ANTI-SPAM ===== */
.as-toggle{display:flex;align-items:flex-start;gap:12px;padding:11px 14px;background:var(--paper-2);border-radius:8px;cursor:pointer;margin-bottom:8px;transition:background .15s;}
.as-toggle:hover{background:#E0DCD0;}
.as-toggle input{margin-top:3px;width:auto;flex-shrink:0;accent-color:var(--terra);}
.as-toggle-title{font-size:13px;font-weight:500;color:var(--ink);margin-bottom:3px;}
.as-toggle-sub{font-size:11.5px;color:var(--ink-mute);line-height:1.5;}

.sp-spam-toast{position:fixed;top:80px;right:24px;z-index:10000;background:var(--ink);color:#FBF8F1;padding:14px 20px;border-radius:10px;box-shadow:var(--shadow-lg);min-width:240px;max-width:320px;border-left:3px solid var(--terra);opacity:0;transform:translateX(50px);transition:all .35s cubic-bezier(.2,.8,.2,1);font-family:'Outfit',sans-serif;font-size:14px;}
.sp-spam-toast.show{opacity:1;transform:translateX(0);}
.sp-spam-toast b{font-family:'Fraunces',serif;font-weight:500;font-size:15px;}

/* =====================================================
   COMPATIBILITÉ MOBILE COMPLÈTE — iPhone, Android, iPad, Surface…
   Ajouts non-intrusifs en fin de feuille pour surcharger.
   ===================================================== */

/* --- Réglages globaux universels --- */
html {
  -webkit-text-size-adjust: 100%;       /* iOS pas de zoom auto sur orientation */
  -moz-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;  /* Pas de halo bleu Android */
}
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overscroll-behavior-y: none;          /* Désactive bounce vertical iOS hors champ */
  /* iOS Safe Area sur iPhone à encoche / Dynamic Island */
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
}
* { -webkit-touch-callout: default; }
input, textarea, select, button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  font-family: inherit;
}
button { cursor: pointer; }

/* iOS : pas de zoom forcé quand un input fait focus si la police < 16px */
@media (max-width: 700px) {
  input, textarea, select {
    font-size: 16px !important;          /* règle iOS critique */
  }
}

/* Tap targets — minimum 44x44 (Apple HIG) / 48dp (Material) */
@media (max-width: 900px) {
  .nav-item { min-height: 44px; padding: 12px 14px; }
  .btn { min-height: 44px; padding-left: 18px; padding-right: 18px; }
  .btn-sm { min-height: 38px; }
  .btn-icon { min-width: 44px; min-height: 44px; }
  a.cal-toggle { min-height: 38px; }
  .doc, .contact-card, .news-card, .forum-thread, .mail-item { min-height: 56px; }
}

/* Sidebar mobile : safe-area + scroll fluide */
@media (max-width: 900px) {
  .sidebar {
    padding-top: calc(28px + env(safe-area-inset-top));
    padding-bottom: calc(28px + env(safe-area-inset-bottom));
    -webkit-overflow-scrolling: touch;
    width: min(86vw, 320px);
    left: calc(-1 * min(86vw, 320px));
  }
  .sidebar.open { left: 0; }
}

/* Mobile topbar : safe-area top */
@media (max-width: 900px) {
  .mobile-topbar {
    padding-top: calc(10px + env(safe-area-inset-top));
    height: auto;
  }
  .main {
    padding-top: calc(64px + env(safe-area-inset-top)) !important;
    padding-bottom: calc(80px + env(safe-area-inset-bottom));
  }
}

/* --- Topbar de page : empile proprement sur mobile --- */
@media (max-width: 700px) {
  .topbar {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
    padding-bottom: 18px;
    margin-bottom: 22px;
  }
  .topbar-left { gap: 8px; flex-direction: column; align-items: flex-start; }
  .topbar h1 { font-size: 22px; line-height: 1.15; }
  .topbar-right { width: 100%; justify-content: flex-start; flex-wrap: wrap; }
  .topbar-right .btn,
  .topbar-right .btn-sm { flex: 1; min-width: 130px; }
}

/* --- Tableaux : scroll horizontal au lieu de débordement --- */
@media (max-width: 900px) {
  .card table,
  table[style*="width:100%"] {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }
}

/* --- Modales : pleine hauteur sur mobile, scrollables --- */
@media (max-width: 700px) {
  .modal-backdrop {
    padding: 0;
    align-items: flex-end;
  }
  .modal {
    max-width: 100% !important;
    width: 100%;
    max-height: 92vh;
    border-radius: 18px 18px 0 0;
    padding: 22px 18px calc(22px + env(safe-area-inset-bottom));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    animation: modalSlideUp .25s cubic-bezier(.2,.8,.2,1);
  }
  @keyframes modalSlideUp {
    from { transform: translateY(40px); opacity: 0; }
    to   { transform: translateY(0);    opacity: 1; }
  }
  .modal h3 { font-size: 18px; margin-bottom: 12px; }
}

/* --- Formulaires : 2 col devient 1 col sur petit écran --- */
@media (max-width: 600px) {
  .two-col-form,
  .grid-2,
  .grid-3 { grid-template-columns: 1fr !important; gap: 10px; }
}

/* --- Boutons en pied de modale : pleine largeur sur mobile --- */
@media (max-width: 600px) {
  .modal form > div[style*="display:flex"][style*="gap:10px"] .btn,
  .modal form > div[style*="display:flex"][style*="gap:10px"] a.btn {
    flex: 1;
    min-width: 130px;
  }
}

/* --- Agenda : adaptation tablette + mobile --- */
@media (max-width: 1100px) and (min-width: 901px) {
  .agenda-layout { grid-template-columns: 220px 1fr; }
}
@media (max-width: 900px) {
  .agenda-layout { grid-template-columns: 1fr; gap: 14px; }
  .cal-sidebar {
    position: relative !important;
    top: 0 !important;
    order: 2;
    padding: 14px;
    max-height: 320px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .cal-week-grid {
    grid-template-columns: 38px repeat(4, 1fr) !important;
  }
  .cal-day-num { font-size: 16px; }
  .cal-day-name { font-size: 9px; letter-spacing: .12em; }
  .cal-hour-label { font-size: 9px; padding-right: 4px; }
  .cal-event { font-size: 10px; padding: 3px 4px; }
  .cal-event-time { font-size: 9px; }
  .cal-week-label { font-size: 14px; }
}

/* --- Mail : layout vertical sur mobile, switch fluide --- */
@media (max-width: 700px) {
  .mail-layout {
    grid-template-columns: 1fr !important;
    height: auto;
    min-height: 0;
  }
  .mail-list-col { max-height: 50vh; }
  .mail-view-col { min-height: 50vh; border-top: 1px solid var(--rule); }
}

/* --- Cartes contacts : 1 par ligne sur petit, 2 sur tablette --- */
@media (max-width: 900px) and (min-width: 601px) {
  .contacts-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .contacts-grid { grid-template-columns: 1fr !important; gap: 10px; }
  .contact-card { padding: 14px; }
}

/* --- Hero accueil : marges + tailles ajustées --- */
@media (max-width: 700px) {
  .hero-greet {
    padding: 22px 18px;
    border-radius: 14px;
    min-height: 0;
  }
  .hero-greet h2 { font-size: 24px; }
  .hero-stats { gap: 18px; }
  .hero-stat b { font-size: 22px; }
}

/* --- News, forum, polls : padding réduit sur mobile --- */
@media (max-width: 600px) {
  .news-card, .forum-thread, .forum-detail, .poll-card { padding: 16px; }
  .news-title, .forum-title { font-size: 16px; }
  .news-actions { flex-wrap: wrap; gap: 10px; }
}

/* --- Liste fichiers : icones plus petites + texte tronqué --- */
@media (max-width: 600px) {
  .doc { gap: 10px; padding: 10px 6px; }
  .doc-icon { width: 32px; height: 40px; font-size: 8px; }
  .doc-name { font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .doc-meta { font-size: 11px; }
  .doc .btn { padding: 8px 10px; font-size: 12px; }
}

/* --- Filtres en chips : scroll horizontal au lieu de wrap --- */
@media (max-width: 600px) {
  .share-folders {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    margin: 0 -18px 14px;
    padding: 0 18px 4px;
  }
  .share-folders::-webkit-scrollbar { display: none; }
  .share-folder-chip {
    flex-shrink: 0;
    white-space: nowrap;
  }
  .share-folders form {
    margin-left: 0 !important;
    flex-shrink: 0;
  }
}

/* --- Auth screen : logo plus petit et padding sain sur mobile --- */
@media (max-width: 700px) {
  .auth-panel { padding: 28px 20px calc(28px + env(safe-area-inset-bottom)); }
  .auth-title { font-size: 26px; }
  .auth-form { max-width: 100%; }
}

/* --- Editor (Works 9-like) : sidebar repliée sur mobile --- */
@media (max-width: 900px) {
  .editor-layout { grid-template-columns: 1fr; }
  .editor-sidebar {
    max-height: 240px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .editor-toolbar {
    flex-wrap: wrap;
    gap: 4px;
    padding: 8px 10px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .editor-toolbar > * { flex-shrink: 0; }
  .editor-area { padding: 16px 18px !important; }
}

/* --- Music player : barre du bas safe-area --- */
@media (max-width: 700px) {
  .player-bar {
    padding-bottom: calc(10px + env(safe-area-inset-bottom)) !important;
  }
}

/* --- Lightbox : pleine zone sur mobile --- */
@media (max-width: 600px) {
  .lightbox { padding: 16px; }
}

/* --- Inputs date/time : alignement iOS --- */
input[type="date"],
input[type="time"],
input[type="datetime-local"] {
  -webkit-appearance: none;
  appearance: none;
  background: var(--cream);
  min-height: 44px;
}
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator {
  cursor: pointer;
  opacity: .6;
}

/* --- Selects : flèche custom universelle --- */
select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%236B7585' d='M5 6L0 0h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 32px !important;
}

/* --- Animations adoucies pour utilisateurs sensibles --- */
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* --- Mode sombre système (si sélectionné par l'utilisateur OS) --- */
@media (prefers-color-scheme: dark) {
  /* On garde notre charte claire pour rester cohérent — mais on adoucit les contrastes */
  body { background-color: var(--paper); }
}

/* --- Hauteur pleine fluide sur iOS Safari (qui ment sur 100vh) --- */
.app-shell {
  min-height: 100vh;
  min-height: 100dvh;        /* dynamic viewport — vrai 100% sur iOS 15.4+ */
}
.auth-screen {
  min-height: 100vh;
  min-height: 100dvh;
}

/* --- Très petits écrans (Galaxy Fold replié, anciens iPhone SE) --- */
@media (max-width: 380px) {
  .topbar h1 { font-size: 20px; }
  .main { padding-left: 12px; padding-right: 12px; }
  .card { padding: 14px; }
  .btn { font-size: 13px; padding: 11px 14px; }
  .hero-greet { padding: 18px 14px; }
  .hero-greet h2 { font-size: 22px; }
}

/* --- Tablette paysage : Surface, iPad… --- */
@media (min-width: 901px) and (max-width: 1100px) {
  .main { padding: 24px 28px 60px; }
  .topbar h1 { font-size: 28px; }
}

/* --- Grand écran retina : marges plus généreuses --- */
@media (min-width: 1500px) {
  .main { padding-left: 64px; padding-right: 64px; max-width: 1500px; }
}
