/* GIROS — shared design system */

:root{
  --ink:#1A1714;
  --ink-2:#2B2622;
  --ink-3:#3a342d;
  --bone:#F4EDDF;
  --bone-2:#EBE2D0;
  --bone-3:#E3D8BF;
  --sand:#D9CBAE;
  --ochre:#9B7A3B;
  --ochre-2:#B8893B;
  --ochre-soft:#C7A56A;
  --forest:#2C3327;
  --forest-2:#3A4031;
  --clay:#A6663C;
  --rust:#8a4a2a;
  --muted:rgba(26,23,20,.62);
  --muted-2:rgba(26,23,20,.45);
  --hair:rgba(26,23,20,.14);
  --hair-soft:rgba(26,23,20,.08);
  --bone-tx:rgba(244,237,223,.7);
  --bone-tx-2:rgba(244,237,223,.5);
  --bone-hair:rgba(244,237,223,.18);

  --serif:"Cormorant Garamond", "EB Garamond", Georgia, serif;
  --sans:"Plus Jakarta Sans", system-ui, -apple-system, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bone);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--ochre);color:var(--bone)}

/* type */
.display{font-family:var(--serif);font-weight:400;letter-spacing:-.01em;line-height:.95}
.display em{font-style:italic;font-weight:400;color:var(--ochre)}
.eyebrow{font-family:var(--sans);font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;color:var(--muted)}
.eyebrow .dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--ochre);margin:0 .7em .15em 0;vertical-align:middle}
.lede{font-family:var(--serif);font-weight:300;font-size:clamp(20px,1.6vw,26px);line-height:1.5;color:var(--ink-2)}
.body{font-size:15px;line-height:1.65;color:var(--ink-2)}
.num{font-family:var(--serif);font-style:italic;font-weight:400}

/* layout */
.wrap{max-width:1440px;margin:0 auto;padding:0 48px}
@media (max-width:780px){.wrap{padding:0 24px}}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .4s ease, backdrop-filter .4s, color .3s, padding .3s, border-color .3s;padding:22px 0;color:var(--bone);border-bottom:1px solid transparent}
.nav.dark{color:var(--ink)}
.nav.scrolled{background:rgba(244,237,223,.94);backdrop-filter:blur(14px);color:var(--ink);padding:14px 0;border-bottom-color:var(--hair-soft)}
.nav-row{display:flex;align-items:center;justify-content:space-between;gap:32px}
.logo{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:26px;letter-spacing:.18em;font-weight:500}
.logo .mark{display:inline-flex;align-items:center;gap:6px}
.logo .mark svg{width:22px;height:22px;opacity:.9}
.logo .mark img{width:44px;height:44px;object-fit:contain;display:block}
.f-brand .logo .mark img{width:64px;height:64px}
.logo .tld{font-family:var(--sans);font-size:9px;letter-spacing:.32em;opacity:.7;margin-left:4px;font-weight:600;text-transform:uppercase}
.nav-links{display:flex;gap:34px;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.nav-links a{position:relative;padding:6px 0;opacity:.85;transition:opacity .2s, color .2s}
.nav-links a:hover{opacity:1}
.nav-links a.active{opacity:1}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--ochre)}
.nav-cta{display:flex;align-items:center;gap:20px;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.nav-cta .phone{opacity:.8;display:none}
@media (min-width:1100px){.nav-cta .phone{display:inline}}

.btn{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;border:1px solid currentColor;border-radius:999px;font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;transition:all .25s;cursor:pointer}
.btn:hover{background:var(--ink);color:var(--bone);border-color:var(--ink)}
.nav.scrolled .btn:hover{background:var(--ink);color:var(--bone)}
.btn.solid{background:var(--ink);color:var(--bone);border-color:var(--ink)}
.btn.solid:hover{background:var(--ochre);border-color:var(--ochre);color:var(--bone)}
.btn .arrow{display:inline-block;transition:transform .25s}
.btn:hover .arrow{transform:translateX(3px)}

/* page header (non-hero pages) */
.page-head{position:relative;padding:160px 0 60px;background:var(--bone);overflow:hidden}
.page-head::before{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--hair-soft)}
.page-head .crumb{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:24px}
.page-head .crumb a{color:var(--ochre);transition:color .2s}
.page-head .crumb a:hover{color:var(--clay)}
.page-head .crumb .sep{margin:0 12px;opacity:.4}
.page-head h1{font-family:var(--serif);font-weight:400;font-size:clamp(56px,7vw,128px);line-height:.95;letter-spacing:-.015em;max-width:1100px}
.page-head h1 em{font-style:italic;color:var(--ochre)}
.page-head .sub{margin-top:32px;display:flex;justify-content:space-between;align-items:flex-end;gap:48px;flex-wrap:wrap;padding-bottom:48px}
.page-head .sub .lede{max-width:560px}
.page-head .sub .meta{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);font-weight:600;line-height:2;text-align:right}
.page-head .sub .meta strong{color:var(--ink);font-weight:600}

/* FOOTER (shared) */
footer{background:var(--ink);color:var(--bone);padding:100px 0 36px}
.f-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:64px;padding-bottom:80px;border-bottom:1px solid rgba(244,237,223,.1)}
.f-brand .logo{font-size:32px}
.f-brand p{margin-top:26px;font-family:var(--serif);font-style:italic;font-weight:300;font-size:22px;line-height:1.35;color:#E8D5A8;max-width:380px}
.f-brand .meta{margin-top:32px;font-size:12.5px;line-height:1.7;color:var(--bone-tx)}
.f-brand .meta a{color:var(--ochre-soft);transition:color .2s}
.f-brand .meta a:hover{color:var(--bone)}
.f-col h5{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:rgba(244,237,223,.55);margin-bottom:22px;font-weight:600}
.f-col ul{list-style:none;display:flex;flex-direction:column;gap:13px;font-family:var(--serif);font-size:18px;color:#F4EDDF}
.f-col li{transition:color .2s, padding .2s}
.f-col li a{display:block;padding:0}
.f-col li:hover{color:var(--ochre-2);padding-left:6px}
.f-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:36px;font-size:12px;letter-spacing:.04em;color:var(--bone-tx);flex-wrap:wrap;gap:20px}
.f-bottom .links{display:flex;gap:30px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500}
.f-bottom .links a{opacity:.7;transition:opacity .2s}
.f-bottom .links a:hover{opacity:1}
@media (max-width:980px){
  .f-top{grid-template-columns:1fr 1fr;gap:48px}
  .f-brand{grid-column:span 2}
}

/* mobile nav toggle */
.nav-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;flex-direction:column;gap:5px;padding:0;cursor:pointer;z-index:60;position:relative}
.nav-toggle span{display:block;width:22px;height:1.5px;background:currentColor;transition:transform .3s, opacity .3s}
.nav-open .nav-toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-open .nav-toggle span:nth-child(2){opacity:0}
.nav-open .nav-toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* mobile drawer */
.mobile-menu{position:fixed;inset:0;background:var(--ink);color:var(--bone);z-index:55;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:36px;padding:80px 32px 60px;opacity:0;pointer-events:none;transition:opacity .35s ease;text-align:center}
.nav-open .mobile-menu{opacity:1;pointer-events:auto}
.mobile-menu a{font-family:var(--serif);font-weight:300;font-size:38px;color:var(--bone);letter-spacing:.01em;transition:color .2s}
.mobile-menu a:hover{color:var(--ochre-soft)}
.mobile-menu .m-cta{margin-top:24px;font-family:var(--sans);font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;padding:14px 28px;border:1px solid var(--bone);border-radius:999px}
.mobile-menu .m-mail{font-family:var(--sans);font-size:13px;letter-spacing:.04em;color:var(--bone-tx);margin-top:8px;text-transform:none;font-weight:400}
.nav-open{overflow:hidden}

/* responsive nav */
@media (max-width:980px){
  .nav-links{display:none}
  .nav-toggle{display:inline-flex}
  .nav-cta .btn{display:none}
  .logo .tld{display:none}
  .logo{font-size:20px;letter-spacing:.14em}
  .logo .mark img{width:36px;height:36px}
  .nav{padding:14px 0}
}
@media (min-width:981px){
  .mobile-menu{display:none}
}

/* general mobile tightening */
@media (max-width:780px){
  .page-head{padding:120px 0 40px}
  .page-head .sub{flex-direction:column;align-items:flex-start;gap:24px;padding-bottom:32px}
  .page-head .sub .meta{text-align:left}
  .bottom-cta{padding:90px 0}
  .bottom-cta-actions{flex-direction:column;align-items:stretch;padding:0 24px}
  .bottom-cta-actions .btn{justify-content:center}
  footer{padding:70px 0 28px}
  .f-top{padding-bottom:52px;gap:36px}
  .f-bottom{flex-direction:column;align-items:flex-start;text-align:left}
  .f-brand p{font-size:18px}
  .f-brand .logo{font-size:24px}
  .f-brand .logo .mark img{width:52px;height:52px}
}
@media (max-width:560px){
  .f-top{grid-template-columns:1fr;gap:40px}
  .f-brand{grid-column:auto}
  .f-col ul{font-size:16px;gap:10px}
}

/* small CTA strip used at the bottom of inner pages */
.bottom-cta{padding:140px 0;background:var(--bone-2);text-align:center;position:relative;overflow:hidden}
.bottom-cta::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:1px;height:60px;background:var(--ochre)}
.bottom-cta .eyebrow{display:block;margin-bottom:32px}
.bottom-cta h2{font-size:clamp(48px,5.5vw,96px);line-height:.95;max-width:1000px;margin:0 auto}
.bottom-cta .lede{margin:30px auto 0;max-width:560px}
.bottom-cta-actions{margin-top:44px;display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

/* fade-in observer setup */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1)}
.fade-up.in{opacity:1;transform:none}

/* shared media block: full-bleed image */
.full-img{width:100%;aspect-ratio:21/9;overflow:hidden;background:var(--sand)}
.full-img img{width:100%;height:100%;object-fit:cover}
