/* =========================================================================
   BedBugSize — "calm clinical instrument" design system
   Palette: clinical paper + specimen browns + a single signal amber
   ========================================================================= */
:root{
  --paper:#f7f5f1;        /* warm clinical paper */
  --paper-2:#efece5;      /* card / panel */
  --ink:#26201c;          /* near-black brown, body text */
  --ink-soft:#6b6157;     /* secondary text */
  --line:#ddd6cb;         /* hairlines */
  --specimen:#8a3a2a;     /* bed bug body brown-red */
  --specimen-dk:#5f2417;  /* shadow / detail */
  --signal:#c8761f;       /* amber — the single accent, used for action only */
  --signal-dk:#a45e12;
  --good:#3f6b4a;         /* "early / DIY" calm green */
  --radius:14px;
  --maxw:1080px;
  --shadow:0 1px 2px rgba(38,32,28,.06), 0 8px 30px rgba(38,32,28,.07);
  --mono:"IBM Plex Mono",ui-monospace,monospace;
  --display:"Fraunces",Georgia,serif;
  --body:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--body);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:var(--display);font-weight:500;line-height:1.08;letter-spacing:-.01em;margin:0}
a{color:inherit}
img,svg{max-width:100%}

/* ---------- header ---------- */
.site-head{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  max-width:var(--maxw);margin:0 auto;padding:1.1rem 1.25rem;
}
.brand{display:flex;align-items:center;gap:.55rem;text-decoration:none;font-weight:600}
.brand-mark{
  width:18px;height:24px;border-radius:50% 50% 48% 48%/42% 42% 58% 58%;
  background:radial-gradient(circle at 38% 30%, var(--specimen), var(--specimen-dk));
  box-shadow:inset 0 -2px 3px rgba(0,0,0,.25);flex:0 0 auto;
}
.brand-name{font-family:var(--display);font-size:1.15rem;letter-spacing:-.02em}
.brand-name em{font-style:normal;color:var(--specimen)}
.site-nav{display:flex;gap:1.4rem}
.site-nav a{text-decoration:none;color:var(--ink-soft);font-size:.95rem;font-weight:500}
.site-nav a:hover{color:var(--specimen)}

/* ---------- hero ---------- */
.hero{max-width:var(--maxw);margin:0 auto;padding:2.5rem 1.25rem 1rem;text-align:center}
.eyebrow{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-soft);margin:0 0 1.1rem
}
.hero h1{font-size:clamp(2.6rem,7vw,4.6rem);margin-bottom:1rem}
.lede{max-width:42ch;margin:0 auto 1.6rem;font-size:1.12rem;color:var(--ink-soft)}
.lede strong{color:var(--ink)}
.lede em{font-style:italic;color:var(--specimen)}
.hero-cta{
  display:inline-block;background:var(--ink);color:var(--paper);
  text-decoration:none;font-weight:600;padding:.85rem 1.8rem;border-radius:100px;
  transition:transform .15s ease, background .15s ease;
}
.hero-cta:hover{background:var(--specimen-dk);transform:translateY(-1px)}
.hero-note{font-size:.85rem;color:var(--ink-soft);margin-top:1rem}

/* ---------- ad rails (chrome only, never over tool) ---------- */
.ad-rail{max-width:var(--maxw);margin:1.5rem auto;padding:0 1.25rem;min-height:0}
.ad-rail:empty{margin:0}
.ad-rail ins{display:block}

/* ---------- generic section heads ---------- */
.tool-head{max-width:var(--maxw);margin:0 auto 1.6rem;padding:0 1.25rem;text-align:center}
.step-tag{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--signal-dk);display:inline-block;margin-bottom:.7rem
}
.tool-head h2{font-size:clamp(1.8rem,4.5vw,2.6rem);margin-bottom:.5rem}
.tool-head p{max-width:50ch;margin:0 auto;color:var(--ink-soft);font-size:1rem}

/* ---------- the comparator ---------- */
.tool{padding:2rem 0 1rem}
.comparator{
  max-width:var(--maxw);margin:0 auto;padding:0 1.25rem;
  display:grid;grid-template-columns:1.1fr .9fr;gap:1.5rem;align-items:stretch;
}
.compare-stage{
  position:relative;background:
    linear-gradient(0deg,var(--paper-2),var(--paper-2));
  border:1px solid var(--line);border-radius:var(--radius);
  min-height:340px;overflow:hidden;display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow);
}
/* subtle grid so it reads as a measuring field */
.compare-stage::before{
  content:"";position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:20px 20px;mask:radial-gradient(circle at center,#000 60%,transparent 100%);
}
.bug-specimen{position:relative;z-index:2;transition:width .25s ease,height .25s ease;will-change:width,height}
.bug-svg{width:100%;height:100%;display:block;overflow:visible}
.bug-body{fill:var(--specimen);stroke:var(--specimen-dk);stroke-width:1.5}
.bug-head{fill:var(--specimen-dk)}
.bug-legs path{fill:none;stroke:var(--specimen-dk);stroke-width:1.6;stroke-linecap:round}
.bug-segments line{stroke:var(--specimen-dk);stroke-width:.8;opacity:.5}
.ref-object{
  position:absolute;z-index:1;border-radius:50%;
  background:radial-gradient(circle at 38% 32%,#6b5234,#3c2c18);
  opacity:.85;transition:width .25s ease,height .25s ease;
}
.ref-object[data-ref="rice"]{background:radial-gradient(circle at 40% 30%,#f3ead6,#d9c7a3);border-radius:50% 50% 50% 50%/60% 60% 40% 40%}
.ref-object[data-ref="penny"]{background:radial-gradient(circle at 38% 32%,#c98a5a,#8a5a33);border-radius:50%}
.ref-object[data-ref="pinhead"]{background:radial-gradient(circle at 35% 30%,#e8e8ee,#9b9ba8)}
.ruler{
  position:absolute;left:0;right:0;bottom:14px;height:26px;z-index:3;
  display:flex;align-items:flex-end;pointer-events:none;padding:0 14px;
}

/* controls */
.compare-controls{display:flex;flex-direction:column;gap:1.25rem;justify-content:center}
.ctl{display:flex;flex-direction:column;gap:.5rem}
.ctl-label{display:flex;justify-content:space-between;align-items:baseline;font-weight:600;font-size:.95rem}
.ctl-label output{font-family:var(--mono);color:var(--specimen);font-weight:500}
.ctl-size{font-family:var(--mono);font-size:.8rem;color:var(--ink-soft)}
input[type=range]{
  -webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;
  background:linear-gradient(90deg,var(--specimen) 0%,var(--specimen) var(--fill,100%),var(--line) var(--fill,100%));
  outline:none;cursor:pointer;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;width:22px;height:22px;border-radius:50%;
  background:var(--paper);border:3px solid var(--specimen);box-shadow:var(--shadow);cursor:grab;
}
input[type=range]::-moz-range-thumb{
  width:22px;height:22px;border-radius:50%;background:var(--paper);
  border:3px solid var(--specimen);box-shadow:var(--shadow);cursor:grab;
}
.ref-picker{border:1px solid var(--line);border-radius:var(--radius);padding:.9rem 1rem;margin:0}
.ref-picker legend{font-weight:600;font-size:.85rem;padding:0 .4rem;color:var(--ink-soft)}
.ref-picker label{display:inline-flex;align-items:center;gap:.4rem;font-size:.9rem;margin:.25rem .9rem .25rem 0;cursor:pointer}
.ref-picker input{accent-color:var(--specimen)}
.calibrate-btn{
  background:var(--paper-2);border:1px solid var(--line);color:var(--ink);
  font-family:var(--body);font-weight:600;font-size:.9rem;padding:.7rem 1rem;
  border-radius:10px;cursor:pointer;transition:border-color .15s
}
.calibrate-btn:hover{border-color:var(--specimen)}
.calibrate-note{font-size:.78rem;color:var(--ink-soft);margin:.1rem 0 0}

/* stage facts */
.stage-facts{
  max-width:var(--maxw);margin:1.5rem auto 0;padding:1.1rem 1.4rem;
  background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);
  font-size:.96rem;color:var(--ink-soft);
}
.stage-facts strong{color:var(--ink)}

/* ---------- lookalikes ---------- */
.lookalikes{padding:3rem 0 1rem}
.look-grid{
  max-width:var(--maxw);margin:0 auto;padding:0 1.25rem;
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;
}
.look-card{
  background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.2rem;cursor:pointer;text-align:left;transition:transform .15s,border-color .15s;
  box-shadow:var(--shadow);
}
.look-card:hover{transform:translateY(-2px);border-color:var(--specimen)}
.look-card[aria-expanded=true]{border-color:var(--specimen)}
.look-card h3{font-size:1.1rem;margin-bottom:.2rem}
.look-card .verdict{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em}
.look-card .verdict.is-bug{color:var(--specimen)}
.look-card .verdict.not-bug{color:var(--good)}
.look-card .tell{margin-top:.7rem;font-size:.9rem;color:var(--ink-soft);display:none}
.look-card[aria-expanded=true] .tell{display:block}
.look-mini{display:flex;gap:.4rem;margin:.6rem 0 0;align-items:center}
.look-mini svg{width:34px;height:34px}

/* ---------- act / paths ---------- */
.act{padding:3rem 0 1rem}
.paths{
  max-width:var(--maxw);margin:0 auto;padding:0 1.25rem;
  display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;
}
.path{
  background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);
  padding:1.6rem;box-shadow:var(--shadow);display:flex;flex-direction:column;
}
.path.featured{border-color:var(--signal);background:linear-gradient(180deg,#fdf6ec,var(--paper-2))}
.path h3{font-size:1.3rem;margin-bottom:.6rem}
.path p{color:var(--ink-soft);font-size:.98rem;margin:0 0 1rem}
.path p strong{color:var(--ink)}
.kit{list-style:none;margin:0 0 1.1rem;padding:0;display:flex;flex-direction:column;gap:.55rem}
.kit li a{
  display:flex;justify-content:space-between;align-items:center;gap:.6rem;
  text-decoration:none;padding:.6rem .8rem;border:1px solid var(--line);border-radius:10px;
  background:var(--paper);font-size:.92rem;font-weight:500;transition:border-color .15s
}
.kit li a:hover{border-color:var(--specimen)}
.kit li a .step{font-family:var(--mono);font-size:.7rem;color:var(--ink-soft)}
.kit li a .go{color:var(--specimen);font-weight:600}
.path-cta{
  margin-top:auto;display:inline-block;text-align:center;text-decoration:none;
  background:var(--signal);color:#fff;font-weight:600;padding:.85rem 1.4rem;border-radius:100px;
  transition:transform .15s,background .15s
}
.path-cta:hover{background:var(--signal-dk);transform:translateY(-1px)}
.path-cta.secondary{background:var(--good)}
.path-cta.secondary:hover{background:#345a3d}
.path-note{font-size:.78rem;color:var(--ink-soft);margin:.7rem 0 0}
.aff-disclosure{
  max-width:var(--maxw);margin:1.5rem auto 0;padding:0 1.25rem;
  font-size:.82rem;color:var(--ink-soft);line-height:1.5
}
.aff-disclosure a{color:var(--specimen)}

/* ---------- facts band ---------- */
.facts-band{
  background:var(--ink);color:var(--paper);margin-top:3rem;padding:3rem 1.25rem
}
.facts-band h2{text-align:center;color:var(--paper);font-size:clamp(1.6rem,4vw,2.2rem);margin-bottom:1.6rem}
.facts{
  max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);overflow:hidden
}
.facts div{background:var(--ink);padding:1.1rem 1.2rem}
.facts dt{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--signal);margin-bottom:.3rem}
.facts dd{margin:0;font-size:1rem}

/* ---------- footer ---------- */
.site-foot{max-width:var(--maxw);margin:0 auto;padding:2.5rem 1.25rem 3rem}
.foot-grid{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:2rem}
.foot-brand{font-size:1.1rem}
.foot-grid p{color:var(--ink-soft);font-size:.9rem;max-width:34ch;margin:.4rem 0 0}
.site-foot nav{display:flex;flex-direction:column;gap:.5rem}
.site-foot nav a{color:var(--ink-soft);text-decoration:none;font-size:.92rem}
.site-foot nav a:hover{color:var(--specimen)}
.foot-fine{font-size:.76rem;color:var(--ink-soft);margin-top:1.6rem;line-height:1.5}

/* ---------- responsive ---------- */
@media(max-width:760px){
  .site-nav{display:none}
  .comparator{grid-template-columns:1fr}
  .compare-stage{min-height:280px}
  .paths{grid-template-columns:1fr}
  .foot-grid{flex-direction:column;gap:1.2rem}
}

/* ---------- a11y ---------- */
:focus-visible{outline:3px solid var(--signal);outline-offset:2px;border-radius:4px}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* =========================================================================
   Shared components for articles, hubs, legal, logo, covers, scroll-to-top
   ========================================================================= */
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:.6rem 1rem;border-radius:0 0 8px 0;z-index:100}
.skip:focus{left:0}

/* logo svg sizing (replaces text brand on built pages) */
.logo-svg{height:34px;width:auto;display:block}
.foot-about .logo-svg{height:30px}

/* footer expanded grid */
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:1.5rem;align-items:start}
.site-foot h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 .7rem}
.site-foot nav{display:flex;flex-direction:column;gap:.45rem}
.foot-about p{margin-top:.7rem}

/* breadcrumbs */
.crumbs{font-size:.8rem;color:var(--ink-soft);margin-bottom:1.2rem}
.crumbs a{color:var(--specimen);text-decoration:none}
.crumbs span{color:var(--ink-soft)}

/* article layout */
.article{max-width:760px;margin:2.2rem auto 0;padding:0 1.25rem}
.art-head h1{font-size:clamp(2rem,5.2vw,3.1rem);margin:.4rem 0 .8rem}
.art-desc{font-size:1.12rem;color:var(--ink-soft);line-height:1.55;margin:0}
.art-cover{margin:1.8rem 0 1.4rem;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;display:flex;justify-content:center;overflow:hidden}
.art-cover svg{max-width:100%;height:auto}

/* prose */
.prose{font-size:1.09rem;line-height:1.72}
.prose h2{font-size:clamp(1.5rem,3.4vw,2rem);margin:2.2rem 0 .7rem;letter-spacing:-.01em}
.prose h3{font-size:1.22rem;margin:1.6rem 0 .5rem;font-family:var(--display);font-weight:600}
.prose p{margin:0 0 1.1rem;color:#322b25}
.prose ul{margin:0 0 1.3rem;padding-left:1.2rem}
.prose li{margin:.4rem 0}
.prose strong{color:var(--ink)}
.prose em{color:var(--specimen);font-style:italic}
.prose .fig{margin:1.6rem 0;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;display:flex;justify-content:center;overflow:hidden}
.prose .fig svg{max-width:100%;height:auto}
.cover-art{display:flex;justify-content:center;align-items:center}

/* in-article CTA */
.cta-card{margin:2.4rem 0;padding:1.8rem;background:linear-gradient(180deg,#fdf6ec,var(--paper-2));border:1px solid var(--signal);border-radius:var(--radius);text-align:center}
.cta-card h3{font-size:1.4rem;margin-bottom:.5rem}
.cta-card p{color:var(--ink-soft);margin:0 auto 1.1rem;max-width:46ch}

/* related */
.related{margin:2.6rem 0 1rem;border-top:1px solid var(--line);padding-top:1.6rem}
.related h2{font-size:1.4rem;margin-bottom:1rem}
.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.9rem}
.related-card{display:flex;flex-direction:column;gap:.5rem;text-decoration:none;color:var(--ink);border:1px solid var(--line);border-radius:12px;padding:.8rem;background:var(--paper-2);transition:border-color .15s,transform .15s;font-size:.92rem;font-weight:500;line-height:1.3}
.related-card:hover{border-color:var(--specimen);transform:translateY(-2px)}
.related-card svg{max-width:100%;height:64px}

/* hub pages */
.hub{max-width:var(--maxw);margin:2.2rem auto 0;padding:0 1.25rem}
.hub h1{font-size:clamp(2.1rem,5.5vw,3.4rem);margin:.3rem 0 .6rem}
.hub-lede{font-size:1.12rem;color:var(--ink-soft);max-width:60ch;margin:0 0 2rem}
.hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.2rem}
.hub-card{display:flex;flex-direction:column;text-decoration:none;color:var(--ink);background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .15s,border-color .15s}
.hub-card:hover{transform:translateY(-3px);border-color:var(--specimen)}
.hub-art{background:var(--paper);border-bottom:1px solid var(--line);padding:1.2rem;display:flex;justify-content:center;align-items:center;min-height:120px;overflow:hidden}
.hub-art svg{max-width:100%;height:auto;max-height:110px}
.hub-meta{padding:1.2rem}
.hub-meta h2{font-size:1.2rem;margin:.4rem 0 .5rem;line-height:1.2}
.hub-meta p{font-size:.92rem;color:var(--ink-soft);margin:0 0 .8rem}
.hub-meta .go{color:var(--specimen);font-weight:600;font-size:.9rem}

/* legal */
.legal .prose{font-size:1.02rem}
.legal h2{font-size:1.3rem}

/* scroll to top */
.to-top{position:fixed;right:18px;bottom:18px;width:46px;height:46px;border-radius:50%;border:none;background:var(--ink);color:#fff;font-size:1.2rem;cursor:pointer;opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .2s,transform .2s,background .15s;z-index:50;box-shadow:var(--shadow)}
.to-top.show{opacity:1;pointer-events:auto;transform:translateY(0)}
.to-top:hover{background:var(--specimen-dk)}

/* responsive */
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:760px){
  .site-nav{display:flex;gap:1rem;font-size:.9rem}
  .site-nav a{color:var(--ink-soft)}
  .article{margin-top:1.4rem}
  .art-cover{padding:1rem}
  .prose{font-size:1.04rem}
}
@media(max-width:560px){
  .site-head{flex-wrap:wrap;gap:.5rem;padding:.9rem 1rem}
  .site-nav{width:100%;justify-content:space-between;gap:.4rem;font-size:.82rem;flex-wrap:wrap}
  .foot-grid{grid-template-columns:1fr}
  .to-top{right:12px;bottom:12px;width:42px;height:42px}
  .compare-stage{min-height:240px}
  .ref-picker label{display:flex;margin:.3rem 0}
}

/* ===== Amazon product grid ===== */
.gear{padding:3rem 0 1rem}
.gear-grid{max-width:var(--maxw);margin:0 auto;padding:0 1.25rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.gear-card{display:flex;flex-direction:column;text-decoration:none;color:var(--ink);background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow);transition:transform .15s,border-color .15s}
.gear-card:hover{transform:translateY(-3px);border-color:var(--signal)}
.gear-tag{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--signal-dk);margin-bottom:.5rem}
.gear-card h3{font-size:1.05rem;line-height:1.25;margin:0 0 .5rem}
.gear-card p{font-size:.9rem;color:var(--ink-soft);margin:0 0 1rem;flex:1}
.gear-go{color:var(--signal-dk);font-weight:600;font-size:.9rem}
.gear .aff-disclosure{margin-top:1.3rem}

/* ===== Rebuilt sizing tool ===== */
.ref-label{position:absolute;z-index:2;font:500 10px var(--mono);color:var(--ink-soft);max-width:120px;text-align:center;pointer-events:none}
.scale-badge{position:absolute;top:10px;right:12px;z-index:4;font:500 10px var(--mono);background:var(--paper);border:1px solid var(--line);color:var(--ink-soft);padding:3px 8px;border-radius:100px}
.bug-ant{fill:none;stroke:#4a1c10;stroke-width:2;stroke-linecap:round}
.bug-body{fill:url(#bgrad);stroke:#4a1c10;stroke-width:1.5;transition:rx .15s}
.bug-head{fill:#5f2417}
.bug-svg .bug-segments path{fill:none;stroke:#4a1c10;stroke-width:.8;opacity:.4}
.quickstage{display:flex;flex-wrap:wrap;gap:.4rem}
.quickstage button{font:500 .8rem var(--body);padding:.4rem .7rem;border:1px solid var(--line);background:var(--paper);border-radius:100px;cursor:pointer;color:var(--ink-soft);transition:all .15s}
.quickstage button:hover{border-color:var(--specimen)}
.quickstage button.on{background:var(--specimen);color:#fff;border-color:var(--specimen)}
.ref-picker label{display:inline-flex;align-items:center;gap:.35rem;font-size:.85rem;margin:.25rem .8rem .25rem 0}

/* calibration modal */
.cal-overlay{position:fixed;inset:0;background:rgba(38,32,28,.6);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}
.cal-box{background:var(--paper);border-radius:16px;padding:1.6rem;max-width:560px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.cal-box h3{font-size:1.4rem;margin-bottom:.5rem}
.cal-box p{color:var(--ink-soft);font-size:.95rem;margin:0 0 1rem}
.cal-bar{height:54px;width:320px;max-width:100%;background:linear-gradient(90deg,#c8761f,#a45e12);border-radius:8px;margin:0 0 1rem;box-shadow:inset 0 -3px 6px rgba(0,0,0,.2)}
.cal-box input[type=range]{width:100%;margin-bottom:1rem;accent-color:var(--specimen)}
.cal-actions{display:flex;gap:.7rem;justify-content:flex-end}
.cal-actions button{padding:.7rem 1.2rem;border-radius:100px;border:1px solid var(--line);background:var(--paper);font-weight:600;cursor:pointer}
.cal-actions .primary{background:var(--specimen);color:#fff;border-color:var(--specimen)}
.cal-fine{font-size:.78rem!important;margin-top:.8rem!important}

/* real photo panel + figures */
.real-photo-panel{max-width:var(--maxw);margin:1.5rem auto 0;padding:1.4rem;display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;align-items:center;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius)}
.rpp-text h3{font-size:1.3rem;margin-bottom:.4rem}
.rpp-text p{color:var(--ink-soft);margin:0 0 .8rem}
.rpp-link{color:var(--specimen);font-weight:600;text-decoration:none}
.rpp-img img{width:100%;height:auto;border-radius:12px;display:block}
.photo-fallback{padding:2rem;text-align:center;color:var(--ink-soft);background:var(--paper);border:1px dashed var(--line);border-radius:12px;font-size:.9rem}
.ph-credit{display:block;font:400 .72rem var(--mono);color:var(--ink-soft);margin-top:.4rem;opacity:.85}
figure.photo{margin:1.6rem 0}
figure.photo img{box-shadow:var(--shadow)}
.ph-cap{font-size:.85rem;color:var(--ink-soft);margin-top:.5rem;text-align:center}

@media(max-width:760px){
  .real-photo-panel{grid-template-columns:1fr}
  .scale-badge{position:static;display:inline-block;margin:8px}
}
