/* ══ HOMEPAGE STYLES ══ */

/* HERO */
#hero { min-height:100vh; display:grid; grid-template-columns:1fr 1fr; overflow:hidden; }
.hero-left { background:var(--forest); display:flex; flex-direction:column; justify-content:flex-end; padding:100px 80px 80px; position:relative; overflow:hidden; }
.hero-left::before { content:'D'; font-family:var(--display); font-size:480px; font-weight:700; color:rgba(255,255,255,0.04); position:absolute; top:-60px; left:-40px; line-height:1; pointer-events:none; user-select:none; }
.hero-label { font-family:var(--sans); font-size:10px; font-weight:500; letter-spacing:0.28em; text-transform:uppercase; color:var(--gold); margin-bottom:32px; opacity:0; transform:translateY(20px); animation:fadeUp 0.9s 0.3s forwards; }
.hero-title { font-family:var(--display); font-size:clamp(48px,5.5vw,88px); font-weight:400; line-height:1.05; color:var(--offwhite); opacity:0; transform:translateY(30px); animation:fadeUp 1s 0.5s forwards; }
.hero-title em { font-style:italic; color:var(--gold); }
.hero-sub { margin-top:36px; font-family:var(--sans); font-weight:300; font-size:14px; line-height:1.8; color:rgba(245,240,232,0.6); max-width:380px; opacity:0; transform:translateY(20px); animation:fadeUp 0.9s 0.8s forwards; }
.hero-actions { margin-top:52px; display:flex; gap:20px; align-items:center; opacity:0; animation:fadeUp 0.9s 1s forwards; }
.hero-right { background:var(--cream); position:relative; overflow:hidden; }
.hero-visual-bg { width:100%; height:100%; background:linear-gradient(160deg,#D5CFC4 0%,#BFB8AC 40%,#A89C8E 100%); display:flex; align-items:center; justify-content:center; position:relative; }
.hero-visual-bg > img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero-d-mark { font-family:var(--display); font-size:200px; font-weight:700; color:rgba(255,255,255,0.18); user-select:none; position:relative; z-index:1; }
.hero-stats { position:absolute; bottom:48px; left:48px; display:grid; grid-template-columns:1fr 1fr; gap:2px; z-index:2; }
.stat { background:rgba(245,240,232,0.9); backdrop-filter:blur(6px); padding:20px 24px; }
.stat-num { font-family:var(--display); font-size:32px; font-weight:700; color:var(--forest); line-height:1; }
.stat-label { font-family:var(--sans); font-size:9px; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; color:var(--charcoal); opacity:0.6; margin-top:4px; }
@keyframes fadeUp { to { opacity:1; transform:translateY(0); } }

/* ABOUT */
#about { padding:160px 60px; display:grid; grid-template-columns:1fr 1fr; gap:120px; align-items:center; }
.about-text h2 { font-family:var(--display); font-size:clamp(36px,4vw,64px); font-weight:400; line-height:1.1; color:var(--forest); margin-bottom:32px; }
.about-text h2 em { font-style:italic; }
.about-text p { font-family:var(--sans); font-weight:300; font-size:15px; line-height:1.9; color:var(--charcoal); max-width:480px; margin-bottom:24px; opacity:0.8; }
.about-link { display:inline-flex; align-items:center; gap:14px; font-family:var(--sans); font-size:10px; font-weight:500; letter-spacing:0.22em; text-transform:uppercase; color:var(--olive); text-decoration:none; margin-top:16px; transition:gap 0.2s; }
.about-link::after { content:''; display:inline-block; width:32px; height:1px; background:var(--gold); transition:width 0.2s; }
.about-link:hover { gap:20px; }
.about-link:hover::after { width:48px; }
.about-img-wrap { position:relative; height:600px; overflow:hidden; }
.img-main { width:100%; height:100%; background:linear-gradient(145deg,#2C3B22,#1C2B1A); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.img-main img { width:100%; height:100%; object-fit:cover; position:absolute; inset:0; }
.about-mono { font-family:var(--display); font-size:120px; font-weight:700; color:rgba(245,240,232,0.12); line-height:1; }
.about-float-card { position:absolute; bottom:-32px; right:-32px; background:var(--gold); padding:32px 36px; width:220px; }
.about-float-card .num { font-family:var(--display); font-size:52px; font-weight:700; color:var(--forest); line-height:1; }
.about-float-card .lbl { font-family:var(--sans); font-size:9px; font-weight:500; letter-spacing:0.22em; text-transform:uppercase; color:var(--forest); opacity:0.7; margin-top:6px; }
.about-visual { position:relative; }

/* SERVICES */
#services { padding:120px 60px; background:var(--forest); }
#services .section-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:80px; }
#services .section-label { color:var(--gold); }
#services .section-label::before { color:rgba(200,169,126,0.5); }
#services h2 { font-family:var(--display); font-size:clamp(32px,3.5vw,56px); font-weight:400; color:var(--offwhite); line-height:1.1; }
#services h2 em { font-style:italic; color:var(--gold); }
.services-desc { font-family:var(--sans); font-weight:300; font-size:14px; color:rgba(245,240,232,0.5); max-width:320px; line-height:1.8; }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; }
.service-card { background:rgba(245,240,232,0.03); border:1px solid rgba(245,240,232,0.08); padding:52px 40px; transition:background 0.3s,border-color 0.3s; position:relative; overflow:hidden; }
.service-card:hover { background:rgba(245,240,232,0.06); border-color:rgba(200,169,126,0.3); }
.service-card::before { content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform 0.4s ease; }
.service-card:hover::before { transform:scaleX(1); }
.service-num { font-family:var(--display); font-size:11px; font-weight:400; letter-spacing:0.1em; color:var(--gold); opacity:0.6; margin-bottom:32px; }
.service-card h3 { font-family:var(--display); font-size:26px; font-weight:400; color:var(--offwhite); margin-bottom:16px; line-height:1.2; }
.service-card p { font-family:var(--sans); font-weight:300; font-size:13px; color:rgba(245,240,232,0.5); line-height:1.8; }

/* BOTANICAL */
#botanical { padding:0; display:grid; grid-template-columns:1fr 1fr; min-height:640px; }
.bot-left { background:var(--olive); padding:100px 80px; display:flex; flex-direction:column; justify-content:center; }
.bot-left .section-label { color:rgba(245,240,232,0.5); }
.bot-left .section-label::before { color:rgba(200,169,126,0.5); }
.bot-left h2 { font-family:var(--display); font-size:clamp(32px,3.5vw,52px); font-weight:400; color:var(--offwhite); line-height:1.1; margin-bottom:28px; }
.bot-left h2 em { font-style:italic; color:var(--gold); }
.bot-left p { font-family:var(--sans); font-weight:300; font-size:14px; color:rgba(245,240,232,0.65); line-height:1.85; margin-bottom:16px; max-width:420px; }
.bot-tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:36px; }
.bot-tag { font-family:var(--sans); font-size:9px; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; color:var(--offwhite); border:1px solid rgba(245,240,232,0.25); padding:8px 16px; transition:background 0.2s,border-color 0.2s; }
.bot-tag:hover { background:rgba(245,240,232,0.1); border-color:var(--gold); }
.bot-right { background:var(--cream); display:grid; grid-template-columns:1fr 1fr; grid-template-rows:1fr 1fr; gap:2px; }
.bot-cell { position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.bot-cell-1 { background:linear-gradient(135deg,#3A4F2E,#2C3B22); }
.bot-cell-2 { background:linear-gradient(135deg,#C8A97E,#A08060); }
.bot-cell-3 { background:linear-gradient(135deg,#E8E0D0,#D0C8B8); }
.bot-cell-4 { background:linear-gradient(135deg,#1C2B1A,#0C1A0C); }
.bot-cell > span:first-child { font-family:var(--display); font-size:48px; font-weight:700; color:rgba(255,255,255,0.08); user-select:none; }
.bot-cell-label { position:absolute; bottom:16px; left:16px; font-family:var(--sans); font-size:9px; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; color:rgba(245,240,232,0.6); }
.bot-cell-3 .bot-cell-label { color:rgba(44,44,42,0.5); }

/* QUOTE */
#quote { padding:120px 60px; background:var(--charcoal); text-align:center; }
#quote blockquote { font-family:var(--display); font-size:clamp(28px,3.5vw,52px); font-weight:400; font-style:italic; color:var(--offwhite); line-height:1.3; max-width:900px; margin:0 auto; }
#quote blockquote em { color:var(--gold); }
#quote cite { display:block; margin-top:40px; font-family:var(--sans); font-size:10px; font-weight:500; letter-spacing:0.24em; text-transform:uppercase; color:rgba(245,240,232,0.35); font-style:normal; }

/* CLIENTS */
#clients { padding:100px 60px; background:var(--offwhite); }
#clients .section-top { text-align:center; margin-bottom:64px; }
#clients h2 { font-family:var(--display); font-size:clamp(24px,2.5vw,40px); font-weight:400; color:var(--forest); }
.clients-grid { display:grid; grid-template-columns:repeat(5,1fr); border-top:1px solid rgba(44,44,42,0.08); }
.client-item { padding:40px 32px; border-right:1px solid rgba(44,44,42,0.08); display:flex; align-items:center; justify-content:center; transition:background 0.2s; }
.client-item:hover { background:rgba(74,94,58,0.04); }
.client-item:last-child { border-right:none; }
.client-item span { font-family:var(--display); font-size:13px; font-weight:400; letter-spacing:0.06em; color:var(--charcoal); opacity:0.35; text-align:center; transition:opacity 0.2s; }
.client-item:hover span { opacity:0.7; }

/* CTA REGISTER */
#cta-register { padding:120px 60px; background:var(--forest); text-align:center; }
#cta-register .cta-inner { max-width:640px; margin:0 auto; }
#cta-register .section-label { color:var(--gold); display:block; text-align:center; margin-bottom:16px; }
#cta-register .section-label::before { color:rgba(200,169,126,0.5); }
#cta-register h2 { font-family:var(--display); font-size:clamp(32px,4vw,60px); font-weight:400; color:var(--offwhite); line-height:1.1; margin-bottom:24px; }
#cta-register h2 em { font-style:italic; color:var(--gold); }
#cta-register p { font-family:var(--sans); font-weight:300; font-size:14px; color:rgba(245,240,232,0.6); line-height:1.8; margin-bottom:44px; }
.cta-actions { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }

/* FAQ */
.faq-item { border-top:1px solid rgba(44,44,42,0.1); padding:32px 0; }
.faq-item:last-child { border-bottom:1px solid rgba(44,44,42,0.1); }
.faq-q { font-family:var(--display); font-size:20px; font-weight:400; color:var(--forest); margin-bottom:16px; cursor:pointer; display:flex; justify-content:space-between; align-items:flex-start; gap:20px; }
.faq-q::after { content:'+'; font-family:var(--sans); font-size:20px; font-weight:300; color:var(--gold); flex-shrink:0; transition:transform 0.3s; }
.faq-item.open .faq-q::after { transform:rotate(45deg); }
.faq-a { font-family:var(--sans); font-weight:300; font-size:14px; line-height:1.85; color:var(--charcoal); opacity:0.75; max-height:0; overflow:hidden; transition:max-height 0.4s ease; }
.faq-item.open .faq-a { max-height:300px; }

/* RESPONSIVE HOME */
@media (max-width:1024px) {
  #hero { grid-template-columns:1fr; }
  .hero-right { min-height:400px; }
  .hero-left { padding:80px 40px 60px; }
  #about { grid-template-columns:1fr; gap:60px; padding:100px 40px; }
  .services-grid { grid-template-columns:1fr; }
  #botanical { grid-template-columns:1fr; }
  .bot-left { padding:60px 40px; }
  .bot-right { min-height:400px; }
  #quote { padding:80px 40px; }
  #clients { padding:60px 40px; }
  .clients-grid { grid-template-columns:repeat(3,1fr); }
  #cta-register { padding:80px 40px; }
  #services { padding:80px 40px; }
  #services .section-header { flex-direction:column; align-items:flex-start; gap:20px; }
}
