/* Tools plugin: header dropdown + tool page styling.
   Self-contained classes so nothing depends on Tailwind utilities that may not
   be in the precompiled style.css build. */

/* ---- Desktop nav dropdown ---- */
.mp-nav-dd { position: relative; }
.mp-nav-dd-btn { display: inline-flex; align-items: center; gap: .25rem; cursor: pointer; background: transparent; border: 0; }
.mp-nav-caret { transition: transform .15s ease; }
.mp-nav-dd.open .mp-nav-caret { transform: rotate(180deg); }
.mp-nav-dd-menu {
  position: absolute; left: 0; top: 100%; margin-top: 6px; min-width: 210px;
  background: var(--card); border: 1px solid var(--border); border-radius: .7rem;
  box-shadow: 0 12px 32px rgba(0,0,0,.14); padding: .35rem; display: none; z-index: 60;
}
.mp-nav-dd.open .mp-nav-dd-menu { display: block; }
.mp-nav-dd-link {
  display: flex; align-items: center; gap: .5rem; padding: .5rem .65rem; border-radius: .45rem;
  font-size: .875rem; font-weight: 500; color: var(--foreground); text-decoration: none; white-space: nowrap;
}
.mp-nav-dd-link:hover { background: var(--muted); }

/* ---- Mobile nav expandable group ---- */
.mp-mnav-toggle { background: transparent; border: 0; cursor: pointer; }
.mp-mnav-caret { transition: transform .15s ease; }
.mp-mnav-group.open .mp-mnav-caret { transform: rotate(180deg); }
.mp-mnav-sub { display: none; padding-left: .5rem; border-left: 2px solid var(--border); margin: .15rem 0 .25rem .65rem; }
.mp-mnav-group.open .mp-mnav-sub { display: block; }

/* ---- Shared field styling ---- */
.mp-field { display: block; }
.mp-field > span { display: block; font-size: .8rem; font-weight: 600; margin-bottom: .35rem; }
.mp-input-money { display: flex; align-items: center; gap: .25rem; border: 1px solid var(--border); border-radius: .5rem; background: var(--background); padding: 0 .65rem; }
.mp-input-money > span { color: var(--muted-foreground); font-size: .9rem; }
.mp-input-money input { flex: 1; border: 0; background: transparent; padding: .55rem .25rem; font-size: .95rem; outline: none; width: 100%; }

/* ---- Print calibration ---- */
.mp-steps { list-style: none; padding: 0; margin: 0; }
.mp-steps li { display: flex; gap: .65rem; align-items: flex-start; }
.mp-step-n { flex: 0 0 auto; display: grid; place-items: center; width: 1.4rem; height: 1.4rem; border-radius: 999px; background: var(--primary); color: var(--primary-foreground); font-size: .75rem; font-weight: 700; }
.mp-vidgrid { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 768px) { .mp-vidgrid { grid-template-columns: repeat(3, 1fr); } }
.mp-vidcard { margin: 0; }
.mp-vidframe { position: relative; aspect-ratio: 16 / 9; border-radius: .6rem; overflow: hidden; border: 1px solid var(--border); background: #000; }
.mp-vidframe iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.mp-vidcap { margin-top: .5rem; font-size: .85rem; color: var(--muted-foreground); }

/* ---- Tabs (cost per proxy) ---- */
.mp-tablist { display: flex; gap: .25rem; border-bottom: 1px solid var(--border); margin-bottom: 1.25rem; }
.mp-tab { background: transparent; border: 0; border-bottom: 2px solid transparent; margin-bottom: -1px; padding: .55rem .9rem; font-size: .9rem; font-weight: 600; color: var(--muted-foreground); cursor: pointer; }
.mp-tab:hover { color: var(--foreground); }
.mp-tab.is-active { color: var(--foreground); border-bottom-color: var(--primary); }

/* ---- Cost per proxy ---- */
.mp-cpp-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.mp-cpp-fields-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 760px) { .mp-cpp-fields-3 { grid-template-columns: 1fr 1fr; } }
.mp-cpp-out { display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem; margin-top: 1.25rem; }
.mp-cpp-stat { border: 1px solid var(--border); border-radius: .6rem; padding: .85rem; text-align: center; background: var(--background); }
.mp-cpp-label { display: block; font-size: .75rem; color: var(--muted-foreground); }
.mp-cpp-val { display: block; margin-top: .25rem; font-size: 1.4rem; font-weight: 700; font-family: var(--font-display, inherit); }
@media (max-width: 560px) { .mp-cpp-fields { grid-template-columns: 1fr; } .mp-cpp-out { grid-template-columns: 1fr; } }

/* ---- Budget to proxy ---- */
.mp-bw-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
@media (max-width: 560px) { .mp-bw-row { grid-template-columns: 1fr; } }
.mp-bw select { width: 100%; border: 1px solid var(--border); border-radius: .5rem; background: var(--background); padding: .4rem; font-size: .9rem; }
.mp-bw select option { padding: .2rem .35rem; }
.mp-bw-go { display: inline-flex; align-items: center; gap: .45rem; margin-top: 1.1rem; padding: .6rem 1rem; border: 0; border-radius: .55rem; background: var(--primary); color: var(--primary-foreground); font-weight: 600; font-size: .9rem; cursor: pointer; }
.mp-bw-go:hover { filter: brightness(.95); }
.mp-bw-results { margin-top: 1.5rem; }
.mp-bw-results h3 { font-weight: 700; font-size: 1.05rem; }
.mp-kit { list-style: none; padding: 0; margin: .75rem 0 0; border: 1px solid var(--border); border-radius: .6rem; overflow: hidden; }
.mp-kit li { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: .7rem .9rem; border-top: 1px solid var(--border); }
.mp-kit li:first-child { border-top: 0; }
.mp-kit-info { display: flex; flex-direction: column; gap: .1rem; min-width: 0; }
.mp-kit .mp-kit-cat { font-size: .9rem; font-weight: 700; color: var(--foreground); }
.mp-kit .mp-kit-name { font-size: .85rem; color: var(--muted-foreground); }
.mp-kit .mp-kit-name a { color: var(--primary); text-decoration: none; }
.mp-kit .mp-kit-name a:hover { text-decoration: underline; }
.mp-kit .mp-kit-price { font-weight: 700; white-space: nowrap; }
.mp-bw-total { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-top: .85rem; padding: .7rem .9rem; border-radius: .6rem; background: var(--muted); font-weight: 600; }
.mp-bw-note { margin-top: .6rem; font-size: .85rem; color: var(--muted-foreground); }

/* ---- Admin "Manage" button on the public page ---- */
.mp-manage-btn { display: inline-flex; align-items: center; gap: .4rem; padding: .45rem .8rem; border: 1px solid var(--border); border-radius: .5rem; font-size: .85rem; font-weight: 600; color: var(--foreground); text-decoration: none; background: var(--card); white-space: nowrap; }
.mp-manage-btn:hover { background: var(--muted); }

/* ---- Tool pages served as dynamic CMS pages ----
   Deck List to PDF and Print Calibration are now real pages (contents table),
   so their body renders inside `.mp-prose`. The prose element-scoped rules
   (ol/li/iframe/figure/a) outrank the single-class tool styles above and would
   break the numbered steps, video frames and buttons. Re-assert the tool
   component styling at higher specificity so the design is preserved. */
.mp-prose ol.mp-steps { list-style: none; padding-left: 0; }
.mp-prose .mp-steps li { margin-top: .75rem; }
.mp-prose .mp-steps li:first-child { margin-top: 0; }
.mp-prose .mp-vidcard { margin: 0; }
.mp-prose .mp-vidframe iframe { margin: 0; aspect-ratio: auto; border-radius: 0; }
.mp-prose .mp-vidcap { margin-top: .5rem; text-align: left; }
.mp-prose a.mp-manage-btn,
.mp-prose a.mp-manage-btn:hover { color: var(--foreground); text-decoration: none; }
