@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600&display=swap');


:root{
  --cream:#e5dacd;   /* crème doux */
  --ink:#1e3a8a;     /* bleu encre */
  --text:#2b2b2b;
  --shadow: rgba(0,0,0,.06);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background: var(--cream);
  color: var(--text);
  font-family: 'Playfair Display', serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  position:relative;
  min-height:100dvh;
  overflow-x:hidden;
}

/* Fixed illustrated background */
.bg-fixed{ position:fixed; inset:0; z-index:-1; pointer-events:none; background-image:url('assets/bg_ink_tile.svg'); background-repeat:repeat; background-size:360px 360px; }

/* Header */
.header{
  padding: clamp(12px, 2.5vw, 18px) 16px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.brand{ text-align:center; color:#444; line-height:1.2 }
.brand-name{ font-weight:800; color:var(--ink); letter-spacing:.2px }
.brand-role{ display:block; font-size:.95rem; opacity:.85 }

/* Grid */
.grid{
  max-width: min(1100px, 94vw);
  margin: 0 auto;
  padding: clamp(14px, 4vw, 28px) 10px clamp(18px, 5vw, 36px);
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(14px, 4vw, 28px);
  align-items: start;
}

.logo-col{ display:flex; align-items:flex-start; justify-content:center }
.logo{
  width:100%;
  max-width:520px;
  height:auto;
  display:block;
  border-radius:14px;
  box-shadow: none;
}

.content-col{ display:flex; flex-direction:column; align-items:flex-start }
.text-block{ font-size: clamp(15.5px, 1.6vw, 18px); line-height:1.55 }
.text-block p{ margin: 0 0 .65em }

/* Icons */
.icons{ display:flex; gap:12px; flex-wrap:wrap; margin-top: clamp(10px, 3vw, 16px) }
.icon{
  width:40px; height:40px; display:grid; place-items:center;
  border-radius:50%; border:1.6px solid var(--ink);
  background: transparent; text-decoration:none;
  transition: transform .08s ease, opacity .2s ease; opacity:.9
}
.icon:hover{ transform: translateY(-1px); opacity:1 }
.icon:active{ transform: scale(.98) }
.icon svg{ width:19px; height:19px; stroke:var(--ink); fill:none; stroke-width:1.6 }
.icon svg rect, .icon svg circle, .icon svg path{ stroke:var(--ink); fill:none }

/* Footer */
.footer{ padding: clamp(16px, 4vw, 28px) 16px 36px; text-align:center; color:#555; font-size:.95rem }

/* Mobile */
@media (max-width: 860px){
  .grid{ grid-template-columns:1fr; gap: clamp(10px, 3.5vw, 18px) }
  .logo{ max-width:420px; margin:0 auto }
  .content-col{ align-items:center; text-align:center }
}

.content-col p{ margin: 0 0 .9em; line-height: 1.6 }
