/* public/css/main.css */

/* ─────────────────────────────────────────
   RESET
───────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth}
body{overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
img{max-width:100%;display:block}

/* ─────────────────────────────────────────
   DESIGN TOKENS
───────────────────────────────────────── */
:root{
  /* palette */
  --slate:      #1a2332;
  --slate2:     #243345;
  --slate3:     #2f4259;
  --copper:     #b5722a;
  --copper2:    #d4924e;
  --copper3:    #edb97a;
  --copper4:    #f7ddb0;
--copper-dark: #8A541C;
  --ivory:      #faf7f2;
  --ivory2:     #f2ece3;
  --ivory3:     #e8dfd2;
  --charcoal:   #2c3a4a;
  --body-text:  #4a5968;
  --muted:      #7a8fa0;
  --white:      #ffffff;
  --a11y-muted: #5e7080;   /* Darker than #7a8fa0 */
  --a11y-copper: #935a1e;  /* Darker than #b5722a */
  /* effects */
  --glow: 0 0 60px rgba(181,114,42,.08);
  --card-shadow: 0 4px 32px rgba(26,35,50,.1);
  --hover-shadow: 0 12px 56px rgba(26,35,50,.18);
}

/* ─────────────────────────────────────────
   BASE TYPOGRAPHY
───────────────────────────────────────── */
body{
  font-family: 'Palatino Linotype','Book Antiqua',Palatino,Georgia,serif;
  background: var(--ivory);
  background-color: var(--slate);
  color: var(--charcoal);
  line-height: 1.6;
}
main {
  background-color: var(--ivory); /* Keeps the middle of your pages ivory */
  min-height: 100vh; /* Ensures short pages push the footer to the bottom */
}
.sans{font-family: -apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,sans-serif}

/* scrollbar */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--ivory2)}
::-webkit-scrollbar-thumb{background:var(--copper);border-radius:2px}

/* ─────────────────────────────────────────
   NAV
───────────────────────────────────────── */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.6rem 4rem;
  transition:padding .45s cubic-bezier(.4,0,.2,1),background .45s,box-shadow .45s;
}
#nav.pinned{
  background:rgba(26,35,50,.97);
  backdrop-filter:blur(18px);
  padding:1rem 4rem;
  box-shadow:0 1px 0 rgba(181,114,42,.12),0 4px 24px rgba(0,0,0,.22);
}

/* logo */
.logo{
  display:flex;align-items:center;gap:.65rem;
  font-size:1.05rem;font-weight:700;letter-spacing:.015em;
  color:var(--white);
}
.logo-mark{
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  border:1.5px solid var(--copper2);
  display:flex;align-items:center;justify-content:center;
  font-size:.62rem;font-weight:900;letter-spacing:.05em;
  color:var(--copper2);
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,sans-serif;
}
.logo-text{line-height:1.2}
.logo-name{display:block;font-size:.95rem;font-weight:700;color:var(--white)}
.logo-sub{
  display:block;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--copper3);
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,sans-serif;
  font-weight:600;margin-top:.15rem;
}

/* nav links */
.nav-menu{display:flex;align-items:center;gap:2.25rem}
.nav-menu a{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,sans-serif;
  font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(250,247,242,.65);transition:color .3s;position:relative;
}
.nav-menu a::after{
  content:'';position:absolute;bottom:-4px;left:0;
  width:0;height:1px;background:var(--copper3);transition:width .35s;
}
.nav-menu a:hover{color:var(--copper3)}
.nav-menu a:hover::after{width:100%}
.nav-menu a.active {
    color: var(--copper3);
}
.nav-menu a.active::after {
    width: 100%;
}

/* Makes the Contact button stay highlighted if they are on the contact page */
.nav-contact.active {
    background: var(--copper) !important;
    color: var(--white) !important;
    border-color: var(--copper) !important;
}

/* Makes the mobile drawer links stay highlighted */
.drawer a.active {
    color: var(--copper3);
}
.nav-contact{
  margin-left:.5rem;
  padding:.55rem 1.5rem;
  border:1.5px solid var(--copper);
  color:var(--copper3)!important;
  font-weight:700!important;
  transition:all .3s!important;
}
.nav-contact::after{display:none!important}
.nav-contact:hover{background:var(--copper)!important;color:var(--white)!important;border-color:var(--copper)!important}

/* hamburger */
.burger{display:none;flex-direction:column;gap:5px;padding:4px;z-index:201}
.burger span{display:block;width:24px;height:1.5px;background:var(--white);transition:all .3s;transform-origin:center}
.burger.x span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.x span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* mobile drawer */
.drawer {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 199;
  background: var(--slate);
  flex-direction: column;
  align-items: center;
  justify-content: flex-start; /* Starts from the top instead of the center */
  padding: 8rem 2rem 4rem;     /* 8rem top padding gives the logo plenty of breathing room */
  gap: 1.5rem;                 /* Reduced gap to fit better */
  overflow-y: auto;            /* Enables scrolling for shorter phones! */
}
.drawer.show{display:flex}
.drawer a {
  font-family: 'Palatino Linotype', Palatino, Georgia, serif;
  font-size: 1.6rem;           /* Slightly smaller font for mobile */
  font-style: italic;
  font-weight: 400;
  color: var(--ivory);
  transition: color 0.3s;
}
.drawer a:hover,
.drawer a.active {
  color: var(--copper3);
}
.drawer-line {
  width: 1px;
  height: 24px;
  background: rgba(181, 114, 42, 0.3);
  flex-shrink: 0;
}
/* ─────────────────────────────────────────
   FOOTER
───────────────────────────────────────── */
footer{
  background:var(--slate);
  padding:2.75rem 4.5rem;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1.5rem;
  border-top:1px solid rgba(181,114,42,.12);
}
.footer-logo{
  display:flex;align-items:center;gap:.65rem;
}
.footer-logo-mark{
  width:28px;height:28px;
  border:1px solid rgba(181,114,42,.3);
  display:flex;align-items:center;justify-content:center;
  font-family:-apple-system,sans-serif;
  font-size:.55rem;font-weight:900;letter-spacing:.05em;
  color:var(--copper2);
}
.footer-name{
  font-size:.92rem;font-weight:700;color:var(--white);
}
.footer-name span{color:var(--copper2)}
.footer-copy{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,sans-serif;
  font-size:.68rem;color:rgba(250,247,242,.3);
  color: rgba(250,247,242,.5);
}
.footer-links{display:flex;gap:2rem;flex-wrap:wrap}
.footer-links a{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,sans-serif;
  font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;
  color: rgba(250,247,242,.6);
}
.footer-links a:hover{color:var(--copper3)}

@media(max-width:1100px){
  #nav,#nav.pinned{padding:1.1rem 2.25rem}
  .nav-menu{display:none}
  .burger{display:flex}
}
@media(max-width:700px){
  footer{flex-direction:column;align-items:flex-start;padding:2.25rem 1.5rem}
  .footer-links{gap:1.25rem}
}

/* ─────────────────────────────────────────
   GLOBAL SCROLL REVEAL ANIMATIONS
───────────────────────────────────────── */
/* Initial hidden state */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* State when scrolled into view (added by JS) */
.reveal.in {
  opacity: 1;
  transform: none;
}

/* Staggered delays for side-by-side elements */
.rv1 { transition-delay: 0.12s; }
.rv2 { transition-delay: 0.24s; }
.rv3 { transition-delay: 0.36s; }


/* ─────────────────────────────────────────
   HERO LOAD ANIMATIONS (For the Homepage)
───────────────────────────────────────── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(36px); }
  to { opacity: 1; transform: none; }
}
@keyframes fadeRight {
  from { opacity: 0; transform: translateX(48px); }
  to { opacity: 1; transform: none; }
}

.anim-up {
  opacity: 0;
  animation: fadeUp 0.85s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
}
.anim-right {
  opacity: 0;
  animation: fadeRight 1s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.55s both;
}

/* Hero Staggered Delays */
.d0 { animation-delay: 0.1s; }
.d1 { animation-delay: 0.25s; }
.d2 { animation-delay: 0.42s; }
.d3 { animation-delay: 0.58s; }
.d4 { animation-delay: 0.74s; }