/* Raaschou Finance Group - shared brand styles for vertical pages */
:root{
  --navy:#0c2340;
  --navy-2:#13315c;
  --navy-deep:#071a31;
  --ink:#1a2a40;
  --slate:#5b6878;
  --slate-2:#8892a0;
  --paper:#fbf9f4;
  --paper-2:#f3efe5;
  --white:#ffffff;
  --gold:#b89968;
  --gold-deep:#8a6f3f;
  --hairline:rgba(12,35,64,.14);
  --hairline-soft:rgba(12,35,64,.08);
  --hairline-light:rgba(255,255,255,.16);
  --periwinkle:#b9c5da;
  --periwinkle-deep:#a3b3cd;
  --sans:"Manrope", -apple-system, system-ui, sans-serif;
  --serif:"Playfair Display","Times New Roman",serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-size:16px;line-height:1.55;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button,input,textarea{font:inherit;color:inherit}

.eyebrow{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--slate);display:block;padding-bottom:14px;border-bottom:1px solid var(--hairline);margin-bottom:28px;font-style:normal}
.kicker{font-family:var(--sans);font-size:12px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--slate);font-style:normal;margin-bottom:28px;display:block;padding-bottom:14px;border-bottom:1px solid var(--hairline);width:100%;max-width:560px}
.h-xxl{font-family:var(--serif);font-weight:400;font-size:clamp(56px,8vw,128px);line-height:1.0;letter-spacing:-.025em;color:var(--navy)}
.h-xl{font-family:var(--serif);font-weight:400;font-size:clamp(42px,5.4vw,84px);line-height:1.04;letter-spacing:-.02em;color:var(--navy)}
.h-l{font-family:var(--serif);font-weight:400;font-size:clamp(34px,4vw,60px);line-height:1.08;letter-spacing:-.018em;color:var(--navy)}
.h-m{font-family:var(--sans);font-weight:400;font-size:clamp(24px,2.4vw,34px);line-height:1.18;letter-spacing:-.01em;color:var(--navy)}
.h-xl em,.h-l em,.h-m em,.h-xxl em{font-style:italic;color:var(--gold-deep);font-family:var(--serif);font-weight:400}
.lede{font-size:clamp(17px,1.25vw,20px);line-height:1.55;color:var(--ink);font-weight:400;letter-spacing:-.005em}
.body{font-size:16px;line-height:1.7;color:var(--ink)}
.muted{color:var(--slate)}

.wrap{max-width:1280px;margin:0 auto;padding:0 40px}
.wrap-wide{max-width:1440px;margin:0 auto;padding:0 40px}

/* Link CTA */
.link-cta{display:inline-flex;align-items:center;gap:14px;font-size:14px;font-weight:500;letter-spacing:.02em;color:var(--navy);padding:14px 0;border-bottom:1px solid var(--navy);transition:gap .25s, color .25s, border-bottom-color .25s}
.link-cta:hover{gap:18px;color:var(--gold-deep);border-bottom-color:var(--gold-deep)}
.link-cta .arr{font-size:18px;font-weight:300}

/* Buttons - pill, periwinkle, navy text */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;padding:20px 42px;background:var(--periwinkle);color:var(--navy);font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;border:0;border-radius:999px;cursor:pointer;transition:background .25s,color .25s}
.btn:hover{background:var(--periwinkle-deep);color:var(--navy)}
.btn.ghost{background:transparent;color:var(--navy);border:1px solid var(--navy)}
.btn.ghost:hover{background:var(--navy);color:#fff}

/* Top nav - slim editorial bar */
.topnav{position:sticky;top:0;background:rgba(251,249,244,.92);backdrop-filter:blur(10px);z-index:80;border-bottom:1px solid var(--hairline-soft)}
.topnav-inner{display:flex;align-items:center;justify-content:space-between;padding:20px 40px;max-width:1440px;margin:0 auto;gap:32px}
.topnav-brand{display:flex;align-items:baseline;gap:14px;color:var(--navy)}
.topnav-brand .mark{font-family:var(--serif);font-weight:500;font-size:22px;letter-spacing:-.01em}
.topnav-brand .mark::after{content:".";color:var(--gold)}
.topnav-brand .sub{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--slate);font-weight:500;border-left:1px solid var(--hairline);padding-left:14px}
/* Wordmark logo — matches homepage hero, recoloured for the light nav */
.brand-logo{display:flex;align-items:center;flex-shrink:0;opacity:.95;transition:opacity .25s}
.brand-logo:hover{opacity:1}
.brand-logo svg{display:block;height:29px;width:auto}
.brand-logo .bl-word{fill:var(--navy);font-family:"Montserrat",sans-serif;font-weight:300;letter-spacing:0}
.brand-logo .bl-sub{fill:var(--gold-deep);font-family:"Montserrat",sans-serif;font-weight:300;letter-spacing:0}
@media (max-width:900px){.brand-logo svg{height:26px}}
@media (max-width:560px){.brand-logo svg{height:24px}}
/* Footer wordmark — cream on the dark footer */
.foot-logo{display:inline-flex;opacity:1}
.foot-logo svg{height:40px}
.foot-logo .bl-word{fill:#fff}
.foot-logo .bl-sub{fill:#e7c994}
.topnav-links{display:flex;gap:34px;align-items:center;margin-left:auto}
.topnav-links a{font-size:14px;color:var(--navy);font-weight:500;transition:color .2s}
.topnav-links a:hover{color:var(--gold-deep)}
.topnav-cta{display:inline-flex;align-items:center;gap:10px;background:var(--periwinkle);color:var(--navy);padding:11px 22px;border-radius:999px;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;border:0;cursor:pointer;transition:background .25s}
.topnav-cta:hover{background:var(--periwinkle-deep)}
.topnav-cta .dot{width:8px;height:8px;border-radius:50%;background:var(--navy)}
.topnav-burger{display:none;background:none;border:0;padding:6px;cursor:pointer;width:42px;height:42px;flex-direction:column;justify-content:center;align-items:center;gap:5px;margin-left:4px}
.topnav-burger span{display:block;width:22px;height:1.5px;background:var(--navy);transition:transform .3s cubic-bezier(.2,.7,.2,1),opacity .2s}
.topnav.open .topnav-burger span:nth-child(1){transform:translateY(3.25px) rotate(45deg)}
.topnav.open .topnav-burger span:nth-child(2){transform:translateY(-3.25px) rotate(-45deg)}
.topnav-sheet{display:none}
@media (max-width:900px){
  .topnav-links{display:none}
  .topnav-brand .sub{display:none}
  .topnav-inner{padding:16px 24px;gap:14px}
  .topnav-cta{padding:9px 16px;font-size:10.5px;letter-spacing:.2em}
  .topnav-burger{display:flex}
  .topnav-sheet{display:flex;flex-direction:column;position:fixed;top:74px;left:0;right:0;background:var(--paper);border-bottom:1px solid var(--hairline);padding:18px 24px 28px;gap:0;transform:translateY(-110%);opacity:0;pointer-events:none;transition:transform .4s cubic-bezier(.2,.7,.2,1),opacity .25s;z-index:79;box-shadow:0 20px 40px -20px rgba(7,26,49,.18)}
  .topnav.open .topnav-sheet{transform:none;opacity:1;pointer-events:auto}
  .topnav-sheet a{padding:16px 2px;border-bottom:1px solid var(--hairline-soft);font-size:16px;color:var(--navy);font-weight:500;letter-spacing:-.005em;transition:color .2s}
  .topnav-sheet a:hover{color:var(--gold-deep)}
  .topnav-sheet .ts-label{padding:18px 2px 8px;font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--slate-2);font-weight:600;border-bottom:0}
  .topnav-sheet .ts-label:first-child{padding-top:4px}
}
@media (max-width:560px){
  .topnav-inner{padding:14px 20px}
  .topnav-brand .mark{font-size:20px}
  .topnav-cta{padding:8px 14px}
}

/* Footer (lifted from home) */
footer{background:var(--navy-deep);color:rgba(255,255,255,.78);padding:90px 0 50px;position:relative;overflow:hidden}
.foot-inner{max-width:1440px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:60px;align-items:start}
.foot-brand{font-family:var(--serif);font-weight:500;font-size:30px;color:#fff;letter-spacing:-.01em}
.foot-brand::after{content:".";color:var(--gold)}
.foot-tag{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(231,201,148,.7);margin-top:6px;font-weight:500}
.foot-blurb{font-size:14px;line-height:1.65;margin-top:20px;color:rgba(255,255,255,.6);max-width:36ch}
.foot-col h5{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(231,201,148,.78);font-weight:600;margin-bottom:18px}
.foot-col ul{list-style:none}
.foot-col ul li{padding:7px 0;font-size:14px;color:rgba(255,255,255,.7)}
.foot-col ul li a{transition:color .2s}
.foot-col ul li a:hover{color:#e7c994}
.foot-base{max-width:1440px;margin:60px auto 0;padding:24px 40px 0;display:flex;justify-content:space-between;align-items:center;gap:24px;border-top:1px solid var(--hairline-light);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.45);font-weight:500;flex-wrap:wrap}
@media (max-width:900px){.foot-inner{grid-template-columns:1fr 1fr;gap:40px}}
@media (max-width:560px){.foot-inner{grid-template-columns:1fr}}

/* Mobile tap-target comfort - larger touch areas without altering desktop */
@media (max-width:900px){
  .topnav-cta{min-height:42px}
  .foot-col ul li{padding:0}
  .foot-col ul li a{display:inline-block;padding:9px 0}
  .v-hero-back{padding:8px 0;margin:-8px 0}
}

/* Contact modal */
.cm-overlay{position:fixed;inset:0;background:rgba(7,26,49,.72);backdrop-filter:blur(6px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .35s ease}
.cm-overlay.open{opacity:1;pointer-events:auto}
.cm-shell{background:#faf5ea;color:var(--navy);max-width:520px;width:100%;padding:56px 52px 48px;position:relative;border:1px solid var(--hairline-soft);transform:translateY(20px);transition:transform .5s cubic-bezier(.22,.7,.2,1)}
.cm-overlay.open .cm-shell{transform:none}
.cm-close{position:absolute;top:18px;right:20px;background:none;border:0;font-size:26px;line-height:1;cursor:pointer;color:var(--slate);padding:6px;font-family:var(--serif)}
.cm-close:hover{color:var(--navy)}
.cm-eyebrow{font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--slate);font-weight:500;margin-bottom:18px}
.cm-title{font-family:var(--serif);font-weight:400;font-size:36px;line-height:1.1;letter-spacing:-.015em;margin:0 0 10px}
.cm-title em{font-style:italic;color:var(--gold-deep)}
.cm-sub{font-size:14px;color:var(--ink);line-height:1.6;margin:0 0 28px}
.cm-form{display:flex;flex-direction:column;gap:18px}
.cm-field{display:flex;flex-direction:column;gap:6px}
.cm-field span{font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--slate);font-weight:500}
.cm-field input,.cm-field textarea{font:inherit;background:transparent;border:0;border-bottom:1px solid var(--hairline);padding:8px 0 10px;color:var(--navy);font-size:15px;outline:none;transition:border-color .25s;font-family:var(--sans);resize:none}
.cm-field input:focus,.cm-field textarea:focus{border-bottom-color:var(--navy)}
.cm-submit{margin-top:14px;align-self:flex-start;display:inline-flex;align-items:center;gap:12px;padding:14px 28px;background:var(--periwinkle);color:var(--navy);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;border:0;border-radius:999px;cursor:pointer;transition:background .25s, color .25s;font-family:var(--sans)}
.cm-submit:hover{background:var(--navy);color:#faf5ea}
.cm-submit:disabled{background:transparent;color:var(--gold-deep);border:1px solid var(--gold-deep)}
.cm-book{display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%;margin:0 0 22px;padding:16px 22px;background:var(--navy);color:#faf5ea;border:0;cursor:pointer;font-family:var(--sans);font-size:11.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;transition:background .25s,color .25s}
.cm-book:hover{background:var(--gold-deep);color:#fff}
.cm-book-ar{font-size:15px;transition:transform .25s}
.cm-book:hover .cm-book-ar{transform:translateX(4px)}
.cm-or{display:flex;align-items:center;gap:16px;margin:0 0 24px;color:var(--slate);font-size:10px;letter-spacing:.2em;text-transform:uppercase;white-space:nowrap}
.cm-or::before,.cm-or::after{content:"";flex:1;height:1px;background:var(--hairline)}
@media (max-width:560px){.cm-shell{padding:48px 28px 36px}.cm-title{font-size:28px}}

/* Reveal */
.rv{opacity:0;transform:translateY(14px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}


/* ════════════════════════════════════════════════════════════════════
   MOTION SUITE - shared brand chrome (topnav + footer + modal)
   ════════════════════════════════════════════════════════════════════ */

/* Footer column cascade - triggered when class .foot-in is added by JS */
footer .foot-inner > *{opacity:0;transform:translateY(18px);transition:opacity 1s cubic-bezier(.22,.7,.2,1), transform 1s cubic-bezier(.22,.7,.2,1)}
footer.foot-in .foot-inner > *{opacity:1;transform:none}
footer.foot-in .foot-inner > *:nth-child(1){transition-delay:.05s}
footer.foot-in .foot-inner > *:nth-child(2){transition-delay:.18s}
footer.foot-in .foot-inner > *:nth-child(3){transition-delay:.31s}
footer.foot-in .foot-inner > *:nth-child(4){transition-delay:.44s}
footer .foot-col h5{position:relative;display:inline-block}
footer .foot-col h5::after{content:"";display:block;height:1px;width:0;background:#e7c994;margin-top:8px;transition:width 1.1s cubic-bezier(.22,.7,.2,1)}
footer.foot-in .foot-col h5::after{width:28px;transition-delay:.6s}
footer .foot-col ul li a{position:relative;display:inline-block;padding-bottom:1px;transition:color .25s}
footer .foot-col ul li a::after{content:"";position:absolute;left:0;bottom:-1px;width:100%;height:1px;background:#e7c994;transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.22,.7,.2,1)}
footer .foot-col ul li a:hover::after{transform:scaleX(1);transform-origin:left}
footer .foot-brand::after{display:inline-block;animation:foot-brand-pulse 4.2s ease-in-out infinite}
@keyframes foot-brand-pulse{0%,100%{opacity:1}50%{opacity:.55}}

/* Modal: scale + fade entrance for inputs */
.cm-overlay.open .cm-shell .cm-field{opacity:0;transform:translateY(8px);animation:cm-field-rise .55s cubic-bezier(.22,.7,.2,1) forwards}
.cm-overlay.open .cm-shell .cm-field:nth-child(1){animation-delay:.2s}
.cm-overlay.open .cm-shell .cm-field:nth-child(2){animation-delay:.28s}
.cm-overlay.open .cm-shell .cm-field:nth-child(3){animation-delay:.36s}
.cm-overlay.open .cm-shell .cm-field:nth-child(4){animation-delay:.44s}
.cm-overlay.open .cm-shell .cm-submit{opacity:0;transform:translateY(8px);animation:cm-field-rise .55s cubic-bezier(.22,.7,.2,1) forwards;animation-delay:.55s}
@keyframes cm-field-rise{to{opacity:1;transform:none}}
.cm-overlay.open .cm-shell .cm-eyebrow,
.cm-overlay.open .cm-shell .cm-title,
.cm-overlay.open .cm-shell .cm-sub{opacity:0;transform:translateY(6px);animation:cm-field-rise .55s cubic-bezier(.22,.7,.2,1) forwards}
.cm-overlay.open .cm-shell .cm-eyebrow{animation-delay:.05s}
.cm-overlay.open .cm-shell .cm-title{animation-delay:.12s}
.cm-overlay.open .cm-shell .cm-sub{animation-delay:.18s}

@media (prefers-reduced-motion: reduce){
  footer .foot-inner > *,footer .foot-col h5::after,footer .foot-brand::after,
  .cm-overlay.open .cm-shell *{animation:none !important;transition:none !important;transform:none !important;opacity:1 !important;width:auto !important}
}

.foot-disclosure{max-width:1440px;margin:20px auto 0;padding:18px 40px 0;border-top:1px solid var(--hairline-light);font-size:12px;line-height:1.65;letter-spacing:.01em;color:rgba(255,255,255,.4);font-weight:400;text-transform:none}

/* Prevent iOS Safari auto-zoom on input focus (font must be ≥16px) — placed last to win the cascade */
@media (max-width:640px){
  .cm-field input,.cm-field textarea{font-size:16px}
}
