*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --cream:    #FAF8F3;
  --cream-2:  #F3EFE6;
  --cream-3:  #EDE7DA;
  --amber:    #C47A2B;
  --amber-d:  #9E5F1A;
  --amber-l:  #FDECD4;
  --amber-xl: #FEF6EB;
  --brown:    #2C1F0E;
  --brown-2:  #4A3520;
  --brown-3:  #7A6248;
  --stone:    #9C8C78;
  --stone-l:  #C8BBAA;
  --border:   #DDD3C0;
  --border-l: #EDE7DA;
  --white:    #FFFFFF;
  --ff-d:     'Playfair Display', Georgia, serif;
  --ff-b:     'Inter', system-ui, sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--ff-b);color:var(--brown);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased}

/* NAV */
nav{position:sticky;top:0;z-index:200;background:rgba(250,248,243,.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:68px;padding:0 2rem}
.logo{display:flex;align-items:center;gap:11px;text-decoration:none}
.logo-mark{width:36px;height:36px;border-radius:9px;background:var(--amber);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo-word{font-family:var(--ff-d);font-size:20px;font-weight:700;color:var(--brown);letter-spacing:-.2px}
.logo-word em{font-style:normal;color:var(--amber)}
.nav-links{display:flex;gap:2rem;list-style:none;align-items:center}
.nav-links a{color:var(--brown-3);text-decoration:none;font-size:14.5px;font-weight:500;transition:color .18s}
.nav-links a:hover{color:var(--brown)}
.nav-cta{background:var(--amber)!important;color:#fff!important;padding:9px 22px;border-radius:8px;font-weight:600!important;transition:background .2s!important}
.nav-cta:hover{background:var(--amber-d)!important}

/* HERO */
#hero{background:var(--cream);padding:6rem 2rem 4.5rem;position:relative;overflow:hidden}
.hero-texture{position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(var(--border) 1px,transparent 1px);background-size:28px 28px;opacity:.35}
.hero-glow{position:absolute;top:-80px;right:-60px;width:520px;height:520px;border-radius:50%;background:radial-gradient(ellipse at 55% 45%,rgba(196,122,43,.1) 0%,rgba(196,122,43,.04) 45%,transparent 68%);pointer-events:none}
.hero-inner{position:relative;max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:3.5rem;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--amber-l);border:1px solid rgba(196,122,43,.28);color:var(--amber-d);font-size:11.5px;font-weight:600;letter-spacing:.05em;padding:5px 14px;border-radius:20px;margin-bottom:1.5rem}
.hero-dot{width:6px;height:6px;background:var(--amber);border-radius:50%;animation:blink 2.4s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
h1{font-family:var(--ff-d);font-weight:700;font-size:clamp(2.3rem,4.8vw,3.8rem);color:var(--brown);line-height:1.1;letter-spacing:-.02em;margin-bottom:1.3rem}
h1 em{font-style:normal;color:var(--amber)}
.hero-sub{font-size:1.05rem;color:var(--brown-3);line-height:1.78;margin-bottom:2.5rem;max-width:500px}
.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}
.btn-primary{display:inline-block;background:var(--amber);color:#fff;font-family:var(--ff-b);font-size:15px;font-weight:600;padding:13px 28px;border-radius:10px;text-decoration:none;border:none;cursor:pointer;transition:all .22s}
.btn-primary:hover{background:var(--amber-d);transform:translateY(-2px);box-shadow:0 8px 24px rgba(196,122,43,.28)}
.btn-ghost{display:inline-block;background:transparent;color:var(--brown);font-family:var(--ff-b);font-size:15px;font-weight:500;padding:13px 28px;border-radius:10px;text-decoration:none;border:1.5px solid var(--border);cursor:pointer;transition:all .22s}
.btn-ghost:hover{border-color:var(--amber);color:var(--amber)}
.hero-stats{display:flex;gap:2.5rem;padding-top:2rem;border-top:1px solid var(--border)}
.stat-num{font-family:var(--ff-d);font-size:2.1rem;font-weight:700;color:var(--amber);line-height:1}
.stat-lbl{font-size:12px;color:var(--stone);margin-top:5px}

/* SERVICES */
#services{padding:6rem 2rem;background:var(--cream-2)}
.container{max-width:1180px;margin:0 auto}
.section-eyebrow{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--amber);margin-bottom:.85rem}
h2{font-family:var(--ff-d);font-weight:700;font-size:clamp(1.8rem,3.2vw,2.7rem);color:var(--brown);line-height:1.13;letter-spacing:-.018em;margin-bottom:.9rem}
.section-intro{font-size:1rem;color:var(--brown-3);max-width:560px;line-height:1.75}
.section-header{margin-bottom:3.5rem}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:1.5rem}
.svc-card{background:var(--white);border:1px solid var(--border-l);border-radius:16px;padding:2rem;opacity:0;transform:translateY(22px);transition:opacity .5s,transform .5s,border-color .25s,box-shadow .25s;position:relative;overflow:hidden}
.svc-card.visible{opacity:1;transform:none}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--amber),#E8A44A);transform:scaleX(0);transform-origin:left;transition:transform .3s;border-radius:16px 16px 0 0}
.svc-card:hover{border-color:rgba(196,122,43,.3);box-shadow:0 12px 40px rgba(196,122,43,.1);transform:translateY(-4px)!important}
.svc-card:hover::before{transform:scaleX(1)}
.svc-icon{width:52px;height:52px;border-radius:12px;background:var(--amber-xl);border:1px solid var(--amber-l);display:flex;align-items:center;justify-content:center;margin-bottom:1.3rem}
.svc-card h3{font-family:var(--ff-d);font-size:1.15rem;font-weight:700;color:var(--brown);margin-bottom:.65rem}
.svc-card p{font-size:.9rem;color:var(--brown-3);line-height:1.74;margin-bottom:1.2rem}
.tags{display:flex;flex-wrap:wrap;gap:6px}
.tag{font-size:11px;font-weight:500;padding:3px 10px;border-radius:20px;background:var(--amber-l);color:var(--amber-d)}

/* APPROCHE */
#approche{padding:6rem 2rem;background:var(--cream)}
.approche-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.val-list{list-style:none;display:flex;flex-direction:column;gap:1rem;margin-top:1.8rem}
.val-list li{display:flex;align-items:flex-start;gap:12px;font-size:.94rem;color:var(--brown-3);line-height:1.65}
.val-check{min-width:22px;width:22px;height:22px;margin-top:1px;background:var(--amber-xl);border:1.5px solid rgba(196,122,43,.35);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.kpi-card{background:var(--cream-2);border:1px solid var(--border);border-radius:14px;padding:1.6rem}
.kpi-num{font-family:var(--ff-d);font-size:2.3rem;font-weight:700;color:var(--amber);line-height:1;margin-bottom:7px}
.kpi-lbl{font-size:13px;color:var(--stone);line-height:1.5}

/* DIVIDER */
.divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:0}

/* CONTACT */
#contact{padding:6rem 2rem;background:var(--cream-2)}
.contact-grid{display:grid;grid-template-columns:1fr 1.45fr;gap:4rem;align-items:start}
.contact-info h3{font-family:var(--ff-d);font-size:1.4rem;font-weight:700;color:var(--brown);margin-bottom:1rem}
.contact-info p{color:var(--brown-3);font-size:.93rem;line-height:1.78;margin-bottom:.9rem}
.contact-detail{display:flex;align-items:center;gap:10px;font-size:.88rem;color:var(--brown-3);margin-top:.9rem}
.contact-detail svg{flex-shrink:0;color:var(--amber)}
.contact-email{color:inherit;text-decoration:none}
.contact-email:hover{text-decoration:underline}
.contact-form{background:var(--white);border:1px solid var(--border-l);border-radius:20px;padding:2.5rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--stone);margin-bottom:5px;letter-spacing:.04em;text-transform:uppercase}
.form-group input,.form-group select,.form-group textarea{width:100%;font-family:var(--ff-b);font-size:14px;color:var(--brown);background:var(--cream);border:1px solid var(--border);border-radius:9px;padding:11px 14px;transition:border .2s,box-shadow .2s;outline:none;appearance:none;-webkit-appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(196,122,43,.12);background:var(--white)}
.form-group textarea{resize:vertical;min-height:124px}
.hp{display:none!important;visibility:hidden;position:absolute}
.form-submit{width:100%;margin-top:.5rem;background:var(--amber);color:#fff;font-family:var(--ff-b);font-size:15px;font-weight:600;padding:14px;border-radius:10px;border:none;cursor:pointer;transition:all .22s}
.form-submit:hover{background:var(--amber-d);transform:translateY(-2px);box-shadow:0 8px 24px rgba(196,122,43,.3)}
.form-submit:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}
.form-msg{margin-top:1rem;padding:12px 16px;border-radius:9px;font-size:13.5px;font-weight:500;display:none}
.form-msg.success{background:#EDFAF3;color:#1A6640;border:1px solid rgba(26,102,64,.2)}
.form-msg.error{background:#FEF3F0;color:#B03A2E;border:1px solid rgba(176,58,46,.2)}

/* FOOTER */
footer{background:var(--brown);padding:3.5rem 2rem}
.footer-inner{max-width:1180px;margin:0 auto;display:flex;flex-direction:column;align-items:center;text-align:center}
.footer-logo{font-family:var(--ff-d);font-size:22px;font-weight:700;color:var(--cream);margin-bottom:.4rem}
.footer-logo em{font-style:normal;color:var(--amber)}
.footer-tagline{color:rgba(250,248,243,.38);font-size:13px;margin-bottom:2rem}
.footer-bottom{width:100%;padding-top:1.5rem;border-top:1px solid rgba(250,248,243,.1);color:rgba(250,248,243,.22);font-size:12px}
.footer-bottom a{color:rgba(250,248,243,.22);text-decoration:none}

@media(max-width:900px){
  .hero-inner,.approche-grid,.contact-grid{grid-template-columns:1fr}
  .hero-visual{display:none}
  .form-row{grid-template-columns:1fr}
  .nav-links{display:none}
  .hero-stats{flex-wrap:wrap;gap:1.5rem}
}
@media(max-width:600px){
  #hero,#services,#approche,#contact{padding-left:1.25rem;padding-right:1.25rem}
}
