:root{
  --bg:#f6f4ef;--panel:#ffffff;--ink:#1f2933;--muted:#65717f;--line:#e7e1d7;--primary:#191919;--accent:#c79a46;--accent-soft:#f5ead5;--danger:#b42318;--success:#137333;--blue:#2563eb;--shadow:0 20px 60px rgba(31,41,51,.10);--radius:24px
}
*{box-sizing:border-box}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);background:var(--bg)}button,input,select,textarea{font:inherit}button{cursor:pointer}.hidden{display:none!important}.small{font-size:.86rem}.muted{color:var(--muted)}.full{width:100%}.toast{position:fixed;right:18px;bottom:18px;z-index:50;max-width:420px}.toast .item{background:#111;color:#fff;padding:14px 16px;border-radius:16px;margin-top:10px;box-shadow:var(--shadow)}.toast .error{background:var(--danger)}.toast .success{background:var(--success)}
.auth-layout{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;gap:28px;padding:28px}.hero-panel{background:linear-gradient(135deg,#191919,#36302a);color:#fff;border-radius:32px;padding:44px;display:flex;flex-direction:column;justify-content:space-between;min-height:calc(100vh - 56px);box-shadow:var(--shadow)}.brand-row{display:flex;align-items:center;gap:12px;font-weight:800;font-size:1.1rem}.logo-mark{width:42px;height:42px;border-radius:14px;background:var(--accent);display:grid;place-items:center;color:#111;font-weight:900}.hero-panel h1{font-size:clamp(2.4rem,5vw,5rem);line-height:.96;margin:80px 0 18px;letter-spacing:-.05em}.hero-panel p{font-size:1.2rem;color:#e7e0d6;max-width:720px}.hero-card{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);padding:22px;border-radius:22px;display:grid;gap:8px;max-width:620px}.hero-card span{color:#eee}.auth-card{background:var(--panel);border:1px solid var(--line);border-radius:32px;padding:28px;align-self:center;box-shadow:var(--shadow);max-width:520px;width:100%;justify-self:center}.tabs{display:flex;background:#f2eee7;border-radius:18px;padding:5px;margin-bottom:24px}.tab{border:0;background:transparent;padding:12px 16px;flex:1;border-radius:14px;color:var(--muted);font-weight:700}.tab.active{background:#fff;color:var(--ink);box-shadow:0 8px 20px rgba(0,0,0,.06)}.form-stack{display:grid;gap:16px}.form-stack h2{margin:0 0 8px;font-size:1.7rem}.form-stack label{display:grid;gap:8px;font-weight:700;color:#35414f}.form-stack input,.form-stack select,.form-stack textarea,.field{width:100%;border:1px solid var(--line);border-radius:15px;padding:13px 14px;background:#fff;color:var(--ink);outline:none}.form-stack input:focus,.form-stack select:focus,.form-stack textarea:focus,.field:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.btn{border:0;border-radius:15px;padding:12px 16px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn.primary{background:var(--primary);color:#fff}.btn.soft{background:var(--accent-soft);color:#6f4b0f}.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--ink)}.btn.danger{background:#fee4e2;color:var(--danger)}.btn.success{background:#dcfce7;color:var(--success)}.btn:disabled{opacity:.55;cursor:not-allowed}
.app{display:grid;grid-template-columns:285px 1fr;min-height:100vh}.sidebar{background:#fff;border-right:1px solid var(--line);padding:22px;display:flex;flex-direction:column;gap:22px;position:sticky;top:0;height:100vh}.sidebar-brand{padding-bottom:10px}.profile-box{background:#f8f5ef;border:1px solid var(--line);border-radius:20px;padding:16px}.profile-box strong{display:block}.role-pill{display:inline-flex;margin-top:8px;background:#111;color:#fff;border-radius:999px;padding:5px 10px;font-size:.78rem;font-weight:800}.nav{display:grid;gap:8px}.nav button{border:0;background:transparent;text-align:left;padding:13px 14px;border-radius:15px;color:var(--muted);font-weight:800}.nav button.active,.nav button:hover{background:#f2eee7;color:var(--ink)}.content{padding:28px;max-width:1220px;width:100%;margin:0 auto}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:24px}.topbar h1{margin:0;font-size:2.2rem;letter-spacing:-.04em}.eyebrow{margin:0 0 6px;color:var(--accent);text-transform:uppercase;font-size:.78rem;font-weight:900;letter-spacing:.12em}.grid{display:grid;gap:18px}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:0 12px 35px rgba(31,41,51,.05)}.card h2,.card h3{margin-top:0;letter-spacing:-.03em}.stat{display:grid;gap:4px}.stat strong{font-size:2rem}.badge{display:inline-flex;border-radius:999px;padding:5px 10px;background:#f2eee7;color:#67584a;font-weight:800;font-size:.78rem}.badge.ok{background:#dcfce7;color:var(--success)}.badge.warn{background:#fef3c7;color:#92400e}.badge.bad{background:#fee4e2;color:var(--danger)}.list{display:grid;gap:12px}.row{display:flex;justify-content:space-between;gap:14px;align-items:center;border:1px solid var(--line);border-radius:18px;padding:14px;background:#fff}.row-main{display:grid;gap:4px}.actions{display:flex;gap:10px;flex-wrap:wrap}.message-box{height:320px;overflow:auto;border:1px solid var(--line);border-radius:20px;padding:14px;background:#faf8f4;display:flex;flex-direction:column;gap:10px}.msg{max-width:78%;padding:11px 13px;border-radius:16px;background:#fff;border:1px solid var(--line)}.msg.mine{align-self:flex-end;background:#111;color:#fff}.msg small{display:block;margin-top:5px;opacity:.7}.kiosk{background:#111;color:#fff;border-radius:30px;padding:26px}.kiosk input,.kiosk select{background:#fff;color:#111}.kiosk .btn.primary{background:var(--accent);color:#111}.table-wrap{overflow:auto}.table{width:100%;border-collapse:separate;border-spacing:0 10px}.table th{text-align:left;color:var(--muted);font-size:.82rem;padding:0 12px}.table td{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 12px}.table td:first-child{border-left:1px solid var(--line);border-radius:14px 0 0 14px}.table td:last-child{border-right:1px solid var(--line);border-radius:0 14px 14px 0}.paywall{border:1px dashed var(--accent);background:#fffaf0}.admin-secret{font-family:ui-monospace,monospace;color:#555}
@media(max-width:900px){.auth-layout{grid-template-columns:1fr;padding:14px}.hero-panel{min-height:auto;padding:28px}.hero-panel h1{margin:46px 0 18px}.app{grid-template-columns:1fr}.sidebar{height:auto;position:relative}.content{padding:18px}.grid.two,.grid.three{grid-template-columns:1fr}.topbar{align-items:flex-start}.row{align-items:flex-start;flex-direction:column}.actions{width:100%}.actions .btn{flex:1}.auth-card{max-width:none}}
@media print{.sidebar,.topbar,.actions,.btn,.nav,.toast{display:none!important}.app{display:block}.content{padding:0}.card{box-shadow:none;border:1px solid #ddd}.hidden{display:none!important}}


/* Public/legal pages */
.public-body{background:var(--bg);min-height:100vh}.public-header{max-width:1060px;margin:0 auto;padding:22px 20px;display:flex;align-items:center;justify-content:space-between;gap:18px}.public-nav{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.public-nav a,.public-footer a{color:var(--muted);text-decoration:none;font-weight:800;font-size:.92rem}.public-nav a:hover,.public-footer a:hover{color:var(--ink)}.public-main{max-width:980px;margin:0 auto;padding:18px 20px 70px}.public-hero{background:#fff;border:1px solid var(--line);border-radius:32px;padding:34px;box-shadow:var(--shadow);margin-bottom:22px}.public-hero h1{font-size:clamp(2rem,4vw,3.6rem);line-height:1;margin:0 0 12px;letter-spacing:-.05em}.legal-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:28px;margin:16px 0;box-shadow:0 12px 35px rgba(31,41,51,.04)}.legal-card h2{margin-top:0;letter-spacing:-.03em}.legal-card h3{margin-bottom:8px}.legal-card p,.legal-card li{line-height:1.65}.legal-card ul{padding-left:22px}.notice{background:#fffaf0;border:1px solid #f0d7a5;border-radius:18px;padding:16px;color:#68460d}.public-footer{max-width:1060px;margin:0 auto;padding:24px 20px 36px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}.price-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.price-card{border:1px solid var(--line);border-radius:24px;padding:22px;background:#fff}.price-card.featured{border-color:var(--accent);box-shadow:0 16px 45px rgba(199,154,70,.16)}.price{font-size:2.3rem;font-weight:900;letter-spacing:-.05em;margin:14px 0}.step-list{counter-reset:step;display:grid;gap:12px}.step{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:flex-start;border:1px solid var(--line);border-radius:20px;background:#fff;padding:16px}.step:before{counter-increment:step;content:counter(step);width:34px;height:34px;border-radius:12px;background:var(--accent);display:grid;place-items:center;font-weight:900;color:#111}.footer-links-auth{position:fixed;bottom:14px;right:18px;left:18px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap;pointer-events:none}.footer-links-auth a{pointer-events:auto;color:rgba(255,255,255,.78);text-decoration:none;font-weight:700;font-size:.86rem}.auth-card .legal-mini{margin-top:10px;display:flex;gap:10px;flex-wrap:wrap}.auth-card .legal-mini a{color:var(--muted);text-decoration:none;font-size:.82rem;font-weight:700}
@media(max-width:900px){.public-header{align-items:flex-start;flex-direction:column}.price-grid{grid-template-columns:1fr}.public-hero{padding:24px}.legal-card{padding:20px}.footer-links-auth{position:static;margin:16px auto 24px}.footer-links-auth a{color:var(--muted)}}

/* Landing page */
.landing-body{background:linear-gradient(180deg,#f8f5ef 0%,#fff 48%,#f8f5ef 100%)}
.landing-header{max-width:1180px;margin:0 auto;padding:20px;display:flex;align-items:center;justify-content:space-between;gap:18px;position:sticky;top:0;background:rgba(248,245,239,.86);backdrop-filter:blur(18px);z-index:20;border-bottom:1px solid rgba(231,225,215,.6)}
.landing-header .brand-row{color:var(--ink);text-decoration:none}.landing-nav{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.landing-nav a{color:var(--muted);text-decoration:none;font-weight:850;font-size:.94rem}.landing-nav a:hover{color:var(--ink)}.nav-login{padding:10px 13px;border:1px solid var(--line);border-radius:999px;background:#fff}.nav-cta{padding:10px 14px;border-radius:999px;background:#111;color:#fff!important}.landing-hero{max-width:1180px;margin:0 auto;padding:62px 20px 40px;display:grid;grid-template-columns:1.05fr .95fr;gap:36px;align-items:center}.landing-hero h1{font-size:clamp(2.7rem,6vw,5.7rem);line-height:.92;margin:10px 0 20px;letter-spacing:-.07em;color:#171717}.lead{font-size:1.18rem;line-height:1.7;color:var(--muted);max-width:720px}.small-lead{font-size:1.05rem}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin:28px 0 22px}.trust-row{display:flex;gap:10px;flex-wrap:wrap;color:#4d5560;font-weight:800}.trust-row span{background:#fff;border:1px solid var(--line);padding:9px 12px;border-radius:999px}.landing-preview{display:flex;justify-content:center}.phone-frame{width:min(390px,100%);border-radius:42px;background:#111;padding:14px;box-shadow:0 30px 80px rgba(0,0,0,.18);transform:rotate(2deg)}.phone-top{width:110px;height:7px;border-radius:99px;background:#3b3b3b;margin:2px auto 12px}.kiosk-mini{background:#fff;border-radius:30px;padding:22px;display:grid;gap:12px}.kiosk-mini h3{font-size:1.7rem;margin:8px 0 0;letter-spacing:-.04em}.kiosk-mini label{font-weight:800;color:#35414f}.fake-input{border:1px solid var(--line);border-radius:15px;padding:13px 14px;background:#f8f5ef;font-weight:900;letter-spacing:.2em}.mini-result{display:grid;grid-template-columns:1fr auto;gap:8px;border-top:1px solid var(--line);padding-top:14px}.mini-result span{color:var(--muted)}.mini-result strong{font-size:1.1rem}.landing-section{max-width:1180px;margin:0 auto;padding:54px 20px}.section-title{max-width:790px;margin-bottom:24px}.section-title.centered{text-align:center;margin-left:auto;margin-right:auto}.section-title h2,.landing-section h2,.landing-cta h2{font-size:clamp(2rem,4vw,3.8rem);line-height:1;margin:0 0 14px;letter-spacing:-.06em}.feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.feature-grid.three-cols{grid-template-columns:repeat(3,minmax(0,1fr))}.feature-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:24px;box-shadow:0 12px 35px rgba(31,41,51,.04)}.feature-card h3{font-size:1.26rem;margin:6px 0 10px;letter-spacing:-.03em}.feature-card p{color:var(--muted);line-height:1.65;margin:0}.feature-icon{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:15px;background:var(--accent-soft);font-size:1.25rem}.split{display:grid;grid-template-columns:.85fr 1.15fr;gap:34px;align-items:start}.landing-steps .step{box-shadow:0 12px 35px rgba(31,41,51,.04)}.landing-steps h3{margin:0 0 4px}.landing-steps p{margin:0;color:var(--muted);line-height:1.55}.pricing-preview{display:grid;grid-template-columns:1fr 360px;gap:28px;align-items:center}.landing-price-card{box-shadow:var(--shadow)}.landing-cta{max-width:1120px;margin:28px auto 70px;background:#111;color:#fff;border-radius:36px;padding:44px 28px;text-align:center;box-shadow:var(--shadow)}.landing-cta p{color:#dedede;font-size:1.12rem}.landing-cta .btn.primary{background:var(--accent);color:#111}.landing-footer{max-width:1180px;margin:0 auto;padding:28px 20px 42px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.footer-links{display:flex;gap:12px;flex-wrap:wrap}.footer-links a{color:var(--muted);text-decoration:none;font-weight:800;font-size:.9rem}.footer-links a:hover{color:var(--ink)}
@media(max-width:940px){.landing-header{align-items:flex-start;position:relative;flex-direction:column}.landing-hero,.split,.pricing-preview{grid-template-columns:1fr}.landing-hero{padding-top:34px}.feature-grid,.feature-grid.three-cols{grid-template-columns:1fr}.phone-frame{transform:none}.landing-nav{gap:8px}.landing-nav a{font-size:.88rem}.landing-section{padding:38px 16px}.landing-cta{margin-left:16px;margin-right:16px}.landing-footer{align-items:flex-start;flex-direction:column}}

/* ==========================================================
   KIDCLOCK visual refresh — inspired by the official logo
   Palette: deep blue, teal, warm yellow, clean white SaaS UI
   ========================================================== */
:root{
  --bg:#f3fbfc;
  --panel:#ffffff;
  --ink:#0b2f4f;
  --muted:#617589;
  --line:#d8e9ef;
  --primary:#064c7a;
  --primary-2:#008f9f;
  --accent:#f5ae2e;
  --accent-soft:#fff4dc;
  --teal-soft:#e7f8fa;
  --blue-soft:#eaf4fb;
  --danger:#b42318;
  --success:#087f5b;
  --shadow:0 22px 70px rgba(6,76,122,.12);
  --radius:26px;
}
body{
  background:
    radial-gradient(circle at 12% 0%, rgba(0,143,159,.13), transparent 34%),
    radial-gradient(circle at 88% 12%, rgba(245,174,46,.13), transparent 28%),
    linear-gradient(180deg,#f6fdff 0%,#ffffff 48%,#f1fafc 100%);
  color:var(--ink);
}
a{color:var(--primary-2)}
.brand-row{gap:14px;min-width:0}.brand-row span{color:var(--ink)}
.brand-logo-img{display:block;width:238px;max-width:100%;height:auto;object-fit:contain;filter:drop-shadow(0 8px 18px rgba(6,76,122,.08))}.sidebar-logo-img{width:210px}.landing-footer .brand-logo-img,.public-footer .brand-logo-img{width:220px}.auth-layout .brand-logo-img{width:250px;filter:drop-shadow(0 12px 24px rgba(0,0,0,.12))}
.logo-mark{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;box-shadow:0 14px 30px rgba(0,143,159,.25)}
.hero-panel{
  background:
    radial-gradient(circle at 15% 18%, rgba(255,255,255,.20), transparent 26%),
    radial-gradient(circle at 92% 8%, rgba(245,174,46,.28), transparent 30%),
    linear-gradient(135deg,#06395f 0%,#056c84 48%,#00a2a9 100%);
  border:1px solid rgba(255,255,255,.28);
  overflow:hidden;
}
.hero-panel:after{content:"";position:absolute;inset:auto -80px -140px auto;width:360px;height:360px;border-radius:999px;background:rgba(255,255,255,.12);pointer-events:none}.hero-panel{position:relative}.hero-panel h1{color:#fff;text-shadow:0 8px 28px rgba(0,0,0,.15)}.hero-panel p{color:rgba(255,255,255,.86)}.hero-card{background:rgba(255,255,255,.17);border-color:rgba(255,255,255,.24);backdrop-filter:blur(10px);color:#fff}.hero-card span{color:rgba(255,255,255,.82)}
.auth-card,.card,.legal-card,.public-hero,.feature-card,.price-card{border-color:var(--line);box-shadow:var(--shadow)}
.tabs{background:var(--blue-soft)}.tab.active{color:var(--primary);box-shadow:0 10px 25px rgba(6,76,122,.10)}
.form-stack input,.form-stack select,.form-stack textarea,.field{border-color:#cfe5ed;background:#fbfeff}.form-stack input:focus,.form-stack select:focus,.form-stack textarea:focus,.field:focus{border-color:var(--primary-2);box-shadow:0 0 0 4px rgba(0,143,159,.13)}
.btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;box-shadow:0 14px 30px rgba(0,143,159,.20);transition:transform .18s ease,box-shadow .18s ease}.btn.primary:hover{transform:translateY(-1px);box-shadow:0 18px 40px rgba(0,143,159,.28)}.btn.soft{background:var(--accent-soft);color:#8a5d08}.btn.ghost{border-color:#cfe5ed;background:#fff;color:var(--primary)}
.sidebar{background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border-right-color:var(--line)}.profile-box{background:linear-gradient(180deg,var(--teal-soft),#fff);border-color:var(--line)}.role-pill{background:linear-gradient(135deg,var(--primary),var(--primary-2));box-shadow:0 10px 22px rgba(0,143,159,.17)}.nav button.active,.nav button:hover{background:var(--teal-soft);color:var(--primary)}
.eyebrow{color:var(--primary-2)}.badge{background:var(--blue-soft);color:var(--primary)}.badge.ok{background:#ddfbef;color:var(--success)}.badge.warn{background:var(--accent-soft);color:#8a5d08}.badge.bad{background:#fee4e2;color:var(--danger)}
.message-box{background:linear-gradient(180deg,#f4fdff,#ffffff);border-color:#cfe5ed}.msg{border-color:#dcecf2}.msg.mine{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;border-color:transparent}.kiosk{background:linear-gradient(135deg,#06395f,#008f9f);box-shadow:var(--shadow)}.kiosk .btn.primary{background:var(--accent);color:#432900}.paywall{border-color:var(--accent);background:linear-gradient(180deg,#fffaf0,#fff)}
.public-header,.landing-header{background:rgba(246,253,255,.82);backdrop-filter:blur(14px)}.public-nav a,.public-footer a,.footer-links a{color:var(--muted)}.public-nav a:hover,.public-footer a:hover,.footer-links a:hover{color:var(--primary)}
.landing-body{background:linear-gradient(180deg,#f5fcff 0%,#ffffff 50%,#f0fbfd 100%)}.landing-hero{background:radial-gradient(circle at 8% 0%, rgba(0,143,159,.16), transparent 32%)}.landing-hero h1,.public-hero h1,.section-title h2,.landing-section h2{color:var(--ink)}.landing-hero .lead,.lead{color:var(--muted)}.hero-visual-card,.phone-mockup{box-shadow:0 28px 80px rgba(6,76,122,.18)}.feature-icon{background:var(--teal-soft);color:var(--primary-2)}.feature-card:hover,.price-card:hover{transform:translateY(-2px);box-shadow:0 26px 75px rgba(6,76,122,.13)}.feature-card,.price-card{transition:transform .18s ease,box-shadow .18s ease}.price-card.featured{border-color:rgba(245,174,46,.75);box-shadow:0 24px 70px rgba(245,174,46,.18)}.price{color:var(--primary)}.step:before{background:linear-gradient(135deg,var(--accent),#ffd078);color:#332000}.landing-cta{background:linear-gradient(135deg,#06395f,#008f9f);color:#fff;box-shadow:var(--shadow)}.landing-cta h2,.landing-cta p{color:#fff}.landing-cta .btn.primary{background:#fff;color:var(--primary)}
.table td{border-color:var(--line)}.toast .item{background:var(--primary)}.toast .success{background:var(--success)}.toast .error{background:var(--danger)}
@media(max-width:900px){.brand-logo-img{width:210px}.auth-layout .brand-logo-img{width:220px}.sidebar-logo-img{width:200px}.landing-footer .brand-logo-img{width:200px}}

/* Ajouts RH + agenda prévisionnel */
.table input,
.table select,
.table textarea {
  width: 100%;
  min-width: 110px;
  padding: 9px 10px;
  border: 1px solid var(--border, #d9e4ee);
  border-radius: 10px;
  background: #fff;
  font: inherit;
}
.table input[type="checkbox"] {
  width: 20px;
  min-width: 20px;
  height: 20px;
}
.badge.warn { display: inline-flex; margin: 8px 0 14px; }
@media print {
  .sidebar, .topbar, .actions, #toast { display: none !important; }
  .app-shell { display: block !important; }
  .content { padding: 0 !important; }
  .card { box-shadow: none !important; border: 1px solid #ddd !important; }
}


/* === KIDCLOCK FINAL PASTEL THEME — bleu / rose / jaune / orange === */
:root{
  --bg:#fff8ef;
  --panel:#ffffff;
  --ink:#17324d;
  --muted:#6b7a90;
  --line:#f1dfd1;
  --primary:#2d7ff9;
  --primary-2:#1fb6c9;
  --accent:#ffb347;
  --accent-soft:#fff0cc;
  --pink:#ff8fb8;
  --pink-soft:#ffe7f0;
  --yellow:#ffd76a;
  --orange:#ff9f43;
  --teal-soft:#dcf8fb;
  --blue-soft:#eaf3ff;
  --danger:#e25555;
  --success:#22a06b;
  --shadow:0 22px 70px rgba(45,127,249,.13);
  --radius:26px;
}
body{background:
  radial-gradient(circle at top left, rgba(255,143,184,.22), transparent 30%),
  radial-gradient(circle at 90% 8%, rgba(255,215,106,.32), transparent 28%),
  radial-gradient(circle at 70% 80%, rgba(31,182,201,.18), transparent 28%),
  var(--bg);}
.landing-body{background:
  radial-gradient(circle at 12% 12%, rgba(255,143,184,.22), transparent 30%),
  radial-gradient(circle at 85% 10%, rgba(255,215,106,.35), transparent 30%),
  linear-gradient(180deg,#fff8ef 0%,#fff 52%,#fff4df 100%)}
.logo-mark{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;box-shadow:0 12px 28px rgba(45,127,249,.22);border-radius:16px}.brand-row span{color:var(--ink)}
.landing-header,.public-header{backdrop-filter:blur(16px);background:rgba(255,248,239,.78);border-bottom:1px solid rgba(241,223,209,.65)}
.landing-nav a,.public-nav a{color:#516173}.nav-cta,.btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff!important;box-shadow:0 14px 34px rgba(45,127,249,.20)}
.nav-login,.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--ink)!important}.btn.soft{background:linear-gradient(135deg,var(--accent-soft),var(--pink-soft));color:#9a5b00}.btn.success{background:#dcfce7;color:var(--success)}
.landing-hero,.public-hero{background:rgba(255,255,255,.83);border:1px solid rgba(241,223,209,.88);box-shadow:var(--shadow);position:relative;overflow:hidden}.landing-hero:before,.public-hero:before{content:"";position:absolute;inset:-80px -120px auto auto;width:300px;height:300px;background:radial-gradient(circle,rgba(255,215,106,.45),transparent 68%);pointer-events:none}.landing-hero:after,.public-hero:after{content:"";position:absolute;left:-120px;bottom:-120px;width:280px;height:280px;background:radial-gradient(circle,rgba(255,143,184,.22),transparent 70%);pointer-events:none}
.landing-hero>*{position:relative}.eyebrow{color:var(--orange);letter-spacing:.13em}.landing-hero h1,.public-hero h1,.topbar h1,.section-title h2,.landing-section h2{color:var(--ink);letter-spacing:-.045em}.lead,.muted{color:var(--muted)}
.phone-frame,.hero-visual-card,.phone-mockup,.kiosk-mini{background:#fff;border:1px solid var(--line);box-shadow:0 28px 90px rgba(45,127,249,.18)}.phone-top{background:linear-gradient(90deg,var(--pink),var(--yellow),var(--primary-2))}.fake-input{background:var(--blue-soft);border:1px solid #d7e9ff;color:var(--ink)}
.feature-card,.card,.legal-card,.price-card,.step,.profile-box{background:rgba(255,255,255,.91);border:1px solid rgba(241,223,209,.92);box-shadow:0 16px 44px rgba(23,50,77,.06)}.feature-card{border-radius:28px}.feature-card:hover,.price-card:hover{transform:translateY(-3px);box-shadow:0 28px 75px rgba(255,143,184,.16)}.feature-icon{background:linear-gradient(135deg,var(--pink-soft),var(--accent-soft));color:#a55800}
.badge{background:var(--blue-soft);color:#2d5f9c}.badge.ok{background:#e5fbef;color:var(--success)}.badge.warn{background:#fff3cf;color:#a05a00}.badge.bad{background:#ffe4e9;color:var(--danger)}.role-pill{background:linear-gradient(135deg,var(--primary),var(--pink));color:#fff}.tabs{background:#fff3e6}.tab.active{box-shadow:0 12px 28px rgba(255,159,67,.13)}.form-stack input:focus,.form-stack select:focus,.form-stack textarea:focus,.field:focus{border-color:var(--primary-2);box-shadow:0 0 0 4px rgba(31,182,201,.15)}
.hero-panel{background:linear-gradient(135deg,#2d7ff9 0%,#1fb6c9 52%,#ffb347 120%);box-shadow:var(--shadow);position:relative;overflow:hidden}.hero-panel:before{content:"";position:absolute;width:260px;height:260px;border-radius:999px;background:rgba(255,255,255,.18);right:-80px;top:-70px}.hero-panel:after{content:"";position:absolute;width:220px;height:220px;border-radius:999px;background:rgba(255,143,184,.22);left:-70px;bottom:-60px}.hero-panel>*{position:relative}.hero-panel p{color:rgba(255,255,255,.88)}.hero-card{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.28)}.auth-card{background:rgba(255,255,255,.94);border-color:var(--line)}
.sidebar{background:rgba(255,255,255,.94);box-shadow:10px 0 40px rgba(45,127,249,.06)}.nav button.active,.nav button:hover{background:linear-gradient(135deg,var(--blue-soft),var(--pink-soft));color:var(--ink)}.content{background:transparent}.message-box{background:linear-gradient(180deg,#fff,#fff8ef)}.msg.mine{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;border:0}.msg{border-color:var(--line)}.kiosk{background:linear-gradient(135deg,#17324d,#2d7ff9);color:#fff}.kiosk .btn.primary{background:linear-gradient(135deg,var(--yellow),var(--orange));color:#432400!important}.table td{background:#fff}.table th{color:#65758a}.step:before{background:linear-gradient(135deg,var(--yellow),var(--orange));color:#4a2900}.landing-cta{background:linear-gradient(135deg,var(--primary),var(--primary-2) 58%,var(--pink));box-shadow:var(--shadow)}.landing-cta h2,.landing-cta p{color:#fff}.landing-cta .btn.primary{background:#fff;color:var(--primary)!important}.notice{background:#fff7df;border-color:#ffe0a0;color:#8a5600}.public-footer,.landing-footer{border-color:var(--line)}
/* small child-friendly decorative dots */
.landing-section{position:relative}.landing-section:before{content:"";position:absolute;right:3%;top:18px;width:12px;height:12px;border-radius:50%;background:var(--pink);box-shadow:24px 24px 0 var(--yellow),-20px 36px 0 var(--primary-2);opacity:.45;pointer-events:none}

/* Planning semaine par semaine */
.week-title {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(66, 165, 245, .14), rgba(255, 183, 77, .16));
  color: var(--ink);
}
.week-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.week-day-card {
  border: 1px solid rgba(27, 66, 97, .09);
  border-radius: 22px;
  padding: 16px;
  background: linear-gradient(180deg, #fff, rgba(245, 250, 255, .88));
  box-shadow: 0 12px 28px rgba(38, 84, 124, .07);
}
.week-day-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}
.checkline {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 8px 0 12px;
  font-weight: 700;
}
.grid.compact {
  gap: 10px;
}
@media (max-width: 780px) {
  .week-grid { grid-template-columns: 1fr; }
}


/* === Bannière cookies KIDCLOCK === */
.cookie-banner{
  position:fixed;
  left:18px;
  right:18px;
  bottom:18px;
  z-index:9999;
  display:flex;
  gap:18px;
  align-items:center;
  justify-content:space-between;
  background:rgba(255,255,255,.96);
  border:1px solid var(--line,#f1dfd1);
  border-radius:24px;
  padding:18px;
  box-shadow:0 24px 80px rgba(23,50,77,.18);
  backdrop-filter:blur(14px);
}
.cookie-banner-text{max-width:780px;display:grid;gap:6px}.cookie-banner-text strong{color:var(--ink,#17324d);font-size:1.05rem}.cookie-banner-text p{margin:0;color:var(--muted,#6b7a90);line-height:1.45}.cookie-banner-text a{font-weight:800;color:var(--primary,#2d7ff9);text-decoration:none}.cookie-banner-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;min-width:310px}.cookie-modal-backdrop{position:fixed;inset:0;background:rgba(23,50,77,.34);z-index:10000;display:grid;place-items:center;padding:18px}.cookie-modal{width:min(680px,100%);background:#fff;border:1px solid var(--line,#f1dfd1);border-radius:28px;padding:24px;box-shadow:0 30px 100px rgba(23,50,77,.24)}.cookie-modal-head{display:flex;align-items:center;justify-content:space-between;gap:14px}.cookie-modal-head h2{margin:0;letter-spacing:-.04em}.cookie-close{border:0;background:var(--pink-soft,#ffe7f0);color:var(--ink,#17324d);width:38px;height:38px;border-radius:14px;font-size:1.5rem;font-weight:900;line-height:1}.cookie-choice{display:flex;align-items:center;justify-content:space-between;gap:18px;border:1px solid var(--line,#f1dfd1);border-radius:18px;padding:15px;margin:12px 0;background:linear-gradient(135deg,#fff,#fffaf2)}.cookie-choice div{display:grid;gap:4px}.cookie-choice span{color:var(--muted,#6b7a90);font-size:.92rem}.cookie-choice input{width:22px;height:22px;accent-color:var(--primary,#2d7ff9)}.cookie-choice.locked{background:linear-gradient(135deg,var(--blue-soft,#eaf3ff),#fff)}.cookie-modal-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;margin-top:16px}.cookie-settings-inline{margin-top:18px}.cookie-settings-inline .btn{margin-top:8px}
@media(max-width:780px){.cookie-banner{flex-direction:column;align-items:stretch}.cookie-banner-actions{min-width:0;justify-content:stretch}.cookie-banner-actions .btn{flex:1}.cookie-choice{align-items:flex-start}.cookie-modal-actions .btn{width:100%}}
.week-day-card.is-muted { opacity: .72; background: rgba(255,255,255,.65); }

/* Logo image replacement */
.brand-logo-icon{width:58px;height:58px;object-fit:contain;border-radius:16px;background:#fff;box-shadow:0 10px 26px rgba(34,76,126,.14);padding:4px;flex:0 0 auto}
.public-header .brand-logo-icon,.landing-header .brand-logo-icon{width:54px;height:54px}
.hero-panel .brand-logo-icon{width:66px;height:66px;background:rgba(255,255,255,.96)}
.sidebar-brand .brand-logo-img{max-width:160px;height:auto;object-fit:contain}
@media(max-width:640px){.brand-logo-icon{width:48px;height:48px}.public-header .brand-logo-icon,.landing-header .brand-logo-icon{width:46px;height:46px}.hero-panel .brand-logo-icon{width:56px;height:56px}}

/* Planning récurrent */
.recurrence-box{
  margin-top:18px;
  padding:18px;
  border-radius:24px;
  border:1px solid rgba(53, 91, 125, .12);
  background:linear-gradient(135deg, rgba(255,236,179,.65), rgba(255,214,224,.55), rgba(203,242,234,.55));
  box-shadow:0 14px 35px rgba(32, 62, 84, .08);
}
.recurrence-box h3{margin:0 0 6px;color:#17496b;}
.btn.accent{
  background:linear-gradient(135deg,#ff9f68,#ffd166);
  color:#263238;
  border:0;
  box-shadow:0 12px 28px rgba(255,159,104,.22);
}
.btn.accent:hover{transform:translateY(-1px);}


/* === Logo page d’accueil taille normale === */
.landing-header .landing-brand{
  flex:0 0 auto;
  max-width:250px;
  min-width:0;
}
.landing-header-logo{
  display:block;
  width:220px;
  max-width:42vw;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 8px 18px rgba(34,76,126,.08));
}
.landing-hero-logo{
  display:none;
}
@media(max-width:940px){
  .landing-header .landing-brand{max-width:240px;width:auto;flex:0 0 auto;}
  .landing-header-logo{width:200px;max-width:50vw;}
}
@media(max-width:520px){
  .landing-header-logo{width:168px;max-width:58vw;}
}

/* === SEO + responsive polish final === */
img{max-width:100%;height:auto}
.landing-header,.public-header{position:sticky;top:0;z-index:50}
.landing-nav,.public-nav{flex-wrap:wrap;gap:10px}
.landing-header-logo{max-width:220px;height:auto}
.brand-logo-img,.brand-logo-icon,.sidebar-logo-img{object-fit:contain}
.landing-hero{max-width:1180px;margin:32px auto;padding:clamp(28px,5vw,70px);display:grid;grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);gap:clamp(24px,4vw,56px);align-items:center}
.landing-hero-logo{max-width:260px;width:52%;min-width:190px;height:auto;margin-bottom:12px}
.landing-hero h1{font-size:clamp(2.25rem,6vw,5.2rem);line-height:.94;max-width:900px}
.landing-hero .lead{font-size:clamp(1rem,2vw,1.25rem);max-width:760px}
.landing-section{max-width:1180px;margin-left:auto;margin-right:auto;padding-left:clamp(18px,4vw,32px);padding-right:clamp(18px,4vw,32px)}
.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}.three-cols{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.public-main,.legal-main{max-width:1060px;margin:0 auto;padding:clamp(22px,4vw,48px)}
.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table{min-width:720px}.week-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
@media(max-width:980px){
  .landing-header,.public-header{align-items:flex-start;gap:16px;padding:16px 18px}.landing-nav,.public-nav{width:100%;justify-content:flex-start;overflow-x:auto;padding-bottom:4px}.landing-hero{grid-template-columns:1fr;margin:18px 14px}.landing-preview{order:-1}.landing-hero-logo{width:260px;max-width:70%}.auth-layout{grid-template-columns:1fr}.hero-panel{min-height:auto}.app-shell{grid-template-columns:1fr}.sidebar{position:relative;width:100%;border-right:0;border-bottom:1px solid var(--line)}.nav{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}.content{padding:18px}.topbar{flex-direction:column;align-items:flex-start;gap:10px}.actions{flex-wrap:wrap}.phone-frame{max-width:390px;margin:0 auto}
}
@media(max-width:620px){
  body{font-size:15px}.landing-header-logo{max-width:185px}.landing-hero{padding:24px 18px}.landing-hero h1{font-size:2.45rem}.hero-actions{display:grid;grid-template-columns:1fr;width:100%}.hero-actions .btn{width:100%;justify-content:center}.trust-row{display:grid;grid-template-columns:1fr;gap:8px}.feature-card,.card,.price-card{border-radius:20px;padding:18px}.auth-card{padding:18px}.tabs{display:grid;grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}.landing-cta{margin:18px 14px;padding:26px 18px}.footer-links{display:grid;grid-template-columns:1fr 1fr;gap:10px}.btn{min-height:44px}.kiosk-mini{padding:18px}.phone-frame{border-radius:26px}.week-day-card{padding:14px}.table{min-width:640px}
}

/* Correctif onglet Compte / mobile : évite que le footer légal recouvre le menu et assure l'affichage complet de la navigation. */
#appView:not(.hidden) ~ .footer-links-auth{
  display:none!important;
}

@media(max-width:900px){
  #appView.app{
    display:block;
    min-height:100svh;
  }
  #appView.app.hidden{
    display:none!important;
  }
  #appView .sidebar{
    position:relative!important;
    top:auto!important;
    height:auto!important;
    min-height:auto!important;
    max-height:none!important;
    overflow:visible!important;
    padding:16px 16px 18px!important;
    border-right:0!important;
    border-bottom:1px solid var(--line)!important;
  }
  #appView .sidebar-brand{
    display:flex;
    justify-content:center;
    padding-bottom:8px;
  }
  #appView .sidebar-brand .brand-logo-img{
    width:178px!important;
    max-width:72%!important;
  }
  #appView .profile-box{
    margin-bottom:4px;
  }
  #appView .nav{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:8px!important;
    max-height:none!important;
    overflow:visible!important;
  }
  #appView .nav button{
    width:100%!important;
    min-height:44px!important;
    padding:11px 12px!important;
    font-size:.92rem!important;
    line-height:1.15!important;
    display:flex!important;
    align-items:center!important;
    justify-content:flex-start!important;
  }
  #logoutBtn{
    position:static!important;
    width:100%!important;
    margin:10px 0 0!important;
    flex-shrink:0!important;
  }
  #appView .content{
    padding:18px 14px 34px!important;
  }
}

@media(max-width:430px){
  #appView .nav{
    grid-template-columns:1fr!important;
  }
}


/* Correctif PC onglet Compte : sidebar scrollable si le menu est plus haut que l'écran. */
#appView:not(.hidden) ~ .footer-links-auth{
  display:none!important;
}
#appView.app{
  min-height:100vh;
}
#appView .sidebar{
  height:100vh!important;
  max-height:100vh!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  gap:14px!important;
  padding-top:14px!important;
  padding-bottom:18px!important;
  scrollbar-width:thin;
}
#appView .sidebar-brand{
  padding-bottom:2px!important;
}
#appView .sidebar-brand .brand-logo-img{
  max-width:155px!important;
}
#appView .profile-box{
  padding:14px!important;
}
#appView .nav{
  gap:6px!important;
}
#appView .nav button{
  padding:10px 12px!important;
  min-height:40px!important;
  line-height:1.15!important;
}
#logoutBtn{
  margin-top:4px!important;
  flex-shrink:0!important;
}
#appView .sidebar::-webkit-scrollbar{
  width:8px;
}
#appView .sidebar::-webkit-scrollbar-thumb{
  background:rgba(100,116,139,.22);
  border-radius:999px;
}
@media(max-width:900px){
  #appView .sidebar{
    height:auto!important;
    max-height:none!important;
    overflow:visible!important;
  }
}
