/* ============================================
   StoneLinked — Shared Styles (subpages)
   Matches homepage design system
   ============================================ */

/* BASE */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{padding-top:104px;font-family:'Inter',sans-serif;background:#F8F6F1;color:#1E1C1A;-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;line-height:1.2}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-thumb{background:#A38A6F;border-radius:2px}
::selection{background:rgba(163,138,111,.2);color:#1E1C1A}
:focus-visible{outline:2px solid #A38A6F;outline-offset:3px}

/* LABELS & DIVIDERS */
.lbl{font-family:'Inter',sans-serif;font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;font-weight:600;color:#A38A6F;display:block}
.divider-c{width:36px;height:2px;background:#A38A6F;margin:.9rem auto}

/* BUTTONS */
.btn-p{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:#A38A6F;color:#fff;font-family:'Inter',sans-serif;font-weight:600;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;padding:.9rem 2rem;border:none;cursor:pointer;min-height:48px;text-decoration:none;transition:background .2s,transform .15s}
.btn-p:hover{background:#8A7259;transform:translateY(-1px)}
.btn-s{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;background:transparent;color:#A38A6F;font-family:'Inter',sans-serif;font-weight:600;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;padding:.9rem 2rem;border:2px solid #A38A6F;cursor:pointer;min-height:48px;text-decoration:none;transition:background .2s,color .2s,transform .15s}
.btn-s:hover{background:#A38A6F;color:#fff;transform:translateY(-1px)}

/* LAYOUT */
.wrap{max-width:1140px;margin:0 auto;padding:0 1.5rem}
.sec{padding:5.5rem 1.5rem}
.sec-hdr{text-align:center;margin-bottom:3.5rem}
.sec-hdr h2{font-size:clamp(1.7rem,3vw,2.4rem);color:#1E1C1A;margin-bottom:.6rem}
.sec-hdr p{font-size:.95rem;color:#5A5750;max-width:480px;margin:.5rem auto 0;line-height:1.75}

/* ANNOUNCEMENT BAR */
.sl-announce{background:#2C2A27;position:fixed;top:0;left:0;right:0;z-index:9999;height:36px;font-family:Inter,sans-serif;font-size:.75rem;display:flex;width:100%;align-items:center}
.sl-announce a{color:#BFA98C;font-weight:600;text-decoration:underline;text-underline-offset:3px;white-space:nowrap}
.sl-announce button{background:none;border:none;cursor:pointer;color:rgba(248,246,241,.7);font-size:1.3rem;line-height:1;padding:0;display:flex;align-items:center;justify-content:center}

/* NAVBAR */
.sl-nav{position:fixed;top:36px;left:0;right:0;z-index:100;background:rgba(248,246,241,.97);box-shadow:0 1px 0 #D4CEC5;backdrop-filter:blur(10px)}
.sl-nav-inner{max-width:1140px;margin:0 auto;padding:0 1.5rem;height:68px;display:flex;align-items:center;justify-content:space-between;gap:1rem}
.sl-logo{display:flex;align-items:center;gap:.8rem;text-decoration:none}
.sl-logo-sq{width:34px;height:34px;border:1.5px solid #A38A6F;display:flex;align-items:center;justify-content:center;transition:background .2s}
.sl-logo-sq span{font-family:'Playfair Display',serif;color:#A38A6F;font-size:1.15rem;line-height:1;transition:color .2s}
.sl-logo-sq:hover{background:#A38A6F}
.sl-logo-sq:hover span{color:#fff}
.sl-logo-name{font-family:'Playfair Display',serif;color:#1E1C1A;font-size:1.1rem}
.sl-nav-links{display:flex;gap:2rem;list-style:none}
.sl-nav-links a{font-size:.8rem;font-weight:500;color:#5A5750;transition:color .2s}
.sl-nav-links a:hover{color:#A38A6F}
.sl-nav-r{display:flex;align-items:center;gap:.75rem;flex-shrink:0}
.sl-ham{display:none;background:transparent;border:none;cursor:pointer;padding:.4rem;color:#1E1C1A}

/* MOBILE NAV */
.sl-mob-nav{display:none;position:fixed;top:104px;left:0;right:0;z-index:99;background:#F8F6F1;border-bottom:1px solid #D4CEC5;padding:1.25rem 1.5rem 1.5rem;flex-direction:column;gap:.85rem}
.sl-mob-nav.open{display:flex}
.sl-mob-nav a{font-size:.95rem;color:#1E1C1A;padding:.4rem 0;border-bottom:1px solid #D4CEC5}

/* HERO (subpages) */
.sl-hero{padding:5rem 1.5rem 4rem;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:#F8F6F1;position:relative}
.sl-hero::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:1px;height:70px;background:linear-gradient(to bottom,transparent,rgba(163,138,111,.3))}
.sl-hero .lbl{margin-bottom:1.5rem}
.sl-hero h1{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:400;color:#1E1C1A;letter-spacing:-.02em;margin-bottom:1rem;max-width:18ch}
.sl-hero h1 em{color:#A38A6F;font-style:italic}
.sl-hero p{font-size:1rem;color:#5A5750;line-height:1.75;max-width:520px;margin:0 auto}

/* FOOTER */
.sl-footer{background:#2C2A27;color:rgba(248,246,241,.65);padding:4rem 1.5rem 0}
.sl-footer-inner{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:3rem;padding-bottom:3rem}
.sl-footer-logo{display:flex;align-items:center;gap:.8rem;margin-bottom:1.25rem}
.sl-footer-logo-sq{width:34px;height:34px;border:1.5px solid rgba(163,138,111,.6);display:flex;align-items:center;justify-content:center}
.sl-footer-logo-sq span{font-family:'Playfair Display',serif;color:#A38A6F;font-size:1.15rem}
.sl-footer-logo-name{font-family:'Playfair Display',serif;color:#F8F6F1;font-size:1.1rem}
.sl-footer-title{font-family:'Inter',sans-serif;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:#A38A6F;margin-bottom:1rem}
.sl-footer-links{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.sl-footer-links a,.sl-footer-links span{font-size:.85rem;color:rgba(248,246,241,.65);transition:color .2s}
.sl-footer-links a:hover{color:#A38A6F}
.sl-footer-bottom{border-top:1px solid rgba(248,246,241,.1);padding:1.5rem 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem;max-width:1140px;margin:0 auto}
.sl-footer-bottom span{font-size:.75rem}
.sl-footer-legal{display:flex;gap:1.5rem}
.sl-footer-legal a{font-size:.75rem;color:rgba(248,246,241,.45);transition:color .2s}
.sl-footer-legal a:hover{color:rgba(248,246,241,.7)}

/* SCROLL ANIMATIONS */
.reveal{opacity:1;transform:none}
.reveal.will-animate{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.reveal.will-animate.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media(max-width:900px){
.sl-nav-links{display:none}
.sl-ham{display:flex}
.sl-footer-inner{grid-template-columns:1fr 1fr;gap:2rem}
}
@media(max-width:600px){
.sl-footer-inner{grid-template-columns:1fr}
.sl-hero h1{font-size:1.7rem}
.sec{padding:3.5rem 1.25rem}
body{padding-top:104px}
}
@media(max-width:768px){
input,textarea,select{font-size:16px !important}
}
