
  :root{
    --white:#FFFFFF;
    --ivory:#F0ECE6;
    --blush:#E0C8BC;
    --mauve:#BD9C89;
    --mauve-deep:#6E5847;
    --ink:#332A23;
    --ink-soft:#5B4F47;
    --line:rgba(189,156,137,0.4);
    --maxw:1180px;
  }

  *{box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  @media (prefers-reduced-motion: reduce){
    html{scroll-behavior:auto;}
    *{animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important;}
  }
  body{
    margin:0;
    background:var(--white);
    color:var(--ink);
    font-family:'Work Sans', sans-serif;
    font-weight:400;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
  }
  img{max-width:100%; display:block;}
  a{color:inherit;}
  ::selection{background:var(--blush); color:var(--ink);}

  h1,h2,h3{
    font-family:'Fraunces', serif;
    font-weight:400;
    margin:0;
    letter-spacing:-0.01em;
  }
  .serif-italic{font-style:italic;}

  .wrap{max-width:var(--maxw); margin:0 auto; padding:0 32px;}
  @media (max-width:640px){ .wrap{padding:0 22px;} }

  .eyebrow{
    display:flex; align-items:center; gap:10px;
    font-family:'Work Sans', sans-serif;
    font-size:12px;
    letter-spacing:0.2em;
    text-transform:uppercase;
    color:var(--mauve-deep);
    font-weight:600;
    margin-bottom:22px;
  }
  .eyebrow svg{flex:none;}

  /* ===== branch motif (signature) ===== */
  .branch-corner{position:absolute; pointer-events:none; opacity:0.55; z-index:0;}
  .branch-corner.br{right:0; bottom:0;}
  .branch-corner.tl{left:0; top:0; transform:scaleX(-1) scaleY(-1);}

  /* ===== nav ===== */
  header{
    position:fixed; top:0; left:0; right:0; z-index:50;
    padding:26px 0;
    transition:background .35s ease, padding .35s ease, border-color .35s ease;
    border-bottom:1px solid transparent;
  }
  header.solid{
    background:rgba(255,255,255,0.92);
    backdrop-filter:blur(10px);
    padding:16px 0;
    border-bottom:1px solid var(--line);
  }
  header .wrap{display:flex; align-items:center; justify-content:space-between; gap:24px;}
  .brand{
    display:inline-flex;
    align-items:baseline;
    text-decoration:none;
    white-space:nowrap;
    color:var(--ink);
    font-size:23px;
    gap:1px;
    flex:none;
  }
  body.dark-section header:not(.solid) .brand{color:var(--white);}
  .logo-script{
    font-family:'Pinyon Script', cursive;
    font-size:1.7em;
    line-height:0.5;
    color:inherit;
  }
  .logo-serif{
    font-family:'Noto Serif Display', serif;
    font-weight:400;
    letter-spacing:0.01em;
    color:inherit;
  }
  .logo-space{width:0.22em; display:inline-block;}
  nav.links{display:flex; gap:23px; list-style:none; margin:0; padding:0; flex-wrap:nowrap;}
  nav.links a{
    font-size:11px; text-decoration:none; letter-spacing:0.05em;
    text-transform:uppercase; font-weight:500; white-space:nowrap;
    color:var(--ink); position:relative; padding-bottom:5px;
  }
  body.dark-section header:not(.solid) nav.links a{color:var(--white);}
  nav.links a::after{
    content:''; position:absolute; left:0; right:100%; bottom:0; height:1px;
    background:var(--mauve-deep); transition:right .25s ease;
  }
  body.dark-section header:not(.solid) nav.links a::after{background:var(--white);}
  nav.links a:hover::after{right:0;}
  .menu-toggle{display:none; background:none; border:0; cursor:pointer; padding:6px; flex:none;}
  .menu-toggle svg{stroke:var(--ink);}
  body.dark-section header:not(.solid) .menu-toggle svg{stroke:var(--white);}

  @media (max-width: 1080px){
    nav.links{
      position:fixed; inset:0; top:0; height:100vh; background:var(--mauve-deep);
      flex-direction:column; justify-content:center; align-items:flex-start;
      padding:0 40px; gap:26px; transform:translateX(100%);
      transition:transform .4s ease; z-index:60;
    }
    nav.links.open{transform:translateX(0);}
    nav.links a{color:var(--white) !important; font-size:22px; font-family:'Fraunces',serif; font-style:italic; letter-spacing:normal; text-transform:none;}
    nav.links a::after{display:none;}
    .menu-toggle{display:block;}
  }

  /* ===== hero ===== */
  .hero{
    position:relative; min-height:100vh;
    background:
      linear-gradient(180deg, rgba(51,42,35,0.12) 0%, rgba(40,30,22,0.7) 100%),
      url('images/hero.jpg') center 30% / cover no-repeat;
    color:var(--white);
    display:flex; align-items:flex-end; justify-content:center; text-align:center;
    overflow:hidden;
    padding-top:120px;
  }
  .hero .wrap{position:relative; z-index:2; padding-bottom:120px; width:100%; display:flex; flex-direction:column; align-items:center;}
  .hero-eyebrow{
    font-size:12.5px; letter-spacing:0.28em; text-transform:uppercase;
    color:rgba(255,255,255,0.9); margin-bottom:24px; opacity:0;
    animation:fadeUp .9s ease forwards .2s;
  }
  .hero h1{
    font-size:clamp(40px, 7vw, 92px);
    font-weight:300; font-style:normal;
    max-width:16ch; line-height:1.05;
    color:var(--white);
    opacity:0; animation:fadeUp .9s ease forwards .4s;
  }
  .hero-sub{
    max-width:480px; margin:24px auto 0; font-size:15.5px;
    color:rgba(255,255,255,0.85); font-weight:300;
    opacity:0; animation:fadeUp .9s ease forwards .6s;
  }
  .hero-actions{display:flex; gap:18px; margin-top:38px; flex-wrap:wrap; justify-content:center;
    opacity:0; animation:fadeUp .9s ease forwards .8s;}
  .btn-primary, .btn-ghost{
    font-family:'Work Sans'; font-size:13.5px; letter-spacing:0.04em;
    padding:15px 28px; text-decoration:none; border-radius:2px;
    display:inline-flex; align-items:center; gap:10px;
    transition:transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
  }
  .btn-primary{background:var(--white); color:var(--mauve-deep); font-weight:500;}
  .btn-primary:hover{background:var(--ivory); transform:translateY(-2px);}
  .btn-ghost{border:1px solid rgba(255,255,255,0.6); color:var(--white);}
  .btn-ghost:hover{border-color:var(--white); transform:translateY(-2px);}

  @keyframes fadeUp{
    from{opacity:0; transform:translateY(16px);}
    to{opacity:1; transform:translateY(0);}
  }

  .scroll-cue{
    position:absolute; right:32px; bottom:36px; z-index:2;
    display:flex; flex-direction:column; align-items:center; gap:10px;
    color:rgba(255,255,255,0.75); font-size:11px; letter-spacing:0.18em;
  }
  .scroll-cue .line{width:1px; height:46px; background:rgba(255,255,255,0.4); position:relative; overflow:hidden;}
  .scroll-cue .line::after{
    content:''; position:absolute; left:0; top:-100%; width:100%; height:100%;
    background:var(--white); animation:drip 2.2s ease-in-out infinite;
  }
  @keyframes drip{0%{top:-100%;} 60%{top:100%;} 100%{top:100%;}}

  /* ===== sections generic ===== */
  section{position:relative; padding:130px 0; z-index:1; overflow:hidden;}
  @media (max-width:640px){ section{padding:90px 0;} }
  .section-head{max-width:560px; margin-bottom:64px;}
  .section-head.center{margin-left:auto; margin-right:auto; text-align:center;}
  .section-head h2{font-size:clamp(28px,3.6vw,46px); font-weight:300;}
  .section-head p{margin-top:18px; font-size:16px; color:var(--ink-soft); font-weight:300; max-width:46ch;}
  .section-head.center p{margin-left:auto; margin-right:auto;}
  .section-head.center .eyebrow{justify-content:center;}

  /* ===== manifesto / intro ===== */
  .manifesto{background:var(--white);}
  .manifesto-grid{
    display:grid; grid-template-columns:0.9fr 1.1fr; gap:70px; align-items:start;
  }
  @media (max-width:860px){ .manifesto-grid{grid-template-columns:1fr; gap:40px;} }
  .manifesto-intro p{font-size:18px; font-weight:300; color:var(--ink-soft); max-width:38ch;}
  .values{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:0;}
  .values li{
    display:flex; gap:22px; padding:28px 0; border-top:1px solid var(--line);
  }
  .values li:last-child{border-bottom:1px solid var(--line);}
  .values .v-icon{
    flex:none; width:38px; height:38px; border-radius:50%;
    border:1px solid var(--mauve); display:flex; align-items:center; justify-content:center;
    color:var(--mauve-deep);
  }
  .values h3{font-size:18px; font-weight:500; font-style:italic; margin-bottom:8px;}
  .values p{margin:0; font-size:14.5px; color:var(--ink-soft); font-weight:300; max-width:42ch;}

  /* ===== offres ===== */
  .offres{background:var(--ivory);}
  .offers-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line);}
  @media (max-width:920px){ .offers-grid{grid-template-columns:1fr;} }
  .offer-card{
    background:var(--ivory); padding:44px 34px; display:flex; flex-direction:column;
    transition:background .3s ease;
  }
  .offer-card:hover{background:var(--white);}
  .offer-card.featured{background:var(--mauve-deep); color:var(--white);}
  .offer-card.featured:hover{background:#5e4a3c;}
  .offer-tag{font-size:11px; letter-spacing:0.16em; text-transform:uppercase; color:var(--mauve-deep); margin-bottom:18px;}
  .offer-card.featured .offer-tag{color:var(--blush);}
  .offer-card h3{font-size:30px; font-style:italic; font-weight:400; margin-bottom:14px;}
  .offer-card .desc{font-size:14.5px; font-weight:300; opacity:0.85; margin-bottom:26px; min-height:42px;}
  .offer-card ul{list-style:none; margin:0 0 30px; padding:0; display:flex; flex-direction:column; gap:10px; flex:1;}
  .offer-card li{font-size:13.5px; font-weight:300; display:flex; gap:10px; align-items:flex-start;}
  .offer-card li::before{content:'—'; color:var(--mauve); flex:none;}
  .offer-card.featured li::before{color:var(--blush);}
  .offer-price{font-size:13px; letter-spacing:0.04em; padding-top:20px; border-top:1px solid var(--line); opacity:0.9;}
  .offer-card.featured .offer-price{border-top-color:rgba(255,255,255,0.25);}
  .offer-price strong{font-family:'Fraunces'; font-style:italic; font-size:19px; font-weight:500; display:block; margin-top:4px;}

  /* ===== portfolio (photo grid) ===== */
  .portfolio{background:var(--white);}
  .pf-grid{
    display:grid; grid-template-columns:repeat(3, 1fr); grid-auto-rows:200px; gap:24px;
    grid-auto-flow:row dense;
  }
  @media (max-width:920px){ .pf-grid{grid-template-columns:repeat(2,1fr); grid-auto-rows:170px;} }
  @media (max-width:560px){ .pf-grid{grid-template-columns:1fr; grid-auto-rows:240px;} }
  .pf-card{
    position:relative; border-radius:2px; overflow:hidden;
  }
  .pf-card.tall{grid-row:span 2;}
  .pf-card.wide{grid-column:span 2;}
  @media (max-width:560px){ .pf-card.wide{grid-column:span 1;} }
  .pf-card .bg{position:absolute; inset:0; transition:transform .6s ease;}
  .pf-card:hover .bg{transform:scale(1.05);}
  .pf1 .bg{background:url('images/portfolio-1.jpg') center 25% / cover no-repeat;}
  .pf2 .bg{background:url('images/portfolio-2.jpg') center 30% / cover no-repeat;}
  .pf3 .bg{background:linear-gradient(135deg,#F0ECE6,#DCC6B6 55%,#B79179);}
  .pf4 .bg{background:linear-gradient(135deg,#E0C8BC,#A9836C 65%,#7E5F4C);}
  .pf5 .bg{background:url('images/portfolio-3.jpg') center 25% / cover no-repeat;}
  .pf6 .bg{background:linear-gradient(135deg,#EADFD3,#C8A68F 55%,#8C6A55);}
  .pf7 .bg{background:url('images/portfolio-4.jpg') center 40% / cover no-repeat;}
  .pf-caption{margin-top:14px; display:flex; justify-content:space-between; align-items:baseline; gap:10px;}
  .pf-caption h3{font-family:'Fraunces'; font-style:italic; font-size:18px; font-weight:400;}
  .pf-caption .loc{font-size:12px; color:var(--ink-soft); letter-spacing:0.03em; white-space:nowrap;}
  .pf-item{display:flex; flex-direction:column;}

  /* ===== temoignages ===== */
  .temoignages{background:var(--white);}
  .temoignages-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:36px;}
  @media (max-width:920px){ .temoignages-grid{grid-template-columns:1fr; gap:30px;} }
  .temoignage-card{
    background:var(--ivory); padding:40px 32px 32px; border-radius:2px;
    border:1px solid var(--line); position:relative;
    display:flex; flex-direction:column;
  }
  .quote-mark{
    font-family:'Fraunces', serif; font-style:italic; font-size:52px;
    color:var(--blush); line-height:1; margin-bottom:6px;
  }
  .temoignage-card p{
    font-size:15px; font-weight:300; color:var(--ink-soft); line-height:1.7; margin:0 0 22px;
    flex:1;
  }
  .temoignage-author{
    font-family:'Fraunces', serif; font-style:italic; font-size:16px; color:var(--mauve-deep);
    padding-top:18px; border-top:1px solid var(--line);
  }

  /* ===== application ===== */
  .app-section{background:var(--ivory);}
  .app-grid{display:grid; grid-template-columns:0.85fr 1.15fr; gap:70px; align-items:center;}
  @media (max-width:920px){ .app-grid{grid-template-columns:1fr; gap:54px;} .phone-wrap{order:2; margin:0 auto;} }
  .phone-wrap{position:relative; display:flex; justify-content:center;}
  .phone{
    width:260px; border-radius:28px; background:var(--mauve-deep);
    padding:10px; box-shadow:0 30px 60px -20px rgba(110,88,71,0.4);
    position:relative;
  }
  .phone-screen{
    background:var(--white); border-radius:20px; overflow:hidden; padding:22px 18px;
    min-height:480px; display:flex; flex-direction:column; gap:16px;
  }
  .phone-screen .ps-top{font-size:11px; color:var(--mauve-deep); letter-spacing:0.1em; text-transform:uppercase;}
  .phone-screen h4{font-family:'Fraunces'; font-style:italic; font-size:19px; font-weight:500; margin:2px 0 6px; color:var(--ink);}
  .budget-bar{background:var(--ivory); border-radius:8px; height:10px; overflow:hidden; margin-top:6px;}
  .budget-bar i{display:block; height:100%; width:62%; background:var(--mauve); border-radius:8px;}
  .budget-row{display:flex; justify-content:space-between; font-size:11.5px; color:var(--ink-soft); margin-top:6px;}
  .ps-list{display:flex; flex-direction:column; gap:10px; margin-top:8px;}
  .ps-item{display:flex; align-items:center; gap:10px; font-size:13px; padding:10px 12px; background:var(--ivory); border-radius:10px; border:1px solid #ece1d6;}
  .ps-item .dot{width:16px; height:16px; border-radius:50%; border:1.5px solid var(--mauve); flex:none;}
  .ps-item.done .dot{background:var(--mauve);}
  .ps-item.done span{text-decoration:line-through; opacity:0.5;}
  .app-features{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:0;}
  .app-features li{display:flex; gap:20px; padding:24px 0; border-top:1px solid var(--line);}
  .app-features li:last-child{border-bottom:1px solid var(--line);}
  .app-features .f-icon{flex:none; width:36px; height:36px; display:flex; align-items:center; justify-content:center; color:var(--mauve-deep);}
  .app-features h3{font-size:17px; font-weight:500; font-style:italic;}
  .app-features p{margin:6px 0 0; font-size:14px; font-weight:300; color:var(--ink-soft); max-width:44ch;}
  .store-row{display:flex; gap:14px; margin-top:34px; flex-wrap:wrap;}
  .store-btn{
    display:flex; align-items:center; gap:10px; padding:13px 20px;
    border:1px solid var(--ink); border-radius:2px; text-decoration:none;
    font-size:13px; color:var(--ink); transition:background .25s, color .25s;
  }
  .store-btn:hover{background:var(--ink); color:var(--white);}
  .store-btn small{display:block; font-size:9.5px; letter-spacing:0.08em; text-transform:uppercase; opacity:0.7;}
  .store-btn strong{font-family:'Fraunces'; font-style:italic; font-weight:500; font-size:14.5px;}

  /* ===== contact ===== */
  /* ===== a propos ===== */
  .about-hero{background:var(--white);}
  .about-grid{display:grid; grid-template-columns:0.8fr 1.2fr; gap:70px; align-items:center;}
  @media (max-width:860px){ .about-grid{grid-template-columns:1fr; gap:40px;} }
  .about-photo{
    position:relative; width:100%; aspect-ratio:4/5; border-radius:2px; overflow:hidden;
    background-color:var(--blush);
    background-image:url('images/chloe-apropos.jpg');
    background-position:center 20%; background-size:cover; background-repeat:no-repeat;
  }
  .about-photo .monogram{
    font-family:'Pinyon Script', cursive; font-size:140px; color:rgba(255,255,255,0.85);
    line-height:1;
  }
  .about-text p{font-size:16px; font-weight:300; color:var(--ink-soft); line-height:1.8; margin:0 0 20px; max-width:52ch;}
  .about-signature{
    font-family:'Pinyon Script', cursive; font-size:34px; color:var(--mauve-deep); margin-top:10px;
  }
  .about-trait{
    display:inline-block; font-size:12px; letter-spacing:0.1em; text-transform:uppercase;
    color:var(--mauve-deep); border:1px solid var(--mauve); border-radius:20px;
    padding:6px 16px; margin:4px 8px 4px 0;
  }

  .about-teaser{background:var(--white);}
  .about-teaser-grid{display:grid; grid-template-columns:0.7fr 1.3fr; gap:56px; align-items:center;}
  @media (max-width:860px){ .about-teaser-grid{grid-template-columns:1fr; gap:32px;} }
  .about-teaser-photo{
    width:100%; aspect-ratio:4/5; border-radius:2px; overflow:hidden; max-width:260px;
    background-color:var(--blush);
    background-image:url('images/chloe-teaser.jpg');
    background-position:center 25%; background-size:cover; background-repeat:no-repeat;
  }
  .about-teaser-photo .monogram{
    font-family:'Pinyon Script', cursive; font-size:90px; color:rgba(255,255,255,0.85); line-height:1;
  }
  .about-teaser-text p{font-size:16px; font-weight:300; color:var(--ink-soft); line-height:1.8; max-width:52ch; margin:0 0 22px;}
  .about-teaser-link{
    font-family:'Fraunces', serif; font-style:italic; font-size:15px; color:var(--mauve-deep);
    text-decoration:none; border-bottom:1px solid var(--mauve); padding-bottom:2px;
  }

  .contact{background:var(--white);}
  .contact-grid{display:grid; grid-template-columns:1.1fr 0.9fr; gap:80px;}
  @media (max-width:920px){ .contact-grid{grid-template-columns:1fr; gap:50px;} }
  .field{display:flex; flex-direction:column; gap:8px; margin-bottom:22px;}
  .field label{font-size:12px; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-soft);}
  .field input, .field textarea{
    background:transparent; border:none; border-bottom:1px solid var(--mauve);
    padding:10px 2px; font-family:'Work Sans'; font-size:15.5px; color:var(--ink);
    outline:none; transition:border-color .25s ease; resize:none;
  }
  .field input:focus, .field textarea:focus{border-color:var(--mauve-deep);}
  .two-col{display:grid; grid-template-columns:1fr 1fr; gap:20px;}
  @media (max-width:520px){ .two-col{grid-template-columns:1fr;} }
  .submit-btn{
    margin-top:10px; background:var(--mauve-deep); color:var(--white); border:none;
    padding:16px 30px; font-family:'Work Sans'; font-size:13.5px; letter-spacing:0.05em;
    border-radius:2px; cursor:pointer; transition:background .25s ease, transform .25s ease;
  }
  .submit-btn:hover{background:#5e4a3c; transform:translateY(-2px);}
  .contact-info{display:flex; flex-direction:column; gap:30px;}
  .contact-info .ci-row{padding-top:22px; border-top:1px solid var(--line);}
  .contact-info .ci-row:first-child{border-top:none; padding-top:0;}
  .contact-info .ci-label{font-size:11.5px; letter-spacing:0.12em; text-transform:uppercase; color:var(--mauve-deep); margin-bottom:8px;}
  .contact-info a{text-decoration:none; font-family:'Fraunces'; font-style:italic; font-size:19px;}
  .contact-info .note{font-size:13.5px; color:var(--ink-soft); font-weight:300; margin-top:4px;}

  /* focus visibility */
  a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
    outline:2px solid var(--mauve-deep); outline-offset:3px;
  }

  /* ===== footer ===== */
  footer{background:var(--mauve-deep); color:rgba(255,255,255,0.78); padding:64px 0 32px;}
  .footer-top{display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:40px; padding-bottom:40px; border-bottom:1px solid rgba(255,255,255,0.18);}
  footer .brand{color:var(--white); font-size:34px;}
  .footer-links{display:flex; gap:30px; list-style:none; padding:0; margin:0; flex-wrap:wrap;}
  .footer-links a{font-size:13px; text-decoration:none; color:rgba(255,255,255,0.78);}
  .footer-links a:hover{color:var(--blush);}
  .footer-bottom{display:flex; justify-content:space-between; padding-top:26px; font-size:12px; flex-wrap:wrap; gap:10px;}

  .toast{
    position:fixed; bottom:28px; left:50%; transform:translate(-50%, 20px);
    background:var(--mauve-deep); color:var(--white); padding:14px 24px; border-radius:3px;
    font-size:13.5px; opacity:0; pointer-events:none; transition:opacity .3s ease, transform .3s ease;
    z-index:100; border:1px solid var(--blush);
  }
  .toast.show{opacity:1; transform:translate(-50%, 0);}

  .reveal{opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease;}
  .reveal.in{opacity:1; transform:translateY(0);}
