:root{
  --bg: #f7f3ec;
  --bg-soft: #efe7da;
  --paper: #fffdf9;
  --paper-2: #faf5ee;
  --text: #1f1a17;
  --text-soft: #5f564f;
  --text-faint: #7a7068;
  --line: rgba(31,26,23,0.10);
  --line-strong: rgba(31,26,23,0.18);

  --brand: #8c1d18;
  --brand-dark: #651410;
  --brand-soft: #f5e1dd;
  --gold: #c89a3d;
  --forest: #355342;
  --navy: #213445;
  --sky: #dce7f2;
  --success: #2f6d4f;
  --warning: #936a17;

  --hero-overlay: linear-gradient(180deg, rgba(16,12,10,0.20), rgba(16,12,10,0.68));

  --shadow-xs: 0 6px 18px rgba(29, 22, 18, 0.05);
  --shadow-sm: 0 10px 24px rgba(29, 22, 18, 0.07);
  --shadow-md: 0 18px 46px rgba(29, 22, 18, 0.10);
  --shadow-lg: 0 28px 72px rgba(29, 22, 18, 0.14);

  --radius-xs: 10px;
  --radius-sm: 16px;
  --radius-md: 22px;
  --radius-lg: 30px;
  --radius-pill: 999px;

  --content: 1200px;
  --reading: 760px;

  --space-1: 6px;
  --space-2: 10px;
  --space-3: 14px;
  --space-4: 18px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 44px;
  --space-8: 60px;
  --space-9: 84px;

  --header-h: 72px;
  --anchor-offset: 94px;

  --font-sans:
    "Hiragino Sans","Hiragino Kaku Gothic ProN","Yu Gothic","YuGothic",
    "Noto Sans JP","Meiryo",system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  --font-serif:
    "Hiragino Mincho ProN","Yu Mincho","Noto Serif JP","BIZ UDPMincho",
    "Times New Roman",serif;
}

*,
*::before,
*::after{ box-sizing:border-box; }

html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
}

body{
  margin:0;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(200,154,61,0.13), transparent 28%),
    linear-gradient(180deg, #fbf8f2 0%, #f7f3ec 40%, #f2ede5 100%);
  font-family:var(--font-sans);
  line-height:1.9;
  letter-spacing:.02em;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}

img{
  max-width:100%;
  display:block;
  height:auto;
}

svg{ display:block; }

a{
  color:inherit;
  text-decoration:none;
}

button,
input,
select,
textarea{
  font:inherit;
}

button{
  cursor:pointer;
}

::selection{
  background:rgba(140,29,24,.14);
  color:var(--text);
}

:focus-visible{
  outline:3px solid rgba(140,29,24,.28);
  outline-offset:2px;
}

.skip-link{
  position:absolute;
  left:16px;
  top:-100px;
  z-index:9999;
  background:#fff;
  color:#111;
  padding:12px 16px;
  border-radius:12px;
  box-shadow:var(--shadow-md);
  transition:top .2s ease;
}
.skip-link:focus{
  top:16px;
}

.container{
  width:min(100% - 32px, var(--content));
  margin-inline:auto;
}

.reading{
  width:min(100%, var(--reading));
  margin-inline:auto;
}

.section{
  padding-block: clamp(42px, 6vw, 84px);
}

.section-tight{
  padding-block: clamp(26px, 4vw, 46px);
}

.section-head{
  display:grid;
  gap:10px;
  margin-bottom:26px;
}

.kicker{
  margin:0;
  color:var(--brand);
  font-size:.82rem;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.page-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  width:max-content;
  padding:8px 14px;
  border-radius:var(--radius-pill);
  background:rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.55);
  backdrop-filter:blur(10px);
  color:#fff;
  font-size:.82rem;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}

h1,h2,h3,h4{
  margin:0;
  line-height:1.22;
  letter-spacing:.01em;
}

h1{
  font-size:clamp(2.1rem, 5vw, 4.8rem);
  font-weight:900;
}

h2{
  font-size:clamp(1.55rem, 3vw, 2.45rem);
  font-weight:850;
}

h3{
  font-size:clamp(1.15rem, 2vw, 1.48rem);
  font-weight:800;
}

h4{
  font-size:1rem;
  font-weight:800;
}

p{
  margin:0;
}

.lead{
  font-size:clamp(1rem, 1.2vw, 1.12rem);
  color:var(--text-soft);
}

.text-soft{
  color:var(--text-soft);
}

.text-faint{
  color:var(--text-faint);
}

.eyecatch{
  font-family:var(--font-serif);
  font-weight:700;
  letter-spacing:.03em;
}

.prose{
  display:grid;
  gap:18px;
  font-size:1.02rem;
}

.prose p{
  color:var(--text);
}

.prose strong{
  color:#18120f;
  font-weight:800;
}

.prose em{
  font-style:normal;
  color:var(--brand);
}

.prose h2,
.prose h3,
.prose h4{
  margin-top:18px;
}

.prose ul,
.prose ol{
  margin:0;
  padding-left:1.3em;
  display:grid;
  gap:8px;
}

.prose li{
  color:var(--text);
}

.prose blockquote{
  margin:8px 0;
  padding:18px 20px;
  background:linear-gradient(180deg, #fff7f5, #fffdfb);
  border:1px solid rgba(140,29,24,.12);
  border-left:5px solid var(--brand);
  border-radius:18px;
  color:#372c28;
  box-shadow:var(--shadow-xs);
}

.small{
  font-size:.92rem;
}

.tiny{
  font-size:.84rem;
}

.mono{
  font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,253,249,.74);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(31,26,23,.06);
  transition:
    background .25s ease,
    box-shadow .25s ease,
    border-color .25s ease,
    transform .25s ease;
}

.site-header.is-scrolled{
  background:rgba(255,253,249,.92);
  box-shadow:0 10px 28px rgba(25,20,15,.07);
  border-bottom-color:rgba(31,26,23,.10);
}

.site-header-inner{
  min-height:var(--header-h);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}

.brand-mark{
  width:42px;
  height:42px;
  border-radius:50%;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  background:linear-gradient(135deg, var(--brand), var(--brand-dark));
  color:#fff;
  font-weight:900;
  box-shadow:var(--shadow-sm);
}

.brand-text{
  min-width:0;
}

.brand-kicker{
  margin:0;
  color:var(--brand);
  font-size:.72rem;
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.brand-title{
  margin:0;
  font-size:1rem;
  font-weight:850;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

.brand-subtitle{
  margin:0;
  color:var(--text-soft);
  font-size:.78rem;
}

.site-nav{
  display:flex;
  align-items:center;
  gap:10px;
}

.nav-links{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.nav-links a{
  padding:10px 14px;
  border-radius:var(--radius-pill);
  color:#2a2421;
  background:rgba(255,255,255,.65);
  border:1px solid rgba(31,26,23,.08);
  font-size:.93rem;
  font-weight:700;
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}

.nav-links a:hover{
  background:#fff;
  border-color:rgba(31,26,23,.14);
  transform:translateY(-1px);
}

.nav-links a[aria-current="page"]{
  background:linear-gradient(135deg, var(--brand), var(--brand-dark));
  color:#fff;
  border-color:transparent;
}

.nav-toggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:46px;
  height:46px;
  border-radius:14px;
  border:1px solid rgba(31,26,23,.10);
  background:#fff;
  color:#201a17;
  box-shadow:var(--shadow-xs);
}

.nav-toggle svg{
  width:22px;
  height:22px;
}

.mobile-nav{
  display:none;
}

/* Hero */
.hero{
  position:relative;
  overflow:hidden;
  color:#fff;
  background-color:#2a2521;
  min-height:min(78vh, 820px);
}

.hero.has-image{
  background-position:center center;
  background-size:cover;
  background-repeat:no-repeat;
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:var(--hero-overlay);
}

.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.24), rgba(0,0,0,.08) 45%, rgba(0,0,0,.22)),
    linear-gradient(180deg, rgba(0,0,0,0) 48%, rgba(0,0,0,.16) 100%);
}

.hero-inner{
  position:relative;
  z-index:1;
  min-height:min(78vh, 820px);
  display:grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(290px, .82fr);
  gap:28px;
  align-items:end;
  padding-block: clamp(72px, 10vw, 118px) 42px;
}

.hero-copy{
  display:grid;
  gap:18px;
  align-self:end;
}

.hero-title{
  max-width:14ch;
}

.hero-title.wide{
  max-width:18ch;
}

.hero-summary{
  max-width:44rem;
  font-size:1.04rem;
  color:rgba(255,255,255,.95);
}

.hero-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding-top:2px;
}

.chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 14px;
  border-radius:var(--radius-pill);
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  font-size:.88rem;
  font-weight:700;
  backdrop-filter:blur(10px);
}

.hero-panel{
  align-self:end;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  border-radius:28px;
  padding:20px 20px 18px;
  backdrop-filter:blur(12px);
  box-shadow:var(--shadow-md);
}

.hero-panel h3{
  color:#fff;
  font-size:1rem;
  margin-bottom:10px;
}

.hero-panel p{
  color:rgba(255,255,255,.95);
  font-size:.96rem;
}

/* Breadcrumbs */
.breadcrumbs{
  padding-top:18px;
  color:var(--text-faint);
  font-size:.92rem;
}

.breadcrumbs ol{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.breadcrumbs li{
  display:flex;
  align-items:center;
  gap:8px;
}

.breadcrumbs li:not(:last-child)::after{
  content:"/";
  color:rgba(31,26,23,.35);
}

.breadcrumbs a:hover{
  color:var(--brand);
}

/* Layouts */
.grid{
  display:grid;
  gap:24px;
}

.grid-2{
  grid-template-columns:repeat(2, minmax(0,1fr));
}

.grid-3{
  grid-template-columns:repeat(3, minmax(0,1fr));
}

.grid-4{
  grid-template-columns:repeat(4, minmax(0,1fr));
}

.sidebar-layout{
  display:grid;
  grid-template-columns:minmax(0, 1.15fr) minmax(280px, .85fr);
  gap:28px;
  align-items:start;
}

.split-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 1fr);
  gap:28px;
  align-items:start;
}

.reading-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(250px,310px);
  gap:28px;
  align-items:start;
}

.sticky{
  position:sticky;
  top:calc(var(--header-h) + 18px);
}

/* Cards */
.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm);
}

.card-pad{
  padding:24px;
}

.card-pad-lg{
  padding:30px;
}

.card-soft{
  background:linear-gradient(180deg, #fffdfa, #faf3ea);
}

.card-tint{
  background:linear-gradient(180deg, #fffdfb, #fff4ef);
  border-color:rgba(140,29,24,.10);
}

.card-dark{
  background:linear-gradient(180deg, #2a211d, #1d1714);
  color:#fff;
  border-color:rgba(255,255,255,.08);
}

.card-dark p,
.card-dark li{
  color:rgba(255,255,255,.90);
}

.card-link{
  display:block;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card-link:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-color:rgba(31,26,23,.16);
}

.media-card{
  overflow:hidden;
}

.media-card img{
  aspect-ratio: 16 / 10;
  object-fit:cover;
}

.media-card-body{
  padding:18px 20px 20px;
  display:grid;
  gap:10px;
}

.card-kicker{
  margin:0;
  color:var(--brand);
  font-size:.78rem;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.card-title{
  margin:0;
  font-size:1.12rem;
  font-weight:850;
  line-height:1.34;
}

.card-text{
  color:var(--text-soft);
  font-size:.96rem;
}

.card-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  color:var(--text-faint);
  font-size:.88rem;
}

/* Images */
.figure{
  margin:0;
  display:grid;
  gap:10px;
}

.figure img{
  width:100%;
  border-radius:24px;
  object-fit:cover;
  box-shadow:var(--shadow-md);
}

.figure figcaption{
  color:var(--text-faint);
  font-size:.88rem;
}

.image-frame{
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow-md);
  border:1px solid rgba(31,26,23,.08);
  background:#fff;
}

.image-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.cover-hero{
  aspect-ratio:16/9;
}

.cover-tall{
  aspect-ratio:4/5;
}

.cover-wide{
  aspect-ratio:21/9;
}

.cover-square{
  aspect-ratio:1/1;
}

/* Pull quote / narrator */
.hiro-note{
  position:relative;
  padding:24px 24px 24px 26px;
  border-radius:24px;
  background:linear-gradient(180deg, #fff6ef, #fffdf9);
  border:1px solid rgba(140,29,24,.14);
  box-shadow:var(--shadow-xs);
}

.hiro-note::before{
  content:"HIRO";
  position:absolute;
  top:14px;
  right:16px;
  font-size:.72rem;
  letter-spacing:.16em;
  color:rgba(140,29,24,.46);
  font-weight:900;
}

.hiro-note p{
  color:#372c28;
}

.hiro-note strong{
  color:var(--brand-dark);
}

/* Lists */
.checklist,
.dotlist{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:12px;
}

.checklist li,
.dotlist li{
  position:relative;
  padding-left:28px;
  color:var(--text);
}

.checklist li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:var(--success);
  font-weight:900;
}

.dotlist li::before{
  content:"";
  position:absolute;
  left:6px;
  top:.9em;
  width:8px;
  height:8px;
  border-radius:50%;
  background:var(--gold);
  transform:translateY(-50%);
}

/* Tables */
.table-wrap{
  overflow:auto;
  border-radius:20px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:var(--shadow-xs);
}

table{
  width:100%;
  border-collapse:collapse;
  min-width:620px;
}

th, td{
  padding:14px 16px;
  border-bottom:1px solid rgba(31,26,23,.08);
  text-align:left;
  vertical-align:top;
}

th{
  background:#f8f1e8;
  color:#312925;
  font-size:.92rem;
  font-weight:850;
}

td{
  color:#2b2521;
  font-size:.96rem;
}

tbody tr:hover td{
  background:#fffaf3;
}

/* Buttons */
.button-row{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:12px 18px;
  border-radius:16px;
  border:1px solid transparent;
  font-weight:800;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}

.btn:hover{
  transform:translateY(-1px);
}

.btn-primary{
  color:#fff;
  background:linear-gradient(135deg, var(--brand), var(--brand-dark));
  box-shadow:var(--shadow-sm);
}

.btn-secondary{
  color:#2b2320;
  background:#fff;
  border-color:rgba(31,26,23,.10);
}

.btn-soft{
  color:var(--brand-dark);
  background:var(--brand-soft);
  border-color:rgba(140,29,24,.10);
}

/* Callout strips */
.ribbon{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:16px 18px;
  border-radius:18px;
  background:linear-gradient(135deg, #fff8ef, #fff1e6);
  border:1px solid rgba(140,29,24,.12);
}

.ribbon strong{
  color:#271f1b;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 12px;
  border-radius:var(--radius-pill);
  background:#fff;
  border:1px solid rgba(31,26,23,.08);
  color:#2b2421;
  font-size:.82rem;
  font-weight:800;
}

/* TOC */
.toc{
  display:grid;
  gap:12px;
}

.toc h3{
  font-size:1rem;
}

.toc nav{
  display:grid;
  gap:8px;
}

.toc a{
  display:block;
  padding:10px 12px;
  border-radius:14px;
  color:#2d2622;
  background:#fff;
  border:1px solid rgba(31,26,23,.08);
  font-size:.94rem;
  transition:background .18s ease, border-color .18s ease, transform .18s ease;
}

.toc a:hover{
  background:#fff8f3;
  border-color:rgba(140,29,24,.16);
  transform:translateX(2px);
}

.toc a.is-active{
  background:linear-gradient(135deg, #fff4ef, #fffaf7);
  border-color:rgba(140,29,24,.22);
  color:var(--brand-dark);
  font-weight:800;
}

/* Footer */
.site-footer{
  margin-top:36px;
  color:#f5ede7;
  background:
    linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.04)),
    linear-gradient(135deg, #34231f, #231916 60%, #1b1311);
}

.site-footer a{
  color:#fff;
}

.site-footer-inner{
  padding-block:42px 34px;
  display:grid;
  gap:28px;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.2fr .8fr .8fr .8fr;
  gap:22px;
}

.footer-brand{
  display:grid;
  gap:12px;
}

.footer-brand p{
  color:rgba(255,255,255,.82);
}

.footer-col{
  display:grid;
  gap:10px;
  align-content:start;
}

.footer-col h3{
  font-size:1rem;
  color:#fff;
}

.footer-links{
  display:grid;
  gap:8px;
}

.footer-links a{
  color:rgba(255,255,255,.84);
}

.footer-links a:hover{
  color:#fff;
}

.footer-bottom{
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.10);
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:12px;
  color:rgba(255,255,255,.72);
  font-size:.9rem;
}

/* Utility */
.surface{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm);
}

.surface-pad{
  padding:24px;
}

.center{
  text-align:center;
}

.right{
  text-align:right;
}

.mt-0{ margin-top:0 !important; }
.mt-1{ margin-top:10px !important; }
.mt-2{ margin-top:18px !important; }
.mt-3{ margin-top:26px !important; }
.mt-4{ margin-top:36px !important; }
.mt-5{ margin-top:52px !important; }

.mb-0{ margin-bottom:0 !important; }
.mb-1{ margin-bottom:10px !important; }
.mb-2{ margin-bottom:18px !important; }
.mb-3{ margin-bottom:26px !important; }
.mb-4{ margin-bottom:36px !important; }
.mb-5{ margin-bottom:52px !important; }

.hidden{ display:none !important; }

.sr-only{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}

/* Reveal animation */
.reveal{
  opacity:0;
  transform:translateY(16px);
  transition:opacity .55s ease, transform .55s ease;
}

.reveal.is-visible{
  opacity:1;
  transform:none;
}

/* Media */
@media (max-width: 1100px){
  .hero-inner,
  .sidebar-layout,
  .split-layout,
  .reading-layout{
    grid-template-columns:1fr;
  }

  .hero-title{
    max-width:18ch;
  }

  .hero-panel{
    max-width:720px;
  }

  .grid-4{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }

  .footer-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media (max-width: 820px){
  :root{
    --header-h: 66px;
    --anchor-offset: 86px;
  }

  body{
    line-height:1.82;
  }

  .container{
    width:min(100% - 24px, var(--content));
  }

  .site-header-inner{
    min-height:var(--header-h);
  }

  .brand-title{
    font-size:.96rem;
  }

  .brand-subtitle{
    display:none;
  }

  .nav-links{
    display:none;
  }

  .nav-toggle{
    display:inline-flex;
  }

  .mobile-nav{
    display:block;
    overflow:hidden;
    max-height:0;
    transition:max-height .28s ease;
    border-top:1px solid rgba(31,26,23,.06);
    background:rgba(255,253,249,.96);
  }

  .mobile-nav.is-open{
    max-height:70vh;
  }

  .mobile-nav-inner{
    padding:12px;
    display:grid;
    gap:8px;
  }

  .mobile-nav a{
    display:block;
    padding:13px 14px;
    border-radius:14px;
    background:#fff;
    border:1px solid rgba(31,26,23,.08);
    font-weight:700;
  }

  .mobile-nav a[aria-current="page"]{
    background:linear-gradient(135deg, var(--brand), var(--brand-dark));
    color:#fff;
    border-color:transparent;
  }

  .hero{
    min-height:auto;
  }

  .hero-inner{
    min-height:auto;
    padding-block:56px 26px;
    gap:18px;
  }

  .hero-summary{
    font-size:1rem;
  }

  .page-eyebrow,
  .chip{
    font-size:.8rem;
  }

  .card-pad,
  .surface-pad{
    padding:20px;
  }

  .card-pad-lg{
    padding:22px;
  }

  .grid-2,
  .grid-3,
  .grid-4{
    grid-template-columns:1fr;
  }

  .media-card img{
    aspect-ratio: 16 / 10;
  }

  .footer-grid{
    grid-template-columns:1fr;
  }

  .footer-bottom{
    flex-direction:column;
    align-items:flex-start;
  }

  .table-wrap{
    border-radius:16px;
  }

  table{
    min-width:560px;
  }
}

@media (max-width: 560px){
  html{
    font-size:16px;
  }

  h1{
    line-height:1.12;
  }

  h2{
    line-height:1.26;
  }

  .breadcrumbs{
    font-size:.88rem;
  }

  .brand-mark{
    width:38px;
    height:38px;
  }

  .hero-inner{
    padding-block:48px 22px;
  }

  .hero-title{
    max-width:100%;
  }

  .button-row{
    flex-direction:column;
  }

  .btn{
    width:100%;
  }

  .card-pad,
  .surface-pad{
    padding:18px;
  }

  .card-pad-lg{
    padding:18px;
  }

  .hiro-note{
    padding:20px 18px 18px 18px;
  }

  .figure img,
  .image-frame{
    border-radius:20px;
  }
}

@media (prefers-reduced-motion: reduce){
  html{
    scroll-behavior:auto;
  }

  *,
  *::before,
  *::after{
    animation:none !important;
    transition:none !important;
  }

  .reveal{
    opacity:1 !important;
    transform:none !important;
  }
}
