/* Sky TCM — the7-style single-page CSS */
@import url('tokens.css');

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--cream-100); color: var(--ink-800); font-family: var(--font-sans); line-height: 1.55; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

:root {
  --page-w: 1280px;
}

/* ========================================================== */
/* Top nav — pill, centered menu, right cluster (template-style) */
/* ========================================================== */
.sr-nav {
  position: sticky; top: 16px; z-index: 40;
  max-width: 1180px; margin: 16px auto 0; padding: 0 24px;
}
.sr-nav .inner {
  display: grid; grid-template-columns: auto 1fr auto;
  align-items: center; gap: 24px;
  padding: 10px 14px 10px 22px;
  background: rgba(255,255,255,0.78);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border-hair);
  border-radius: 999px;
  box-shadow: 0 10px 32px -16px rgba(15,69,56,0.18);
}
.sr-nav .links { justify-content: center; }
.sr-nav .logo { display:flex; align-items:center; gap:10px; white-space: nowrap; }
.sr-nav .logo img { width: 42px; height: 42px; object-fit: contain; }
.sr-nav .logo .wm { font-family: var(--font-display); font-style: italic; font-weight: 500; font-size: 22px; color: var(--sage-900); line-height: 1; }
.sr-nav .logo .zh { font-family: var(--font-serif-zh); font-size: 12px; color: var(--sage-700); letter-spacing: 0.14em; margin-top: 2px; }
.sr-nav .links { display:flex; gap: 28px; }
.sr-nav .right { display: flex; align-items: center; gap: 14px; }
.sr-nav .links a { font-size: 14px; color: var(--ink-700); padding: 8px 0; position: relative; }
.sr-nav .links a:hover { color: var(--sage-800); }
.sr-nav .links a.active { color: var(--sage-900); }
.sr-nav .links a.active::after { content:""; position:absolute; left:0; right:0; bottom:0; height:1px; background: var(--gold-600); }
.sr-nav .lang { display: inline-flex; border: 1px solid var(--border); border-radius: 999px; overflow: hidden; font-size: 12px; cursor:pointer; background: rgba(255,255,255,0.6); }
.sr-nav .lang span { padding: 6px 11px; color: var(--ink-700); }
.sr-nav .lang span.on { background: var(--sage-700); color: var(--cream-100); }
.sr-nav .cta { background: var(--sage-900); color: var(--cream-100); padding: 10px 20px; border-radius: 999px; font-size: 13px; letter-spacing: 0.04em; }
.sr-nav .cta:hover { background: var(--ink-900); }

/* ========================================================== */
/* Hero — full-bleed brand image with overlay copy            */
/* ========================================================== */
.hero-full {
  position: relative;
  width: 100%;
  min-height: 720px;
  height: calc(100vh - 80px);
  max-height: 880px;
  overflow: hidden;
  background: var(--sage-900);
  margin-top: -74px;
}
.hero-full .bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center 40%;
}
.hero-full .veil {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(15,40,70,0.30) 0%, rgba(15,40,70,0) 30%, rgba(15,40,70,0) 55%, rgba(8,22,40,0.60) 100%),
    linear-gradient(90deg, rgba(8,25,50,0.70) 0%, rgba(8,25,50,0.25) 55%, rgba(8,25,50,0.05) 100%);
}
.hero-full .hero-inner {
  position: relative; z-index: 2;
  max-width: var(--page-w); margin: 0 auto;
  padding: 120px 32px 80px;
  color: var(--cream-100);
  max-width: 900px;
}
.hero-full .badges { display: flex; gap: 10px; margin-bottom: 40px; flex-wrap: wrap; }
.hero-full .badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 16px;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.25);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border-radius: 999px;
  font-size: 12.5px; color: var(--cream-100); letter-spacing: 0.02em;
}
.hero-full .badge i { color: var(--gold-400); font-size: 14px; }
.hero-full .kicker {
  font-size: 12px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--gold-400); font-weight: 600; margin-bottom: 18px;
  display: inline-flex; align-items: center; gap: 12px;
}
.hero-full .kicker::before { content:""; width: 24px; height: 1px; background: var(--gold-500); }
.hero-full h1 {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(36px, 4.5vw, 64px); line-height: 1.02; letter-spacing: -0.02em;
  color: var(--cream-50); margin: 0 0 18px;
}
.hero-full h1 em { font-style: italic; color: var(--gold-300); }
.hero-full .sub-zh {
  font-family: var(--font-serif-zh); font-weight: 500;
  font-size: clamp(20px, 2vw, 26px); letter-spacing: 0.1em;
  color: var(--cream-200); margin-bottom: 28px;
}
.hero-full .lede {
  font-size: 17px; line-height: 1.7; color: rgba(245,239,230,0.9);
  max-width: 620px; margin: 0 0 32px;
}
.hero-full .focus-row {
  display: flex; gap: 28px; margin: 0 0 40px; flex-wrap: wrap;
  padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.15);
}
.hero-full .focus {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 14px; color: var(--cream-200);
}
.hero-full .focus i { color: var(--gold-400); font-size: 20px; }
.hero-full .ctas { display: flex; gap: 14px; flex-wrap: wrap; }
.hero-full .ctas .btn-primary { background: var(--gold-600); color: var(--cream-50); }
.hero-full .ctas .btn-primary:hover { background: var(--gold-700); }
.hero-full .ctas .btn-outline.light { color: var(--cream-100); border-color: rgba(255,255,255,0.5); }
.hero-full .ctas .btn-outline.light:hover { background: rgba(255,255,255,0.1); border-color: var(--cream-100); }

/* ========================================================== */
/* Shared section headings + containers                       */
/* ========================================================== */
.sec { padding: 104px 32px; }
.sec .inner { max-width: var(--page-w); margin: 0 auto; }
.sec.cream { background: var(--cream-200); }
.sec.white { background: #fff; }
.sec.dark { background: var(--sage-900); color: var(--cream-200); }
.sec.dark h2, .sec.dark h3 { color: var(--cream-100); }

.sec-head { max-width: 720px; margin: 0 0 56px; }
.sec-head.center { margin: 0 auto 64px; text-align: center; }
.sec-head .eyebrow { font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold-700); font-weight: 600; margin-bottom: 18px; display: inline-flex; align-items: center; gap: 10px; }
.sec-head .eyebrow::before { content:""; width: 18px; height: 1px; background: var(--gold-600); }
.sec-head h2 {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(32px, 3.5vw, 54px); line-height: 1.1; letter-spacing: -0.01em;
  color: var(--sage-900); margin: 0 0 12px;
}
.sec-head .zh { font-family: var(--font-serif-zh); font-weight: 500; font-size: 18px; letter-spacing: 0.1em; color: var(--sage-700); }
.sec.dark .sec-head .zh { color: var(--gold-300); }

/* ========================================================== */
/* Hero feature strip — 4-up small cards pinned below hero    */
/* ========================================================== */
.hero-strip { max-width: var(--page-w); margin: -64px auto 0; padding: 0 32px; position: relative; z-index: 3; }
.hero-strip .grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.hero-strip .cell {
  position: relative; aspect-ratio: 5/4; border-radius: 18px; overflow: hidden;
  background: var(--cream-200);
}
.hero-strip .cell img { width: 100%; height: 100%; object-fit: cover; }
.hero-strip .cell .tint { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(15,69,56,0) 30%, rgba(15,69,56,0.85) 100%); }
.hero-strip .cell .label { position: absolute; left: 16px; right: 16px; bottom: 14px; color: var(--cream-100); }
.hero-strip .cell .label .t { font-family: var(--font-serif); font-weight: 500; font-size: 15px; line-height: 1.2; }
.hero-strip .cell .label .z { font-family: var(--font-serif-zh); font-size: 11.5px; letter-spacing: 0.08em; opacity: 0.85; margin-top: 3px; }

/* ========================================================== */
/* Feature grid — 3 × 2 image cards with title + caption      */
/* ========================================================== */
.features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px 28px; }
.feature .thumb { aspect-ratio: 4/3; border-radius: 18px; overflow: hidden; background: var(--cream-200); margin-bottom: 22px; position: relative; }
.feature .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 600ms var(--ease-out); }
.feature:hover .thumb img { transform: scale(1.03); }
.feature .thumb.fallback { display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--sage-600), var(--sage-800)); }
.feature .thumb.fallback i { font-size: 72px; color: var(--cream-100); opacity: 0.7; }
.feature h3 { font-family: var(--font-serif); font-weight: 500; font-size: 24px; margin: 0 0 4px; color: var(--sage-900); line-height: 1.2; }
.feature .zh { font-family: var(--font-serif-zh); font-size: 14px; letter-spacing: 0.08em; color: var(--sage-700); margin-bottom: 10px; }
.feature p { font-size: 14.5px; color: var(--ink-600); line-height: 1.6; margin: 0; }

/* ========================================================== */
/* Mid CTA bar — "Want to learn more" + button                */
/* ========================================================== */
.mid-cta {
  display: flex; align-items: center; justify-content: space-between; gap: 32px;
  padding: 44px 56px; background: #fff; border-radius: 22px;
  border: 1px solid var(--border-hair); box-shadow: var(--shadow-sm);
  flex-wrap: wrap;
}
.mid-cta h3 { font-family: var(--font-display); font-weight: 500; font-size: 28px; color: var(--sage-900); margin: 0; }
.mid-cta .zh { font-family: var(--font-serif-zh); font-size: 15px; color: var(--sage-700); margin-top: 4px; letter-spacing: 0.06em; }

/* ========================================================== */
/* Split section — image + text + specs + awards              */
/* ========================================================== */
.split { display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center; }
.split.reverse { grid-template-columns: 1fr 1.1fr; }
.split.reverse .media { order: 2; }
.split .media { position: relative; }
.split .media img { width: 100%; aspect-ratio: 4/5; object-fit: cover; border-radius: 22px; box-shadow: var(--shadow-lg); }
.split .copy h2 { font-family: var(--font-display); font-weight: 500; font-size: clamp(32px, 3.4vw, 48px); line-height: 1.1; letter-spacing: -0.01em; color: var(--sage-900); margin: 0 0 22px; }
.split .copy .zh-lead { font-family: var(--font-serif-zh); font-weight: 500; font-size: 20px; color: var(--sage-700); margin: -12px 0 24px; letter-spacing: 0.08em; }
.split .copy p { font-size: 16px; line-height: 1.75; color: var(--ink-700); margin: 0 0 18px; }

.specs { margin: 28px 0 32px; }
.specs .row { display: flex; justify-content: space-between; padding: 14px 0; border-top: 1px solid var(--border-hair); }
.specs .row:last-child { border-bottom: 1px solid var(--border-hair); }
.specs .k { font-size: 13px; color: var(--ink-500); letter-spacing: 0.06em; text-transform: uppercase; font-weight: 500; }
.specs .v { font-family: var(--font-serif); font-size: 15px; color: var(--sage-900); font-weight: 500; }
.specs .v .zh { font-family: var(--font-serif-zh); color: var(--sage-700); font-weight: 500; margin-left: 8px; font-size: 14px; }

.awards { display: flex; gap: 18px; margin-top: 28px; flex-wrap: wrap; }
.award { display: flex; align-items: center; gap: 12px; padding: 12px 18px; background: var(--cream-100); border: 1px solid var(--border-hair); border-radius: 14px; }
.award i { color: var(--gold-600); font-size: 22px; }
.award .t { font-family: var(--font-serif); font-weight: 500; font-size: 13.5px; color: var(--sage-900); }
.award .y { font-size: 11px; color: var(--ink-500); letter-spacing: 0.1em; margin-top: 2px; }

/* ========================================================== */
/* Two-image wide section + right text + CTA                  */
/* ========================================================== */
.two-img { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.two-img img { width: 100%; aspect-ratio: 4/5; object-fit: cover; border-radius: 22px; }
.two-img img:first-child { aspect-ratio: 3/4; align-self: start; margin-top: 48px; }

/* ========================================================== */
/* 3-column icon/image cards                                  */
/* ========================================================== */
.icon-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.icard { background: #fff; border-radius: 22px; padding: 28px; border: 1px solid var(--border-hair); transition: box-shadow 260ms var(--ease-out); }
.icard:hover { box-shadow: var(--shadow-lg); }
.icard .thumb { aspect-ratio: 4/3; border-radius: 14px; overflow: hidden; margin-bottom: 22px; background: linear-gradient(135deg, var(--sage-600), var(--sage-800)); display:flex; align-items:center; justify-content:center; }
.icard .thumb img { width: 100%; height: 100%; object-fit: cover; }
.icard .thumb i { font-size: 64px; color: var(--cream-100); opacity: 0.85; }
.icard h3 { font-family: var(--font-serif); font-weight: 500; font-size: 22px; color: var(--sage-900); margin: 0 0 6px; line-height: 1.25; }
.icard .zh { font-family: var(--font-serif-zh); font-size: 14px; color: var(--sage-700); letter-spacing: 0.08em; margin-bottom: 12px; }
.icard p { font-size: 14.5px; line-height: 1.65; color: var(--ink-600); margin: 0; }

/* ========================================================== */
/* Big statement — huge product image + overlay title         */
/* ========================================================== */
.big-statement {
  position: relative;
  aspect-ratio: 21/9;
  border-radius: 28px;
  overflow: hidden;
  background: #0f4538;
  margin: 0 auto;
  max-width: var(--page-w);
}
.big-statement img { width: 100%; height: 100%; object-fit: cover; opacity: 0.45; }
.big-statement .overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(15,69,56,0.85) 0%, rgba(15,69,56,0.5) 60%, rgba(15,69,56,0.2) 100%); }
.big-statement .copy {
  position: absolute; left: 56px; top: 50%; transform: translateY(-50%);
  color: var(--cream-100); max-width: 560px;
}
.big-statement .eyebrow { font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold-500); font-weight: 600; margin-bottom: 20px; display: inline-flex; align-items: center; gap: 10px; }
.big-statement .eyebrow::before { content:""; width: 18px; height: 1px; background: var(--gold-600); }
.big-statement h2 { font-family: var(--font-display); font-weight: 500; font-size: clamp(36px, 4vw, 60px); line-height: 1.08; letter-spacing: -0.01em; margin: 0 0 14px; }
.big-statement .zh { font-family: var(--font-serif-zh); font-weight: 500; font-size: 20px; color: var(--gold-300); letter-spacing: 0.1em; }

/* ========================================================== */
/* Choose your style — 4 product squares                      */
/* ========================================================== */
.styles-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.style-card { background: var(--cream-100); border-radius: 18px; overflow: hidden; cursor: pointer; transition: transform 260ms var(--ease-out); }
.style-card:hover { transform: translateY(-4px); }
.style-card .thumb { aspect-ratio: 1; background-size: cover; background-position: center; background-color: var(--cream-200); }
.style-card .body { padding: 20px 22px 24px; }
.style-card h3 { font-family: var(--font-serif); font-weight: 500; font-size: 20px; color: var(--sage-900); margin: 0 0 2px; }
.style-card .zh { font-family: var(--font-serif-zh); font-size: 13px; letter-spacing: 0.08em; color: var(--sage-700); margin-bottom: 8px; }
.style-card .desc { font-size: 13px; color: var(--ink-600); line-height: 1.55; margin: 0; }

/* ========================================================== */
/* Video CTA banner                                            */
/* ========================================================== */
.video-banner {
  position: relative;
  border-radius: 28px;
  overflow: hidden;
  aspect-ratio: 21/8;
  max-width: var(--page-w);
  margin: 0 auto;
  background: #0f4538;
}
.video-banner img { width: 100%; height: 100%; object-fit: cover; opacity: 0.55; }
.video-banner .overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(15,69,56,0.3), rgba(15,69,56,0.7)); }
.video-banner .play { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -80%); width: 80px; height: 80px; border-radius: 999px; background: rgba(255,255,255,0.15); backdrop-filter: blur(8px); border: 1.5px solid rgba(255,255,255,0.6); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 220ms var(--ease-out); }
.video-banner .play:hover { background: var(--gold-600); border-color: var(--gold-600); transform: translate(-50%, -80%) scale(1.05); }
.video-banner .play i { color: #fff; font-size: 32px; margin-left: 4px; }
.video-banner h3 { position: absolute; left: 50%; bottom: 56px; transform: translateX(-50%); color: var(--cream-100); font-family: var(--font-display); font-weight: 500; font-style: italic; font-size: clamp(22px, 2.2vw, 32px); text-align: center; max-width: 680px; margin: 0; line-height: 1.3; }
.video-banner .zh { position: absolute; left: 50%; bottom: 24px; transform: translateX(-50%); font-family: var(--font-serif-zh); color: var(--gold-300); font-size: 15px; letter-spacing: 0.12em; }

/* ========================================================== */
/* Awards / Featured in — 4 logos + description                */
/* ========================================================== */
.featured { display: grid; grid-template-columns: repeat(4, 1fr); gap: 40px; }
.featured .item { text-align: left; }
.featured .logo { height: 42px; display: flex; align-items: center; margin-bottom: 20px; color: var(--sage-800); font-family: var(--font-display); font-style: italic; font-size: 22px; letter-spacing: 0.02em; opacity: 0.85; }
.featured .logo.pub1 { font-family: var(--font-serif); font-weight: 500; font-style: normal; letter-spacing: 0.12em; text-transform: uppercase; font-size: 14px; }
.featured .logo.pub2 { font-family: var(--font-display); font-style: italic; font-weight: 500; font-size: 26px; }
.featured .logo.pub3 { font-family: var(--font-serif-zh); font-weight: 500; font-size: 22px; letter-spacing: 0.2em; }
.featured .logo.pub4 { font-family: var(--font-serif); font-weight: 500; text-transform: uppercase; letter-spacing: 0.18em; font-size: 13px; }
.featured p { font-size: 14.5px; color: var(--ink-600); line-height: 1.65; margin: 0; }

/* ========================================================== */
/* Testimonials — horizontal row of 5                          */
/* ========================================================== */
.testimonials { display: grid; grid-template-columns: repeat(5, 1fr); gap: 20px; }
.t-card { background: var(--cream-200); border-radius: 18px; padding: 26px 24px; display: flex; flex-direction: column; gap: 18px; }
.t-card .face { width: 64px; height: 64px; border-radius: 999px; background-size: cover; background-position: center; background-color: var(--cream-100); border: 2px solid #fff; box-shadow: var(--shadow-sm); }
.t-card .face.init { display:flex; align-items:center; justify-content:center; background: var(--sage-700); color: var(--cream-100); font-family: var(--font-display); font-style: italic; font-size: 22px; }
.t-card .name { font-family: var(--font-serif); font-weight: 500; font-size: 17px; color: var(--sage-900); }
.t-card .role { font-size: 12px; letter-spacing: 0.08em; color: var(--ink-500); margin-top: 2px; }
.t-card blockquote { font-family: var(--font-serif); font-style: italic; font-size: 14.5px; color: var(--ink-700); line-height: 1.65; margin: 0; border-left: 2px solid var(--gold-600); padding-left: 16px; }
.t-card blockquote.zh { font-family: var(--font-serif-zh); font-style: normal; letter-spacing: 0.04em; }

/* ========================================================== */
/* Blog cards                                                 */
/* ========================================================== */
.blog { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.post .thumb { aspect-ratio: 4/3; border-radius: 18px; overflow: hidden; margin-bottom: 18px; background: var(--cream-200); }
.post .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 600ms var(--ease-out); }
.post:hover .thumb img { transform: scale(1.04); }
.post h3 { font-family: var(--font-serif); font-weight: 500; font-size: 22px; color: var(--sage-900); margin: 0 0 10px; line-height: 1.3; }
.post .meta { display: flex; gap: 14px; align-items: center; font-size: 12px; color: var(--ink-500); letter-spacing: 0.08em; }
.post .cat { color: var(--gold-700); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; font-size: 11px; }
.post .cat::after { content:" ·"; color: var(--border); margin-left: 8px; }

/* ========================================================== */
/* Footer                                                     */
/* ========================================================== */
.sr-footer { background: var(--cream-200); border-top: 1px solid var(--border-hair); padding: 60px 32px 32px; }
.sr-footer .inner { max-width: var(--page-w); margin: 0 auto; display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 40px; }
.sr-footer .logo { display:flex; align-items:center; gap:10px; white-space: nowrap; margin-bottom: 18px; }
.sr-footer .logo img { width: 42px; height: 42px; object-fit: contain; }
.sr-footer .logo .wm { font-family: var(--font-display); font-style: italic; font-weight: 500; font-size: 22px; color: var(--sage-900); }
.sr-footer .logo .zh { font-family: var(--font-serif-zh); font-size: 12px; color: var(--sage-700); letter-spacing: 0.14em; margin-top: 2px; }
.sr-footer .copy { font-size: 13.5px; color: var(--ink-600); line-height: 1.65; max-width: 280px; }
.sr-footer h5 { font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--sage-900); font-weight: 600; margin: 0 0 16px; }
.sr-footer a.link { display: block; padding: 5px 0; font-size: 13.5px; color: var(--ink-600); }
.sr-footer a.link:hover { color: var(--sage-800); }
.sr-footer .bottom { max-width: var(--page-w); margin: 44px auto 0; padding-top: 22px; border-top: 1px solid var(--border-hair); display: flex; justify-content: space-between; font-size: 12px; color: var(--ink-500); letter-spacing: 0.04em; flex-wrap: wrap; gap: 14px; }
.sr-footer .socials { display: flex; gap: 16px; }
.sr-footer .socials a { width: 34px; height: 34px; border-radius: 999px; border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; color: var(--sage-800); transition: all 180ms var(--ease-out); }
.sr-footer .socials a:hover { background: var(--sage-700); color: var(--cream-100); border-color: var(--sage-700); }

/* ========================================================== */
/* Buttons — inherit from website.css but local names         */
/* ========================================================== */
.btn { display: inline-flex; align-items: center; gap: 10px; cursor: pointer; border: 0; font-family: var(--font-sans); font-weight: 500; letter-spacing: 0.02em; transition: all 160ms var(--ease-out); text-decoration: none; font-size: 14px; }
.btn-primary { background: var(--sage-900); color: var(--cream-100); padding: 14px 28px; border-radius: 999px; }
.btn-primary:hover { background: var(--ink-900); }
.btn-gold { background: var(--gold-600); color: var(--cream-50); padding: 14px 28px; border-radius: 999px; }
.btn-gold:hover { background: var(--gold-700); }
.btn-outline { background: transparent; color: var(--sage-900); padding: 13px 27px; border-radius: 999px; border: 1px solid var(--sage-800); }
.btn-outline:hover { background: var(--sage-900); color: var(--cream-100); }
.btn-ghost { background: transparent; color: var(--sage-800); padding: 10px 0; font-weight: 500; }
.btn-ghost:hover { color: var(--sage-900); }
.btn-ghost i { transition: transform 220ms var(--ease-out); }
.btn-ghost:hover i { transform: translateX(4px); }

/* ========================================================== */
/* Responsive                                                  */
/* ========================================================== */
@media (max-width: 960px) {
  .hero-full { min-height: 620px; height: auto; }
  .hero-full .hero-inner { padding: 100px 24px 80px; }
  .hero-strip .grid { grid-template-columns: repeat(2, 1fr); }
  .split, .split.reverse { grid-template-columns: 1fr; gap: 48px; }
  .split.reverse .media { order: 0; }
  .features, .icon-cards, .blog { grid-template-columns: repeat(2, 1fr); }
  .featured { grid-template-columns: repeat(2, 1fr); gap: 32px; }
  .testimonials { grid-template-columns: repeat(2, 1fr); }
  .styles-grid { grid-template-columns: repeat(2, 1fr); }
  .sr-nav .links { display: none; }
  .sr-footer .inner { grid-template-columns: 1fr 1fr; }
  .big-statement .copy { left: 32px; right: 32px; }
  .two-img img:first-child { margin-top: 0; }
}
@media (max-width: 560px) {
  .sec { padding: 72px 24px; }
  .features, .icon-cards, .blog, .styles-grid, .testimonials, .featured { grid-template-columns: 1fr; }
  .sr-footer .inner { grid-template-columns: 1fr; }
}
