/* ============================================================
   GHRT Limited — Editorial Tech redesign
   Fonts: Fraunces (display) · Hanken Grotesk (body) · JetBrains Mono (labels)
   ============================================================ */

:root{
  --paper:#F3EFE6;
  --paper-2:#EAE4D6;
  --ink:#15120C;
  --ink-soft:#3A352B;
  --muted:#7A7263;
  --line:#DBD3C2;
  --blue:#1F2BE8;
  --blue-dark:#161FB0;
  --coral:#EE6037;
  --white:#FFFFFF;
  --radius:18px;
  --radius-lg:28px;
  --shadow:0 24px 60px -28px rgba(21,18,12,.45);
  --shadow-sm:0 10px 30px -18px rgba(21,18,12,.4);
  --maxw:1200px;
  --ease:cubic-bezier(.4,.05,.15,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
  position:relative;
}
/* paper grain */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}

h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:600;line-height:1.04;letter-spacing:-.015em;color:var(--ink)}
.serif-italic{font-style:italic;font-weight:400}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:2}
.section{padding:110px 0}
.section-sm{padding:72px 0}

/* ---------- kicker label ---------- */
.kicker{
  font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:500;
  text-transform:uppercase;letter-spacing:.22em;color:var(--blue);
  display:inline-flex;align-items:center;gap:10px;margin-bottom:22px;
}
.kicker::before{content:"";width:26px;height:2px;background:var(--coral);display:inline-block}
.kicker.center{justify-content:center}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;font-family:'Hanken Grotesk',sans-serif;
  font-weight:700;font-size:15px;padding:15px 28px;border-radius:100px;cursor:pointer;
  border:2px solid var(--ink);background:var(--ink);color:var(--paper);
  transition:transform .35s var(--ease),background .3s,color .3s,box-shadow .3s;
}
.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.btn .arr{transition:transform .35s var(--ease)}
.btn:hover .arr{transform:translate(4px,-4px)}
.btn-blue{background:var(--blue);border-color:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-dark);border-color:var(--blue-dark)}
.btn-ghost{background:transparent;color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-coral{background:var(--coral);border-color:var(--coral);color:#fff}

.link-arrow{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:500;
  text-transform:uppercase;letter-spacing:.15em;display:inline-flex;align-items:center;gap:8px;
  border-bottom:2px solid transparent;padding-bottom:3px;transition:border-color .3s,gap .3s}
.link-arrow:hover{border-color:var(--coral);gap:14px}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:sticky;top:0;z-index:50;background:rgba(243,239,230,.82);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.logo img{height:40px;width:auto}
.nav-links{display:flex;align-items:center;gap:34px}
.nav-links a{font-weight:600;font-size:15px;position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;
  background:var(--blue);transition:width .3s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:18px}
.menu-btn{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.menu-btn span{width:26px;height:2px;background:var(--ink);transition:.3s}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding:84px 0 96px;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(42px,6vw,82px);margin:14px 0 26px}
.hero h1 .hl{color:var(--blue);position:relative;display:inline-block}
.hero p.lead{font-size:19px;color:var(--ink-soft);max-width:46ch;margin-bottom:36px}
.hero-cta{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.hero-visual{position:relative}
.hero-visual .panel{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);
  border:1px solid var(--line)}
.hero-visual .panel img{width:100%}
.float-card{position:absolute;background:var(--paper);border:1px solid var(--line);
  border-radius:16px;padding:16px 20px;box-shadow:var(--shadow-sm);display:flex;
  align-items:center;gap:14px}
.float-card .dot{width:42px;height:42px;border-radius:12px;background:var(--coral);
  display:grid;place-items:center;color:#fff;font-weight:800;font-family:'Fraunces',serif}
.float-card.fc1{bottom:-26px;left:-26px}
.float-card.fc2{top:34px;right:-22px;background:var(--ink);color:var(--paper);border-color:var(--ink)}
.float-card small{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;opacity:.7;display:block}
.float-card b{font-family:'Fraunces',serif;font-size:20px;font-weight:600}

.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--ink);overflow:hidden;padding:16px 0}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:scroll 26s linear infinite;width:max-content}
.marquee span{font-family:'JetBrains Mono',monospace;color:var(--paper);font-size:14px;
  letter-spacing:.18em;text-transform:uppercase;display:flex;align-items:center;gap:60px}
.marquee span::after{content:"✦";color:var(--coral)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.sec-head{max-width:640px;margin-bottom:56px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(32px,4.4vw,54px)}
.sec-head .desc{margin-top:18px;color:var(--ink-soft);font-size:18px}
.head-row{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;
  margin-bottom:56px;flex-wrap:wrap}
.head-row .sec-head{margin-bottom:0}

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:60px;align-items:center}
.about-media{position:relative}
.about-media img{border-radius:var(--radius-lg);width:100%;border:1px solid var(--line)}
.about-badge{position:absolute;right:-22px;bottom:-22px;width:138px;height:138px;border-radius:50%;
  background:var(--blue);color:#fff;display:grid;place-content:center;text-align:center;
  font-family:'Fraunces',serif;line-height:1.05;box-shadow:var(--shadow-sm);padding:18px}
.about-badge b{font-size:34px;display:block}
.about-badge small{font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.14em;
  text-transform:uppercase;opacity:.85}
.about-body p{margin-bottom:18px;color:var(--ink-soft)}
.feature-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.feature-tags li{font-family:'JetBrains Mono',monospace;font-size:12.5px;letter-spacing:.04em;
  background:var(--paper);border:1px solid var(--line);border-radius:100px;padding:9px 16px;
  display:flex;align-items:center;gap:8px;transition:.3s}
.feature-tags li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--coral)}
.feature-tags li:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);transform:translateY(-2px)}

/* ============================================================
   SERVICES GRID
   ============================================================ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;display:flex;flex-direction:column;transition:transform .45s var(--ease),box-shadow .4s,border-color .4s;
  position:relative}
.svc-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--ink)}
.svc-thumb{aspect-ratio:4/3;overflow:hidden;position:relative}
.svc-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.svc-card:hover .svc-thumb img{transform:scale(1.06)}
.svc-num{position:absolute;top:14px;left:14px;font-family:'JetBrains Mono',monospace;
  font-size:12px;background:var(--paper);border-radius:100px;padding:5px 12px;letter-spacing:.1em}
.svc-body{padding:26px 26px 30px;flex:1;display:flex;flex-direction:column}
.svc-body h3{font-size:25px;margin-bottom:12px}
.svc-body p{color:var(--ink-soft);font-size:15.5px;flex:1}
.svc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:22px}
.svc-foot .arrow-circle{width:46px;height:46px;border-radius:50%;border:2px solid var(--ink);
  display:grid;place-items:center;transition:.35s var(--ease)}
.svc-card:hover .arrow-circle{background:var(--blue);border-color:var(--blue);transform:rotate(-45deg)}
.svc-card:hover .arrow-circle svg path{stroke:#fff}
.svc-tag{font-family:'JetBrains Mono',monospace;font-size:11px;text-transform:uppercase;
  letter-spacing:.14em;color:var(--muted)}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi-sec{background:var(--ink);color:var(--paper)}
.testi-sec h2,.testi-sec .kicker{color:var(--paper)}
.testi-sec .kicker{color:#A9B0FF}
.testi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.testi-card{background:#211D16;border:1px solid #322C22;border-radius:var(--radius-lg);
  padding:34px;transition:.4s var(--ease)}
.testi-card:hover{transform:translateY(-6px);border-color:var(--coral)}
.stars{display:flex;gap:4px;margin-bottom:20px}
.stars svg{width:18px;height:18px}
.testi-card p{font-size:16.5px;color:#E7E1D4;margin-bottom:26px}
.testi-author{display:flex;align-items:center;gap:14px}
.testi-author img{width:52px;height:52px;border-radius:50%}
.testi-author b{font-family:'Fraunces',serif;font-size:19px;font-weight:600;display:block}
.testi-author small{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:#A29B8B}

/* ============================================================
   BLOG
   ============================================================ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.blog-card{border-radius:var(--radius-lg);overflow:hidden;background:var(--paper);
  border:1px solid var(--line);transition:transform .45s var(--ease),box-shadow .4s,border-color .4s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--ink)}
.blog-thumb{aspect-ratio:16/10;overflow:hidden}
.blog-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.blog-card:hover .blog-thumb img{transform:scale(1.06)}
.blog-body{padding:26px 26px 30px;flex:1;display:flex;flex-direction:column}
.blog-meta{display:flex;align-items:center;gap:12px;margin-bottom:14px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted)}
.blog-meta .by{background:var(--blue);color:#fff;border-radius:100px;padding:4px 11px}
.blog-body h3{font-size:22px;line-height:1.2;flex:1}
.blog-body h3 a:hover{color:var(--blue)}
.blog-body .more{margin-top:20px}

/* ============================================================
   PAGE HEADER (interior pages)
   ============================================================ */
.page-head{padding:72px 0 64px;background:var(--paper-2);border-bottom:1px solid var(--line);
  position:relative;overflow:hidden}
.page-head::after{content:"";position:absolute;right:-80px;top:-80px;width:320px;height:320px;
  border-radius:50%;background:radial-gradient(circle,var(--blue) 0%,transparent 70%);opacity:.12}
.page-head h1{font-size:clamp(40px,6vw,74px)}
.crumbs{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted);margin-top:16px;display:flex;gap:10px;align-items:center}
.crumbs a:hover{color:var(--blue)}
.crumbs .sep{color:var(--coral)}

/* ============================================================
   SERVICE DETAIL
   ============================================================ */
.svc-detail{display:grid;grid-template-columns:1fr 340px;gap:54px;align-items:start}
.svc-hero-img{border-radius:var(--radius-lg);overflow:hidden;margin-bottom:36px;border:1px solid var(--line)}
.svc-detail .body p{color:var(--ink-soft);margin-bottom:22px;font-size:17px}
.svc-detail .body h3{font-size:30px;margin:38px 0 16px}
.svc-callout{background:var(--blue);color:#fff;border-radius:var(--radius-lg);padding:34px 38px;
  margin-top:38px}
.svc-callout h4{font-family:'Fraunces',serif;color:#fff;font-size:24px;font-weight:600;line-height:1.25}
.share-row{display:flex;align-items:center;gap:12px;margin-top:34px}
.share-row .lbl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted)}
.share-row a{width:40px;height:40px;border-radius:50%;border:1px solid var(--line);display:grid;
  place-items:center;transition:.3s}
.share-row a:hover{background:var(--ink);border-color:var(--ink)}
.share-row a:hover svg path,.share-row a:hover svg circle{fill:var(--paper)}
.svc-sidebar{position:sticky;top:100px}
.side-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:26px;margin-bottom:22px}
.side-card h4{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:18px}
.side-list li{margin-bottom:4px}
.side-list a{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;
  border-radius:12px;font-weight:600;font-size:15px;transition:.3s}
.side-list a:hover,.side-list a.active{background:var(--ink);color:var(--paper)}
.side-list a.active .n,.side-list a:hover .n{color:var(--coral)}
.side-list .n{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--muted)}
.side-cta{background:var(--ink);color:var(--paper);border-radius:var(--radius-lg);padding:30px;text-align:center}
.side-cta h4{font-family:'Fraunces',serif;color:#fff;font-size:23px;letter-spacing:0;text-transform:none;margin-bottom:10px}
.side-cta p{font-size:14px;color:#C9C2B4;margin-bottom:20px}
.recent-list{display:flex;flex-direction:column;gap:18px}
.recent-item{display:flex;gap:14px;align-items:flex-start}
.recent-item img{width:74px;height:60px;flex:0 0 74px;border-radius:10px;object-fit:cover;border:1px solid var(--line)}
.recent-item .by{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted);margin-bottom:5px}
.recent-item strong{display:block;font-family:'Fraunces',serif;font-weight:500;font-size:15px;
  line-height:1.3;color:var(--ink);transition:color .3s}
.recent-item:hover strong{color:var(--blue)}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:64px}
.contact-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:34px;transition:.4s var(--ease)}
.contact-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--ink)}
.contact-card .ic{width:56px;height:56px;border-radius:14px;background:var(--blue);display:grid;
  place-items:center;margin-bottom:22px}
.contact-card .ic svg{width:26px;height:26px}
.contact-card .lbl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.contact-card p,.contact-card a{font-size:17px;color:var(--ink);line-height:1.45}
.contact-card a:hover{color:var(--blue)}

.contact-split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.form{display:grid;gap:18px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field label{display:block;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.field input,.field textarea,.field select{width:100%;padding:15px 18px;border:1px solid var(--line);
  border-radius:14px;background:var(--paper);font-family:'Hanken Grotesk',sans-serif;font-size:16px;
  color:var(--ink);transition:.3s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--blue);
  box-shadow:0 0 0 4px rgba(31,43,232,.10)}
.field textarea{resize:vertical;min-height:130px}
.map-embed{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);height:100%;min-height:420px}
.map-embed iframe{width:100%;height:100%;border:0;display:block}

/* ============================================================
   CTA STRIP
   ============================================================ */
.cta-strip{background:var(--ink);color:var(--paper);border-radius:var(--radius-lg);
  padding:64px 56px;display:flex;justify-content:space-between;align-items:center;gap:40px;
  flex-wrap:wrap;position:relative;overflow:hidden}
.cta-strip::before{content:"";position:absolute;right:-60px;bottom:-100px;width:300px;height:300px;
  border-radius:50%;background:var(--blue);opacity:.35;filter:blur(20px)}
.cta-strip h2{color:#fff;font-size:clamp(28px,3.6vw,44px);max-width:18ch;position:relative}
.cta-strip .kicker{color:#A9B0FF}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--ink);color:#C9C2B4;padding:80px 0 0;position:relative}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:56px}
.footer-brand img{height:42px;margin-bottom:22px}
.footer-brand p{font-size:15px;max-width:34ch;margin-bottom:22px}
.footer-contact li{margin-bottom:8px;font-size:15px}
.footer-contact a:hover{color:#fff}
.footer-col h4{font-family:'JetBrains Mono',monospace;color:#fff;font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;font-weight:500;margin-bottom:22px}
.footer-col li{margin-bottom:11px}
.footer-col a{font-size:15px;transition:.3s;position:relative;padding-left:0}
.footer-col a:hover{color:#fff;padding-left:8px}
.socials{display:flex;gap:12px;margin-top:6px}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid #322C22;display:grid;
  place-items:center;transition:.3s}
.socials a:hover{background:var(--blue);border-color:var(--blue)}
.socials svg{width:17px;height:17px}
.socials a:hover svg path{fill:#fff}
.footer-bottom{border-top:1px solid #2A2620;padding:26px 0;display:flex;justify-content:space-between;
  align-items:center;flex-wrap:wrap;gap:14px;font-size:13.5px}
.footer-bottom .mono{font-family:'JetBrains Mono',monospace;letter-spacing:.04em}

/* ============================================================
   ANIMATIONS — staggered reveal
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
.reveal.d5{transition-delay:.40s}.reveal.d6{transition-delay:.48s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none}
  .marquee-track{animation:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .hero-grid,.about-grid,.contact-split,.svc-detail{grid-template-columns:1fr;gap:46px}
  .services-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .svc-sidebar{position:static}
  .hero-visual{order:-1}
}
@media (max-width:760px){
  .menu-btn{display:flex}
  .nav-links{position:fixed;inset:78px 0 auto;background:var(--paper);flex-direction:column;
    align-items:flex-start;padding:24px 28px;gap:6px;border-bottom:1px solid var(--line);
    transform:translateY(-120%);transition:transform .4s var(--ease);box-shadow:var(--shadow-sm)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{width:100%;padding:12px 0;border-bottom:1px solid var(--line);font-size:18px}
  .nav-cta .btn{display:none}
  .section{padding:72px 0}
  .testi-grid,.services-grid,.blog-grid,.contact-cards,.form .row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cta-strip{padding:44px 30px}
  .about-badge{width:108px;height:108px}
  body{font-size:16px}
}
@media (max-width:480px){
  .wrap{padding:0 20px}
  .footer-grid{grid-template-columns:1fr}
  .hero h1{font-size:40px}
}
