*{box-sizing:border-box}html{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;line-height:1.5;color:#3B3A36}
body{margin:0;background:#F5F5F5;padding-top:0}
.container{max-width:1100px;margin:0 auto;padding:0 20px}

.hero-logo{display:flex;justify-content:flex-start;margin-bottom:32px;padding:0}
.main-logo{height:120px;width:auto;object-fit:contain;max-width:100%}
.brand{font-weight:700;font-size:1.1rem}

.hero{display:grid;grid-template-columns:1fr;gap:32px;padding:40px 0;text-align:center}
/* Hero Content Layout */
.hero-content{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;text-align:left}

/* Hero Image Styling */
.hero-image{display:flex;justify-content:center;align-items:center;min-height:300px}
.hero-visual{max-width:100%;height:auto;border-radius:16px;box-shadow:0 12px 32px rgba(62,94,80,0.25),0 4px 16px rgba(0,0,0,0.1);transition:transform 0.3s ease,box-shadow 0.3s ease;display:block;max-height:400px;object-fit:cover}
.hero-visual:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(62,94,80,0.35),0 8px 24px rgba(0,0,0,0.15)}

/* Typography Hierarchy */
.hero h1{font-size:2.5rem;line-height:1.1;margin:0 0 0.5em 0;font-weight:700}
.hero h2{font-size:2rem;line-height:1.2;margin:0 0 0.5em 0;font-weight:600}
h2{font-size:2rem;line-height:1.2;margin:0 0 0.8em 0;font-weight:600}
h3{font-size:1.5rem;line-height:1.3;margin:0 0 0.6em 0;font-weight:600}
p{font-size:1rem;line-height:1.6;margin:0 0 1em 0}

.hero p{opacity:.85;font-size:1.125rem;line-height:1.6}

/* Buttons */
.cta-row{display:flex;gap:12px;margin:18px 0}
.cta{display:inline-block;padding:12px 18px;border-radius:12px;background:#5C8DBC;color:white;text-decoration:none;font-weight:600;font-size:1rem;border:none;box-shadow:none;outline:none}
.secondary{display:inline-block;padding:12px 18px;border-radius:12px;border:1px solid #A9745B;text-decoration:none;color:#A9745B;font-size:1rem}

/* Cards */
.hero-card{background:white;border:1px solid #e2e8f0;border-radius:16px;padding:16px;box-shadow:0 6px 16px rgba(2,8,23,.06)}
.hero-card ul{margin:0;padding-left:20px}
.note{font-size:0.875rem;color:#3B3A36;line-height:1.5;font-weight:500}

/* Enhanced mobile card styling */
@media (max-width: 768px) {
  .card { 
    border-radius: 12px; 
    box-shadow: 0 4px 12px rgba(62,94,80,0.08);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
  }
  
  .card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(62,94,80,0.12);
  }
}

/* Sections */
.section{padding:24px 0}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.card{background:white;border:1px solid #3E5E50;border-radius:16px;padding:24px;box-shadow:0 6px 16px rgba(62,94,80,.1)}

/* Forms */
.contact-form{background:white;border:1px solid #3E5E50;border-radius:16px;padding:24px;display:grid;gap:16px;max-width:720px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
label{display:grid;gap:6px;font-weight:600;color:#3B3A36}
input,textarea{padding:10px 12px;border:1px solid #3E5E50;border-radius:10px;font:inherit;background:#F5F5F5;transition:border-color 0.2s ease;min-height:44px}
input:focus,textarea:focus{border-color:#5C8DBC;outline:none}
.footer{display:flex;align-items:center;justify-content:space-between;padding:24px 0;border-top:1px solid #3E5E50;margin-top:40px}
.footer-links{display:flex;gap:12px;align-items:center}
.tiny{font-size:.85rem;color:#3E5E50}
/* Mobile-First Responsive Design */
@media (max-width: 1200px) {
  .container { padding: 0 16px; }
  .hero h1 { font-size: 2.2rem; }
  .hero h2 { font-size: 1.8rem; }
}

@media (max-width: 900px) {
  /* Tablet Styles */
  .hero { padding: 32px 0; gap: 24px; }
  .hero-content { grid-template-columns: 1fr; gap: 32px; text-align: center; }
  .hero h1 { font-size: 2rem; }
  .hero h2 { font-size: 1.6rem; }
  .grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .section { padding: 20px 0; }
  .card { padding: 20px; }
  .contact-form { padding: 20px; }
  
  /* Logo adjustments for tablet */
  .main-logo { height: 100px; }
}

@media (max-width: 768px) {
  /* Mobile Styles */
  body { padding-top: 80px; }
  
  /* Container padding for mobile edges - increased for better breathing room */
  .container { padding: 0 24px; }
  
  /* Typography scaling for mobile - improved readability */
  .hero h1 { font-size: 1.8rem; line-height: 1.3; }
  .hero h2 { font-size: 1.5rem; line-height: 1.4; }
  h2 { font-size: 1.7rem; line-height: 1.3; }
  h3 { font-size: 1.4rem; line-height: 1.4; }
  .hero p { font-size: 1.1rem; line-height: 1.6; }
  p { line-height: 1.7; }
  
  /* Layout adjustments - better spacing */
  .hero { padding: 32px 0; gap: 20px; }
  .hero-content { grid-template-columns: 1fr; gap: 24px; text-align: center; }
  .section { padding: 24px 0; }
  .grid { grid-template-columns: 1fr; gap: 20px; }
  .card { padding: 20px; margin-bottom: 8px; }
  
  /* Hero image mobile optimization */
  .hero-image { margin-top: 0; min-height: 250px; }
  .hero-visual { border-radius: 12px; box-shadow: 0 6px 16px rgba(62,94,80,0.12); }
  
  /* Form optimization for mobile - better touch targets */
  .contact-form { padding: 20px; gap: 16px; }
  .form-row { grid-template-columns: 1fr; gap: 16px; }
  input, textarea { padding: 14px; font-size: 16px; min-height: 48px; } /* Prevents zoom on iOS */
  label { margin-bottom: 8px; }
  
  /* Logo mobile optimization */
  .main-logo { height: 80px; }
  
  /* Button optimization for touch - larger touch targets */
  .cta, .secondary { padding: 16px 24px; font-size: 1.1rem; min-height: 48px; border-radius: 12px; }
  
  /* Footer mobile optimization */
  .footer { flex-direction: column; gap: 16px; text-align: center; }
  .footer-links { justify-content: center; }
}

@media (max-width: 480px) {
  /* Small mobile optimization */
  .container { padding: 0 20px; }
  .main-logo { height: 70px; }
  .hero h2 { font-size: 1.3rem; line-height: 1.4; }
  .section { padding: 20px 0; }
  .card { padding: 16px; margin-bottom: 12px; }
  .contact-form { padding: 16px; gap: 14px; }
  

  
  /* Better button sizing for small screens */
  .cta, .secondary { padding: 14px 20px; font-size: 1rem; min-height: 44px; }
  
  /* Improved spacing for very small screens */
  .hero { padding: 24px 0; gap: 16px; }
  .hero-content { grid-template-columns: 1fr; gap: 20px; text-align: center; }
  .grid { gap: 16px; }
  
  /* Hero image small mobile optimization */
  .hero-image { margin-top: 0; min-height: 200px; }
  .hero-visual { border-radius: 10px; }
}
