
/* ══════════════════════════════════════════════
   DESIGN TOKENS
   Palette: dusty Wedgwood blue meets warm berry.
   The photos bring the colour — the site brings
   the calm, editorial backdrop.
══════════════════════════════════════════════ */
:root {
  /* Backgrounds */
  --page:    #F4F8FB;
  --white:   #FFFFFF;
  --tint:    #EBF3F9;
  --tint2:   #DCEBf4;

  /* Wedgwood blue scale */
  --b100: #E8F2FA;
  --b200: #C4DDEF;
  --b300: #8DBCD8;
  --b400: #5A9ABE;
  --b500: #3A7FA8;   /* primary            */
  --b600: #2460849;  /* deep               */
  --b700: #1A4D6E;   /* darkest accent     */
  --b800: #0F2E46;   /* footer / dark bg   */

  /* Type */
  --t1: #152233;
  --t2: #334E65;
  --t3: #6B8FA8;
  --t4: #A8C4D5;

  /* Rules */
  --rule: rgba(58,127,168,.13);
  --rule2: rgba(58,127,168,.24);

  --shadow: 0 4px 28px rgba(15,46,70,.08);
  --shadow2: 0 12px 48px rgba(15,46,70,.14);

  --font: 'DM Sans', system-ui, sans-serif;
  --ease: cubic-bezier(0.22, 0, 0.12, 1);
}

/* ══════════════════════════════════════════════
   BASE
══════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);font-weight:300;
  background:var(--page);color:var(--t1);
  line-height:1.75;-webkit-font-smoothing:antialiased;
  overflow-x:hidden
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:100%;object-fit:cover}

.w{width:min(1060px,100% - 3rem);margin-inline:auto}

/* ══════════════════════════════════════════════
   SHARED TYPE SYSTEM
   One body paragraph style applied site-wide.
══════════════════════════════════════════════ */
.over{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.62rem;font-weight:500;letter-spacing:.24em;
  text-transform:uppercase;color:var(--b500);margin-bottom:1rem
}
.over::before{content:'';width:20px;height:1px;background:var(--b400);flex-shrink:0}

h2{
  font-size:clamp(1.9rem,3.6vw,3.1rem);font-weight:300;
  line-height:1.12;letter-spacing:-.032em;color:var(--t1)
}
h2 strong{font-weight:600;color:var(--b700)}

/* ── THE approved body paragraph style ── */
p,li{
  font-family:var(--font);font-size:1.05rem;
  font-weight:300;line-height:1.8;color:var(--t2);
  text-align:justify;-webkit-hyphens:auto;hyphens:auto
}

/* Undo justify for short UI elements where ragged-right is correct */
.btn,.over,.nav-links a,.nav-name,.nav-sub,.nav-book,
.hero-tag,.hero-name,.hero-title-line,.stat-l,.stat-v,
.svc-name,.svc-cta,.art-pub,.art-ttl,.art-more,
.chip,.apill,.clients-lbl,.logo-board-ttl,.lv-label,
.fc-ttl,.fc,.ft-name,.ft-subt,.ft-tag,.ci-lbl,.ci-val,
.fi-q,.over,.mcat,.dot,.ti,.draft,
.svc-hd p,.svc-desc,.media-left p,.faq-left p,.book-body,
.hero-intro,.verify p,
h2,h2 strong{text-align:left;-webkit-hyphens:none;hyphens:none}

.btn{
  display:inline-block;font-family:var(--font);
  font-size:.74rem;font-weight:500;letter-spacing:.13em;
  text-transform:uppercase;padding:.82rem 1.9rem;
  border-radius:100px;border:none;cursor:pointer;
  transition:all .28s var(--ease)
}
.solid{background:var(--b700);color:#fff;box-shadow:0 4px 20px rgba(26,77,110,.3)}
.solid:hover{background:var(--b700);transform:translateY(-1px);box-shadow:0 6px 28px rgba(26,77,110,.38)}
.outline{background:transparent;color:var(--b700);border:1.5px solid var(--b300)}
.outline:hover{border-color:var(--b500);background:var(--b100)}
.wh{background:#fff;color:var(--b700);box-shadow:0 4px 20px rgba(0,0,0,.12)}
.wh:hover{background:var(--b100);transform:translateY(-1px)}
.gl{background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.25)}
.gl:hover{background:rgba(255,255,255,.18)}

/* Scroll reveal */
.r{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.r.on{opacity:1;transform:none}
.d1{transition-delay:.1s}.d2{transition-delay:.18s}.d3{transition-delay:.27s}

/* ══════════════════════════════════════════════
   DRAFT BANNER
══════════════════════════════════════════════ */
.draft{
  background:var(--b700);color:rgba(255,255,255,.75);
  text-align:center;padding:.45rem 1rem;
  font-size:.62rem;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase
}

/* ══════════════════════════════════════════════
   LOGO BOARD — presented above nav
══════════════════════════════════════════════ */
.logo-board{
  background:var(--white);border-bottom:1px solid var(--rule);
  padding:2.8rem 0
}
.logo-board-ttl{
  text-align:center;font-size:.6rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--t4);margin-bottom:2.2rem
}
.logo-variants{
  display:flex;justify-content:center;
  align-items:center;gap:5rem;flex-wrap:wrap
}
.lv{display:flex;flex-direction:column;align-items:center;gap:.7rem}
.lv-label{font-size:.58rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:var(--t4)}
.lv-dark{background:var(--b800);padding:1.4rem 2rem;border-radius:6px}

/* ══════════════════════════════════════════════
   NAV
══════════════════════════════════════════════ */
nav{
  position:sticky;top:0;z-index:300;
  background:rgba(244,248,251,.93);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--rule)
}
.nav-in{
  display:flex;align-items:center;
  justify-content:space-between;padding:.95rem 0
}
.nav-brand{display:flex;align-items:center;gap:.7rem}
.nav-mark{width:34px;height:34px}
.nav-words{display:flex;flex-direction:column}
.nav-name{font-size:.96rem;font-weight:600;letter-spacing:-.01em;color:var(--t1);line-height:1.2}
.nav-sub{font-size:.57rem;font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:var(--t2)}
.nav-links{display:flex;align-items:center;gap:1.8rem;list-style:none}
.nav-links a{
  font-size:.73rem;font-weight:400;letter-spacing:.09em;
  text-transform:uppercase;color:var(--t2);
  transition:color .24s;position:relative;padding-bottom:2px
}
.nav-links a::after{
  content:'';position:absolute;bottom:0;left:0;
  width:0;height:1.5px;background:var(--b500);
  transition:width .28s var(--ease)
}
.nav-links a:hover{color:var(--b700)}
.nav-links a:hover::after{width:100%}
.nav-book{
  background:var(--b500)!important;color:#fff!important;
  padding:.52rem 1.3rem!important;border-radius:100px
}
.nav-book::after{display:none!important}
.nav-book:hover{background:var(--b700)!important}

/* ══════════════════════════════════════════════
   HERO — Photo dominant, full height
══════════════════════════════════════════════ */
.hero{
  display:grid;
  grid-template-columns:52% 48%;
  overflow:hidden
}
.hero-img{position:relative;overflow:hidden;min-height:600px;max-height:780px}
.hero-img img{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  display:block
}
/* Subtle blue gradient overlay bottom of photo */
.hero-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(
    to right,
    transparent 60%,
    rgba(244,248,251,.18) 100%
  );
  pointer-events:none
}

.hero-content{
  background:var(--white);
  display:flex;align-items:flex-start;
  padding:5rem 5% 5rem 6%
}
.hero-inner{max-width:460px}

.hero-tag{
  display:inline-flex;align-items:center;gap:.42rem;
  background:var(--tint);border:1px solid var(--b200);
  border-radius:100px;padding:.3rem .85rem .3rem .5rem;
  font-size:.62rem;font-weight:500;letter-spacing:.13em;
  text-transform:uppercase;color:var(--b700);margin-bottom:1.8rem
}
.hero-tag-dot{
  width:7px;height:7px;background:var(--b400);
  border-radius:50%;flex-shrink:0;
  animation:pulse 2.5s ease infinite
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}

.hero-name{
  font-size:clamp(2.6rem,4.8vw,4.4rem);
  font-weight:600;line-height:1.0;letter-spacing:-.04em;
  color:var(--b700);margin-bottom:.5rem
}
.hero-title-line{
  font-size:clamp(1rem,2vw,1.4rem);
  font-weight:400;color:var(--b500);
  letter-spacing:.02em;margin-bottom:1.8rem
}

/* Body paragraph — same style throughout */
.hero-intro{
  font-family:var(--font);font-size:1.05rem;
  font-weight:300;line-height:1.8;color:var(--t2);
  margin-bottom:2.4rem
}

.hero-btns{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:2rem}

.hero-stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1rem;padding-top:1.8rem;
  border-top:1px solid var(--rule)
}
.stat{display:flex;flex-direction:column;gap:.15rem}
.stat-v{
  font-size:1.5rem;font-weight:600;
  color:var(--b500);letter-spacing:-.04em;line-height:1
}
.stat-l{
  font-size:.6rem;font-weight:400;
  letter-spacing:.14em;text-transform:uppercase;color:var(--t2)
}

/* ══════════════════════════════════════════════
   TICKER
══════════════════════════════════════════════ */
.ticker{background:var(--b800);padding:1rem 0;overflow:hidden}
.ticker-track{
  display:flex;gap:2.5rem;align-items:center;
  width:max-content;animation:tick 32s linear infinite
}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ti{
  font-size:.78rem;font-weight:300;font-style:italic;
  color:rgba(255,255,255,.72);white-space:nowrap;letter-spacing:.05em
}
.ts{color:var(--b300);opacity:.5;font-size:.35rem;flex-shrink:0}

/* ══════════════════════════════════════════════
   ABOUT — Photo left, bio right
══════════════════════════════════════════════ */
.about{padding:7rem 0;background:var(--white)}
.about-grid{
  display:grid;grid-template-columns:5fr 7fr;
  gap:6rem;align-items:start
}
.about-photo-col{position:sticky;top:5.5rem}
.about-photo-wrap{
  position:relative;border-radius:8px;
  overflow:hidden;box-shadow:var(--shadow2);
  aspect-ratio:2/3;max-height:560px
}
.about-photo-wrap img{width:100%;height:100%;object-fit:cover;object-position:center top}

/* Floating credential badge on photo */
.about-badge{
  position:absolute;bottom:1.5rem;left:1.5rem;right:1.5rem;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(8px);
  border-radius:6px;padding:1rem 1.2rem;
  display:flex;flex-direction:column;gap:.25rem;
  border:1px solid rgba(255,255,255,.6)
}
.about-badge-name{font-size:.88rem;font-weight:600;color:var(--t1)}
.about-badge-title{font-size:.63rem;font-weight:400;letter-spacing:.13em;text-transform:uppercase;color:var(--t3)}
.about-badge-pills{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.4rem}
.apill{
  padding:.18rem .6rem;background:var(--b100);
  border-radius:100px;font-size:.6rem;
  font-weight:400;letter-spacing:.05em;color:var(--b700)
}

.about-body p{
  font-family:var(--font);font-size:1.05rem;
  font-weight:300;line-height:1.8;color:var(--t2);
  margin-bottom:1.3rem
}

.about-quote{
  margin:2rem 0;padding:1.6rem 2rem;
  background:var(--tint);border-left:3px solid var(--b400);
  border-radius:0 6px 6px 0
}
.about-quote p{
  font-size:1rem;font-weight:300;
  font-style:italic;line-height:1.7;color:var(--b600)
}

/* ══════════════════════════════════════════════
   SERVICES — Editorial cards
══════════════════════════════════════════════ */
.services{padding:7rem 0;background:var(--page)}
.svc-hd{
  display:grid;grid-template-columns:1fr 1fr;
  gap:.5rem 2.5rem;margin-bottom:3.5rem
}
.svc-hd .over{grid-column:1;margin-bottom:.2rem}
.svc-hd h2{grid-column:1}
.svc-hd p{
  grid-column:2;grid-row:1/3;align-self:end;
  font-family:var(--font);font-size:1.05rem;
  font-weight:300;line-height:1.8;color:var(--t2);margin-top:0
}

.svc-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1.5px;background:var(--b200);
  border-radius:10px;overflow:hidden;box-shadow:var(--shadow)
}
.svc{
  background:var(--white);padding:3rem 2.8rem 2.8rem;
  position:relative;overflow:hidden;transition:background .28s
}
.svc::after{
  content:'';position:absolute;bottom:0;left:0;
  height:2.5px;width:0;background:var(--b500);
  transition:width .48s var(--ease)
}
.svc:hover{background:var(--tint)}
.svc:hover::after{width:100%}

.svc-num{
  font-size:4rem;font-weight:700;color:var(--b100);
  line-height:1;margin-bottom:1rem;letter-spacing:-.06em;
  transition:color .28s
}
.svc:hover .svc-num{color:var(--b200)}
.svc-name{
  font-size:1.2rem;font-weight:500;
  letter-spacing:-.02em;color:var(--t1);margin-bottom:.65rem
}
.svc-desc{
  font-family:var(--font);font-size:1.05rem;
  font-weight:300;line-height:1.8;color:var(--t2);
  margin-bottom:1.4rem
}
.svc-list{list-style:none;display:flex;flex-direction:column;gap:.3rem}
.svc-list li{
  font-size:.83rem;font-weight:300;
  color:var(--t2);padding-left:.9rem;position:relative
}
.svc-list li::before{
  content:'—';position:absolute;left:0;
  color:var(--b400);font-size:.7rem;top:.1rem
}
.svc-cta{
  display:inline-flex;align-items:center;gap:.35rem;
  margin-top:1.8rem;font-size:.7rem;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--b500);transition:gap .28s
}
.svc:hover .svc-cta{gap:.65rem}

/* Clients */
.clients{
  margin-top:3.5rem;padding:2.5rem 0;
  border-top:1px solid var(--rule2)
}
.clients-lbl{
  text-align:center;font-size:.6rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--t4);margin-bottom:1.6rem
}
.chips{
  display:flex;flex-wrap:wrap;
  gap:.4rem .7rem;justify-content:center
}
.chip{
  padding:.25rem .72rem;background:var(--white);
  border:1px solid var(--b200);border-radius:3px;
  font-size:.66rem;font-weight:300;color:var(--t2);
  transition:all .2s
}
.chip:hover{background:var(--tint);border-color:var(--b400);color:var(--b700)}

/* ══════════════════════════════════════════════
   MEDIA
══════════════════════════════════════════════ */
.media{padding:7rem 0;background:var(--white)}
.media-grid{
  display:grid;grid-template-columns:4fr 8fr;
  gap:5rem;align-items:start
}
.media-left{position:sticky;top:5.5rem}
.media-left p{
  font-family:var(--font);font-size:1.05rem;
  font-weight:300;line-height:1.8;color:var(--t2);margin-top:1rem
}
.media-cats{margin-top:1.8rem;display:flex;flex-direction:column;gap:.65rem}
.mcat{display:flex;align-items:center;gap:.7rem;font-size:.75rem;font-weight:300;color:var(--t2)}
.dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dt{background:var(--b500)}
.dp{background:var(--b300)}
.dr{background:var(--t3)}

.art-list{
  display:flex;flex-direction:column;gap:1px;
  background:var(--b200);border-radius:10px;
  overflow:hidden;box-shadow:var(--shadow)
}
.art{
  display:flex;align-items:center;gap:1.3rem;
  padding:1.15rem 1.6rem;background:var(--white);
  cursor:pointer;transition:background .22s
}
.art:hover{background:var(--tint)}
.art-pub{
  flex-shrink:0;width:100px;font-size:.62rem;
  font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--b500)
}
.art-rule{width:1px;height:1.7rem;background:var(--b200);flex-shrink:0}
.art-ttl{
  flex:1;font-family:var(--font);font-size:.87rem;
  font-weight:300;line-height:1.5;color:var(--t2)
}
.art-arr{
  font-size:.7rem;color:var(--t4);flex-shrink:0;
  transition:transform .22s,color .22s
}
.art:hover .art-arr{transform:translate(3px,-2px);color:var(--b500)}
.art-more{
  background:var(--tint);padding:.9rem;text-align:center;
  font-size:.67rem;font-weight:500;letter-spacing:.12em;
  text-transform:uppercase;color:var(--b500);cursor:pointer
}

/* ══════════════════════════════════════════════
   FAQ
══════════════════════════════════════════════ */
.faq{padding:7rem 0;background:var(--page)}
.faq-grid{
  display:grid;grid-template-columns:4fr 7fr;
  gap:5rem;align-items:start
}
.faq-left{position:sticky;top:5.5rem}
.faq-left p{
  font-family:var(--font);font-size:1.05rem;
  font-weight:300;line-height:1.8;color:var(--t2);margin-top:1rem
}

.faqs{display:flex;flex-direction:column}
.fi{border-bottom:1px solid var(--rule2)}
.fi:first-child{border-top:1px solid var(--rule2)}
.fi-btn{
  width:100%;display:flex;justify-content:space-between;
  align-items:center;gap:1rem;padding:1.3rem 0;
  background:none;border:none;cursor:pointer;text-align:left;
  font-family:var(--font)
}
.fi-q{font-size:1rem;font-weight:400;color:var(--t1);line-height:1.35}
.fi-icon{
  flex-shrink:0;width:26px;height:26px;border-radius:50%;
  border:1.5px solid var(--b200);background:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:.88rem;color:var(--b400);transition:all .26s
}
.fi.open .fi-icon{background:var(--b500);border-color:var(--b500);color:#fff;transform:rotate(45deg)}
.fi-ans{max-height:0;overflow:hidden;transition:max-height .42s var(--ease),padding .26s}
.fi-ans.open{max-height:250px;padding-bottom:1.3rem}
.fi-ans p{font-family:var(--font);font-size:1.05rem;font-weight:300;line-height:1.8;color:var(--t2)}

/* ══════════════════════════════════════════════
   BOOK / CONTACT — Photo-backed dark section
══════════════════════════════════════════════ */
.book{
  position:relative;padding:7rem 0;
  background:var(--b800);overflow:hidden
}
/* coffee-mug photo as right panel background */
.book-photo{
  position:absolute;top:0;right:0;bottom:0;width:42%;
  overflow:hidden
}
.book-photo img{
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  opacity:.25;filter:saturate(.6)
}
.book-photo::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to right,var(--b800) 0%,transparent 60%);
  z-index:1;pointer-events:none
}
/* Decorative rings */
.book-ring{
  position:absolute;border-radius:50%;
  border:1px solid rgba(255,255,255,.04)
}
.br1{width:600px;height:600px;top:-200px;left:-150px}
.br2{width:350px;height:350px;bottom:-100px;right:35%}

.book-inner{
  position:relative;z-index:2;
  max-width:540px
}
.book-title{
  font-size:clamp(2rem,3.5vw,3rem);font-weight:300;
  color:#fff;line-height:1.14;
  letter-spacing:-.03em;margin-bottom:1.1rem
}
.book-title strong{font-weight:600;color:var(--b300)}
.book-body{
  font-family:var(--font);font-size:1.05rem;
  font-weight:300;line-height:1.8;
  color:rgba(255,255,255,.55);margin-bottom:2rem
}
.book-btns{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:3rem}

.ci-list{display:flex;flex-direction:column;gap:1.2rem}
.ci{display:flex;align-items:flex-start;gap:1rem}
.ci-icon{
  flex-shrink:0;width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(255,255,255,.14);
  display:flex;align-items:center;justify-content:center;font-size:.85rem
}
.ci-lbl{font-size:.58rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--b300);margin-bottom:.15rem}
.ci-val{font-family:var(--font);font-size:.95rem;font-weight:300;color:rgba(255,255,255,.75)}

.bookem-box{
  margin-top:2.5rem;padding:1.6rem 2rem;
  border:1px dashed rgba(255,255,255,.15);border-radius:8px;text-align:center
}
.bookem-box p{font-size:.62rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.22);margin-bottom:.32rem}
.bookem-box code{font-size:.72rem;color:rgba(144,189,216,.45);font-family:'Courier New',monospace}

.verify{
  margin-top:1.8rem;padding:1.1rem 1.4rem;
  background:rgba(255,255,255,.05);border-left:2px solid var(--b400);
  border-radius:0 6px 6px 0
}
.verify p{font-family:var(--font);font-size:.8rem;font-weight:300;line-height:1.65;color:rgba(255,255,255,.42)}
.verify strong{color:rgba(196,221,240,.75);font-weight:500}

/* ══════════════════════════════════════════════
   FOOTER
══════════════════════════════════════════════ */
footer{background:#09202F;padding:3.5rem 0 2rem}
.ft{
  display:grid;grid-template-columns:2.2fr 1fr 1fr;
  gap:4rem;padding-bottom:2.5rem;
  border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:1.8rem
}
.ft-logo-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.35rem}
.ft-mark{width:40px;height:40px}
.ft-name{font-size:1.05rem;font-weight:600;color:#fff;letter-spacing:-.01em}
.ft-subt{font-size:.57rem;font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.72);margin-bottom:1rem}
.ft-tag{font-size:.86rem;font-weight:300;font-style:italic;color:rgba(255,255,255,.78);line-height:1.65;max-width:240px}
.ft-social{display:flex;gap:.5rem;margin-top:1.4rem}
.soc{
  width:32px;height:32px;border-radius:50%;
  border:1px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  font-size:.64rem;font-weight:500;color:rgba(255,255,255,.75);transition:all .24s
}
.soc:hover{border-color:var(--b300);color:var(--b300)}
.fc-ttl{font-size:.58rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.72);margin-bottom:1rem}
.fc-links{list-style:none;display:flex;flex-direction:column;gap:.52rem}
.fc-links a{font-size:.82rem;font-weight:300;color:rgba(255,255,255,.78);transition:color .22s}
.fc-links a:hover{color:rgba(255,255,255,.8)}
.ft-base{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}
.fc{font-size:.63rem;font-weight:300;color:rgba(255,255,255,.68)}
.fc a{color:var(--b300);opacity:.85;transition:opacity .22s}
.fc a:hover{opacity:.9}

/* Responsive */
@media(max-width:900px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-img{height:55vw;min-height:300px}
  .hero-content{padding:3rem 1.5rem}
  .about-grid,.media-grid,.faq-grid,.ft{grid-template-columns:1fr;gap:2.5rem}
  .about-photo-col,.media-left,.faq-left{position:static}
  .svc-grid{grid-template-columns:1fr}
  .nav-links{display:none}
  .book-photo{display:none}
  .book-inner{max-width:100%}
  .logo-variants{gap:2rem}
}