/* Poppins est déjà chargé par website/layout.blade.php — pas d'@import ici. */

/* =========================================================
   Kanimmo SMS — Home (refonte)
   Tout est scopé sous .kn-home pour ne pas impacter
   le header/footer du layout ni les autres pages.
   Couleurs de marque modifiables ci-dessous.
   ========================================================= */
.kn-home{
    --kn-navy:#09132d;
    --kn-blue:#1f3cad;
    --kn-green:#1aa981;
    --kn-green-dk:#158a69;
    --kn-yellow:#fcae3b;
    --kn-text:rgba(0,0,0,.72);
    --kn-muted:rgba(255,255,255,.78);
    font-family:'Poppins',sans-serif;
    color:var(--kn-text);
    line-height:1.6;
    overflow-x:hidden;
}
.kn-home *{box-sizing:border-box}
.kn-home img{max-width:100%;display:block}
.kn-home a{text-decoration:none}
.kn-home .kn-wrap{max-width:1180px;margin-inline:auto;padding-inline:24px}

/* ---------- Boutons ---------- */
.kn-home .kn-btn{
    display:inline-flex;align-items:center;justify-content:center;gap:8px;
    font-family:'Poppins',sans-serif;font-weight:700;font-size:13px;
    letter-spacing:1.5px;text-transform:uppercase;
    padding:15px 34px;border:0;border-radius:999px;cursor:pointer;
    color:#fff;background:var(--kn-green);
    box-shadow:0 12px 26px -12px rgba(26,169,129,.8);
    transition:transform .18s ease,background .18s ease,box-shadow .18s ease,filter .18s ease;
}
.kn-home .kn-btn:hover{background:var(--kn-green-dk);transform:translateY(-2px);color:#fff}

/* ---------- Hero ---------- */
.kn-home .kn-hero{
    position:relative;background:var(--kn-navy);color:#fff;text-align:center;
    padding:130px 0 40px;overflow:hidden;
}
.kn-home .kn-hero::before{
    content:"";position:absolute;inset:0;background:
        radial-gradient(820px 380px at 50% -8%, rgba(31,60,173,.55), transparent 68%),
        radial-gradient(600px 400px at 90% 110%, rgba(26,169,129,.18), transparent 60%);
}
.kn-home .kn-hero__inner{position:relative;max-width:760px;margin-inline:auto}
.kn-home .kn-hero__sub{
    font-weight:800;font-size:clamp(2rem,4.8vw,3.2rem);line-height:1.1;
    margin:0 0 14px;color:#fff;letter-spacing:-.5px;
    min-height:2.2em;display:flex;align-items:center;justify-content:center;
}
.kn-home .kn-rotate{
    display:inline-block;text-align:center;
    transition:opacity .45s ease, transform .45s ease;
}
.kn-home .kn-rotate.is-out{opacity:0;transform:translateY(-16px)}
.kn-home .kn-hero__title{font-weight:600;font-size:1.1rem;color:#fff;margin:0 0 14px}
.kn-home .kn-hero__body{
    color:#1aa981;font-weight:600;font-size:clamp(1rem,1.5vw,1.12rem);
    max-width:600px;margin:0 auto 30px;
}
.kn-home .kn-hero__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- Mockup laptop (chevauche le hero) ---------- */
.kn-home .kn-showcase{position:relative;background:#fff;padding:0 0 90px}
.kn-home .kn-showcase::before{
    content:"";position:absolute;top:0;left:0;right:0;height:160px;
    background:#09132d;z-index:0;
}
.kn-home .kn-laptop{position:relative;z-index:1;max-width:680px;margin:0 auto;padding:40px 24px 0}

/* Capot + bezel argenté */
.kn-home .kn-laptop__lid{
    position:relative;
    background:linear-gradient(180deg,#f1f3f7 0%,#dfe3ea 100%);
    border-radius:16px 16px 8px 8px;
    padding:14px 14px 16px;
    box-shadow:0 34px 64px -30px rgba(9,19,45,.5);
}
.kn-home .kn-laptop__lid::before{
    content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);
    width:5px;height:5px;border-radius:50%;background:#b6bcc8;
}
.kn-home .kn-laptop__screen{
    border-radius:5px;overflow:hidden;background:#eef1f5;
    box-shadow:inset 0 0 0 1px rgba(9,19,45,.12);
}
.kn-home .kn-laptop__screen img{display:block;width:100%;height:auto;background:#eef1f5}

/* Base / clavier */
.kn-home .kn-laptop__base{
    position:relative;left:50%;transform:translateX(-50%);
    width:122%;height:16px;margin-top:-1px;
    background:linear-gradient(180deg,#d9dde6 0%,#eef0f5 45%,#cdd2dc 100%);
    border-radius:2px 2px 12px 12px;
    clip-path:polygon(2% 0, 98% 0, 100% 100%, 0 100%);
    box-shadow:0 18px 26px -16px rgba(9,19,45,.45);
}
.kn-home .kn-laptop__base::after{
    content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
    width:120px;height:7px;background:#bcc2cf;border-radius:0 0 7px 7px;
}

/* ---------- Sections ---------- */
.kn-home .kn-section{padding:90px 0}
.kn-home .kn-eyebrow{
    display:inline-block;color:var(--kn-green);font-weight:700;font-size:13px;
    letter-spacing:2px;text-transform:uppercase;margin-bottom:14px;
}
.kn-home .kn-h2{
    font-weight:800;font-size:clamp(1.7rem,3.4vw,2.5rem);color:var(--kn-navy);
    line-height:1.15;letter-spacing:-.4px;margin:0;
}

/* ---------- Introduction (split) ---------- */
.kn-home .kn-split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.kn-home .kn-split__lead{margin:6px 0 24px;font-size:1.02rem}

/* Grille de services (remplace l'image dans l'intro) */
.kn-home .kn-feats{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.kn-home .kn-feat{
    display:flex;align-items:center;gap:14px;
    background:#f3f5f8;border-radius:14px;padding:22px 20px;min-height:96px;
    transition:transform .18s ease,box-shadow .18s ease;
}
.kn-home .kn-feat:hover{transform:translateY(-3px);box-shadow:0 16px 30px -20px rgba(9,19,45,.35)}
.kn-home .kn-feat__icon{width:32px;height:32px;flex:0 0 32px;object-fit:contain}
.kn-home .kn-feat__txt{font-weight:700;color:var(--kn-navy);line-height:1.25}
.kn-home .kn-checks{list-style:none;display:grid;gap:14px;margin:0;padding:0}
.kn-home .kn-checks li{display:flex;align-items:center;gap:12px;font-weight:500;color:var(--kn-navy)}
.kn-home .kn-checks li img{width:24px;height:24px;flex:0 0 24px;object-fit:contain}
.kn-home .kn-split__img{border-radius:18px;overflow:hidden;box-shadow:0 30px 60px -30px rgba(9,19,45,.35)}
.kn-home .kn-split__img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}

/* ---------- Packs (style cartes Tarifications) ---------- */
.kn-home .kn-packs{background:#f5f7fb}
.kn-home .kn-packs__head{text-align:center;margin-bottom:50px}
.kn-home .kn-packs__sub{max-width:560px;margin:14px auto 0;color:var(--kn-text)}
.kn-home .kn-packs__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;align-items:stretch}
.kn-home .kn-pack{
    --accent:var(--kn-blue);
    background:#fff;border-radius:14px;padding:0 26px 32px;
    border-top:4px solid var(--accent);text-align:center;
    display:flex;flex-direction:column;
    box-shadow:0 18px 40px -26px rgba(9,19,45,.35);
    transition:transform .2s ease,box-shadow .2s ease;
}
.kn-home .kn-pack:hover{transform:translateY(-6px);box-shadow:0 28px 54px -26px rgba(9,19,45,.45)}
.kn-home .kn-pack__name{font-weight:800;font-size:1.2rem;color:var(--accent);margin:32px 0 18px}
.kn-home .kn-pack__badge{
    align-self:center;background:var(--accent);color:#fff;font-weight:700;font-size:.92rem;
    letter-spacing:.5px;padding:11px 24px;border-radius:8px;margin-bottom:18px;
    box-shadow:0 12px 24px -12px var(--accent);
}
.kn-home .kn-pack__unit{font-size:.86rem;color:rgba(0,0,0,.55);margin-bottom:28px}
.kn-home .kn-pack__unit b{color:var(--accent);font-size:1rem}
.kn-home .kn-pack .kn-btn{
    width:100%;font-size:12px;padding:13px 0;margin-top:auto;
    background:var(--accent);box-shadow:0 12px 26px -14px var(--accent);
}
.kn-home .kn-pack .kn-btn:hover{filter:brightness(.93);transform:translateY(-2px);background:var(--accent)}

/* ---------- Responsive ---------- */
@media (max-width:900px){
    .kn-home .kn-split{grid-template-columns:1fr;gap:32px}
    .kn-home .kn-packs__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
    .kn-home .kn-packs__grid{grid-template-columns:1fr}
    .kn-home .kn-feats{grid-template-columns:1fr}
    .kn-home .kn-hero{padding:100px 0 90px}
    .kn-home .kn-section{padding:64px 0}
}

/* =========================================================
   Chrome partagé du layout website (navbar + footer)
   Hors scope .kn-home car ces éléments vivent dans le layout.
   ========================================================= */

/* ---------- Navbar (fixed-top) ---------- */
.kn-navbar{
    background:rgba(9,19,45,.92)!important;
    -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
    box-shadow:0 6px 24px -16px rgba(0,0,0,.6);
    padding-top:.55rem;padding-bottom:.55rem;
    transition:background .2s ease;
}
.kn-navbar .navbar-brand img{height:34px;width:auto}
.kn-navbar .navbar-nav{align-items:center;gap:6px}
.kn-navbar .nav-link{
    color:#fff!important;font-family:'Poppins',sans-serif;font-weight:500;font-size:14px;
    opacity:.85;transition:opacity .15s ease;
}
.kn-navbar .nav-link:hover{opacity:1;color:#fff!important}
.kn-navbar .navbar-toggler{border-color:rgba(255,255,255,.35)}
.kn-navbar .navbar-toggler i{color:#fff}

/* « Connexion » / « Mon espace » en bouton vert */
.kn-navbar .kn-nav-cta{
    background:#1aa981;color:#fff!important;opacity:1;
    padding:9px 24px!important;border-radius:999px;
    font-weight:700!important;letter-spacing:.5px;
    box-shadow:0 10px 22px -12px rgba(26,169,129,.8);
    transition:background .18s ease,transform .18s ease;
}
.kn-navbar .kn-nav-cta:hover{background:#158a69;transform:translateY(-2px)}

/* Menu mobile (collapse ouvert) : fond navy pour rester lisible */
@media (max-width:991px){
    .kn-navbar .navbar-collapse{
        background:rgba(9,19,45,.98);border-radius:12px;
        margin-top:10px;padding:12px 16px;
    }
    .kn-navbar .navbar-nav{align-items:flex-start;gap:4px}
    .kn-navbar .kn-nav-cta{display:inline-block;margin-top:6px}
}

/* ---------- Footer ---------- */
.kn-footer{background:#09132d!important;background-image:none!important;padding:46px 0 0}
.kn-footer .ftr_btm{padding:0 0 28px}
.kn-footer h6{
    color:rgba(255,255,255,.7);font-family:'Poppins',sans-serif;
    font-weight:400;font-size:.9rem;margin:0;
}
.kn-footer h6 strong{color:#fff}
.kn-footer a{color:#1aa981;text-decoration:none}
.kn-footer a:hover{color:#36c49d}

/* =========================================================
   Animations d'entrée du hero (texte + laptop)
   ========================================================= */
@keyframes knFadeUp{
    from{opacity:0;transform:translateY(26px)}
    to{opacity:1;transform:translateY(0)}
}
.kn-home .kn-hero__sub,
.kn-home .kn-hero__title,
.kn-home .kn-hero__body,
.kn-home .kn-hero__cta{
    opacity:0;
    animation:knFadeUp .7s cubic-bezier(.22,.61,.36,1) forwards;
}
.kn-home .kn-hero__sub{animation-delay:.10s}
.kn-home .kn-hero__title{animation-delay:.28s}
.kn-home .kn-hero__body{animation-delay:.44s}
.kn-home .kn-hero__cta{animation-delay:.60s}
.kn-home .kn-laptop{animation:knFadeUp .8s cubic-bezier(.22,.61,.36,1) .72s both}

/* Accessibilité : pas d'animation si l'utilisateur la désactive */
@media (prefers-reduced-motion:reduce){
    .kn-home .kn-hero__sub,
    .kn-home .kn-hero__title,
    .kn-home .kn-hero__body,
    .kn-home .kn-hero__cta,
    .kn-home .kn-laptop{animation:none;opacity:1;transform:none}
}

/* ---------- Logo navbar ---------- */
.kn-navbar__logo{height:34px;width:auto}
/* Si ton logo est monochrome et doit ressortir en blanc sur la navbar navy,
   décommente la ligne suivante :
.kn-navbar__logo{filter:brightness(0) invert(1);}
*/