*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:#fdf8f5;color:#4a3f3a;line-height:1.75;font-size:1.05rem}
a{color:#c4727e;text-decoration:none;transition:color .2s}
a:hover{color:#a85662}
img{max-width:100%;height:auto;display:block}

/* --- Header --- */
.site-header{text-align:center;padding:3rem 1.5rem 2rem;border-bottom:1px solid #ecddd5}
.site-header__name{font-size:2.2rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase;color:#c4727e}
.site-header__tagline{margin-top:.4rem;font-size:.95rem;color:#9a8a82}
.main-nav{display:flex;justify-content:center;gap:2rem;padding:.9rem 0;background:#faf3ef;border-bottom:1px solid #ecddd5;font-size:.9rem;text-transform:uppercase;letter-spacing:.06em}
.main-nav a{color:#7a6b63}
.main-nav a:hover{color:#c4727e}

/* --- Layout --- */
.content{max-width:760px;margin:0 auto;padding:2.5rem 1.5rem}
.content--wide{max-width:940px}

/* --- Homepage article list --- */
.article-list{list-style:none;display:flex;flex-direction:column;gap:2.5rem}
.preview{border-bottom:1px solid #ecddd5;padding-bottom:2rem}
.preview__link{display:block}
.preview__title{font-size:1.35rem;font-weight:600;color:#4a3f3a;margin-bottom:.3rem;transition:color .2s}
.preview__link:hover .preview__title{color:#c4727e}
.preview__date{font-size:.82rem;color:#b0a29a;margin-bottom:.5rem}
.preview__excerpt{color:#6b5e57;font-size:.97rem}

/* --- Article --- */
.article-head{margin-bottom:2rem;border-bottom:1px solid #ecddd5;padding-bottom:1.5rem}
.article-head__title{font-size:1.9rem;font-weight:700;color:#3d3530;line-height:1.25}
.article-head__meta{margin-top:.6rem;font-size:.85rem;color:#b0a29a}
.article-body{font-size:1.05rem;color:#5a4f49}
.article-body h2{font-size:1.4rem;color:#3d3530;margin:2.2rem 0 .8rem;padding-bottom:.4rem;border-bottom:1px solid #ecddd5}
.article-body h3{font-size:1.15rem;color:#c4727e;margin:1.6rem 0 .5rem}
.article-body p{margin-bottom:1.2rem}
.article-body ul,.article-body ol{margin:0 0 1.2rem 1.5rem;color:#6b5e57}
.article-body li{margin-bottom:.4rem}
.article-body blockquote{border-left:3px solid #c4727e;padding:.8rem 1.2rem;margin:1.5rem 0;background:#faf3ef;color:#6b5e57;font-style:italic}
.article-body strong{color:#3d3530}
.article-img{margin:1.8rem 0;border-radius:6px;overflow:hidden}

/* --- Info pages (about, contact, legal) --- */
.info-page h1{font-size:1.7rem;color:#3d3530;margin-bottom:1.2rem}
.info-page h2{font-size:1.25rem;color:#c4727e;margin:1.8rem 0 .6rem}
.info-page p{margin-bottom:1rem;color:#6b5e57}

/* --- Contact form --- */
.contact-form{display:flex;flex-direction:column;gap:1rem;max-width:500px}
.contact-form label{font-size:.9rem;color:#9a8a82}
.contact-form input,.contact-form textarea{background:#fff;border:1px solid #ecddd5;color:#4a3f3a;padding:.6rem .8rem;font-size:1rem;border-radius:4px;font-family:inherit}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:#c4727e}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-form button{background:#c4727e;color:#fff;border:none;padding:.7rem 1.5rem;font-size:1rem;cursor:pointer;border-radius:4px;font-weight:600;align-self:flex-start;transition:background .2s}
.contact-form button:hover{background:#a85662}

/* --- Footer --- */
.site-footer{text-align:center;padding:2rem 1.5rem;border-top:1px solid #ecddd5;margin-top:3rem;font-size:.82rem;color:#b0a29a}
.site-footer a{color:#9a8a82}
.site-footer a:hover{color:#c4727e}
.site-footer__links{display:flex;justify-content:center;gap:1.5rem;margin-bottom:.6rem}

/* --- Partner card --- */
.reco{position:fixed;bottom:1.5rem;right:1.5rem;width:320px;background:#fff;border:1px solid #ecddd5;border-radius:10px;padding:1.4rem;z-index:1000;box-shadow:0 4px 20px rgba(0,0,0,.08);opacity:0;transform:translateY(20px);transition:opacity .4s,transform .4s;pointer-events:none}
.reco--visible{opacity:1;transform:translateY(0);pointer-events:auto}
.reco__close{position:absolute;top:.5rem;right:.7rem;background:none;border:none;color:#b0a29a;font-size:1.2rem;cursor:pointer;line-height:1}
.reco__close:hover{color:#4a3f3a}
.reco__badge{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:#b0a29a;margin-bottom:.5rem}
.reco__heading{font-size:1rem;font-weight:600;color:#3d3530;margin-bottom:.4rem}
.reco__text{font-size:.88rem;color:#6b5e57;margin-bottom:.8rem;line-height:1.5}
.reco__code{display:inline-block;background:#faf3ef;border:1px dashed #c4727e;color:#c4727e;padding:.3rem .8rem;font-size:.9rem;font-weight:600;letter-spacing:.05em;border-radius:4px;margin-bottom:.8rem}
.reco__cta{display:inline-block;background:#c4727e;color:#fff;padding:.45rem 1rem;font-size:.88rem;font-weight:600;border-radius:4px;transition:background .2s}
.reco__cta:hover{background:#a85662;color:#fff}

@media(max-width:600px){
  .site-header__name{font-size:1.5rem}
  .main-nav{flex-wrap:wrap;gap:1rem .8rem;padding:.7rem 1rem}
  .content{padding:1.5rem 1rem}
  .article-head__title{font-size:1.5rem}
  .article-body h2{font-size:1.2rem}
  .reco{bottom:0;right:0;left:0;width:auto;border-radius:10px 10px 0 0;border-bottom:none}
}
