[ Index ]

PHP Cross Reference of WordPress Trunk (Updated Daily)

Search

title

Body

[close]

/wp-includes/js/dist/script-modules/boot/ -> index.js (source)

   1  var __create = Object.create;
   2  var __defProp = Object.defineProperty;
   3  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
   4  var __getOwnPropNames = Object.getOwnPropertyNames;
   5  var __getProtoOf = Object.getPrototypeOf;
   6  var __hasOwnProp = Object.prototype.hasOwnProperty;
   7  var __commonJS = (cb, mod) => function __require() {
   8    return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
   9  };
  10  var __export = (target, all) => {
  11    for (var name in all)
  12      __defProp(target, name, { get: all[name], enumerable: true });
  13  };
  14  var __copyProps = (to, from, except, desc) => {
  15    if (from && typeof from === "object" || typeof from === "function") {
  16      for (let key of __getOwnPropNames(from))
  17        if (!__hasOwnProp.call(to, key) && key !== except)
  18          __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
  19    }
  20    return to;
  21  };
  22  var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
  23    // If the importer is in node compatibility mode or this is not an ESM
  24    // file that has been converted to a CommonJS file using a Babel-
  25    // compatible transform (i.e. "__esModule" has not been set), then set
  26    // "default" to the CommonJS "module.exports" for node compatibility.
  27    isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
  28    mod
  29  ));
  30  
  31  // package-external:@wordpress/element
  32  var require_element = __commonJS({
  33    "package-external:@wordpress/element"(exports, module) {
  34      module.exports = window.wp.element;
  35    }
  36  });
  37  
  38  // package-external:@wordpress/data
  39  var require_data = __commonJS({
  40    "package-external:@wordpress/data"(exports, module) {
  41      module.exports = window.wp.data;
  42    }
  43  });
  44  
  45  // package-external:@wordpress/i18n
  46  var require_i18n = __commonJS({
  47    "package-external:@wordpress/i18n"(exports, module) {
  48      module.exports = window.wp.i18n;
  49    }
  50  });
  51  
  52  // package-external:@wordpress/components
  53  var require_components = __commonJS({
  54    "package-external:@wordpress/components"(exports, module) {
  55      module.exports = window.wp.components;
  56    }
  57  });
  58  
  59  // vendor-external:react/jsx-runtime
  60  var require_jsx_runtime = __commonJS({
  61    "vendor-external:react/jsx-runtime"(exports, module) {
  62      module.exports = window.ReactJSXRuntime;
  63    }
  64  });
  65  
  66  // package-external:@wordpress/core-data
  67  var require_core_data = __commonJS({
  68    "package-external:@wordpress/core-data"(exports, module) {
  69      module.exports = window.wp.coreData;
  70    }
  71  });
  72  
  73  // package-external:@wordpress/commands
  74  var require_commands = __commonJS({
  75    "package-external:@wordpress/commands"(exports, module) {
  76      module.exports = window.wp.commands;
  77    }
  78  });
  79  
  80  // package-external:@wordpress/editor
  81  var require_editor = __commonJS({
  82    "package-external:@wordpress/editor"(exports, module) {
  83      module.exports = window.wp.editor;
  84    }
  85  });
  86  
  87  // package-external:@wordpress/compose
  88  var require_compose = __commonJS({
  89    "package-external:@wordpress/compose"(exports, module) {
  90      module.exports = window.wp.compose;
  91    }
  92  });
  93  
  94  // package-external:@wordpress/primitives
  95  var require_primitives = __commonJS({
  96    "package-external:@wordpress/primitives"(exports, module) {
  97      module.exports = window.wp.primitives;
  98    }
  99  });
 100  
 101  // package-external:@wordpress/html-entities
 102  var require_html_entities = __commonJS({
 103    "package-external:@wordpress/html-entities"(exports, module) {
 104      module.exports = window.wp.htmlEntities;
 105    }
 106  });
 107  
 108  // package-external:@wordpress/keycodes
 109  var require_keycodes = __commonJS({
 110    "package-external:@wordpress/keycodes"(exports, module) {
 111      module.exports = window.wp.keycodes;
 112    }
 113  });
 114  
 115  // package-external:@wordpress/url
 116  var require_url = __commonJS({
 117    "package-external:@wordpress/url"(exports, module) {
 118      module.exports = window.wp.url;
 119    }
 120  });
 121  
 122  // package-external:@wordpress/private-apis
 123  var require_private_apis = __commonJS({
 124    "package-external:@wordpress/private-apis"(exports, module) {
 125      module.exports = window.wp.privateApis;
 126    }
 127  });
 128  
 129  // package-external:@wordpress/keyboard-shortcuts
 130  var require_keyboard_shortcuts = __commonJS({
 131    "package-external:@wordpress/keyboard-shortcuts"(exports, module) {
 132      module.exports = window.wp.keyboardShortcuts;
 133    }
 134  });
 135  
 136  // package-external:@wordpress/theme
 137  var require_theme = __commonJS({
 138    "package-external:@wordpress/theme"(exports, module) {
 139      module.exports = window.wp.theme;
 140    }
 141  });
 142  
 143  // packages/boot/build-module/components/app/index.js
 144  var import_element15 = __toESM(require_element());
 145  var import_data11 = __toESM(require_data());
 146  
 147  // packages/boot/build-module/components/app/router.js
 148  var import_i18n11 = __toESM(require_i18n());
 149  var import_element14 = __toESM(require_element());
 150  
 151  // node_modules/clsx/dist/clsx.mjs
 152  function r(e) {
 153    var t, f, n = "";
 154    if ("string" == typeof e || "number" == typeof e) n += e;
 155    else if ("object" == typeof e) if (Array.isArray(e)) {
 156      var o = e.length;
 157      for (t = 0; t < o; t++) e[t] && (f = r(e[t])) && (n && (n += " "), n += f);
 158    } else for (f in e) e[f] && (n && (n += " "), n += f);
 159    return n;
 160  }
 161  function clsx() {
 162    for (var e, t, f = 0, n = "", o = arguments.length; f < o; f++) (e = arguments[f]) && (t = r(e)) && (n && (n += " "), n += t);
 163    return n;
 164  }
 165  var clsx_default = clsx;
 166  
 167  // packages/admin-ui/build-module/navigable-region/index.js
 168  var import_element = __toESM(require_element());
 169  var import_jsx_runtime = __toESM(require_jsx_runtime());
 170  var NavigableRegion = (0, import_element.forwardRef)(
 171    ({ children, className, ariaLabel, as: Tag = "div", ...props }, ref) => {
 172      return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
 173        Tag,
 174        {
 175          ref,
 176          className: clsx_default("admin-ui-navigable-region", className),
 177          "aria-label": ariaLabel,
 178          role: "region",
 179          tabIndex: "-1",
 180          ...props,
 181          children
 182        }
 183      );
 184    }
 185  );
 186  NavigableRegion.displayName = "NavigableRegion";
 187  var navigable_region_default = NavigableRegion;
 188  
 189  // packages/admin-ui/build-module/page/header.js
 190  var import_components2 = __toESM(require_components());
 191  
 192  // packages/admin-ui/build-module/page/sidebar-toggle-slot.js
 193  var import_components = __toESM(require_components());
 194  var { Fill: SidebarToggleFill, Slot: SidebarToggleSlot } = (0, import_components.createSlotFill)("SidebarToggle");
 195  
 196  // packages/admin-ui/build-module/page/header.js
 197  var import_jsx_runtime2 = __toESM(require_jsx_runtime());
 198  function Header({
 199    breadcrumbs,
 200    badges,
 201    title,
 202    subTitle,
 203    actions,
 204    showSidebarToggle = true
 205  }) {
 206    return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_components2.__experimentalVStack, { className: "admin-ui-page__header", as: "header", children: [
 207      /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_components2.__experimentalHStack, { justify: "space-between", spacing: 2, children: [
 208        /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_components2.__experimentalHStack, { spacing: 2, justify: "left", children: [
 209          showSidebarToggle && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
 210            SidebarToggleSlot,
 211            {
 212              bubblesVirtually: true,
 213              className: "admin-ui-page__sidebar-toggle-slot"
 214            }
 215          ),
 216          title && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_components2.__experimentalHeading, { as: "h2", level: 3, weight: 500, truncate: true, children: title }),
 217          breadcrumbs,
 218          badges
 219        ] }),
 220        /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
 221          import_components2.__experimentalHStack,
 222          {
 223            style: { width: "auto", flexShrink: 0 },
 224            spacing: 2,
 225            className: "admin-ui-page__header-actions",
 226            children: actions
 227          }
 228        )
 229      ] }),
 230      subTitle && /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("p", { className: "admin-ui-page__header-subtitle", children: subTitle })
 231    ] });
 232  }
 233  
 234  // packages/admin-ui/build-module/page/index.js
 235  var import_jsx_runtime3 = __toESM(require_jsx_runtime());
 236  function Page({
 237    breadcrumbs,
 238    badges,
 239    title,
 240    subTitle,
 241    children,
 242    className,
 243    actions,
 244    hasPadding = false,
 245    showSidebarToggle = true
 246  }) {
 247    const classes = clsx_default("admin-ui-page", className);
 248    return /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(navigable_region_default, { className: classes, ariaLabel: title, children: [
 249      (title || breadcrumbs || badges) && /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(
 250        Header,
 251        {
 252          breadcrumbs,
 253          badges,
 254          title,
 255          subTitle,
 256          actions,
 257          showSidebarToggle
 258        }
 259      ),
 260      hasPadding ? /* @__PURE__ */ (0, import_jsx_runtime3.jsx)("div", { className: "admin-ui-page__content has-padding", children }) : children
 261    ] });
 262  }
 263  Page.SidebarToggleFill = SidebarToggleFill;
 264  var page_default = Page;
 265  
 266  // packages/boot/build-module/components/app/router.js
 267  var import_data10 = __toESM(require_data());
 268  var import_core_data6 = __toESM(require_core_data());
 269  import {
 270    privateApis as routePrivateApis6
 271  } from "@wordpress/route";
 272  
 273  // packages/boot/build-module/components/root/index.js
 274  var import_commands2 = __toESM(require_commands());
 275  var import_editor4 = __toESM(require_editor());
 276  var import_compose4 = __toESM(require_compose());
 277  var import_components14 = __toESM(require_components());
 278  import { privateApis as routePrivateApis5 } from "@wordpress/route";
 279  
 280  // packages/icons/build-module/icon/index.js
 281  var import_element2 = __toESM(require_element());
 282  var icon_default = (0, import_element2.forwardRef)(
 283    ({ icon, size = 24, ...props }, ref) => {
 284      return (0, import_element2.cloneElement)(icon, {
 285        width: size,
 286        height: size,
 287        ...props,
 288        ref
 289      });
 290    }
 291  );
 292  
 293  // packages/icons/build-module/library/arrow-up-left.js
 294  var import_primitives = __toESM(require_primitives());
 295  var import_jsx_runtime4 = __toESM(require_jsx_runtime());
 296  var arrow_up_left_default = /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(import_primitives.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(import_primitives.Path, { d: "M14 6H6v8h1.5V8.5L17 18l1-1-9.5-9.5H14V6Z" }) });
 297  
 298  // packages/icons/build-module/library/check.js
 299  var import_primitives2 = __toESM(require_primitives());
 300  var import_jsx_runtime5 = __toESM(require_jsx_runtime());
 301  var check_default = /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_primitives2.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_primitives2.Path, { d: "M16.5 7.5 10 13.9l-2.5-2.4-1 1 3.5 3.6 7.5-7.6z" }) });
 302  
 303  // packages/icons/build-module/library/chevron-down-small.js
 304  var import_primitives3 = __toESM(require_primitives());
 305  var import_jsx_runtime6 = __toESM(require_jsx_runtime());
 306  var chevron_down_small_default = /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(import_primitives3.SVG, { viewBox: "0 0 24 24", xmlns: "http://www.w3.org/2000/svg", children: /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(import_primitives3.Path, { d: "m15.99 10.889-3.988 3.418-3.988-3.418.976-1.14 3.012 2.582 3.012-2.581.976 1.139Z" }) });
 307  
 308  // packages/icons/build-module/library/chevron-left-small.js
 309  var import_primitives4 = __toESM(require_primitives());
 310  var import_jsx_runtime7 = __toESM(require_jsx_runtime());
 311  var chevron_left_small_default = /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(import_primitives4.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(import_primitives4.Path, { d: "m13.1 16-3.4-4 3.4-4 1.1 1-2.6 3 2.6 3-1.1 1z" }) });
 312  
 313  // packages/icons/build-module/library/chevron-left.js
 314  var import_primitives5 = __toESM(require_primitives());
 315  var import_jsx_runtime8 = __toESM(require_jsx_runtime());
 316  var chevron_left_default = /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(import_primitives5.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(import_primitives5.Path, { d: "M14.6 7l-1.2-1L8 12l5.4 6 1.2-1-4.6-5z" }) });
 317  
 318  // packages/icons/build-module/library/chevron-right-small.js
 319  var import_primitives6 = __toESM(require_primitives());
 320  var import_jsx_runtime9 = __toESM(require_jsx_runtime());
 321  var chevron_right_small_default = /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_primitives6.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_primitives6.Path, { d: "M10.8622 8.04053L14.2805 12.0286L10.8622 16.0167L9.72327 15.0405L12.3049 12.0286L9.72327 9.01672L10.8622 8.04053Z" }) });
 322  
 323  // packages/icons/build-module/library/chevron-right.js
 324  var import_primitives7 = __toESM(require_primitives());
 325  var import_jsx_runtime10 = __toESM(require_jsx_runtime());
 326  var chevron_right_default = /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(import_primitives7.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(import_primitives7.Path, { d: "M10.6 6L9.4 7l4.6 5-4.6 5 1.2 1 5.4-6z" }) });
 327  
 328  // packages/icons/build-module/library/menu.js
 329  var import_primitives8 = __toESM(require_primitives());
 330  var import_jsx_runtime11 = __toESM(require_jsx_runtime());
 331  var menu_default = /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(import_primitives8.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(import_primitives8.Path, { d: "M5 5v1.5h14V5H5zm0 7.8h14v-1.5H5v1.5zM5 19h14v-1.5H5V19z" }) });
 332  
 333  // packages/icons/build-module/library/search.js
 334  var import_primitives9 = __toESM(require_primitives());
 335  var import_jsx_runtime12 = __toESM(require_jsx_runtime());
 336  var search_default = /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_primitives9.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_primitives9.Path, { d: "M13 5c-3.3 0-6 2.7-6 6 0 1.4.5 2.7 1.3 3.7l-3.8 3.8 1.1 1.1 3.8-3.8c1 .8 2.3 1.3 3.7 1.3 3.3 0 6-2.7 6-6S16.3 5 13 5zm0 10.5c-2.5 0-4.5-2-4.5-4.5s2-4.5 4.5-4.5 4.5 2 4.5 4.5-2 4.5-4.5 4.5z" }) });
 337  
 338  // packages/icons/build-module/library/wordpress.js
 339  var import_primitives10 = __toESM(require_primitives());
 340  var import_jsx_runtime13 = __toESM(require_jsx_runtime());
 341  var wordpress_default = /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(import_primitives10.SVG, { xmlns: "http://www.w3.org/2000/svg", viewBox: "-2 -2 24 24", children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(import_primitives10.Path, { d: "M20 10c0-5.51-4.49-10-10-10C4.48 0 0 4.49 0 10c0 5.52 4.48 10 10 10 5.51 0 10-4.48 10-10zM7.78 15.37L4.37 6.22c.55-.02 1.17-.08 1.17-.08.5-.06.44-1.13-.06-1.11 0 0-1.45.11-2.37.11-.18 0-.37 0-.58-.01C4.12 2.69 6.87 1.11 10 1.11c2.33 0 4.45.87 6.05 2.34-.68-.11-1.65.39-1.65 1.58 0 .74.45 1.36.9 2.1.35.61.55 1.36.55 2.46 0 1.49-1.4 5-1.4 5l-3.03-8.37c.54-.02.82-.17.82-.17.5-.05.44-1.25-.06-1.22 0 0-1.44.12-2.38.12-.87 0-2.33-.12-2.33-.12-.5-.03-.56 1.2-.06 1.22l.92.08 1.26 3.41zM17.41 10c.24-.64.74-1.87.43-4.25.7 1.29 1.05 2.71 1.05 4.25 0 3.29-1.73 6.24-4.4 7.78.97-2.59 1.94-5.2 2.92-7.78zM6.1 18.09C3.12 16.65 1.11 13.53 1.11 10c0-1.3.23-2.48.72-3.59C3.25 10.3 4.67 14.2 6.1 18.09zm4.03-6.63l2.58 6.98c-.86.29-1.76.45-2.71.45-.79 0-1.57-.11-2.29-.33.81-2.38 1.62-4.74 2.42-7.1z" }) });
 342  
 343  // packages/boot/build-module/components/root/index.js
 344  var import_element13 = __toESM(require_element());
 345  var import_i18n10 = __toESM(require_i18n());
 346  
 347  // packages/boot/build-module/components/site-hub/index.js
 348  var import_data2 = __toESM(require_data());
 349  var import_components3 = __toESM(require_components());
 350  var import_i18n2 = __toESM(require_i18n());
 351  var import_core_data2 = __toESM(require_core_data());
 352  var import_html_entities = __toESM(require_html_entities());
 353  var import_keycodes = __toESM(require_keycodes());
 354  var import_commands = __toESM(require_commands());
 355  var import_url = __toESM(require_url());
 356  
 357  // packages/boot/build-module/components/site-icon-link/index.js
 358  import { Link, privateApis as routePrivateApis } from "@wordpress/route";
 359  
 360  // packages/boot/build-module/lock-unlock.js
 361  var import_private_apis = __toESM(require_private_apis());
 362  var { lock, unlock } = (0, import_private_apis.__dangerousOptInToUnstableAPIsOnlyForCoreModules)(
 363    "I acknowledge private features are not for use in themes or plugins and doing so will break in the next version of WordPress.",
 364    "@wordpress/boot"
 365  );
 366  
 367  // packages/boot/build-module/components/site-icon/index.js
 368  var import_data = __toESM(require_data());
 369  var import_i18n = __toESM(require_i18n());
 370  var import_core_data = __toESM(require_core_data());
 371  var import_jsx_runtime14 = __toESM(require_jsx_runtime());
 372  var css = `/**
 373   * SCSS Variables.
 374   *
 375   * Please use variables from this sheet to ensure consistency across the UI.
 376   * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
 377   * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
 378   */
 379  /**
 380   * Colors
 381   */
 382  /**
 383   * Fonts & basic variables.
 384   */
 385  /**
 386   * Typography
 387   */
 388  /**
 389   * Grid System.
 390   * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
 391   */
 392  /**
 393   * Radius scale.
 394   */
 395  /**
 396   * Elevation scale.
 397   */
 398  /**
 399   * Dimensions.
 400   */
 401  /**
 402   * Mobile specific styles
 403   */
 404  /**
 405   * Editor styles.
 406   */
 407  /**
 408   * Block & Editor UI.
 409   */
 410  /**
 411   * Block paddings.
 412   */
 413  /**
 414   * React Native specific.
 415   * These variables do not appear to be used anywhere else.
 416   */
 417  .boot-site-icon {
 418    display: flex;
 419  }
 420  
 421  .boot-site-icon__icon {
 422    width: 32px;
 423    height: 32px;
 424    color: var(--wpds-color-fg-content-neutral, #1e1e1e);
 425  }
 426  
 427  .boot-site-icon__image {
 428    width: 32px;
 429    height: 32px;
 430    object-fit: cover;
 431    aspect-ratio: 1/1;
 432    border-radius: var(--wpds-border-radius-surface-md, 4px);
 433  }
 434  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/site-icon","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEjKA;EACC;;;AAGD;EACC,OFkDc;EEjDd,QFiDc;EEhDd;;;AAGD;EACC,OF4Cc;EE3Cd,QF2Cc;EE1Cd;EACA;EACA","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n.boot-site-icon {\n\tdisplay: flex;\n}\n\n.boot-site-icon__icon {\n\twidth: variables.$grid-unit-40;\n\theight: variables.$grid-unit-40;\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n}\n\n.boot-site-icon__image {\n\twidth: variables.$grid-unit-40;\n\theight: variables.$grid-unit-40;\n\tobject-fit: cover;\n\taspect-ratio: 1 / 1;\n\tborder-radius: var(--wpds-border-radius-surface-md, 4px);\n}\n"]} */`;
 435  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css));
 436  function SiteIcon({ className }) {
 437    const { isRequestingSite, siteIconUrl } = (0, import_data.useSelect)((select) => {
 438      const { getEntityRecord } = select(import_core_data.store);
 439      const siteData = getEntityRecord(
 440        "root",
 441        "__unstableBase",
 442        void 0
 443      );
 444      return {
 445        isRequestingSite: !siteData,
 446        siteIconUrl: siteData?.site_icon_url
 447      };
 448    }, []);
 449    let icon = null;
 450    if (isRequestingSite && !siteIconUrl) {
 451      icon = /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("div", { className: "boot-site-icon__image" });
 452    } else {
 453      icon = siteIconUrl ? /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(
 454        "img",
 455        {
 456          className: "boot-site-icon__image",
 457          alt: (0, import_i18n.__)("Site Icon"),
 458          src: siteIconUrl
 459        }
 460      ) : /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(
 461        icon_default,
 462        {
 463          className: "boot-site-icon__icon",
 464          icon: wordpress_default,
 465          size: 48
 466        }
 467      );
 468    }
 469    return /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("div", { className: clsx_default(className, "boot-site-icon"), children: icon });
 470  }
 471  var site_icon_default = SiteIcon;
 472  
 473  // packages/boot/build-module/components/site-icon-link/index.js
 474  var import_jsx_runtime15 = __toESM(require_jsx_runtime());
 475  var css2 = `/**
 476   * SCSS Variables.
 477   *
 478   * Please use variables from this sheet to ensure consistency across the UI.
 479   * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
 480   * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
 481   */
 482  /**
 483   * Colors
 484   */
 485  /**
 486   * Fonts & basic variables.
 487   */
 488  /**
 489   * Typography
 490   */
 491  /**
 492   * Grid System.
 493   * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
 494   */
 495  /**
 496   * Radius scale.
 497   */
 498  /**
 499   * Elevation scale.
 500   */
 501  /**
 502   * Dimensions.
 503   */
 504  /**
 505   * Mobile specific styles
 506   */
 507  /**
 508   * Editor styles.
 509   */
 510  /**
 511   * Block & Editor UI.
 512   */
 513  /**
 514   * Block paddings.
 515   */
 516  /**
 517   * React Native specific.
 518   * These variables do not appear to be used anywhere else.
 519   */
 520  .boot-site-icon-link {
 521    width: 64px;
 522    height: 64px;
 523    display: inline-flex;
 524    align-items: center;
 525    justify-content: center;
 526    background: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);
 527    text-decoration: none;
 528  }
 529  @media not (prefers-reduced-motion) {
 530    .boot-site-icon-link {
 531      transition: outline 0.1s ease-out;
 532    }
 533  }
 534  .boot-site-icon-link:focus:not(:active) {
 535    outline: var(--wpds-border-width-interactive-focus, 2px) solid var(--wpds-color-stroke-focus-brand, #0073aa);
 536    outline-offset: calc(-1 * var(--wpds-border-width-interactive-focus, 2px));
 537  }
 538  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/site-icon-link","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AE/JA;EACC,OF8Fe;EE7Ff,QF6Fe;EE5Ff;EACA;EACA;EACA;EACA;;AAEA;EATD;IAUE;;;AAGD;EACC,SACC;EAED","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n$header-height: variables.$header-height;\n\n.boot-site-icon-link {\n\twidth: $header-height;\n\theight: $header-height;\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\tbackground: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);\n\ttext-decoration: none;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: outline 0.1s ease-out;\n\t}\n\n\t&:focus:not(:active) {\n\t\toutline:\n\t\t\tvar(--wpds-border-width-interactive-focus, 2px) solid\n\t\t\tvar(--wpds-color-stroke-focus-brand, #0073aa);\n\t\toutline-offset: calc(-1 * var(--wpds-border-width-interactive-focus, 2px));\n\t}\n}\n"]} */`;
 539  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css2));
 540  var { useCanGoBack, useRouter } = unlock(routePrivateApis);
 541  function SiteIconLink({
 542    to,
 543    isBackButton,
 544    ...props
 545  }) {
 546    const router = useRouter();
 547    const canGoBack = useCanGoBack();
 548    return /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(
 549      Link,
 550      {
 551        to,
 552        "aria-label": props["aria-label"],
 553        className: "boot-site-icon-link",
 554        onClick: (event) => {
 555          if (canGoBack && isBackButton) {
 556            event.preventDefault();
 557            router.history.back();
 558          }
 559        },
 560        children: /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(site_icon_default, {})
 561      }
 562    );
 563  }
 564  var site_icon_link_default = SiteIconLink;
 565  
 566  // packages/boot/build-module/components/site-hub/index.js
 567  var import_jsx_runtime16 = __toESM(require_jsx_runtime());
 568  var css3 = `/**
 569   * SCSS Variables.
 570   *
 571   * Please use variables from this sheet to ensure consistency across the UI.
 572   * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
 573   * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
 574   */
 575  /**
 576   * Colors
 577   */
 578  /**
 579   * Fonts & basic variables.
 580   */
 581  /**
 582   * Typography
 583   */
 584  /**
 585   * Grid System.
 586   * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
 587   */
 588  /**
 589   * Radius scale.
 590   */
 591  /**
 592   * Elevation scale.
 593   */
 594  /**
 595   * Dimensions.
 596   */
 597  /**
 598   * Mobile specific styles
 599   */
 600  /**
 601   * Editor styles.
 602   */
 603  /**
 604   * Block & Editor UI.
 605   */
 606  /**
 607   * Block paddings.
 608   */
 609  /**
 610   * React Native specific.
 611   * These variables do not appear to be used anywhere else.
 612   */
 613  .boot-site-hub {
 614    position: sticky;
 615    top: 0;
 616    background-color: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);
 617    z-index: 1;
 618    display: grid;
 619    grid-template-columns: 60px 1fr auto;
 620    align-items: center;
 621    padding-right: 16px;
 622    flex-shrink: 0;
 623  }
 624  
 625  .boot-site-hub__actions {
 626    flex-shrink: 0;
 627  }
 628  
 629  .boot-site-hub__title {
 630    display: flex;
 631    align-items: center;
 632    text-decoration: none;
 633  }
 634  .boot-site-hub__title .components-external-link__contents {
 635    text-decoration: none;
 636    margin-inline-start: 4px;
 637    overflow: hidden;
 638    max-width: 140px;
 639  }
 640  .boot-site-hub__title .components-external-link__icon {
 641    opacity: 0;
 642    transition: opacity 0.1s ease-out;
 643  }
 644  .boot-site-hub__title:hover .components-external-link__icon {
 645    opacity: 1;
 646  }
 647  @media not (prefers-reduced-motion) {
 648    .boot-site-hub__title {
 649      transition: outline 0.1s ease-out;
 650    }
 651  }
 652  .boot-site-hub__title:focus:not(:active) {
 653    outline: var(--wpds-border-width-interactive-focus, 2px) solid var(--wpds-color-stroke-focus-brand, #0073aa);
 654    outline-offset: calc(-1 * var(--wpds-border-width-interactive-focus, 2px));
 655  }
 656  
 657  .boot-site-hub__title-text {
 658    color: var(--wpds-color-fg-content-neutral, #1e1e1e);
 659    font-size: 13px;
 660    font-weight: 499;
 661    overflow: hidden;
 662    text-overflow: ellipsis;
 663    white-space: nowrap;
 664  }
 665  
 666  .boot-site-hub__url {
 667    color: var(--wpds-color-fg-content-neutral-weak, #757575);
 668    font-size: 12px;
 669    overflow: hidden;
 670    text-overflow: ellipsis;
 671    white-space: nowrap;
 672  }
 673  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/site-hub","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEjKA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA,eF6Cc;EE5Cd;;;AAGD;EACC;;;AAGD;EACC;EACA;EACA;;AAEA;EACC;EACA,qBF2Ba;EE1Bb;EACA;;AAID;EACC;EACA;;AAGD;EACC;;AAID;EAvBD;IAwBE;;;AAGD;EACC,SACC;EAED;;;AAIF;EACC;EACA,WF/BkB;EEgClB,aFjBoB;EEkBpB;EACA;EACA;;;AAGD;EACC;EACA,WFzCiB;EE0CjB;EACA;EACA","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n.boot-site-hub {\n\tposition: sticky;\n\ttop: 0;\n\tbackground-color: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);\n\tz-index: 1;\n\tdisplay: grid;\n\tgrid-template-columns: 60px 1fr auto;\n\talign-items: center;\n\tpadding-right: variables.$grid-unit-20;\n\tflex-shrink: 0; // Prevent flex parent from shrinking this element.\n}\n\n.boot-site-hub__actions {\n\tflex-shrink: 0;\n}\n\n.boot-site-hub__title {\n\tdisplay: flex;\n\talign-items: center;\n\ttext-decoration: none;\n\n\t.components-external-link__contents {\n\t\ttext-decoration: none;\n\t\tmargin-inline-start: variables.$grid-unit-05;\n\t\toverflow: hidden;\n\t\tmax-width: 140px;\n\t}\n\n\t// Show icon on hover\n\t.components-external-link__icon {\n\t\topacity: 0;\n\t\ttransition: opacity 0.1s ease-out;\n\t}\n\n\t&:hover .components-external-link__icon {\n\t\topacity: 1;\n\t}\n\n\t// Focus styles\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: outline 0.1s ease-out;\n\t}\n\n\t&:focus:not(:active) {\n\t\toutline:\n\t\t\tvar(--wpds-border-width-interactive-focus, 2px) solid\n\t\t\tvar(--wpds-color-stroke-focus-brand, #0073aa);\n\t\toutline-offset: calc(-1 * var(--wpds-border-width-interactive-focus, 2px));\n\t}\n}\n\n.boot-site-hub__title-text {\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tfont-size: variables.$font-size-medium;\n\tfont-weight: variables.$font-weight-medium;\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n}\n\n.boot-site-hub__url {\n\tcolor: var(--wpds-color-fg-content-neutral-weak, #757575);\n\tfont-size: variables.$font-size-small;\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n}\n"]} */`;
 674  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css3));
 675  function SiteHub() {
 676    const { homeUrl, siteTitle } = (0, import_data2.useSelect)((select) => {
 677      const { getEntityRecord } = select(import_core_data2.store);
 678      const _base = getEntityRecord(
 679        "root",
 680        "__unstableBase"
 681      );
 682      return {
 683        homeUrl: _base?.home,
 684        siteTitle: !_base?.name && !!_base?.url ? (0, import_url.filterURLForDisplay)(_base?.url) : _base?.name
 685      };
 686    }, []);
 687    const { open: openCommandCenter } = (0, import_data2.useDispatch)(import_commands.store);
 688    return /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)("div", { className: "boot-site-hub", children: [
 689      /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(site_icon_link_default, { to: "/", "aria-label": (0, import_i18n2.__)("Go to the Dashboard") }),
 690      /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)(
 691        import_components3.ExternalLink,
 692        {
 693          href: homeUrl ?? "/",
 694          className: "boot-site-hub__title",
 695          children: [
 696            /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("div", { className: "boot-site-hub__title-text", children: siteTitle && (0, import_html_entities.decodeEntities)(siteTitle) }),
 697            /* @__PURE__ */ (0, import_jsx_runtime16.jsx)("div", { className: "boot-site-hub__url", children: (0, import_url.filterURLForDisplay)(homeUrl ?? "") })
 698          ]
 699        }
 700      ),
 701      /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(import_components3.__experimentalHStack, { className: "boot-site-hub__actions", children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
 702        import_components3.Button,
 703        {
 704          variant: "tertiary",
 705          icon: search_default,
 706          onClick: () => openCommandCenter(),
 707          size: "compact",
 708          label: (0, import_i18n2.__)("Open command palette"),
 709          shortcut: import_keycodes.displayShortcut.primary("k")
 710        }
 711      ) })
 712    ] });
 713  }
 714  var site_hub_default = SiteHub;
 715  
 716  // packages/boot/build-module/components/navigation/index.js
 717  var import_element6 = __toESM(require_element());
 718  var import_data6 = __toESM(require_data());
 719  
 720  // packages/boot/build-module/store/index.js
 721  var import_data3 = __toESM(require_data());
 722  
 723  // packages/boot/build-module/store/reducer.js
 724  var initialState = {
 725    menuItems: {},
 726    routes: []
 727  };
 728  function reducer(state = initialState, action) {
 729    switch (action.type) {
 730      case "REGISTER_MENU_ITEM":
 731        return {
 732          ...state,
 733          menuItems: {
 734            ...state.menuItems,
 735            [action.id]: action.menuItem
 736          }
 737        };
 738      case "UPDATE_MENU_ITEM":
 739        return {
 740          ...state,
 741          menuItems: {
 742            ...state.menuItems,
 743            [action.id]: {
 744              ...state.menuItems[action.id],
 745              ...action.updates
 746            }
 747          }
 748        };
 749      case "REGISTER_ROUTE":
 750        return {
 751          ...state,
 752          routes: [...state.routes, action.route]
 753        };
 754    }
 755    return state;
 756  }
 757  
 758  // packages/boot/build-module/store/actions.js
 759  var actions_exports = {};
 760  __export(actions_exports, {
 761    registerMenuItem: () => registerMenuItem,
 762    registerRoute: () => registerRoute,
 763    updateMenuItem: () => updateMenuItem
 764  });
 765  function registerMenuItem(id, menuItem) {
 766    return {
 767      type: "REGISTER_MENU_ITEM",
 768      id,
 769      menuItem
 770    };
 771  }
 772  function updateMenuItem(id, updates) {
 773    return {
 774      type: "UPDATE_MENU_ITEM",
 775      id,
 776      updates
 777    };
 778  }
 779  function registerRoute(route) {
 780    return {
 781      type: "REGISTER_ROUTE",
 782      route
 783    };
 784  }
 785  
 786  // packages/boot/build-module/store/selectors.js
 787  var selectors_exports = {};
 788  __export(selectors_exports, {
 789    getMenuItems: () => getMenuItems,
 790    getRoutes: () => getRoutes
 791  });
 792  function getMenuItems(state) {
 793    return Object.values(state.menuItems);
 794  }
 795  function getRoutes(state) {
 796    return state.routes;
 797  }
 798  
 799  // packages/boot/build-module/store/index.js
 800  var STORE_NAME = "wordpress/boot";
 801  var store = (0, import_data3.createReduxStore)(STORE_NAME, {
 802    reducer,
 803    actions: actions_exports,
 804    selectors: selectors_exports
 805  });
 806  (0, import_data3.register)(store);
 807  
 808  // packages/boot/build-module/components/navigation/navigation-item/index.js
 809  var import_components6 = __toESM(require_components());
 810  
 811  // packages/boot/build-module/components/navigation/router-link-item.js
 812  var import_element3 = __toESM(require_element());
 813  var import_components4 = __toESM(require_components());
 814  import { privateApis as routePrivateApis2 } from "@wordpress/route";
 815  var import_jsx_runtime17 = __toESM(require_jsx_runtime());
 816  var { createLink } = unlock(routePrivateApis2);
 817  function AnchorOnlyItem(props, forwardedRef) {
 818    return /* @__PURE__ */ (0, import_jsx_runtime17.jsx)(import_components4.__experimentalItem, { as: "a", ref: forwardedRef, ...props });
 819  }
 820  var RouterLinkItem = createLink((0, import_element3.forwardRef)(AnchorOnlyItem));
 821  var router_link_item_default = RouterLinkItem;
 822  
 823  // packages/boot/build-module/components/navigation/items.js
 824  var import_element4 = __toESM(require_element());
 825  var import_components5 = __toESM(require_components());
 826  var import_primitives11 = __toESM(require_primitives());
 827  var import_jsx_runtime18 = __toESM(require_jsx_runtime());
 828  function isSvg(element) {
 829    return (0, import_element4.isValidElement)(element) && (element.type === import_primitives11.SVG || element.type === "svg");
 830  }
 831  function wrapIcon(icon, shouldShowPlaceholder = true) {
 832    if (isSvg(icon)) {
 833      return /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(import_components5.Icon, { icon });
 834    }
 835    if (typeof icon === "string" && icon.startsWith("dashicons-")) {
 836      const iconKey = icon.replace(
 837        /^dashicons-/,
 838        ""
 839      );
 840      return /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
 841        import_components5.Dashicon,
 842        {
 843          style: { padding: "2px" },
 844          icon: iconKey,
 845          "aria-hidden": "true"
 846        }
 847      );
 848    }
 849    if (typeof icon === "string" && icon.startsWith("data:")) {
 850      return /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
 851        "img",
 852        {
 853          src: icon,
 854          alt: "",
 855          "aria-hidden": "true",
 856          style: {
 857            width: "20px",
 858            height: "20px",
 859            display: "block",
 860            padding: "2px"
 861          }
 862        }
 863      );
 864    }
 865    if (icon) {
 866      return icon;
 867    }
 868    if (shouldShowPlaceholder) {
 869      return /* @__PURE__ */ (0, import_jsx_runtime18.jsx)(
 870        "div",
 871        {
 872          style: { width: "24px", height: "24px" },
 873          "aria-hidden": "true"
 874        }
 875      );
 876    }
 877    return null;
 878  }
 879  
 880  // packages/boot/build-module/components/navigation/navigation-item/index.js
 881  var import_jsx_runtime19 = __toESM(require_jsx_runtime());
 882  var css4 = `/**
 883   * SCSS Variables.
 884   *
 885   * Please use variables from this sheet to ensure consistency across the UI.
 886   * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
 887   * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
 888   */
 889  /**
 890   * Colors
 891   */
 892  /**
 893   * Fonts & basic variables.
 894   */
 895  /**
 896   * Typography
 897   */
 898  /**
 899   * Grid System.
 900   * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
 901   */
 902  /**
 903   * Radius scale.
 904   */
 905  /**
 906   * Elevation scale.
 907   */
 908  /**
 909   * Dimensions.
 910   */
 911  /**
 912   * Mobile specific styles
 913   */
 914  /**
 915   * Editor styles.
 916   */
 917  /**
 918   * Block & Editor UI.
 919   */
 920  /**
 921   * Block paddings.
 922   */
 923  /**
 924   * React Native specific.
 925   * These variables do not appear to be used anywhere else.
 926   */
 927  /**
 928   * Typography
 929   */
 930  /**
 931   * Breakpoints & Media Queries
 932   */
 933  /**
 934  *  Converts a hex value into the rgb equivalent.
 935  *
 936  * @param {string} hex - the hexadecimal value to convert
 937  * @return {string} comma separated rgb values
 938  */
 939  /**
 940   * Long content fade mixin
 941   *
 942   * Creates a fading overlay to signify that the content is longer
 943   * than the space allows.
 944   */
 945  /**
 946   * Breakpoint mixins
 947   */
 948  /**
 949   * Focus styles.
 950   */
 951  /**
 952   * Applies editor left position to the selector passed as argument
 953   */
 954  /**
 955   * Styles that are reused verbatim in a few places
 956   */
 957  /**
 958   * Allows users to opt-out of animations via OS-level preferences.
 959   */
 960  /**
 961   * Reset default styles for JavaScript UI based pages.
 962   * This is a WP-admin agnostic reset
 963   */
 964  /**
 965   * Reset the WP Admin page styles for Gutenberg-like pages.
 966   */
 967  .boot-navigation-item.components-item {
 968    color: var(--wpds-color-fg-interactive-neutral, #1e1e1e);
 969    padding-inline: 4px;
 970    padding-block: 0;
 971    margin-inline: 12px;
 972    margin-block-end: 4px;
 973    width: calc(100% - 24px);
 974    border: none;
 975    min-height: 32px;
 976    display: flex;
 977    align-items: center;
 978    font-family: -apple-system, "system-ui", "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
 979    font-weight: 400;
 980    font-size: 13px;
 981    line-height: 20px;
 982  }
 983  .boot-dropdown-item__children .boot-navigation-item.components-item {
 984    min-height: 24px;
 985  }
 986  .boot-navigation-item.components-item {
 987    border-radius: var(--wpds-border-radius-surface-sm, 2px);
 988  }
 989  .boot-navigation-item.components-item.active, .boot-navigation-item.components-item:hover, .boot-navigation-item.components-item:focus, .boot-navigation-item.components-item[aria-current=true] {
 990    color: var(--wpds-color-fg-interactive-brand-active, #0073aa);
 991  }
 992  .boot-navigation-item.components-item.active {
 993    font-weight: 499;
 994  }
 995  .boot-navigation-item.components-item svg:last-child {
 996    padding: 4px;
 997  }
 998  .boot-navigation-item.components-item[aria-current=true] {
 999    color: var(--wpds-color-fg-interactive-brand-active, #0073aa);
1000    font-weight: 499;
1001  }
1002  .boot-navigation-item.components-item:focus-visible {
1003    transform: translateZ(0);
1004  }
1005  .boot-navigation-item.components-item.with-suffix {
1006    padding-right: 16px;
1007  }
1008  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/navigation/navigation-item","sources":["../../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../../node_modules/@wordpress/base-styles/_colors.scss","../../../../../../node_modules/@wordpress/base-styles/_mixins.scss","../../../../../../node_modules/@wordpress/base-styles/_breakpoints.scss","../../../../../../node_modules/@wordpress/base-styles/_functions.scss","../../../../../../node_modules/@wordpress/base-styles/_long-content-fade.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEnKA;AAAA;AAAA;ACAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AH4EA;AAAA;AAAA;AA0DA;AAAA;AAAA;AAgDA;AAAA;AAAA;AAqCA;AAAA;AAAA;AAoBA;AAAA;AAAA;AAwLA;AAAA;AAAA;AAAA;AAgDA;AAAA;AAAA;AIpdA;EACC;EACA,gBN+Cc;EM9Cd;EACA,eN+Cc;EM9Cd,kBN4Cc;EM3Cd;EACA;EACA,YN8Cc;EM7Cd;EACA;EJKA,aFyBkB;EExBlB,aFmBqB;EEsBrB,WFpCkB;EEqClB,aF9BwB;;AMfxB;EACC,YNuCa;;AMrDf;EAkBC;;AAEA;EAIC;;AAGD;EACC,aNQmB;;AMLpB;EACC,SNiBa;;AMdd;EACC;EACA,aNDmB;;AMKpB;EACC;;AAGD;EACC,eNMa","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","/**\n * Typography\n */\n\n@use \"sass:color\";\n@use \"sass:math\";\n@use \"./variables\";\n@use \"./colors\";\n@use \"./breakpoints\";\n@use \"./functions\";\n@use \"./long-content-fade\";\n\n@mixin _text-heading() {\n\tfont-family: variables.$font-family-headings;\n\tfont-weight: variables.$font-weight-medium;\n}\n\n@mixin _text-body() {\n\tfont-family: variables.$font-family-body;\n\tfont-weight: variables.$font-weight-regular;\n}\n\n@mixin heading-small() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin heading-medium() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin heading-2x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-2x-large;\n\tline-height: variables.$font-line-height-2x-large;\n}\n\n@mixin body-small() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin body-medium() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin body-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin body-x-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-x-large;\n}\n\n/**\n * Breakpoint mixins\n */\n\n@mixin break-xhuge() {\n\t@media (min-width: #{ (breakpoints.$break-xhuge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-huge() {\n\t@media (min-width: #{ (breakpoints.$break-huge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-wide() {\n\t@media (min-width: #{ (breakpoints.$break-wide) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-xlarge() {\n\t@media (min-width: #{ (breakpoints.$break-xlarge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-large() {\n\t@media (min-width: #{ (breakpoints.$break-large) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-medium() {\n\t@media (min-width: #{ (breakpoints.$break-medium) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-small() {\n\t@media (min-width: #{ (breakpoints.$break-small) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-mobile() {\n\t@media (min-width: #{ (breakpoints.$break-mobile) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-zoomed-in() {\n\t@media (min-width: #{ (breakpoints.$break-zoomed-in) }) {\n\t\t@content;\n\t}\n}\n\n/**\n * Focus styles.\n */\n\n@mixin block-toolbar-button-style__focus() {\n\tbox-shadow: inset 0 0 0 variables.$border-width colors.$white, 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n// Tabs, Inputs, Square buttons.\n@mixin input-style__neutral() {\n\tbox-shadow: 0 0 0 transparent;\n\tborder-radius: variables.$radius-small;\n\tborder: variables.$border-width solid colors.$gray-600;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n}\n\n\n@mixin input-style__focus($accent-color: var(--wp-admin-theme-color)) {\n\tborder-color: $accent-color;\n\t// Expand the default border focus style by .5px to be a total of 1.5px.\n\tbox-shadow: 0 0 0 0.5px $accent-color;\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n@mixin button-style__focus() {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n\n@mixin button-style-outset__focus($focus-color) {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) colors.$white, 0 0 0 calc(2 * var(--wp-admin-border-width-focus)) $focus-color;\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n\toutline-offset: 2px;\n}\n\n\n/**\n * Applies editor left position to the selector passed as argument\n */\n\n@mixin editor-left($selector) {\n\t#{$selector} { /* Set left position when auto-fold is not on the body element. */\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t.auto-fold #{$selector} { /* Auto fold is when on smaller breakpoints, nav menu auto collapses. */\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\n\t\t@media (min-width: #{ (breakpoints.$break-large + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t/* Sidebar manually collapsed. */\n\t.folded #{$selector} {\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\t}\n\n\tbody.is-fullscreen-mode #{$selector} {\n\t\tleft: 0 !important;\n\t}\n}\n\n/**\n * Styles that are reused verbatim in a few places\n */\n\n// These are additional styles for all captions, when the theme opts in to block styles.\n@mixin caption-style() {\n\tmargin-top: 0.5em;\n\tmargin-bottom: 1em;\n}\n\n@mixin caption-style-theme() {\n\tcolor: #555;\n\tfont-size: variables.$default-font-size;\n\ttext-align: center;\n\n\t.is-dark-theme & {\n\t\tcolor: colors.$light-gray-placeholder;\n\t}\n}\n\n/**\n * Allows users to opt-out of animations via OS-level preferences.\n */\n\n@mixin reduce-motion($property: \"\") {\n\n\t@if $property == \"transition\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t}\n\t} @else if $property == \"animation\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t} @else {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t}\n}\n\n@mixin input-control($accent-color: var(--wp-admin-theme-color)) {\n\tfont-family: variables.$default-font;\n\tpadding: 6px 8px;\n\t/* Fonts smaller than 16px causes mobile safari to zoom. */\n\tfont-size: variables.$mobile-text-min-font-size;\n\t/* Override core line-height. To be reviewed. */\n\tline-height: normal;\n\t@include input-style__neutral();\n\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size;\n\t\t/* Override core line-height. To be reviewed. */\n\t\tline-height: normal;\n\t}\n\n\t&:focus {\n\t\t@include input-style__focus($accent-color);\n\t}\n\n\t// Use opacity to work in various editor styles.\n\t&::-webkit-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&::-moz-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&:-ms-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n}\n\n@mixin checkbox-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-small;\n\t@include input-control;\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t// Hide default checkbox styles in IE.\n\t\t&::-ms-check {\n\t\t\topacity: 0;\n\t\t}\n\t}\n\n\t&:checked::before,\n\t&[aria-checked=\"mixed\"]::before {\n\t\tmargin: -3px -5px;\n\t\tcolor: colors.$white;\n\n\t\t@include break-medium() {\n\t\t\tmargin: -4px 0 0 -5px;\n\t\t}\n\t}\n\n\t&[aria-checked=\"mixed\"] {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t&::before {\n\t\t\t// Inherited from `forms.css`.\n\t\t\t// See: https://github.com/WordPress/wordpress-develop/tree/5.1.1/src/wp-admin/css/forms.css#L122-L132\n\t\t\tcontent: \"\\f460\";\n\t\t\tfloat: left;\n\t\t\tdisplay: inline-block;\n\t\t\tvertical-align: middle;\n\t\t\twidth: 16px;\n\t\t\t/* stylelint-disable-next-line font-family-no-missing-generic-family-keyword -- dashicons don't need a generic family keyword. */\n\t\t\tfont: normal 30px/1 dashicons;\n\t\t\tspeak: none;\n\t\t\t-webkit-font-smoothing: antialiased;\n\t\t\t-moz-osx-font-smoothing: grayscale;\n\n\t\t\t@include break-medium() {\n\t\t\t\tfloat: none;\n\t\t\t\tfont-size: 21px;\n\t\t\t}\n\t\t}\n\t}\n\n\t&[aria-disabled=\"true\"],\n\t&:disabled {\n\t\tbackground: colors.$gray-100;\n\t\tborder-color: colors.$gray-300;\n\t\tcursor: default;\n\n\t\t// Override style inherited from wp-admin. Required to avoid degraded appearance on different backgrounds.\n\t\topacity: 1;\n\t}\n}\n\n@mixin radio-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-round;\n\twidth: variables.$radio-input-size-sm;\n\theight: variables.$radio-input-size-sm;\n\tmin-width: variables.$radio-input-size-sm;\n\tmax-width: variables.$radio-input-size-sm;\n\tposition: relative;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n\n\t@include break-small() {\n\t\theight: variables.$radio-input-size;\n\t\twidth: variables.$radio-input-size;\n\t\tmin-width: variables.$radio-input-size;\n\t\tmax-width: variables.$radio-input-size;\n\t}\n\n\t&:checked::before {\n\t\tbox-sizing: inherit;\n\t\twidth: math.div(variables.$radio-input-size-sm, 2);\n\t\theight: math.div(variables.$radio-input-size-sm, 2);\n\t\tposition: absolute;\n\t\ttop: 50%;\n\t\tleft: 50%;\n\t\ttransform: translate(-50%, -50%);\n\t\tmargin: 0;\n\t\tbackground-color: colors.$white;\n\n\t\t// This border serves as a background color in Windows High Contrast mode.\n\t\tborder: 4px solid colors.$white;\n\n\t\t@include break-small() {\n\t\t\twidth: math.div(variables.$radio-input-size, 2);\n\t\t\theight: math.div(variables.$radio-input-size, 2);\n\t\t}\n\t}\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder: none;\n\t}\n}\n\n/**\n * Reset default styles for JavaScript UI based pages.\n * This is a WP-admin agnostic reset\n */\n\n@mixin reset {\n\tbox-sizing: border-box;\n\n\t*,\n\t*::before,\n\t*::after {\n\t\tbox-sizing: inherit;\n\t}\n}\n\n@mixin link-reset {\n\t&:focus {\n\t\tcolor: var(--wp-admin-theme-color--rgb);\n\t\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color, #007cba);\n\t\tborder-radius: variables.$radius-small;\n\t}\n}\n\n// The editor input reset with increased specificity to avoid theme styles bleeding in.\n@mixin editor-input-reset() {\n\tfont-family: variables.$editor-html-font !important;\n\tcolor: colors.$gray-900 !important;\n\tbackground: colors.$white !important;\n\tpadding: variables.$grid-unit-15 !important;\n\tborder: variables.$border-width solid colors.$gray-900 !important;\n\tbox-shadow: none !important;\n\tborder-radius: variables.$radius-small !important;\n\n\t// Fonts smaller than 16px causes mobile safari to zoom.\n\tfont-size: variables.$mobile-text-min-font-size !important;\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size !important;\n\t}\n\n\t&:focus {\n\t\tborder-color: var(--wp-admin-theme-color) !important;\n\t\tbox-shadow: 0 0 0 (variables.$border-width-focus-fallback - variables.$border-width) var(--wp-admin-theme-color) !important;\n\n\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\toutline: 2px solid transparent !important;\n\t}\n}\n\n/**\n * Reset the WP Admin page styles for Gutenberg-like pages.\n */\n\n@mixin wp-admin-reset( $content-container ) {\n\tbackground: colors.$white;\n\n\t#wpcontent {\n\t\tpadding-left: 0;\n\t}\n\n\t#wpbody-content {\n\t\tpadding-bottom: 0;\n\t}\n\n\t/* We hide legacy notices in Gutenberg Based Pages, because they were not designed in a way that scaled well.\n\t   Plugins can use Gutenberg notices if they need to pass on information to the user when they are editing. */\n\t#wpbody-content > div:not(#{ $content-container }):not(#screen-meta) {\n\t\tdisplay: none;\n\t}\n\n\t#wpfooter {\n\t\tdisplay: none;\n\t}\n\n\t.a11y-speak-region {\n\t\tleft: -1px;\n\t\ttop: -1px;\n\t}\n\n\tul#adminmenu a.wp-has-current-submenu::after,\n\tul#adminmenu > li.current > a.current::after {\n\t\tborder-right-color: colors.$white;\n\t}\n\n\t.media-frame select.attachment-filters:last-of-type {\n\t\twidth: auto;\n\t\tmax-width: 100%;\n\t}\n}\n\n@mixin admin-scheme($color-primary) {\n\t// Define RGB equivalents for use in rgba function.\n\t// Hexadecimal css vars do not work in the rgba function.\n\t--wp-admin-theme-color: #{$color-primary};\n\t--wp-admin-theme-color--rgb: #{functions.hex-to-rgb($color-primary)};\n\t// Darker shades.\n\t--wp-admin-theme-color-darker-10: #{color.adjust($color-primary, $lightness: -5%)};\n\t--wp-admin-theme-color-darker-10--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -5%))};\n\t--wp-admin-theme-color-darker-20: #{color.adjust($color-primary, $lightness: -10%)};\n\t--wp-admin-theme-color-darker-20--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -10%))};\n\n\t// Focus style width.\n\t// Avoid rounding issues by showing a whole 2px for 1x screens, and 1.5px on high resolution screens.\n\t--wp-admin-border-width-focus: 2px;\n\t@media ( -webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {\n\t\t--wp-admin-border-width-focus: 1.5px;\n\t}\n}\n\n@mixin wordpress-admin-schemes() {\n\tbody.admin-color-light {\n\t\t@include admin-scheme(#0085ba);\n\t}\n\n\tbody.admin-color-modern {\n\t\t@include admin-scheme(#3858e9);\n\t}\n\n\tbody.admin-color-blue {\n\t\t@include admin-scheme(#096484);\n\t}\n\n\tbody.admin-color-coffee {\n\t\t@include admin-scheme(#46403c);\n\t}\n\n\tbody.admin-color-ectoplasm {\n\t\t@include admin-scheme(#523f6d);\n\t}\n\n\tbody.admin-color-midnight {\n\t\t@include admin-scheme(#e14d43);\n\t}\n\n\tbody.admin-color-ocean {\n\t\t@include admin-scheme(#627c83);\n\t}\n\n\tbody.admin-color-sunrise {\n\t\t@include admin-scheme(#dd823b);\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin background-colors-deprecated() {\n\t.has-very-light-gray-background-color {\n\t\tbackground-color: #eee;\n\t}\n\n\t.has-very-dark-gray-background-color {\n\t\tbackground-color: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin foreground-colors-deprecated() {\n\t.has-very-light-gray-color {\n\t\tcolor: #eee;\n\t}\n\n\t.has-very-dark-gray-color {\n\t\tcolor: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin gradient-colors-deprecated() {\n\t// Our classes uses the same values we set for gradient value attributes.\n\n\t/* stylelint-disable @stylistic/function-comma-space-after -- We can not use spacing because of WP multi site kses rule. */\n\t.has-vivid-green-cyan-to-vivid-cyan-blue-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgba(0,208,132,1) 0%,rgba(6,147,227,1) 100%);\n\t}\n\n\t.has-purple-crush-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(52,226,228) 0%,rgb(71,33,251) 50%,rgb(171,29,254) 100%);\n\t}\n\n\t.has-hazy-dawn-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,172,168) 0%,rgb(218,208,236) 100%);\n\t}\n\n\t.has-subdued-olive-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,250,225) 0%,rgb(103,166,113) 100%);\n\t}\n\n\t.has-atomic-cream-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(253,215,154) 0%,rgb(0,74,89) 100%);\n\t}\n\n\t.has-nightshade-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(51,9,104) 0%,rgb(49,205,207) 100%);\n\t}\n\n\t.has-midnight-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(2,3,129) 0%,rgb(40,116,252) 100%);\n\t}\n\t/* stylelint-enable @stylistic/function-comma-space-after */\n}\n\n@mixin custom-scrollbars-on-hover($handle-color, $handle-color-hover) {\n\n\t// WebKit\n\t&::-webkit-scrollbar {\n\t\twidth: 12px;\n\t\theight: 12px;\n\t}\n\t&::-webkit-scrollbar-track {\n\t\tbackground-color: transparent;\n\t}\n\t&::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color;\n\t\tborder-radius: 8px;\n\t\tborder: 3px solid transparent;\n\t\tbackground-clip: padding-box;\n\t}\n\t&:hover::-webkit-scrollbar-thumb, // This needs specificity.\n\t&:focus::-webkit-scrollbar-thumb,\n\t&:focus-within::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color-hover;\n\t}\n\n\t// Firefox 109+ and Chrome 111+\n\tscrollbar-width: thin;\n\tscrollbar-gutter: stable both-edges;\n\tscrollbar-color: $handle-color transparent; // Syntax, \"dark\", \"light\", or \"#handle-color #track-color\"\n\n\t&:hover,\n\t&:focus,\n\t&:focus-within {\n\t\tscrollbar-color: $handle-color-hover transparent;\n\t}\n\n\t// Needed to fix a Safari rendering issue.\n\twill-change: transform;\n\n\t// Always show scrollbar on Mobile devices.\n\t@media (hover: none) {\n\t\t& {\n\t\t\tscrollbar-color: $handle-color-hover transparent;\n\t\t}\n\t}\n}\n\n@mixin selected-block-outline($widthRatio: 1) {\n\toutline-color: var(--wp-admin-theme-color);\n\toutline-style: solid;\n\toutline-width: calc(#{$widthRatio} * (var(--wp-admin-border-width-focus) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n\toutline-offset: calc(#{$widthRatio} * ((-1 * var(--wp-admin-border-width-focus) ) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n}\n\n@mixin selected-block-focus($widthRatio: 1) {\n\tcontent: \"\";\n\tposition: absolute;\n\tpointer-events: none;\n\ttop: 0;\n\tright: 0;\n\tbottom: 0;\n\tleft: 0;\n\t@include selected-block-outline($widthRatio);\n}\n","/**\n * Breakpoints & Media Queries\n */\n\n// Most used breakpoints\n$break-xhuge: 1920px;\n$break-huge: 1440px;\n$break-wide: 1280px;\n$break-xlarge: 1080px;\n$break-large: 960px;\t// admin sidebar auto folds\n$break-medium: 782px;\t// adminbar goes big\n$break-small: 600px;\n$break-mobile: 480px;\n$break-zoomed-in: 280px;\n\n// All media queries currently in WordPress:\n//\n// min-width: 2000px\n// min-width: 1680px\n// min-width: 1250px\n// max-width: 1120px *\n// max-width: 1000px\n// min-width: 769px and max-width: 1000px\n// max-width: 960px *\n// max-width: 900px\n// max-width: 850px\n// min-width: 800px and max-width: 1499px\n// max-width: 800px\n// max-width: 799px\n// max-width: 782px *\n// max-width: 768px\n// max-width: 640px *\n// max-width: 600px *\n// max-width: 520px\n// max-width: 500px\n// max-width: 480px *\n// max-width: 400px *\n// max-width: 380px\n// max-width: 320px *\n//\n// Those marked * seem to be more commonly used than the others.\n// Let's try and use as few of these as possible, and be mindful about adding new ones, so we don't make the situation worse\n","/**\n*  Converts a hex value into the rgb equivalent.\n*\n* @param {string} hex - the hexadecimal value to convert\n* @return {string} comma separated rgb values\n*/\n\n@use \"sass:color\";\n@use \"sass:meta\";\n\n@function hex-to-rgb($hex) {\n\t/*\n\t * TODO: `color.{red|green|blue}` will trigger a deprecation warning in Dart Sass,\n\t * but the Sass used by the Gutenberg project doesn't support `color.channel()` yet,\n\t * so we can't migrate to it at this time.\n\t * In the future, after the Gutenberg project has been fully migrated to Dart Sass,\n\t * Remove this conditional statement and use only `color.channel()`.\n\t */\n\t@if meta.function-exists(\"channel\", \"color\") {\n\t\t@return color.channel($hex, \"red\"), color.channel($hex, \"green\"), color.channel($hex, \"blue\");\n\t} @else {\n\t\t@return color.red($hex), color.green($hex), color.blue($hex);\n\t}\n}\n","/**\n * Long content fade mixin\n *\n * Creates a fading overlay to signify that the content is longer\n * than the space allows.\n */\n\n@mixin long-content-fade($direction: right, $size: 20%, $color: #fff, $edge: 0, $z-index: false) {\n\tcontent: \"\";\n\tdisplay: block;\n\tposition: absolute;\n\t-webkit-touch-callout: none;\n\t-webkit-user-select: none;\n\t-khtml-user-select: none;\n\t-moz-user-select: none;\n\t-ms-user-select: none;\n\tuser-select: none;\n\tpointer-events: none;\n\n\t@if $z-index {\n\t\tz-index: $z-index;\n\t}\n\n\t@if $direction == \"bottom\" {\n\t\tbackground: linear-gradient(to top, transparent, $color 90%);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\ttop: $edge;\n\t\tbottom: calc(100% - $size);\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"top\" {\n\t\tbackground: linear-gradient(to bottom, transparent, $color 90%);\n\t\ttop: calc(100% - $size);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\tbottom: $edge;\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"left\" {\n\t\tbackground: linear-gradient(to left, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tleft: $edge;\n\t\tbottom: $edge;\n\t\tright: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n\n\t@if $direction == \"right\" {\n\t\tbackground: linear-gradient(to right, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tbottom: $edge;\n\t\tright: $edge;\n\t\tleft: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n}\n","@use \"@wordpress/base-styles/variables\";\n@use \"@wordpress/base-styles/mixins\";\n\n.boot-navigation-item.components-item {\n\tcolor: var(--wpds-color-fg-interactive-neutral, #1e1e1e);\n\tpadding-inline: variables.$grid-unit-05;\n\tpadding-block: 0;\n\tmargin-inline: variables.$grid-unit-15;\n\tmargin-block-end: variables.$grid-unit-05;\n\twidth: calc(100% - variables.$grid-unit-15 * 2);\n\tborder: none;\n\tmin-height: variables.$grid-unit-40;\n\tdisplay: flex;\n\talign-items: center;\n\t@include mixins.body-medium();\n\n\t.boot-dropdown-item__children & {\n\t\tmin-height: variables.$grid-unit-30;\n\t}\n\n\t// Rounded focus ring\n\tborder-radius: var(--wpds-border-radius-surface-sm, 2px);\n\n\t&.active,\n\t&:hover,\n\t&:focus,\n\t&[aria-current=\"true\"] {\n\t\tcolor: var(--wpds-color-fg-interactive-brand-active, #0073aa);\n\t}\n\n\t&.active {\n\t\tfont-weight: variables.$font-weight-medium;\n\t}\n\n\tsvg:last-child {\n\t\tpadding: variables.$grid-unit-05;\n\t}\n\n\t&[aria-current=\"true\"] {\n\t\tcolor: var(--wpds-color-fg-interactive-brand-active, #0073aa);\n\t\tfont-weight: variables.$font-weight-medium;\n\t}\n\n\t// Make sure the focus style is drawn on top of the current item background.\n\t&:focus-visible {\n\t\ttransform: translateZ(0);\n\t}\n\n\t&.with-suffix {\n\t\tpadding-right: variables.$grid-unit-20;\n\t}\n}\n"]} */`;
1009  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css4));
1010  function NavigationItem({
1011    className,
1012    icon,
1013    shouldShowPlaceholder = true,
1014    children,
1015    to
1016  }) {
1017    const isExternal = !String(
1018      new URL(to, window.location.origin)
1019    ).startsWith(window.location.origin);
1020    const content = /* @__PURE__ */ (0, import_jsx_runtime19.jsxs)(import_components6.__experimentalHStack, { justify: "flex-start", spacing: 2, style: { flexGrow: "1" }, children: [
1021      wrapIcon(icon, shouldShowPlaceholder),
1022      /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(import_components6.FlexBlock, { children })
1023    ] });
1024    if (isExternal) {
1025      return /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
1026        import_components6.__experimentalItem,
1027        {
1028          as: "a",
1029          href: to,
1030          className: clsx_default("boot-navigation-item", className),
1031          children: content
1032        }
1033      );
1034    }
1035    return /* @__PURE__ */ (0, import_jsx_runtime19.jsx)(
1036      router_link_item_default,
1037      {
1038        to,
1039        className: clsx_default("boot-navigation-item", className),
1040        children: content
1041      }
1042    );
1043  }
1044  
1045  // packages/boot/build-module/components/navigation/drilldown-item/index.js
1046  var import_components7 = __toESM(require_components());
1047  var import_i18n3 = __toESM(require_i18n());
1048  var import_jsx_runtime20 = __toESM(require_jsx_runtime());
1049  function DrilldownItem({
1050    className,
1051    id,
1052    icon,
1053    shouldShowPlaceholder = true,
1054    children,
1055    onNavigate
1056  }) {
1057    const handleClick = (e) => {
1058      e.preventDefault();
1059      onNavigate({ id, direction: "forward" });
1060    };
1061    return /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(
1062      import_components7.__experimentalItem,
1063      {
1064        className: clsx_default("boot-navigation-item", className),
1065        onClick: handleClick,
1066        children: /* @__PURE__ */ (0, import_jsx_runtime20.jsxs)(
1067          import_components7.__experimentalHStack,
1068          {
1069            justify: "flex-start",
1070            spacing: 2,
1071            style: { flexGrow: "1" },
1072            children: [
1073              wrapIcon(icon, shouldShowPlaceholder),
1074              /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(import_components7.FlexBlock, { children }),
1075              /* @__PURE__ */ (0, import_jsx_runtime20.jsx)(import_components7.Icon, { icon: (0, import_i18n3.isRTL)() ? chevron_left_small_default : chevron_right_small_default })
1076            ]
1077          }
1078        )
1079      }
1080    );
1081  }
1082  
1083  // packages/boot/build-module/components/navigation/dropdown-item/index.js
1084  var import_components8 = __toESM(require_components());
1085  var import_compose = __toESM(require_compose());
1086  var import_data4 = __toESM(require_data());
1087  var import_jsx_runtime21 = __toESM(require_jsx_runtime());
1088  var css5 = `/**
1089   * SCSS Variables.
1090   *
1091   * Please use variables from this sheet to ensure consistency across the UI.
1092   * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
1093   * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
1094   */
1095  /**
1096   * Colors
1097   */
1098  /**
1099   * Fonts & basic variables.
1100   */
1101  /**
1102   * Typography
1103   */
1104  /**
1105   * Grid System.
1106   * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
1107   */
1108  /**
1109   * Radius scale.
1110   */
1111  /**
1112   * Elevation scale.
1113   */
1114  /**
1115   * Dimensions.
1116   */
1117  /**
1118   * Mobile specific styles
1119   */
1120  /**
1121   * Editor styles.
1122   */
1123  /**
1124   * Block & Editor UI.
1125   */
1126  /**
1127   * Block paddings.
1128   */
1129  /**
1130   * React Native specific.
1131   * These variables do not appear to be used anywhere else.
1132   */
1133  .boot-dropdown-item__children {
1134    display: flex;
1135    flex-direction: column;
1136    padding: 2px;
1137    margin-block-start: -2px;
1138    margin-block-end: 2px;
1139    margin-inline-start: 30px;
1140    overflow: hidden;
1141  }
1142  
1143  .boot-dropdown-item__chevron.is-up {
1144    transform: rotate(180deg);
1145  }
1146  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/navigation/dropdown-item","sources":["../../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../../node_modules/@wordpress/base-styles/_colors.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEjKA;EACC;EACA;EAOA,SADsC;EAEtC;EACA,kBAHsC;EAItC,qBACC;EAED;;;AAGD;EACC","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n.boot-dropdown-item__children {\n\tdisplay: flex;\n\tflex-direction: column;\n\n\t// In order to avoid the focus ring of each list item from being cut off,\n\t// we add padding around the menu items.\n\t// At the same time, we use the same value to tweak margins so that\n\t// the items still retain the same position and footprint.\n\t$padding-to-avoid-cutting-focus-ring: 2px;\n\tpadding: $padding-to-avoid-cutting-focus-ring;\n\tmargin-block-start: -$padding-to-avoid-cutting-focus-ring;\n\tmargin-block-end: $padding-to-avoid-cutting-focus-ring;\n\tmargin-inline-start:\n\t\tvariables.$grid-unit-40 -\n\t\t$padding-to-avoid-cutting-focus-ring;\n\toverflow: hidden;\n}\n\n.boot-dropdown-item__chevron.is-up {\n\ttransform: rotate(180deg);\n}\n"]} */`;
1147  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css5));
1148  var ANIMATION_DURATION = 0.2;
1149  function DropdownItem({
1150    className,
1151    id,
1152    icon,
1153    children,
1154    isExpanded,
1155    onToggle
1156  }) {
1157    const menuItems = (0, import_data4.useSelect)(
1158      (select) => (
1159        // @ts-ignore
1160        select(STORE_NAME).getMenuItems()
1161      ),
1162      []
1163    );
1164    const items = menuItems.filter((item) => item.parent === id);
1165    const disableMotion = (0, import_compose.useReducedMotion)();
1166    return /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)("div", { className: "boot-dropdown-item", children: [
1167      /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(
1168        import_components8.__experimentalItem,
1169        {
1170          className: clsx_default("boot-navigation-item", className),
1171          onClick: (e) => {
1172            e.preventDefault();
1173            e.stopPropagation();
1174            onToggle();
1175          },
1176          onMouseDown: (e) => e.preventDefault(),
1177          children: /* @__PURE__ */ (0, import_jsx_runtime21.jsxs)(
1178            import_components8.__experimentalHStack,
1179            {
1180              justify: "flex-start",
1181              spacing: 2,
1182              style: { flexGrow: "1" },
1183              children: [
1184                wrapIcon(icon, false),
1185                /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(import_components8.FlexBlock, { children }),
1186                /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(
1187                  import_components8.Icon,
1188                  {
1189                    icon: chevron_down_small_default,
1190                    className: clsx_default("boot-dropdown-item__chevron", {
1191                      "is-up": isExpanded
1192                    })
1193                  }
1194                )
1195              ]
1196            }
1197          )
1198        }
1199      ),
1200      /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(import_components8.__unstableAnimatePresence, { initial: false, children: isExpanded && /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(
1201        import_components8.__unstableMotion.div,
1202        {
1203          initial: { height: 0 },
1204          animate: { height: "auto" },
1205          exit: { height: 0 },
1206          transition: {
1207            type: "tween",
1208            duration: disableMotion ? 0 : ANIMATION_DURATION,
1209            ease: "easeOut"
1210          },
1211          className: "boot-dropdown-item__children",
1212          children: items.map((item, index) => /* @__PURE__ */ (0, import_jsx_runtime21.jsx)(
1213            NavigationItem,
1214            {
1215              to: item.to,
1216              shouldShowPlaceholder: false,
1217              children: item.label
1218            },
1219            index
1220          ))
1221        }
1222      ) })
1223    ] });
1224  }
1225  
1226  // packages/boot/build-module/components/navigation/navigation-screen/index.js
1227  var import_components9 = __toESM(require_components());
1228  var import_i18n4 = __toESM(require_i18n());
1229  var import_compose2 = __toESM(require_compose());
1230  var import_jsx_runtime22 = __toESM(require_jsx_runtime());
1231  var css6 = `/**
1232   * SCSS Variables.
1233   *
1234   * Please use variables from this sheet to ensure consistency across the UI.
1235   * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
1236   * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
1237   */
1238  /**
1239   * Colors
1240   */
1241  /**
1242   * Fonts & basic variables.
1243   */
1244  /**
1245   * Typography
1246   */
1247  /**
1248   * Grid System.
1249   * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
1250   */
1251  /**
1252   * Radius scale.
1253   */
1254  /**
1255   * Elevation scale.
1256   */
1257  /**
1258   * Dimensions.
1259   */
1260  /**
1261   * Mobile specific styles
1262   */
1263  /**
1264   * Editor styles.
1265   */
1266  /**
1267   * Block & Editor UI.
1268   */
1269  /**
1270   * Block paddings.
1271   */
1272  /**
1273   * React Native specific.
1274   * These variables do not appear to be used anywhere else.
1275   */
1276  .boot-navigation-screen {
1277    padding-block-end: 4px;
1278  }
1279  
1280  .boot-navigation-screen .components-text {
1281    color: var(--wpds-color-fg-content-neutral, #1e1e1e);
1282  }
1283  
1284  .boot-navigation-screen__title-icon {
1285    position: sticky;
1286    top: 0;
1287    padding: 12px 16px 8px 16px;
1288  }
1289  
1290  .boot-navigation-screen__title {
1291    flex-grow: 1;
1292    overflow-wrap: break-word;
1293  }
1294  .boot-navigation-screen__title.boot-navigation-screen__title, .boot-navigation-screen__title.boot-navigation-screen__title .boot-navigation-screen__title {
1295    line-height: 32px;
1296    color: var(--wpds-color-fg-content-neutral, #1e1e1e);
1297  }
1298  
1299  .boot-navigation-screen__actions {
1300    display: flex;
1301    flex-shrink: 0;
1302  }
1303  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/navigation/navigation-screen","sources":["../../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../../node_modules/@wordpress/base-styles/_colors.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEjKA;EAEC,mBFgDc;;;AE7Cf;EACC;;;AAGD;EACC;EACA;EACA,SACC;;;AAIF;EACC;EACA;;AAEA;EAEC,aFSyB;EERzB;;;AAIF;EACC;EACA","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n.boot-navigation-screen {\n\t// Avoid cutting off focus ring of the last menu item\n\tpadding-block-end: variables.$grid-unit-05;\n}\n\n.boot-navigation-screen .components-text {\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n}\n\n.boot-navigation-screen__title-icon {\n\tposition: sticky;\n\ttop: 0;\n\tpadding:\n\t\tvariables.$grid-unit-15 variables.$grid-unit-20\n\t\tvariables.$grid-unit-10 variables.$grid-unit-20;\n}\n\n.boot-navigation-screen__title {\n\tflex-grow: 1;\n\toverflow-wrap: break-word;\n\n\t&#{&},\n\t&#{&} .boot-navigation-screen__title {\n\t\tline-height: variables.$font-line-height-x-large;\n\t\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\t}\n}\n\n.boot-navigation-screen__actions {\n\tdisplay: flex;\n\tflex-shrink: 0;\n}\n"]} */`;
1304  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css6));
1305  var ANIMATION_DURATION2 = 0.3;
1306  var slideVariants = {
1307    initial: (direction) => ({
1308      x: direction === "forward" ? 100 : -100,
1309      opacity: 0
1310    }),
1311    animate: {
1312      x: 0,
1313      opacity: 1
1314    },
1315    exit: (direction) => ({
1316      x: direction === "forward" ? 100 : -100,
1317      opacity: 0
1318    })
1319  };
1320  function NavigationScreen({
1321    isRoot,
1322    title,
1323    actions,
1324    content,
1325    description,
1326    animationDirection,
1327    backMenuItem,
1328    backButtonRef,
1329    navigationKey,
1330    onNavigate
1331  }) {
1332    const icon = (0, import_i18n4.isRTL)() ? chevron_right_default : chevron_left_default;
1333    const disableMotion = (0, import_compose2.useReducedMotion)();
1334    const handleBackClick = (e) => {
1335      e.preventDefault();
1336      onNavigate({ id: backMenuItem, direction: "backward" });
1337    };
1338    return /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(
1339      "div",
1340      {
1341        className: "boot-navigation-screen",
1342        style: {
1343          overflow: "hidden",
1344          position: "relative",
1345          display: "grid",
1346          gridTemplateColumns: "1fr",
1347          gridTemplateRows: "1fr"
1348        },
1349        children: /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(import_components9.__unstableAnimatePresence, { initial: false, children: /* @__PURE__ */ (0, import_jsx_runtime22.jsxs)(
1350          import_components9.__unstableMotion.div,
1351          {
1352            custom: animationDirection,
1353            variants: slideVariants,
1354            initial: "initial",
1355            animate: "animate",
1356            exit: "exit",
1357            transition: {
1358              type: "tween",
1359              duration: disableMotion ? 0 : ANIMATION_DURATION2,
1360              ease: [0.33, 0, 0, 1]
1361            },
1362            style: {
1363              width: "100%",
1364              gridColumn: "1",
1365              gridRow: "1"
1366            },
1367            children: [
1368              /* @__PURE__ */ (0, import_jsx_runtime22.jsxs)(
1369                import_components9.__experimentalHStack,
1370                {
1371                  spacing: 2,
1372                  className: "boot-navigation-screen__title-icon",
1373                  children: [
1374                    !isRoot && /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(
1375                      import_components9.Button,
1376                      {
1377                        ref: backButtonRef,
1378                        icon,
1379                        onClick: handleBackClick,
1380                        label: (0, import_i18n4.__)("Back"),
1381                        size: "small",
1382                        variant: "tertiary"
1383                      }
1384                    ),
1385                    /* @__PURE__ */ (0, import_jsx_runtime22.jsx)(
1386                      import_components9.__experimentalHeading,
1387                      {
1388                        className: "boot-navigation-screen__title",
1389                        level: 1,
1390                        size: "15px",
1391                        children: title
1392                      }
1393                    ),
1394                    actions && /* @__PURE__ */ (0, import_jsx_runtime22.jsx)("div", { className: "boot-navigation-screen__actions", children: actions })
1395                  ]
1396                }
1397              ),
1398              description && /* @__PURE__ */ (0, import_jsx_runtime22.jsx)("div", { className: "boot-navigation-screen__description", children: description }),
1399              content
1400            ]
1401          },
1402          navigationKey
1403        ) })
1404      }
1405    );
1406  }
1407  
1408  // packages/boot/build-module/components/navigation/use-sidebar-parent.js
1409  var import_element5 = __toESM(require_element());
1410  var import_data5 = __toESM(require_data());
1411  import { privateApis as routePrivateApis3 } from "@wordpress/route";
1412  
1413  // packages/boot/build-module/components/navigation/path-matching.js
1414  var isValidParentPath = (currentPath, menuPath) => {
1415    if (!menuPath || menuPath === currentPath) {
1416      return false;
1417    }
1418    const normalizePath = (path) => {
1419      const normalized = path.startsWith("/") ? path : "/" + path;
1420      return normalized.endsWith("/") && normalized.length > 1 ? normalized.slice(0, -1) : normalized;
1421    };
1422    const normalizedCurrent = normalizePath(currentPath);
1423    const normalizedMenu = normalizePath(menuPath);
1424    return normalizedCurrent.startsWith(normalizedMenu) && (normalizedCurrent[normalizedMenu.length] === "/" || normalizedMenu === "/");
1425  };
1426  var findClosestMenuItem = (currentPath, menuItems) => {
1427    const exactMatch = menuItems.find((item) => item.to === currentPath);
1428    if (exactMatch) {
1429      return exactMatch;
1430    }
1431    let bestMatch = null;
1432    let bestPathLength = 0;
1433    for (const item of menuItems) {
1434      if (!item.to) {
1435        continue;
1436      }
1437      if (isValidParentPath(currentPath, item.to)) {
1438        if (item.to.length > bestPathLength) {
1439          bestMatch = item;
1440          bestPathLength = item.to.length;
1441        }
1442      }
1443    }
1444    return bestMatch;
1445  };
1446  var findDrilldownParent = (id, menuItems) => {
1447    if (!id) {
1448      return void 0;
1449    }
1450    const currentItem = menuItems.find((item) => item.id === id);
1451    if (!currentItem) {
1452      return void 0;
1453    }
1454    if (currentItem.parent) {
1455      const parentItem = menuItems.find(
1456        (item) => item.id === currentItem.parent
1457      );
1458      if (parentItem?.parent_type === "drilldown") {
1459        return parentItem.id;
1460      }
1461      if (parentItem) {
1462        return findDrilldownParent(parentItem.id, menuItems);
1463      }
1464    }
1465    return void 0;
1466  };
1467  var findDropdownParent = (id, menuItems) => {
1468    if (!id) {
1469      return void 0;
1470    }
1471    const currentItem = menuItems.find((item) => item.id === id);
1472    if (!currentItem) {
1473      return void 0;
1474    }
1475    if (currentItem.parent) {
1476      const parentItem = menuItems.find(
1477        (item) => item.id === currentItem.parent
1478      );
1479      if (parentItem?.parent_type === "dropdown") {
1480        return parentItem.id;
1481      }
1482    }
1483    return void 0;
1484  };
1485  
1486  // packages/boot/build-module/components/navigation/use-sidebar-parent.js
1487  var { useRouter: useRouter2, useMatches } = unlock(routePrivateApis3);
1488  function useSidebarParent() {
1489    const matches = useMatches();
1490    const router = useRouter2();
1491    const menuItems = (0, import_data5.useSelect)(
1492      (select) => (
1493        // @ts-ignore
1494        select(STORE_NAME).getMenuItems()
1495      ),
1496      []
1497    );
1498    const currentPath = matches[matches.length - 1].pathname.slice(
1499      router.options.basepath?.length ?? 0
1500    );
1501    const currentMenuItem = findClosestMenuItem(currentPath, menuItems);
1502    const [parentId, setParentId] = (0, import_element5.useState)(
1503      findDrilldownParent(currentMenuItem?.id, menuItems)
1504    );
1505    const [parentDropdownId, setParentDropdownId] = (0, import_element5.useState)(findDropdownParent(currentMenuItem?.id, menuItems));
1506    (0, import_element5.useEffect)(() => {
1507      const matchedMenuItem = findClosestMenuItem(currentPath, menuItems);
1508      const updatedParentId = findDrilldownParent(
1509        matchedMenuItem?.id,
1510        menuItems
1511      );
1512      const updatedDropdownParent = findDropdownParent(
1513        matchedMenuItem?.id,
1514        menuItems
1515      );
1516      setParentId(updatedParentId);
1517      setParentDropdownId(updatedDropdownParent);
1518    }, [currentPath, menuItems]);
1519    return [
1520      parentId,
1521      setParentId,
1522      parentDropdownId,
1523      setParentDropdownId
1524    ];
1525  }
1526  
1527  // packages/boot/build-module/components/navigation/index.js
1528  var import_jsx_runtime23 = __toESM(require_jsx_runtime());
1529  function Navigation() {
1530    const backButtonRef = (0, import_element6.useRef)(null);
1531    const [animationDirection, setAnimationDirection] = (0, import_element6.useState)(null);
1532    const [parentId, setParentId, parentDropdownId, setParentDropdownId] = useSidebarParent();
1533    const menuItems = (0, import_data6.useSelect)(
1534      (select) => (
1535        // @ts-ignore
1536        select(STORE_NAME).getMenuItems()
1537      ),
1538      []
1539    );
1540    const parent = (0, import_element6.useMemo)(
1541      () => menuItems.find((item) => item.id === parentId),
1542      [menuItems, parentId]
1543    );
1544    const navigationKey = parent ? `drilldown-$parent.id}` : "root";
1545    const handleNavigate = ({
1546      id,
1547      direction
1548    }) => {
1549      setAnimationDirection(direction);
1550      setParentId(id);
1551    };
1552    const handleDropdownToggle = (dropdownId) => {
1553      setParentDropdownId(
1554        parentDropdownId === dropdownId ? void 0 : dropdownId
1555      );
1556    };
1557    const items = (0, import_element6.useMemo)(
1558      () => menuItems.filter((item) => item.parent === parentId),
1559      [menuItems, parentId]
1560    );
1561    const hasRealIcons = items.some((item) => !!item.icon);
1562    return /* @__PURE__ */ (0, import_jsx_runtime23.jsx)(
1563      NavigationScreen,
1564      {
1565        isRoot: !parent,
1566        title: parent ? parent.label : "",
1567        backMenuItem: parent?.parent,
1568        backButtonRef,
1569        animationDirection: animationDirection || void 0,
1570        navigationKey,
1571        onNavigate: handleNavigate,
1572        content: /* @__PURE__ */ (0, import_jsx_runtime23.jsx)(import_jsx_runtime23.Fragment, { children: items.map((item) => {
1573          if (item.parent_type === "dropdown") {
1574            return /* @__PURE__ */ (0, import_jsx_runtime23.jsx)(
1575              DropdownItem,
1576              {
1577                id: item.id,
1578                className: "boot-navigation-item",
1579                icon: item.icon,
1580                shouldShowPlaceholder: hasRealIcons,
1581                isExpanded: parentDropdownId === item.id,
1582                onToggle: () => handleDropdownToggle(item.id),
1583                children: item.label
1584              },
1585              item.id
1586            );
1587          }
1588          if (item.parent_type === "drilldown") {
1589            return /* @__PURE__ */ (0, import_jsx_runtime23.jsx)(
1590              DrilldownItem,
1591              {
1592                id: item.id,
1593                icon: item.icon,
1594                shouldShowPlaceholder: hasRealIcons,
1595                onNavigate: handleNavigate,
1596                children: item.label
1597              },
1598              item.id
1599            );
1600          }
1601          return /* @__PURE__ */ (0, import_jsx_runtime23.jsx)(
1602            NavigationItem,
1603            {
1604              to: item.to,
1605              icon: item.icon,
1606              shouldShowPlaceholder: hasRealIcons,
1607              children: item.label
1608            },
1609            item.id
1610          );
1611        }) })
1612      }
1613    );
1614  }
1615  var navigation_default = Navigation;
1616  
1617  // packages/boot/build-module/components/save-button/index.js
1618  var import_element8 = __toESM(require_element());
1619  var import_data8 = __toESM(require_data());
1620  var import_i18n6 = __toESM(require_i18n());
1621  var import_core_data4 = __toESM(require_core_data());
1622  var import_keycodes2 = __toESM(require_keycodes());
1623  var import_editor2 = __toESM(require_editor());
1624  var import_components10 = __toESM(require_components());
1625  
1626  // packages/boot/build-module/components/save-panel/use-save-shortcut.js
1627  var import_element7 = __toESM(require_element());
1628  var import_keyboard_shortcuts = __toESM(require_keyboard_shortcuts());
1629  var import_i18n5 = __toESM(require_i18n());
1630  var import_data7 = __toESM(require_data());
1631  var import_core_data3 = __toESM(require_core_data());
1632  var import_editor = __toESM(require_editor());
1633  var shortcutName = "core/boot/save";
1634  function useSaveShortcut({
1635    openSavePanel
1636  }) {
1637    const { __experimentalGetDirtyEntityRecords, isSavingEntityRecord } = (0, import_data7.useSelect)(import_core_data3.store);
1638    const { hasNonPostEntityChanges, isPostSavingLocked } = (0, import_data7.useSelect)(import_editor.store);
1639    const { savePost } = (0, import_data7.useDispatch)(import_editor.store);
1640    const { registerShortcut, unregisterShortcut } = (0, import_data7.useDispatch)(
1641      import_keyboard_shortcuts.store
1642    );
1643    (0, import_element7.useEffect)(() => {
1644      registerShortcut({
1645        name: shortcutName,
1646        category: "global",
1647        description: (0, import_i18n5.__)("Save your changes."),
1648        keyCombination: {
1649          modifier: "primary",
1650          character: "s"
1651        }
1652      });
1653      return () => {
1654        unregisterShortcut(shortcutName);
1655      };
1656    }, [registerShortcut, unregisterShortcut]);
1657    (0, import_keyboard_shortcuts.useShortcut)(shortcutName, (event) => {
1658      event.preventDefault();
1659      const dirtyEntityRecords = __experimentalGetDirtyEntityRecords();
1660      const hasDirtyEntities = !!dirtyEntityRecords.length;
1661      const isSaving = dirtyEntityRecords.some(
1662        (record) => isSavingEntityRecord(record.kind, record.name, record.key)
1663      );
1664      if (!hasDirtyEntities || isSaving) {
1665        return;
1666      }
1667      if (hasNonPostEntityChanges()) {
1668        openSavePanel();
1669      } else if (!isPostSavingLocked()) {
1670        savePost();
1671      }
1672    });
1673  }
1674  
1675  // packages/boot/build-module/components/save-button/index.js
1676  var import_jsx_runtime24 = __toESM(require_jsx_runtime());
1677  var css7 = `.boot-save-button {
1678    width: 100%;
1679  }
1680  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VSb290IjoiL2hvbWUvc3ZuL2NoZWNrb3V0cy9kZXZlbG9wLnN2bi53b3JkcHJlc3Mub3JnL3RydW5rL2d1dGVuYmVyZy9wYWNrYWdlcy9ib290L3NyYy9jb21wb25lbnRzL3NhdmUtYnV0dG9uIiwic291cmNlcyI6WyJzdHlsZS5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0VBQ0MiLCJzb3VyY2VzQ29udGVudCI6WyIuYm9vdC1zYXZlLWJ1dHRvbiB7XG5cdHdpZHRoOiAxMDAlO1xufVxuIl19 */`;
1681  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css7));
1682  function SaveButton() {
1683    const [isSaveViewOpen, setIsSaveViewOpened] = (0, import_element8.useState)(false);
1684    const { isSaving, dirtyEntityRecordsCount } = (0, import_data8.useSelect)((select) => {
1685      const { isSavingEntityRecord, __experimentalGetDirtyEntityRecords } = select(import_core_data4.store);
1686      const dirtyEntityRecords = __experimentalGetDirtyEntityRecords();
1687      return {
1688        isSaving: dirtyEntityRecords.some(
1689          (record) => isSavingEntityRecord(record.kind, record.name, record.key)
1690        ),
1691        dirtyEntityRecordsCount: dirtyEntityRecords.length
1692      };
1693    }, []);
1694    const [showSavedState, setShowSavedState] = (0, import_element8.useState)(false);
1695    (0, import_element8.useEffect)(() => {
1696      if (isSaving) {
1697        setShowSavedState(true);
1698      }
1699    }, [isSaving]);
1700    const hasChanges = dirtyEntityRecordsCount > 0;
1701    (0, import_element8.useEffect)(() => {
1702      if (!isSaving && hasChanges) {
1703        setShowSavedState(false);
1704      }
1705    }, [isSaving, hasChanges]);
1706    function hideSavedState() {
1707      if (showSavedState) {
1708        setShowSavedState(false);
1709      }
1710    }
1711    const shouldShowButton = hasChanges || showSavedState;
1712    useSaveShortcut({ openSavePanel: () => setIsSaveViewOpened(true) });
1713    if (!shouldShowButton) {
1714      return null;
1715    }
1716    const isInSavedState = showSavedState && !hasChanges;
1717    const disabled = isSaving || isInSavedState;
1718    const getLabel = () => {
1719      if (isInSavedState) {
1720        return (0, import_i18n6.__)("Saved");
1721      }
1722      return (0, import_i18n6.sprintf)(
1723        // translators: %d: number of unsaved changes (number).
1724        (0, import_i18n6._n)(
1725          "Review %d change\u2026",
1726          "Review %d changes\u2026",
1727          dirtyEntityRecordsCount
1728        ),
1729        dirtyEntityRecordsCount
1730      );
1731    };
1732    const label = getLabel();
1733    return /* @__PURE__ */ (0, import_jsx_runtime24.jsxs)(import_jsx_runtime24.Fragment, { children: [
1734      /* @__PURE__ */ (0, import_jsx_runtime24.jsx)(
1735        import_components10.Tooltip,
1736        {
1737          text: hasChanges ? label : void 0,
1738          shortcut: import_keycodes2.displayShortcut.primary("s"),
1739          children: /* @__PURE__ */ (0, import_jsx_runtime24.jsx)(
1740            import_components10.Button,
1741            {
1742              variant: "primary",
1743              size: "compact",
1744              onClick: () => setIsSaveViewOpened(true),
1745              onBlur: hideSavedState,
1746              disabled,
1747              accessibleWhenDisabled: true,
1748              isBusy: isSaving,
1749              "aria-keyshortcuts": import_keycodes2.rawShortcut.primary("s"),
1750              className: "boot-save-button",
1751              icon: isInSavedState ? check_default : void 0,
1752              children: label
1753            }
1754          )
1755        }
1756      ),
1757      isSaveViewOpen && /* @__PURE__ */ (0, import_jsx_runtime24.jsx)(
1758        import_components10.Modal,
1759        {
1760          title: (0, import_i18n6.__)("Review changes"),
1761          onRequestClose: () => setIsSaveViewOpened(false),
1762          size: "small",
1763          children: /* @__PURE__ */ (0, import_jsx_runtime24.jsx)(
1764            import_editor2.EntitiesSavedStates,
1765            {
1766              close: () => setIsSaveViewOpened(false),
1767              variant: "inline"
1768            }
1769          )
1770        }
1771      )
1772    ] });
1773  }
1774  
1775  // packages/boot/build-module/components/sidebar/index.js
1776  var import_jsx_runtime25 = __toESM(require_jsx_runtime());
1777  var css8 = `/**
1778   * SCSS Variables.
1779   *
1780   * Please use variables from this sheet to ensure consistency across the UI.
1781   * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
1782   * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
1783   */
1784  /**
1785   * Colors
1786   */
1787  /**
1788   * Fonts & basic variables.
1789   */
1790  /**
1791   * Typography
1792   */
1793  /**
1794   * Grid System.
1795   * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
1796   */
1797  /**
1798   * Radius scale.
1799   */
1800  /**
1801   * Elevation scale.
1802   */
1803  /**
1804   * Dimensions.
1805   */
1806  /**
1807   * Mobile specific styles
1808   */
1809  /**
1810   * Editor styles.
1811   */
1812  /**
1813   * Block & Editor UI.
1814   */
1815  /**
1816   * Block paddings.
1817   */
1818  /**
1819   * React Native specific.
1820   * These variables do not appear to be used anywhere else.
1821   */
1822  .boot-sidebar__scrollable {
1823    overflow: auto;
1824    height: 100%;
1825    position: relative;
1826    display: flex;
1827    flex-direction: column;
1828  }
1829  
1830  .boot-sidebar__content {
1831    flex-grow: 1;
1832    contain: content;
1833    position: relative;
1834  }
1835  
1836  .boot-sidebar__footer {
1837    padding: 16px 8px 8px 16px;
1838  }
1839  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/sidebar","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEjKA;EACC;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;;;AAGD;EACC","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n.boot-sidebar__scrollable {\n\toverflow: auto;\n\theight: 100%;\n\tposition: relative;\n\tdisplay: flex;\n\tflex-direction: column;\n}\n\n.boot-sidebar__content {\n\tflex-grow: 1;\n\tcontain: content;\n\tposition: relative;\n}\n\n.boot-sidebar__footer {\n\tpadding: variables.$grid-unit-20 variables.$grid-unit-10 variables.$grid-unit-10 variables.$grid-unit-20;\n}\n"]} */`;
1840  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css8));
1841  function Sidebar() {
1842    return /* @__PURE__ */ (0, import_jsx_runtime25.jsxs)("div", { className: "boot-sidebar__scrollable", children: [
1843      /* @__PURE__ */ (0, import_jsx_runtime25.jsx)(site_hub_default, {}),
1844      /* @__PURE__ */ (0, import_jsx_runtime25.jsx)("div", { className: "boot-sidebar__content", children: /* @__PURE__ */ (0, import_jsx_runtime25.jsx)(navigation_default, {}) }),
1845      /* @__PURE__ */ (0, import_jsx_runtime25.jsx)("div", { className: "boot-sidebar__footer", children: /* @__PURE__ */ (0, import_jsx_runtime25.jsx)(SaveButton, {}) })
1846    ] });
1847  }
1848  
1849  // packages/boot/build-module/components/save-panel/index.js
1850  var import_element9 = __toESM(require_element());
1851  var import_components11 = __toESM(require_components());
1852  var import_editor3 = __toESM(require_editor());
1853  var import_i18n7 = __toESM(require_i18n());
1854  var import_jsx_runtime26 = __toESM(require_jsx_runtime());
1855  function SavePanel() {
1856    const [isOpen, setIsOpen] = (0, import_element9.useState)(false);
1857    useSaveShortcut({
1858      openSavePanel: () => setIsOpen(true)
1859    });
1860    if (!isOpen) {
1861      return false;
1862    }
1863    return /* @__PURE__ */ (0, import_jsx_runtime26.jsx)(
1864      import_components11.Modal,
1865      {
1866        className: "edit-site-save-panel__modal",
1867        onRequestClose: () => setIsOpen(false),
1868        title: (0, import_i18n7.__)("Review changes"),
1869        size: "small",
1870        children: /* @__PURE__ */ (0, import_jsx_runtime26.jsx)(
1871          import_editor3.EntitiesSavedStates,
1872          {
1873            close: () => setIsOpen(false),
1874            variant: "inline"
1875          }
1876        )
1877      }
1878    );
1879  }
1880  
1881  // packages/boot/build-module/components/canvas-renderer/index.js
1882  var import_element11 = __toESM(require_element());
1883  
1884  // packages/boot/build-module/components/canvas/index.js
1885  var import_element10 = __toESM(require_element());
1886  var import_components13 = __toESM(require_components());
1887  import { useNavigate } from "@wordpress/route";
1888  
1889  // packages/boot/build-module/components/canvas/back-button.js
1890  var import_components12 = __toESM(require_components());
1891  var import_compose3 = __toESM(require_compose());
1892  var import_i18n8 = __toESM(require_i18n());
1893  var import_jsx_runtime27 = __toESM(require_jsx_runtime());
1894  var css9 = `/**
1895   * SCSS Variables.
1896   *
1897   * Please use variables from this sheet to ensure consistency across the UI.
1898   * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
1899   * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
1900   */
1901  /**
1902   * Colors
1903   */
1904  /**
1905   * Fonts & basic variables.
1906   */
1907  /**
1908   * Typography
1909   */
1910  /**
1911   * Grid System.
1912   * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
1913   */
1914  /**
1915   * Radius scale.
1916   */
1917  /**
1918   * Elevation scale.
1919   */
1920  /**
1921   * Dimensions.
1922   */
1923  /**
1924   * Mobile specific styles
1925   */
1926  /**
1927   * Editor styles.
1928   */
1929  /**
1930   * Block & Editor UI.
1931   */
1932  /**
1933   * Block paddings.
1934   */
1935  /**
1936   * React Native specific.
1937   * These variables do not appear to be used anywhere else.
1938   */
1939  .boot-canvas-back-button {
1940    position: absolute;
1941    top: 0;
1942    left: 0;
1943    height: 64px;
1944    width: 64px;
1945    z-index: 100;
1946  }
1947  
1948  .boot-canvas-back-button__container {
1949    position: relative;
1950    width: 100%;
1951    height: 100%;
1952  }
1953  
1954  .boot-canvas-back-button__link.components-button {
1955    width: 64px;
1956    height: 64px;
1957    display: inline-flex;
1958    align-items: center;
1959    justify-content: center;
1960    background: var(--wpds-color-bg-surface-neutral-weak);
1961    text-decoration: none;
1962    padding: 0;
1963    border-radius: 0;
1964  }
1965  @media not (prefers-reduced-motion) {
1966    .boot-canvas-back-button__link.components-button {
1967      transition: outline 0.1s ease-out;
1968    }
1969  }
1970  .boot-canvas-back-button__link.components-button:focus:not(:active) {
1971    outline: var(--wpds-border-width-interactive-focus) solid var(--wpds-color-stroke-focus-brand);
1972    outline-offset: calc(-1 * var(--wpds-border-width-interactive-focus));
1973  }
1974  
1975  .boot-canvas-back-button__icon {
1976    position: absolute;
1977    top: 0;
1978    left: 0;
1979    width: 64px;
1980    height: 64px;
1981    display: flex;
1982    align-items: center;
1983    justify-content: center;
1984    background-color: hsl(0, 0%, 80%);
1985    pointer-events: none;
1986  }
1987  .boot-canvas-back-button__icon svg {
1988    fill: currentColor;
1989  }
1990  .boot-canvas-back-button__icon.has-site-icon {
1991    background-color: hsla(0, 0%, 100%, 0.6);
1992    -webkit-backdrop-filter: saturate(180%) blur(15px);
1993    backdrop-filter: saturate(180%) blur(15px);
1994  }
1995  
1996  .interface-interface-skeleton__header {
1997    margin-top: 0 !important;
1998  }
1999  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/canvas","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","back-button.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEjKA;EACC;EACA;EACA;EACA,QF6Fe;EE5Ff,OF4Fe;EE3Ff;;;AAGD;EACC;EACA;EACA;;;AAGD;EACC,OFiFe;EEhFf,QFgFe;EE/Ef;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EAXD;IAYE;;;AAGD;EACC,SACC;EAED;;;AAIF;EACC;EACA;EACA;EACA,OFuDe;EEtDf,QFsDe;EErDf;EACA;EACA;EACA;EACA;;AAEA;EACC;;AAGD;EACC;EACA;EACA;;;AAKF;EACC","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/variables\";\n\n.boot-canvas-back-button {\n\tposition: absolute;\n\ttop: 0;\n\tleft: 0;\n\theight: variables.$header-height;\n\twidth: variables.$header-height;\n\tz-index: 100;\n}\n\n.boot-canvas-back-button__container {\n\tposition: relative;\n\twidth: 100%;\n\theight: 100%;\n}\n\n.boot-canvas-back-button__link.components-button {\n\twidth: variables.$header-height;\n\theight: variables.$header-height;\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\tbackground: var(--wpds-color-bg-surface-neutral-weak);\n\ttext-decoration: none;\n\tpadding: 0;\n\tborder-radius: 0;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: outline 0.1s ease-out;\n\t}\n\n\t&:focus:not(:active) {\n\t\toutline:\n\t\t\tvar(--wpds-border-width-interactive-focus) solid\n\t\t\tvar(--wpds-color-stroke-focus-brand);\n\t\toutline-offset: calc(-1 * var(--wpds-border-width-interactive-focus));\n\t}\n}\n\n.boot-canvas-back-button__icon {\n\tposition: absolute;\n\ttop: 0;\n\tleft: 0;\n\twidth: variables.$header-height;\n\theight: variables.$header-height;\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n\tbackground-color: hsla(0, 0%, 80%);\n\tpointer-events: none;\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n\n\t&.has-site-icon {\n\t\tbackground-color: hsla(0, 0%, 100%, 0.6);\n\t\t-webkit-backdrop-filter: saturate(180%) blur(15px);\n\t\tbackdrop-filter: saturate(180%) blur(15px);\n\t}\n}\n\n// Remove the header slide-in animation so the back logo does not move.\n.interface-interface-skeleton__header {\n\tmargin-top: 0 !important;\n}\n"]} */`;
2000  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css9));
2001  var toggleHomeIconVariants = {
2002    edit: {
2003      opacity: 0,
2004      scale: 0.2
2005    },
2006    hover: {
2007      opacity: 1,
2008      scale: 1,
2009      clipPath: "inset( 22% round 2px )"
2010    }
2011  };
2012  function BootBackButton({ length }) {
2013    const disableMotion = (0, import_compose3.useReducedMotion)();
2014    const handleBack = () => {
2015      window.history.back();
2016    };
2017    if (length > 1) {
2018      return null;
2019    }
2020    const transition = {
2021      duration: disableMotion ? 0 : 0.3
2022    };
2023    return /* @__PURE__ */ (0, import_jsx_runtime27.jsxs)(
2024      import_components12.__unstableMotion.div,
2025      {
2026        className: "boot-canvas-back-button",
2027        animate: "edit",
2028        initial: "edit",
2029        whileHover: "hover",
2030        whileTap: "tap",
2031        transition,
2032        children: [
2033          /* @__PURE__ */ (0, import_jsx_runtime27.jsx)(
2034            import_components12.Button,
2035            {
2036              className: "boot-canvas-back-button__link",
2037              onClick: handleBack,
2038              "aria-label": (0, import_i18n8.__)("Go back"),
2039              __next40pxDefaultSize: true,
2040              children: /* @__PURE__ */ (0, import_jsx_runtime27.jsx)(site_icon_default, {})
2041            }
2042          ),
2043          /* @__PURE__ */ (0, import_jsx_runtime27.jsx)(
2044            import_components12.__unstableMotion.div,
2045            {
2046              className: "boot-canvas-back-button__icon",
2047              variants: toggleHomeIconVariants,
2048              children: /* @__PURE__ */ (0, import_jsx_runtime27.jsx)(import_components12.Icon, { icon: arrow_up_left_default })
2049            }
2050          )
2051        ]
2052      }
2053    );
2054  }
2055  
2056  // packages/boot/build-module/components/canvas/index.js
2057  var import_jsx_runtime28 = __toESM(require_jsx_runtime());
2058  function Canvas({ canvas }) {
2059    const [Editor, setEditor] = (0, import_element10.useState)(null);
2060    const navigate = useNavigate();
2061    (0, import_element10.useEffect)(() => {
2062      import("@wordpress/lazy-editor").then((module) => {
2063        setEditor(() => module.Editor);
2064      }).catch((error) => {
2065        console.error("Failed to load lazy editor:", error);
2066      });
2067    }, []);
2068    if (!Editor) {
2069      return /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(
2070        "div",
2071        {
2072          style: {
2073            display: "flex",
2074            justifyContent: "center",
2075            alignItems: "center",
2076            height: "100%",
2077            padding: "2rem"
2078          },
2079          children: /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(import_components13.Spinner, {})
2080        }
2081      );
2082    }
2083    const backButton = !canvas.isPreview ? ({ length }) => /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(BootBackButton, { length }) : void 0;
2084    return /* @__PURE__ */ (0, import_jsx_runtime28.jsxs)("div", { style: { height: "100%", position: "relative" }, children: [
2085      /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(
2086        "div",
2087        {
2088          style: { height: "100%" },
2089          inert: canvas.isPreview ? "true" : void 0,
2090          children: /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(
2091            Editor,
2092            {
2093              postType: canvas.postType,
2094              postId: canvas.postId,
2095              settings: { isPreviewMode: canvas.isPreview },
2096              backButton
2097            }
2098          )
2099        }
2100      ),
2101      canvas.isPreview && canvas.editLink && /* @__PURE__ */ (0, import_jsx_runtime28.jsx)(
2102        "div",
2103        {
2104          onClick: () => navigate({ to: canvas.editLink }),
2105          onKeyDown: (e) => {
2106            if (e.key === "Enter" || e.key === " ") {
2107              e.preventDefault();
2108              navigate({ to: canvas.editLink });
2109            }
2110          },
2111          style: {
2112            position: "absolute",
2113            inset: 0,
2114            cursor: "pointer",
2115            zIndex: 1
2116          },
2117          role: "button",
2118          tabIndex: 0,
2119          "aria-label": "Click to edit"
2120        }
2121      )
2122    ] });
2123  }
2124  
2125  // packages/boot/build-module/components/canvas-renderer/index.js
2126  var import_jsx_runtime29 = __toESM(require_jsx_runtime());
2127  function CanvasRenderer({
2128    canvas,
2129    routeContentModule
2130  }) {
2131    const [CustomCanvas, setCustomCanvas] = (0, import_element11.useState)(null);
2132    (0, import_element11.useEffect)(() => {
2133      if (canvas === null && routeContentModule) {
2134        import(routeContentModule).then((module) => {
2135          setCustomCanvas(() => module.canvas);
2136        }).catch((error) => {
2137          console.error("Failed to load custom canvas:", error);
2138        });
2139      } else {
2140        setCustomCanvas(null);
2141      }
2142    }, [canvas, routeContentModule]);
2143    if (canvas === void 0) {
2144      return null;
2145    }
2146    if (canvas === null) {
2147      if (!CustomCanvas) {
2148        return null;
2149      }
2150      return /* @__PURE__ */ (0, import_jsx_runtime29.jsx)(CustomCanvas, {});
2151    }
2152    return /* @__PURE__ */ (0, import_jsx_runtime29.jsx)(Canvas, { canvas });
2153  }
2154  
2155  // packages/boot/build-module/components/app/use-route-title.js
2156  var import_element12 = __toESM(require_element());
2157  var import_data9 = __toESM(require_data());
2158  var import_core_data5 = __toESM(require_core_data());
2159  var import_i18n9 = __toESM(require_i18n());
2160  var import_html_entities2 = __toESM(require_html_entities());
2161  import { speak } from "@wordpress/a11y";
2162  import { privateApis as routePrivateApis4 } from "@wordpress/route";
2163  var { useLocation, useMatches: useMatches2 } = unlock(routePrivateApis4);
2164  function useRouteTitle() {
2165    const location = useLocation();
2166    const matches = useMatches2();
2167    const currentMatch = matches[matches.length - 1];
2168    const routeTitle = currentMatch?.loaderData?.title;
2169    const siteTitle = (0, import_data9.useSelect)(
2170      (select) => select(import_core_data5.store).getEntityRecord(
2171        "root",
2172        "__unstableBase"
2173      )?.name,
2174      []
2175    );
2176    const isInitialLocationRef = (0, import_element12.useRef)(true);
2177    (0, import_element12.useEffect)(() => {
2178      isInitialLocationRef.current = false;
2179    }, [location]);
2180    (0, import_element12.useEffect)(() => {
2181      if (isInitialLocationRef.current) {
2182        return;
2183      }
2184      if (routeTitle && typeof routeTitle === "string" && siteTitle && typeof siteTitle === "string") {
2185        const decodedRouteTitle = (0, import_html_entities2.decodeEntities)(routeTitle);
2186        const decodedSiteTitle = (0, import_html_entities2.decodeEntities)(siteTitle);
2187        const formattedTitle = (0, import_i18n9.sprintf)(
2188          /* translators: Admin document title. 1: Admin screen name, 2: Site name. */
2189          (0, import_i18n9.__)("%1$s \u2039 %2$s \u2014 WordPress"),
2190          decodedRouteTitle,
2191          decodedSiteTitle
2192        );
2193        document.title = formattedTitle;
2194        if (decodedRouteTitle) {
2195          speak(decodedRouteTitle, "assertive");
2196        }
2197      }
2198    }, [routeTitle, siteTitle, location]);
2199  }
2200  
2201  // packages/boot/build-module/components/user-theme-provider/index.js
2202  var import_theme = __toESM(require_theme());
2203  var import_jsx_runtime30 = __toESM(require_jsx_runtime());
2204  var ThemeProvider = unlock(import_theme.privateApis).ThemeProvider;
2205  var THEME_PRIMARY_COLORS = /* @__PURE__ */ new Map([
2206    ["light", "#0085ba"],
2207    ["modern", "#3858e9"],
2208    ["blue", "#096484"],
2209    ["coffee", "#46403c"],
2210    ["ectoplasm", "#523f6d"],
2211    ["midnight", "#e14d43"],
2212    ["ocean", "#627c83"],
2213    ["sunrise", "#dd823b"]
2214  ]);
2215  function getAdminThemePrimaryColor() {
2216    const theme = document.body.className.match(/admin-color-([a-z]+)/)?.[1];
2217    return theme && THEME_PRIMARY_COLORS.get(theme);
2218  }
2219  function UserThemeProvider({
2220    color,
2221    ...restProps
2222  }) {
2223    const primary = getAdminThemePrimaryColor();
2224    return /* @__PURE__ */ (0, import_jsx_runtime30.jsx)(ThemeProvider, { ...restProps, color: { primary, ...color } });
2225  }
2226  
2227  // packages/boot/build-module/components/root/index.js
2228  var import_jsx_runtime31 = __toESM(require_jsx_runtime());
2229  var css10 = `/**
2230   * SCSS Variables.
2231   *
2232   * Please use variables from this sheet to ensure consistency across the UI.
2233   * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
2234   * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
2235   */
2236  /**
2237   * Colors
2238   */
2239  /**
2240   * Fonts & basic variables.
2241   */
2242  /**
2243   * Typography
2244   */
2245  /**
2246   * Grid System.
2247   * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
2248   */
2249  /**
2250   * Radius scale.
2251   */
2252  /**
2253   * Elevation scale.
2254   */
2255  /**
2256   * Dimensions.
2257   */
2258  /**
2259   * Mobile specific styles
2260   */
2261  /**
2262   * Editor styles.
2263   */
2264  /**
2265   * Block & Editor UI.
2266   */
2267  /**
2268   * Block paddings.
2269   */
2270  /**
2271   * React Native specific.
2272   * These variables do not appear to be used anywhere else.
2273   */
2274  /**
2275   * Typography
2276   */
2277  /**
2278   * Breakpoints & Media Queries
2279   */
2280  /**
2281  *  Converts a hex value into the rgb equivalent.
2282  *
2283  * @param {string} hex - the hexadecimal value to convert
2284  * @return {string} comma separated rgb values
2285  */
2286  /**
2287   * Long content fade mixin
2288   *
2289   * Creates a fading overlay to signify that the content is longer
2290   * than the space allows.
2291   */
2292  /**
2293   * Breakpoint mixins
2294   */
2295  /**
2296   * Focus styles.
2297   */
2298  /**
2299   * Applies editor left position to the selector passed as argument
2300   */
2301  /**
2302   * Styles that are reused verbatim in a few places
2303   */
2304  /**
2305   * Allows users to opt-out of animations via OS-level preferences.
2306   */
2307  /**
2308   * Reset default styles for JavaScript UI based pages.
2309   * This is a WP-admin agnostic reset
2310   */
2311  /**
2312   * Reset the WP Admin page styles for Gutenberg-like pages.
2313   */
2314  .boot-layout {
2315    height: 100%;
2316    width: 100%;
2317    display: flex;
2318    flex-direction: row;
2319    color: var(--wpds-color-fg-content-neutral, #1e1e1e);
2320    isolation: isolate;
2321    background: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);
2322  }
2323  
2324  .boot-layout__sidebar-backdrop {
2325    position: fixed;
2326    top: 0;
2327    left: 0;
2328    right: 0;
2329    bottom: 0;
2330    background-color: rgba(0, 0, 0, 0.5);
2331    z-index: 100002;
2332    cursor: pointer;
2333  }
2334  
2335  .boot-layout__sidebar {
2336    height: 100%;
2337    flex-shrink: 0;
2338    width: 240px;
2339    position: relative;
2340    overflow: hidden;
2341  }
2342  .boot-layout__sidebar.is-mobile {
2343    position: fixed;
2344    top: 0;
2345    bottom: 0;
2346    left: 0;
2347    width: 300px;
2348    max-width: 85vw;
2349    background: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);
2350    z-index: 100003;
2351    box-shadow: 2px 0 8px rgba(0, 0, 0, 0.2);
2352  }
2353  
2354  .boot-layout__mobile-sidebar-drawer {
2355    position: fixed;
2356    top: 0;
2357    left: 0;
2358    right: 0;
2359    z-index: 3;
2360    background: var(--wpds-color-bg-surface-neutral, #fff);
2361    padding: 16px;
2362    border-bottom: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);
2363    display: flex;
2364    justify-content: flex-start;
2365    align-items: center;
2366  }
2367  
2368  .boot-layout__canvas.has-mobile-drawer {
2369    position: relative;
2370    padding-top: 65px;
2371  }
2372  
2373  .boot-layout__surfaces {
2374    display: flex;
2375    flex-grow: 1;
2376    margin: 0;
2377    gap: 8px;
2378  }
2379  @media (min-width: 782px) {
2380    .boot-layout__surfaces {
2381      margin: 8px;
2382    }
2383    .boot-layout--single-page .boot-layout__surfaces {
2384      margin-top: 0;
2385      margin-left: 0;
2386    }
2387  }
2388  
2389  .boot-layout__stage,
2390  .boot-layout__inspector {
2391    flex: 1;
2392    overflow-y: auto;
2393    background: var(--wpds-color-bg-surface-neutral, #fff);
2394    color: var(--wpds-color-fg-content-neutral, #1e1e1e);
2395    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
2396    border: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);
2397    position: relative;
2398    position: fixed;
2399    top: 0;
2400    left: 0;
2401    right: 0;
2402    bottom: 0;
2403    width: 100vw;
2404    height: 100vh;
2405    border-radius: 0;
2406    margin: 0;
2407  }
2408  @media (min-width: 782px) {
2409    .boot-layout__stage,
2410    .boot-layout__inspector {
2411      position: static;
2412      width: auto;
2413      height: auto;
2414      border-radius: 8px;
2415      margin: 0;
2416    }
2417  }
2418  
2419  .boot-layout__stage {
2420    z-index: 2;
2421  }
2422  @media (min-width: 782px) {
2423    .boot-layout__stage {
2424      z-index: auto;
2425    }
2426  }
2427  
2428  .boot-layout__inspector {
2429    z-index: 3;
2430  }
2431  @media (min-width: 782px) {
2432    .boot-layout__inspector {
2433      z-index: auto;
2434    }
2435  }
2436  
2437  .boot-layout__canvas {
2438    flex: 1;
2439    overflow-y: auto;
2440    background: var(--wpds-color-bg-surface-neutral, #fff);
2441    color: var(--wpds-color-fg-content-neutral, #1e1e1e);
2442    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
2443    border: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);
2444    position: relative;
2445    position: fixed;
2446    top: 0;
2447    left: 0;
2448    right: 0;
2449    bottom: 0;
2450    width: 100vw;
2451    height: 100vh;
2452    z-index: 1;
2453    border-radius: 0;
2454    margin: 0;
2455  }
2456  @media (min-width: 782px) {
2457    .boot-layout__canvas {
2458      position: static;
2459      width: auto;
2460      height: auto;
2461      border-radius: 8px;
2462      z-index: auto;
2463    }
2464  }
2465  
2466  @media (min-width: 782px) {
2467    .boot-layout.has-canvas .boot-layout__stage,
2468    .boot-layout__inspector {
2469      max-width: 400px;
2470    }
2471  }
2472  
2473  .boot-layout__canvas .interface-interface-skeleton {
2474    position: relative;
2475    height: 100%;
2476    top: 0 !important;
2477    left: 0 !important;
2478  }
2479  
2480  .boot-layout.has-full-canvas .boot-layout__surfaces {
2481    margin: 0;
2482    gap: 0;
2483  }
2484  
2485  .boot-layout.has-full-canvas .boot-layout__stage,
2486  .boot-layout.has-full-canvas .boot-layout__inspector {
2487    display: none;
2488  }
2489  
2490  .boot-layout.has-full-canvas .boot-layout__canvas {
2491    position: fixed;
2492    top: 0;
2493    left: 0;
2494    right: 0;
2495    bottom: 0;
2496    max-width: none;
2497    margin: 0;
2498    border-radius: 0;
2499    border: none;
2500    box-shadow: none;
2501    overflow: hidden;
2502  }
2503  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/root","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","../../../../../node_modules/@wordpress/base-styles/_mixins.scss","../../../../../node_modules/@wordpress/base-styles/_breakpoints.scss","../../../../../node_modules/@wordpress/base-styles/_functions.scss","../../../../../node_modules/@wordpress/base-styles/_long-content-fade.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEnKA;AAAA;AAAA;ACAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AH4EA;AAAA;AAAA;AA0DA;AAAA;AAAA;AAgDA;AAAA;AAAA;AAqCA;AAAA;AAAA;AAoBA;AAAA;AAAA;AAwLA;AAAA;AAAA;AAAA;AAgDA;AAAA;AAAA;AIpdA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;;AAEA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA,SNIc;EMHd;EACA;EACA;EACA;;;AAGD;EACC;EACA;;;AAGD;EACC;EACA;EACA;EACA,KNdc;;AE0Dd;EIhDD;IAOE,QNjBa;;EMmBb;IACC;IACA;;;;AAKH;AAAA;EAEC;EACA;EACA;EACA;EACA;EACA;EACA;EAGA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AJaA;EIhCD;AAAA;IAuBE;IACA;IACA;IACA;IACA;;;;AAIF;EACC;;AJAA;EIDD;IAIE;;;;AAIF;EACC;;AJRA;EIOD;IAIE;;;;AAIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EAGA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AJlCA;EIeD;IAuBE;IACA;IACA;IACA;IACA;;;;AJ1CD;EI8CD;AAAA;IAGE;;;;AAIF;EACC;EACA;EACA;EACA;;;AAID;EACC;EACA;;;AAGD;AAAA;EAEC;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","/**\n * Typography\n */\n\n@use \"sass:color\";\n@use \"sass:math\";\n@use \"./variables\";\n@use \"./colors\";\n@use \"./breakpoints\";\n@use \"./functions\";\n@use \"./long-content-fade\";\n\n@mixin _text-heading() {\n\tfont-family: variables.$font-family-headings;\n\tfont-weight: variables.$font-weight-medium;\n}\n\n@mixin _text-body() {\n\tfont-family: variables.$font-family-body;\n\tfont-weight: variables.$font-weight-regular;\n}\n\n@mixin heading-small() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin heading-medium() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin heading-2x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-2x-large;\n\tline-height: variables.$font-line-height-2x-large;\n}\n\n@mixin body-small() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin body-medium() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin body-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin body-x-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-x-large;\n}\n\n/**\n * Breakpoint mixins\n */\n\n@mixin break-xhuge() {\n\t@media (min-width: #{ (breakpoints.$break-xhuge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-huge() {\n\t@media (min-width: #{ (breakpoints.$break-huge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-wide() {\n\t@media (min-width: #{ (breakpoints.$break-wide) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-xlarge() {\n\t@media (min-width: #{ (breakpoints.$break-xlarge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-large() {\n\t@media (min-width: #{ (breakpoints.$break-large) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-medium() {\n\t@media (min-width: #{ (breakpoints.$break-medium) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-small() {\n\t@media (min-width: #{ (breakpoints.$break-small) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-mobile() {\n\t@media (min-width: #{ (breakpoints.$break-mobile) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-zoomed-in() {\n\t@media (min-width: #{ (breakpoints.$break-zoomed-in) }) {\n\t\t@content;\n\t}\n}\n\n/**\n * Focus styles.\n */\n\n@mixin block-toolbar-button-style__focus() {\n\tbox-shadow: inset 0 0 0 variables.$border-width colors.$white, 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n// Tabs, Inputs, Square buttons.\n@mixin input-style__neutral() {\n\tbox-shadow: 0 0 0 transparent;\n\tborder-radius: variables.$radius-small;\n\tborder: variables.$border-width solid colors.$gray-600;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n}\n\n\n@mixin input-style__focus($accent-color: var(--wp-admin-theme-color)) {\n\tborder-color: $accent-color;\n\t// Expand the default border focus style by .5px to be a total of 1.5px.\n\tbox-shadow: 0 0 0 0.5px $accent-color;\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n@mixin button-style__focus() {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n\n@mixin button-style-outset__focus($focus-color) {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) colors.$white, 0 0 0 calc(2 * var(--wp-admin-border-width-focus)) $focus-color;\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n\toutline-offset: 2px;\n}\n\n\n/**\n * Applies editor left position to the selector passed as argument\n */\n\n@mixin editor-left($selector) {\n\t#{$selector} { /* Set left position when auto-fold is not on the body element. */\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t.auto-fold #{$selector} { /* Auto fold is when on smaller breakpoints, nav menu auto collapses. */\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\n\t\t@media (min-width: #{ (breakpoints.$break-large + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t/* Sidebar manually collapsed. */\n\t.folded #{$selector} {\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\t}\n\n\tbody.is-fullscreen-mode #{$selector} {\n\t\tleft: 0 !important;\n\t}\n}\n\n/**\n * Styles that are reused verbatim in a few places\n */\n\n// These are additional styles for all captions, when the theme opts in to block styles.\n@mixin caption-style() {\n\tmargin-top: 0.5em;\n\tmargin-bottom: 1em;\n}\n\n@mixin caption-style-theme() {\n\tcolor: #555;\n\tfont-size: variables.$default-font-size;\n\ttext-align: center;\n\n\t.is-dark-theme & {\n\t\tcolor: colors.$light-gray-placeholder;\n\t}\n}\n\n/**\n * Allows users to opt-out of animations via OS-level preferences.\n */\n\n@mixin reduce-motion($property: \"\") {\n\n\t@if $property == \"transition\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t}\n\t} @else if $property == \"animation\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t} @else {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t}\n}\n\n@mixin input-control($accent-color: var(--wp-admin-theme-color)) {\n\tfont-family: variables.$default-font;\n\tpadding: 6px 8px;\n\t/* Fonts smaller than 16px causes mobile safari to zoom. */\n\tfont-size: variables.$mobile-text-min-font-size;\n\t/* Override core line-height. To be reviewed. */\n\tline-height: normal;\n\t@include input-style__neutral();\n\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size;\n\t\t/* Override core line-height. To be reviewed. */\n\t\tline-height: normal;\n\t}\n\n\t&:focus {\n\t\t@include input-style__focus($accent-color);\n\t}\n\n\t// Use opacity to work in various editor styles.\n\t&::-webkit-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&::-moz-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&:-ms-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n}\n\n@mixin checkbox-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-small;\n\t@include input-control;\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t// Hide default checkbox styles in IE.\n\t\t&::-ms-check {\n\t\t\topacity: 0;\n\t\t}\n\t}\n\n\t&:checked::before,\n\t&[aria-checked=\"mixed\"]::before {\n\t\tmargin: -3px -5px;\n\t\tcolor: colors.$white;\n\n\t\t@include break-medium() {\n\t\t\tmargin: -4px 0 0 -5px;\n\t\t}\n\t}\n\n\t&[aria-checked=\"mixed\"] {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t&::before {\n\t\t\t// Inherited from `forms.css`.\n\t\t\t// See: https://github.com/WordPress/wordpress-develop/tree/5.1.1/src/wp-admin/css/forms.css#L122-L132\n\t\t\tcontent: \"\\f460\";\n\t\t\tfloat: left;\n\t\t\tdisplay: inline-block;\n\t\t\tvertical-align: middle;\n\t\t\twidth: 16px;\n\t\t\t/* stylelint-disable-next-line font-family-no-missing-generic-family-keyword -- dashicons don't need a generic family keyword. */\n\t\t\tfont: normal 30px/1 dashicons;\n\t\t\tspeak: none;\n\t\t\t-webkit-font-smoothing: antialiased;\n\t\t\t-moz-osx-font-smoothing: grayscale;\n\n\t\t\t@include break-medium() {\n\t\t\t\tfloat: none;\n\t\t\t\tfont-size: 21px;\n\t\t\t}\n\t\t}\n\t}\n\n\t&[aria-disabled=\"true\"],\n\t&:disabled {\n\t\tbackground: colors.$gray-100;\n\t\tborder-color: colors.$gray-300;\n\t\tcursor: default;\n\n\t\t// Override style inherited from wp-admin. Required to avoid degraded appearance on different backgrounds.\n\t\topacity: 1;\n\t}\n}\n\n@mixin radio-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-round;\n\twidth: variables.$radio-input-size-sm;\n\theight: variables.$radio-input-size-sm;\n\tmin-width: variables.$radio-input-size-sm;\n\tmax-width: variables.$radio-input-size-sm;\n\tposition: relative;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n\n\t@include break-small() {\n\t\theight: variables.$radio-input-size;\n\t\twidth: variables.$radio-input-size;\n\t\tmin-width: variables.$radio-input-size;\n\t\tmax-width: variables.$radio-input-size;\n\t}\n\n\t&:checked::before {\n\t\tbox-sizing: inherit;\n\t\twidth: math.div(variables.$radio-input-size-sm, 2);\n\t\theight: math.div(variables.$radio-input-size-sm, 2);\n\t\tposition: absolute;\n\t\ttop: 50%;\n\t\tleft: 50%;\n\t\ttransform: translate(-50%, -50%);\n\t\tmargin: 0;\n\t\tbackground-color: colors.$white;\n\n\t\t// This border serves as a background color in Windows High Contrast mode.\n\t\tborder: 4px solid colors.$white;\n\n\t\t@include break-small() {\n\t\t\twidth: math.div(variables.$radio-input-size, 2);\n\t\t\theight: math.div(variables.$radio-input-size, 2);\n\t\t}\n\t}\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder: none;\n\t}\n}\n\n/**\n * Reset default styles for JavaScript UI based pages.\n * This is a WP-admin agnostic reset\n */\n\n@mixin reset {\n\tbox-sizing: border-box;\n\n\t*,\n\t*::before,\n\t*::after {\n\t\tbox-sizing: inherit;\n\t}\n}\n\n@mixin link-reset {\n\t&:focus {\n\t\tcolor: var(--wp-admin-theme-color--rgb);\n\t\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color, #007cba);\n\t\tborder-radius: variables.$radius-small;\n\t}\n}\n\n// The editor input reset with increased specificity to avoid theme styles bleeding in.\n@mixin editor-input-reset() {\n\tfont-family: variables.$editor-html-font !important;\n\tcolor: colors.$gray-900 !important;\n\tbackground: colors.$white !important;\n\tpadding: variables.$grid-unit-15 !important;\n\tborder: variables.$border-width solid colors.$gray-900 !important;\n\tbox-shadow: none !important;\n\tborder-radius: variables.$radius-small !important;\n\n\t// Fonts smaller than 16px causes mobile safari to zoom.\n\tfont-size: variables.$mobile-text-min-font-size !important;\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size !important;\n\t}\n\n\t&:focus {\n\t\tborder-color: var(--wp-admin-theme-color) !important;\n\t\tbox-shadow: 0 0 0 (variables.$border-width-focus-fallback - variables.$border-width) var(--wp-admin-theme-color) !important;\n\n\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\toutline: 2px solid transparent !important;\n\t}\n}\n\n/**\n * Reset the WP Admin page styles for Gutenberg-like pages.\n */\n\n@mixin wp-admin-reset( $content-container ) {\n\tbackground: colors.$white;\n\n\t#wpcontent {\n\t\tpadding-left: 0;\n\t}\n\n\t#wpbody-content {\n\t\tpadding-bottom: 0;\n\t}\n\n\t/* We hide legacy notices in Gutenberg Based Pages, because they were not designed in a way that scaled well.\n\t   Plugins can use Gutenberg notices if they need to pass on information to the user when they are editing. */\n\t#wpbody-content > div:not(#{ $content-container }):not(#screen-meta) {\n\t\tdisplay: none;\n\t}\n\n\t#wpfooter {\n\t\tdisplay: none;\n\t}\n\n\t.a11y-speak-region {\n\t\tleft: -1px;\n\t\ttop: -1px;\n\t}\n\n\tul#adminmenu a.wp-has-current-submenu::after,\n\tul#adminmenu > li.current > a.current::after {\n\t\tborder-right-color: colors.$white;\n\t}\n\n\t.media-frame select.attachment-filters:last-of-type {\n\t\twidth: auto;\n\t\tmax-width: 100%;\n\t}\n}\n\n@mixin admin-scheme($color-primary) {\n\t// Define RGB equivalents for use in rgba function.\n\t// Hexadecimal css vars do not work in the rgba function.\n\t--wp-admin-theme-color: #{$color-primary};\n\t--wp-admin-theme-color--rgb: #{functions.hex-to-rgb($color-primary)};\n\t// Darker shades.\n\t--wp-admin-theme-color-darker-10: #{color.adjust($color-primary, $lightness: -5%)};\n\t--wp-admin-theme-color-darker-10--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -5%))};\n\t--wp-admin-theme-color-darker-20: #{color.adjust($color-primary, $lightness: -10%)};\n\t--wp-admin-theme-color-darker-20--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -10%))};\n\n\t// Focus style width.\n\t// Avoid rounding issues by showing a whole 2px for 1x screens, and 1.5px on high resolution screens.\n\t--wp-admin-border-width-focus: 2px;\n\t@media ( -webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {\n\t\t--wp-admin-border-width-focus: 1.5px;\n\t}\n}\n\n@mixin wordpress-admin-schemes() {\n\tbody.admin-color-light {\n\t\t@include admin-scheme(#0085ba);\n\t}\n\n\tbody.admin-color-modern {\n\t\t@include admin-scheme(#3858e9);\n\t}\n\n\tbody.admin-color-blue {\n\t\t@include admin-scheme(#096484);\n\t}\n\n\tbody.admin-color-coffee {\n\t\t@include admin-scheme(#46403c);\n\t}\n\n\tbody.admin-color-ectoplasm {\n\t\t@include admin-scheme(#523f6d);\n\t}\n\n\tbody.admin-color-midnight {\n\t\t@include admin-scheme(#e14d43);\n\t}\n\n\tbody.admin-color-ocean {\n\t\t@include admin-scheme(#627c83);\n\t}\n\n\tbody.admin-color-sunrise {\n\t\t@include admin-scheme(#dd823b);\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin background-colors-deprecated() {\n\t.has-very-light-gray-background-color {\n\t\tbackground-color: #eee;\n\t}\n\n\t.has-very-dark-gray-background-color {\n\t\tbackground-color: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin foreground-colors-deprecated() {\n\t.has-very-light-gray-color {\n\t\tcolor: #eee;\n\t}\n\n\t.has-very-dark-gray-color {\n\t\tcolor: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin gradient-colors-deprecated() {\n\t// Our classes uses the same values we set for gradient value attributes.\n\n\t/* stylelint-disable @stylistic/function-comma-space-after -- We can not use spacing because of WP multi site kses rule. */\n\t.has-vivid-green-cyan-to-vivid-cyan-blue-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgba(0,208,132,1) 0%,rgba(6,147,227,1) 100%);\n\t}\n\n\t.has-purple-crush-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(52,226,228) 0%,rgb(71,33,251) 50%,rgb(171,29,254) 100%);\n\t}\n\n\t.has-hazy-dawn-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,172,168) 0%,rgb(218,208,236) 100%);\n\t}\n\n\t.has-subdued-olive-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,250,225) 0%,rgb(103,166,113) 100%);\n\t}\n\n\t.has-atomic-cream-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(253,215,154) 0%,rgb(0,74,89) 100%);\n\t}\n\n\t.has-nightshade-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(51,9,104) 0%,rgb(49,205,207) 100%);\n\t}\n\n\t.has-midnight-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(2,3,129) 0%,rgb(40,116,252) 100%);\n\t}\n\t/* stylelint-enable @stylistic/function-comma-space-after */\n}\n\n@mixin custom-scrollbars-on-hover($handle-color, $handle-color-hover) {\n\n\t// WebKit\n\t&::-webkit-scrollbar {\n\t\twidth: 12px;\n\t\theight: 12px;\n\t}\n\t&::-webkit-scrollbar-track {\n\t\tbackground-color: transparent;\n\t}\n\t&::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color;\n\t\tborder-radius: 8px;\n\t\tborder: 3px solid transparent;\n\t\tbackground-clip: padding-box;\n\t}\n\t&:hover::-webkit-scrollbar-thumb, // This needs specificity.\n\t&:focus::-webkit-scrollbar-thumb,\n\t&:focus-within::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color-hover;\n\t}\n\n\t// Firefox 109+ and Chrome 111+\n\tscrollbar-width: thin;\n\tscrollbar-gutter: stable both-edges;\n\tscrollbar-color: $handle-color transparent; // Syntax, \"dark\", \"light\", or \"#handle-color #track-color\"\n\n\t&:hover,\n\t&:focus,\n\t&:focus-within {\n\t\tscrollbar-color: $handle-color-hover transparent;\n\t}\n\n\t// Needed to fix a Safari rendering issue.\n\twill-change: transform;\n\n\t// Always show scrollbar on Mobile devices.\n\t@media (hover: none) {\n\t\t& {\n\t\t\tscrollbar-color: $handle-color-hover transparent;\n\t\t}\n\t}\n}\n\n@mixin selected-block-outline($widthRatio: 1) {\n\toutline-color: var(--wp-admin-theme-color);\n\toutline-style: solid;\n\toutline-width: calc(#{$widthRatio} * (var(--wp-admin-border-width-focus) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n\toutline-offset: calc(#{$widthRatio} * ((-1 * var(--wp-admin-border-width-focus) ) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n}\n\n@mixin selected-block-focus($widthRatio: 1) {\n\tcontent: \"\";\n\tposition: absolute;\n\tpointer-events: none;\n\ttop: 0;\n\tright: 0;\n\tbottom: 0;\n\tleft: 0;\n\t@include selected-block-outline($widthRatio);\n}\n","/**\n * Breakpoints & Media Queries\n */\n\n// Most used breakpoints\n$break-xhuge: 1920px;\n$break-huge: 1440px;\n$break-wide: 1280px;\n$break-xlarge: 1080px;\n$break-large: 960px;\t// admin sidebar auto folds\n$break-medium: 782px;\t// adminbar goes big\n$break-small: 600px;\n$break-mobile: 480px;\n$break-zoomed-in: 280px;\n\n// All media queries currently in WordPress:\n//\n// min-width: 2000px\n// min-width: 1680px\n// min-width: 1250px\n// max-width: 1120px *\n// max-width: 1000px\n// min-width: 769px and max-width: 1000px\n// max-width: 960px *\n// max-width: 900px\n// max-width: 850px\n// min-width: 800px and max-width: 1499px\n// max-width: 800px\n// max-width: 799px\n// max-width: 782px *\n// max-width: 768px\n// max-width: 640px *\n// max-width: 600px *\n// max-width: 520px\n// max-width: 500px\n// max-width: 480px *\n// max-width: 400px *\n// max-width: 380px\n// max-width: 320px *\n//\n// Those marked * seem to be more commonly used than the others.\n// Let's try and use as few of these as possible, and be mindful about adding new ones, so we don't make the situation worse\n","/**\n*  Converts a hex value into the rgb equivalent.\n*\n* @param {string} hex - the hexadecimal value to convert\n* @return {string} comma separated rgb values\n*/\n\n@use \"sass:color\";\n@use \"sass:meta\";\n\n@function hex-to-rgb($hex) {\n\t/*\n\t * TODO: `color.{red|green|blue}` will trigger a deprecation warning in Dart Sass,\n\t * but the Sass used by the Gutenberg project doesn't support `color.channel()` yet,\n\t * so we can't migrate to it at this time.\n\t * In the future, after the Gutenberg project has been fully migrated to Dart Sass,\n\t * Remove this conditional statement and use only `color.channel()`.\n\t */\n\t@if meta.function-exists(\"channel\", \"color\") {\n\t\t@return color.channel($hex, \"red\"), color.channel($hex, \"green\"), color.channel($hex, \"blue\");\n\t} @else {\n\t\t@return color.red($hex), color.green($hex), color.blue($hex);\n\t}\n}\n","/**\n * Long content fade mixin\n *\n * Creates a fading overlay to signify that the content is longer\n * than the space allows.\n */\n\n@mixin long-content-fade($direction: right, $size: 20%, $color: #fff, $edge: 0, $z-index: false) {\n\tcontent: \"\";\n\tdisplay: block;\n\tposition: absolute;\n\t-webkit-touch-callout: none;\n\t-webkit-user-select: none;\n\t-khtml-user-select: none;\n\t-moz-user-select: none;\n\t-ms-user-select: none;\n\tuser-select: none;\n\tpointer-events: none;\n\n\t@if $z-index {\n\t\tz-index: $z-index;\n\t}\n\n\t@if $direction == \"bottom\" {\n\t\tbackground: linear-gradient(to top, transparent, $color 90%);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\ttop: $edge;\n\t\tbottom: calc(100% - $size);\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"top\" {\n\t\tbackground: linear-gradient(to bottom, transparent, $color 90%);\n\t\ttop: calc(100% - $size);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\tbottom: $edge;\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"left\" {\n\t\tbackground: linear-gradient(to left, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tleft: $edge;\n\t\tbottom: $edge;\n\t\tright: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n\n\t@if $direction == \"right\" {\n\t\tbackground: linear-gradient(to right, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tbottom: $edge;\n\t\tright: $edge;\n\t\tleft: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n}\n","@use \"@wordpress/base-styles/variables\";\n@use \"@wordpress/base-styles/mixins\";\n\n.boot-layout {\n\theight: 100%;\n\twidth: 100%;\n\tdisplay: flex;\n\tflex-direction: row;\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tisolation: isolate;\n\tbackground: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);\n}\n\n.boot-layout__sidebar-backdrop {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tbackground-color: rgba(0, 0, 0, 0.5);\n\tz-index: 100002;\n\tcursor: pointer;\n}\n\n.boot-layout__sidebar {\n\theight: 100%;\n\tflex-shrink: 0;\n\twidth: 240px;\n\tposition: relative;\n\toverflow: hidden;\n\n\t&.is-mobile {\n\t\tposition: fixed;\n\t\ttop: 0;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\twidth: 300px;\n\t\tmax-width: 85vw;\n\t\tbackground: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);\n\t\tz-index: 100003;\n\t\tbox-shadow: 2px 0 8px rgba(0, 0, 0, 0.2);\n\t}\n}\n\n.boot-layout__mobile-sidebar-drawer {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tz-index: 3;\n\tbackground: var(--wpds-color-bg-surface-neutral, #fff);\n\tpadding: variables.$grid-unit-20;\n\tborder-bottom: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\talign-items: center;\n}\n\n.boot-layout__canvas.has-mobile-drawer {\n\tposition: relative;\n\tpadding-top: 65px;\n}\n\n.boot-layout__surfaces {\n\tdisplay: flex;\n\tflex-grow: 1;\n\tmargin: 0;\n\tgap: variables.$grid-unit-10;\n\n\t@include mixins.break-medium {\n\t\tmargin: variables.$grid-unit-10;\n\n\t\t.boot-layout--single-page & {\n\t\t\tmargin-top: 0;\n\t\t\tmargin-left: 0;\n\t\t}\n\t}\n}\n\n.boot-layout__stage,\n.boot-layout__inspector {\n\tflex: 1;\n\toverflow-y: auto;\n\tbackground: var(--wpds-color-bg-surface-neutral, #fff);\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tbox-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);\n\tborder: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);\n\tposition: relative;\n\n\t// Mobile-first: surfaces take full screen with fixed positioning\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\twidth: 100vw;\n\theight: 100vh;\n\tborder-radius: 0;\n\tmargin: 0;\n\n\t// Desktop: restore original styles\n\t@include mixins.break-medium {\n\t\tposition: static;\n\t\twidth: auto;\n\t\theight: auto;\n\t\tborder-radius: 8px;\n\t\tmargin: 0;\n\t}\n}\n\n.boot-layout__stage {\n\tz-index: 2; // Highest surface priority on mobile\n\n\t@include mixins.break-medium {\n\t\tz-index: auto;\n\t}\n}\n\n.boot-layout__inspector {\n\tz-index: 3; // Medium surface priority on mobile\n\n\t@include mixins.break-medium {\n\t\tz-index: auto;\n\t}\n}\n\n.boot-layout__canvas {\n\tflex: 1;\n\toverflow-y: auto;\n\tbackground: var(--wpds-color-bg-surface-neutral, #fff);\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tbox-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);\n\tborder: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);\n\tposition: relative;\n\n\t// Mobile-first: full screen with lowest priority\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\twidth: 100vw;\n\theight: 100vh;\n\tz-index: 1; // Lowest surface priority\n\tborder-radius: 0;\n\tmargin: 0;\n\n\t// Desktop: restore original styles\n\t@include mixins.break-medium {\n\t\tposition: static;\n\t\twidth: auto;\n\t\theight: auto;\n\t\tborder-radius: 8px;\n\t\tz-index: auto;\n\t}\n}\n\n.boot-layout.has-canvas .boot-layout__stage,\n.boot-layout__inspector {\n\t@include mixins.break-medium {\n\t\tmax-width: 400px;\n\t}\n}\n\n.boot-layout__canvas .interface-interface-skeleton {\n\tposition: relative;\n\theight: 100%;\n\ttop: 0 !important;\n\tleft: 0 !important;\n}\n\n// Full-screen canvas mode\n.boot-layout.has-full-canvas .boot-layout__surfaces {\n\tmargin: 0;\n\tgap: 0;\n}\n\n.boot-layout.has-full-canvas .boot-layout__stage,\n.boot-layout.has-full-canvas .boot-layout__inspector {\n\tdisplay: none;\n}\n\n.boot-layout.has-full-canvas .boot-layout__canvas {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tmax-width: none;\n\tmargin: 0;\n\tborder-radius: 0;\n\tborder: none;\n\tbox-shadow: none;\n\toverflow: hidden;\n}\n"]} */`;
2504  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css10));
2505  var { useLocation: useLocation2, useMatches: useMatches3, Outlet } = unlock(routePrivateApis5);
2506  function Root() {
2507    const matches = useMatches3();
2508    const location = useLocation2();
2509    const currentMatch = matches[matches.length - 1];
2510    const canvas = currentMatch?.loaderData?.canvas;
2511    const routeContentModule = currentMatch?.loaderData?.routeContentModule;
2512    const isFullScreen = canvas && !canvas.isPreview;
2513    useRouteTitle();
2514    const isMobileViewport = (0, import_compose4.useViewportMatch)("medium", "<");
2515    const [isMobileSidebarOpen, setIsMobileSidebarOpen] = (0, import_element13.useState)(false);
2516    const disableMotion = (0, import_compose4.useReducedMotion)();
2517    (0, import_element13.useEffect)(() => {
2518      setIsMobileSidebarOpen(false);
2519    }, [location.pathname, isMobileViewport]);
2520    return /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(import_components14.SlotFillProvider, { children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(UserThemeProvider, { isRoot: true, color: { bg: "#f8f8f8" }, children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(UserThemeProvider, { color: { bg: "#1d2327" }, children: /* @__PURE__ */ (0, import_jsx_runtime31.jsxs)(
2521      "div",
2522      {
2523        className: clsx_default("boot-layout", {
2524          "has-canvas": !!canvas || canvas === null,
2525          "has-full-canvas": isFullScreen
2526        }),
2527        children: [
2528          /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(import_commands2.CommandMenu, {}),
2529          /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(SavePanel, {}),
2530          /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(import_editor4.EditorSnackbars, {}),
2531          isMobileViewport && /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(page_default.SidebarToggleFill, { children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(
2532            import_components14.Button,
2533            {
2534              icon: menu_default,
2535              onClick: () => setIsMobileSidebarOpen(true),
2536              label: (0, import_i18n10.__)("Open navigation panel"),
2537              size: "compact"
2538            }
2539          ) }),
2540          /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(import_components14.__unstableAnimatePresence, { children: isMobileViewport && isMobileSidebarOpen && !isFullScreen && /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(
2541            import_components14.__unstableMotion.div,
2542            {
2543              initial: { opacity: 0 },
2544              animate: { opacity: 1 },
2545              exit: { opacity: 0 },
2546              transition: {
2547                type: "tween",
2548                duration: disableMotion ? 0 : 0.2,
2549                ease: "easeOut"
2550              },
2551              className: "boot-layout__sidebar-backdrop",
2552              onClick: () => setIsMobileSidebarOpen(false),
2553              onKeyDown: (event) => {
2554                if (event.key === "Escape") {
2555                  setIsMobileSidebarOpen(false);
2556                }
2557              },
2558              role: "button",
2559              tabIndex: -1,
2560              "aria-label": (0, import_i18n10.__)(
2561                "Close navigation panel"
2562              )
2563            }
2564          ) }),
2565          /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(import_components14.__unstableAnimatePresence, { children: isMobileViewport && isMobileSidebarOpen && !isFullScreen && /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(
2566            import_components14.__unstableMotion.div,
2567            {
2568              initial: { x: "-100%" },
2569              animate: { x: 0 },
2570              exit: { x: "-100%" },
2571              transition: {
2572                type: "tween",
2573                duration: disableMotion ? 0 : 0.2,
2574                ease: "easeOut"
2575              },
2576              className: "boot-layout__sidebar is-mobile",
2577              children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(Sidebar, {})
2578            }
2579          ) }),
2580          !isMobileViewport && !isFullScreen && /* @__PURE__ */ (0, import_jsx_runtime31.jsx)("div", { className: "boot-layout__sidebar", children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(Sidebar, {}) }),
2581          /* @__PURE__ */ (0, import_jsx_runtime31.jsxs)("div", { className: "boot-layout__surfaces", children: [
2582            /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(UserThemeProvider, { color: { bg: "#ffffff" }, children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(Outlet, {}) }),
2583            (canvas || canvas === null) && /* @__PURE__ */ (0, import_jsx_runtime31.jsxs)(
2584              "div",
2585              {
2586                className: clsx_default("boot-layout__canvas", {
2587                  "has-mobile-drawer": canvas?.isPreview && isMobileViewport
2588                }),
2589                children: [
2590                  canvas?.isPreview && isMobileViewport && /* @__PURE__ */ (0, import_jsx_runtime31.jsx)("div", { className: "boot-layout__mobile-sidebar-drawer", children: /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(
2591                    import_components14.Button,
2592                    {
2593                      icon: menu_default,
2594                      onClick: () => setIsMobileSidebarOpen(
2595                        true
2596                      ),
2597                      label: (0, import_i18n10.__)(
2598                        "Open navigation panel"
2599                      ),
2600                      size: "compact"
2601                    }
2602                  ) }),
2603                  /* @__PURE__ */ (0, import_jsx_runtime31.jsx)(
2604                    CanvasRenderer,
2605                    {
2606                      canvas,
2607                      routeContentModule
2608                    }
2609                  )
2610                ]
2611              }
2612            )
2613          ] })
2614        ]
2615      }
2616    ) }) }) });
2617  }
2618  
2619  // packages/boot/build-module/components/app/router.js
2620  var import_jsx_runtime32 = __toESM(require_jsx_runtime());
2621  var {
2622    createLazyRoute,
2623    createRouter,
2624    createRootRoute,
2625    createRoute,
2626    RouterProvider,
2627    createBrowserHistory,
2628    parseHref,
2629    useLoaderData
2630  } = unlock(routePrivateApis6);
2631  function NotFoundComponent() {
2632    return /* @__PURE__ */ (0, import_jsx_runtime32.jsx)("div", { className: "boot-layout__stage", children: /* @__PURE__ */ (0, import_jsx_runtime32.jsx)(page_default, { title: (0, import_i18n11.__)("Route not found"), hasPadding: true, children: (0, import_i18n11.__)("The page you're looking for does not exist") }) });
2633  }
2634  function createRouteFromDefinition(route, parentRoute) {
2635    let tanstackRoute = createRoute({
2636      getParentRoute: () => parentRoute,
2637      path: route.path,
2638      beforeLoad: async (opts) => {
2639        if (route.route_module) {
2640          const module = await import(route.route_module);
2641          const routeConfig = module.route || {};
2642          if (routeConfig.beforeLoad) {
2643            return routeConfig.beforeLoad({
2644              params: opts.params || {},
2645              search: opts.search || {}
2646            });
2647          }
2648        }
2649      },
2650      loader: async (opts) => {
2651        let routeConfig = {};
2652        if (route.route_module) {
2653          const module = await import(route.route_module);
2654          routeConfig = module.route || {};
2655        }
2656        const context = {
2657          params: opts.params || {},
2658          search: opts.deps || {}
2659        };
2660        const [, loaderData, canvasData, titleData] = await Promise.all([
2661          (0, import_data10.resolveSelect)(import_core_data6.store).getEntityRecord(
2662            "root",
2663            "__unstableBase"
2664          ),
2665          routeConfig.loader ? routeConfig.loader(context) : Promise.resolve(void 0),
2666          routeConfig.canvas ? routeConfig.canvas(context) : Promise.resolve(void 0),
2667          routeConfig.title ? routeConfig.title(context) : Promise.resolve(void 0)
2668        ]);
2669        let inspector = true;
2670        if (routeConfig.inspector) {
2671          inspector = await routeConfig.inspector(context);
2672        }
2673        return {
2674          ...loaderData,
2675          canvas: canvasData,
2676          inspector,
2677          title: titleData,
2678          routeContentModule: route.content_module
2679        };
2680      },
2681      loaderDeps: (opts) => opts.search
2682    });
2683    tanstackRoute = tanstackRoute.lazy(async () => {
2684      const module = route.content_module ? await import(route.content_module) : {};
2685      const Stage = module.stage;
2686      const Inspector = module.inspector;
2687      return createLazyRoute(route.path)({
2688        component: function RouteComponent() {
2689          const { inspector: showInspector } = useLoaderData({ from: route.path }) ?? {};
2690          return /* @__PURE__ */ (0, import_jsx_runtime32.jsxs)(import_jsx_runtime32.Fragment, { children: [
2691            Stage && /* @__PURE__ */ (0, import_jsx_runtime32.jsx)("div", { className: "boot-layout__stage", children: /* @__PURE__ */ (0, import_jsx_runtime32.jsx)(Stage, {}) }),
2692            Inspector && showInspector && /* @__PURE__ */ (0, import_jsx_runtime32.jsx)("div", { className: "boot-layout__inspector", children: /* @__PURE__ */ (0, import_jsx_runtime32.jsx)(Inspector, {}) })
2693          ] });
2694        }
2695      });
2696    });
2697    return tanstackRoute;
2698  }
2699  function createRouteTree(routes, rootComponent = Root) {
2700    const rootRoute = createRootRoute({
2701      component: rootComponent,
2702      context: () => ({})
2703    });
2704    const dynamicRoutes = routes.map(
2705      (route) => createRouteFromDefinition(route, rootRoute)
2706    );
2707    return rootRoute.addChildren(dynamicRoutes);
2708  }
2709  function createPathHistory() {
2710    return createBrowserHistory({
2711      parseLocation: () => {
2712        const url = new URL(window.location.href);
2713        const path = url.searchParams.get("p") || "/";
2714        const pathHref = `$path}$url.hash}`;
2715        return parseHref(pathHref, window.history.state);
2716      },
2717      createHref: (href) => {
2718        const searchParams = new URLSearchParams(window.location.search);
2719        searchParams.set("p", href);
2720        return `$window.location.pathname}?$searchParams}`;
2721      }
2722    });
2723  }
2724  function Router({
2725    routes,
2726    rootComponent = Root
2727  }) {
2728    const router = (0, import_element14.useMemo)(() => {
2729      const history = createPathHistory();
2730      const routeTree = createRouteTree(routes, rootComponent);
2731      return createRouter({
2732        history,
2733        routeTree,
2734        defaultPreload: "intent",
2735        defaultNotFoundComponent: NotFoundComponent,
2736        defaultViewTransition: {
2737          types: ({
2738            fromLocation
2739          }) => {
2740            if (!fromLocation) {
2741              return false;
2742            }
2743            return ["navigate"];
2744          }
2745        }
2746      });
2747    }, [routes, rootComponent]);
2748    return /* @__PURE__ */ (0, import_jsx_runtime32.jsx)(RouterProvider, { router });
2749  }
2750  
2751  // packages/boot/build-module/components/root/single-page.js
2752  var import_commands3 = __toESM(require_commands());
2753  var import_editor5 = __toESM(require_editor());
2754  import { privateApis as routePrivateApis7 } from "@wordpress/route";
2755  var import_jsx_runtime33 = __toESM(require_jsx_runtime());
2756  var css11 = `/**
2757   * SCSS Variables.
2758   *
2759   * Please use variables from this sheet to ensure consistency across the UI.
2760   * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
2761   * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
2762   */
2763  /**
2764   * Colors
2765   */
2766  /**
2767   * Fonts & basic variables.
2768   */
2769  /**
2770   * Typography
2771   */
2772  /**
2773   * Grid System.
2774   * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
2775   */
2776  /**
2777   * Radius scale.
2778   */
2779  /**
2780   * Elevation scale.
2781   */
2782  /**
2783   * Dimensions.
2784   */
2785  /**
2786   * Mobile specific styles
2787   */
2788  /**
2789   * Editor styles.
2790   */
2791  /**
2792   * Block & Editor UI.
2793   */
2794  /**
2795   * Block paddings.
2796   */
2797  /**
2798   * React Native specific.
2799   * These variables do not appear to be used anywhere else.
2800   */
2801  /**
2802   * Typography
2803   */
2804  /**
2805   * Breakpoints & Media Queries
2806   */
2807  /**
2808  *  Converts a hex value into the rgb equivalent.
2809  *
2810  * @param {string} hex - the hexadecimal value to convert
2811  * @return {string} comma separated rgb values
2812  */
2813  /**
2814   * Long content fade mixin
2815   *
2816   * Creates a fading overlay to signify that the content is longer
2817   * than the space allows.
2818   */
2819  /**
2820   * Breakpoint mixins
2821   */
2822  /**
2823   * Focus styles.
2824   */
2825  /**
2826   * Applies editor left position to the selector passed as argument
2827   */
2828  /**
2829   * Styles that are reused verbatim in a few places
2830   */
2831  /**
2832   * Allows users to opt-out of animations via OS-level preferences.
2833   */
2834  /**
2835   * Reset default styles for JavaScript UI based pages.
2836   * This is a WP-admin agnostic reset
2837   */
2838  /**
2839   * Reset the WP Admin page styles for Gutenberg-like pages.
2840   */
2841  .boot-layout {
2842    height: 100%;
2843    width: 100%;
2844    display: flex;
2845    flex-direction: row;
2846    color: var(--wpds-color-fg-content-neutral, #1e1e1e);
2847    isolation: isolate;
2848    background: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);
2849  }
2850  
2851  .boot-layout__sidebar-backdrop {
2852    position: fixed;
2853    top: 0;
2854    left: 0;
2855    right: 0;
2856    bottom: 0;
2857    background-color: rgba(0, 0, 0, 0.5);
2858    z-index: 100002;
2859    cursor: pointer;
2860  }
2861  
2862  .boot-layout__sidebar {
2863    height: 100%;
2864    flex-shrink: 0;
2865    width: 240px;
2866    position: relative;
2867    overflow: hidden;
2868  }
2869  .boot-layout__sidebar.is-mobile {
2870    position: fixed;
2871    top: 0;
2872    bottom: 0;
2873    left: 0;
2874    width: 300px;
2875    max-width: 85vw;
2876    background: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);
2877    z-index: 100003;
2878    box-shadow: 2px 0 8px rgba(0, 0, 0, 0.2);
2879  }
2880  
2881  .boot-layout__mobile-sidebar-drawer {
2882    position: fixed;
2883    top: 0;
2884    left: 0;
2885    right: 0;
2886    z-index: 3;
2887    background: var(--wpds-color-bg-surface-neutral, #fff);
2888    padding: 16px;
2889    border-bottom: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);
2890    display: flex;
2891    justify-content: flex-start;
2892    align-items: center;
2893  }
2894  
2895  .boot-layout__canvas.has-mobile-drawer {
2896    position: relative;
2897    padding-top: 65px;
2898  }
2899  
2900  .boot-layout__surfaces {
2901    display: flex;
2902    flex-grow: 1;
2903    margin: 0;
2904    gap: 8px;
2905  }
2906  @media (min-width: 782px) {
2907    .boot-layout__surfaces {
2908      margin: 8px;
2909    }
2910    .boot-layout--single-page .boot-layout__surfaces {
2911      margin-top: 0;
2912      margin-left: 0;
2913    }
2914  }
2915  
2916  .boot-layout__stage,
2917  .boot-layout__inspector {
2918    flex: 1;
2919    overflow-y: auto;
2920    background: var(--wpds-color-bg-surface-neutral, #fff);
2921    color: var(--wpds-color-fg-content-neutral, #1e1e1e);
2922    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
2923    border: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);
2924    position: relative;
2925    position: fixed;
2926    top: 0;
2927    left: 0;
2928    right: 0;
2929    bottom: 0;
2930    width: 100vw;
2931    height: 100vh;
2932    border-radius: 0;
2933    margin: 0;
2934  }
2935  @media (min-width: 782px) {
2936    .boot-layout__stage,
2937    .boot-layout__inspector {
2938      position: static;
2939      width: auto;
2940      height: auto;
2941      border-radius: 8px;
2942      margin: 0;
2943    }
2944  }
2945  
2946  .boot-layout__stage {
2947    z-index: 2;
2948  }
2949  @media (min-width: 782px) {
2950    .boot-layout__stage {
2951      z-index: auto;
2952    }
2953  }
2954  
2955  .boot-layout__inspector {
2956    z-index: 3;
2957  }
2958  @media (min-width: 782px) {
2959    .boot-layout__inspector {
2960      z-index: auto;
2961    }
2962  }
2963  
2964  .boot-layout__canvas {
2965    flex: 1;
2966    overflow-y: auto;
2967    background: var(--wpds-color-bg-surface-neutral, #fff);
2968    color: var(--wpds-color-fg-content-neutral, #1e1e1e);
2969    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
2970    border: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);
2971    position: relative;
2972    position: fixed;
2973    top: 0;
2974    left: 0;
2975    right: 0;
2976    bottom: 0;
2977    width: 100vw;
2978    height: 100vh;
2979    z-index: 1;
2980    border-radius: 0;
2981    margin: 0;
2982  }
2983  @media (min-width: 782px) {
2984    .boot-layout__canvas {
2985      position: static;
2986      width: auto;
2987      height: auto;
2988      border-radius: 8px;
2989      z-index: auto;
2990    }
2991  }
2992  
2993  @media (min-width: 782px) {
2994    .boot-layout.has-canvas .boot-layout__stage,
2995    .boot-layout__inspector {
2996      max-width: 400px;
2997    }
2998  }
2999  
3000  .boot-layout__canvas .interface-interface-skeleton {
3001    position: relative;
3002    height: 100%;
3003    top: 0 !important;
3004    left: 0 !important;
3005  }
3006  
3007  .boot-layout.has-full-canvas .boot-layout__surfaces {
3008    margin: 0;
3009    gap: 0;
3010  }
3011  
3012  .boot-layout.has-full-canvas .boot-layout__stage,
3013  .boot-layout.has-full-canvas .boot-layout__inspector {
3014    display: none;
3015  }
3016  
3017  .boot-layout.has-full-canvas .boot-layout__canvas {
3018    position: fixed;
3019    top: 0;
3020    left: 0;
3021    right: 0;
3022    bottom: 0;
3023    max-width: none;
3024    margin: 0;
3025    border-radius: 0;
3026    border: none;
3027    box-shadow: none;
3028    overflow: hidden;
3029  }
3030  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src/components/root","sources":["../../../../../node_modules/@wordpress/base-styles/_variables.scss","../../../../../node_modules/@wordpress/base-styles/_colors.scss","../../../../../node_modules/@wordpress/base-styles/_mixins.scss","../../../../../node_modules/@wordpress/base-styles/_breakpoints.scss","../../../../../node_modules/@wordpress/base-styles/_functions.scss","../../../../../node_modules/@wordpress/base-styles/_long-content-fade.scss","style.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEnKA;AAAA;AAAA;ACAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AH4EA;AAAA;AAAA;AA0DA;AAAA;AAAA;AAgDA;AAAA;AAAA;AAqCA;AAAA;AAAA;AAoBA;AAAA;AAAA;AAwLA;AAAA;AAAA;AAAA;AAgDA;AAAA;AAAA;AIpdA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;;AAEA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA,SNIc;EMHd;EACA;EACA;EACA;;;AAGD;EACC;EACA;;;AAGD;EACC;EACA;EACA;EACA,KNdc;;AE0Dd;EIhDD;IAOE,QNjBa;;EMmBb;IACC;IACA;;;;AAKH;AAAA;EAEC;EACA;EACA;EACA;EACA;EACA;EACA;EAGA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AJaA;EIhCD;AAAA;IAuBE;IACA;IACA;IACA;IACA;;;;AAIF;EACC;;AJAA;EIDD;IAIE;;;;AAIF;EACC;;AJRA;EIOD;IAIE;;;;AAIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EAGA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AJlCA;EIeD;IAuBE;IACA;IACA;IACA;IACA;;;;AJ1CD;EI8CD;AAAA;IAGE;;;;AAIF;EACC;EACA;EACA;EACA;;;AAID;EACC;EACA;;;AAGD;AAAA;EAEC;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA","sourcesContent":["/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","/**\n * Typography\n */\n\n@use \"sass:color\";\n@use \"sass:math\";\n@use \"./variables\";\n@use \"./colors\";\n@use \"./breakpoints\";\n@use \"./functions\";\n@use \"./long-content-fade\";\n\n@mixin _text-heading() {\n\tfont-family: variables.$font-family-headings;\n\tfont-weight: variables.$font-weight-medium;\n}\n\n@mixin _text-body() {\n\tfont-family: variables.$font-family-body;\n\tfont-weight: variables.$font-weight-regular;\n}\n\n@mixin heading-small() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin heading-medium() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin heading-2x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-2x-large;\n\tline-height: variables.$font-line-height-2x-large;\n}\n\n@mixin body-small() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin body-medium() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin body-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin body-x-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-x-large;\n}\n\n/**\n * Breakpoint mixins\n */\n\n@mixin break-xhuge() {\n\t@media (min-width: #{ (breakpoints.$break-xhuge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-huge() {\n\t@media (min-width: #{ (breakpoints.$break-huge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-wide() {\n\t@media (min-width: #{ (breakpoints.$break-wide) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-xlarge() {\n\t@media (min-width: #{ (breakpoints.$break-xlarge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-large() {\n\t@media (min-width: #{ (breakpoints.$break-large) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-medium() {\n\t@media (min-width: #{ (breakpoints.$break-medium) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-small() {\n\t@media (min-width: #{ (breakpoints.$break-small) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-mobile() {\n\t@media (min-width: #{ (breakpoints.$break-mobile) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-zoomed-in() {\n\t@media (min-width: #{ (breakpoints.$break-zoomed-in) }) {\n\t\t@content;\n\t}\n}\n\n/**\n * Focus styles.\n */\n\n@mixin block-toolbar-button-style__focus() {\n\tbox-shadow: inset 0 0 0 variables.$border-width colors.$white, 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n// Tabs, Inputs, Square buttons.\n@mixin input-style__neutral() {\n\tbox-shadow: 0 0 0 transparent;\n\tborder-radius: variables.$radius-small;\n\tborder: variables.$border-width solid colors.$gray-600;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n}\n\n\n@mixin input-style__focus($accent-color: var(--wp-admin-theme-color)) {\n\tborder-color: $accent-color;\n\t// Expand the default border focus style by .5px to be a total of 1.5px.\n\tbox-shadow: 0 0 0 0.5px $accent-color;\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n@mixin button-style__focus() {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n\n@mixin button-style-outset__focus($focus-color) {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) colors.$white, 0 0 0 calc(2 * var(--wp-admin-border-width-focus)) $focus-color;\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n\toutline-offset: 2px;\n}\n\n\n/**\n * Applies editor left position to the selector passed as argument\n */\n\n@mixin editor-left($selector) {\n\t#{$selector} { /* Set left position when auto-fold is not on the body element. */\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t.auto-fold #{$selector} { /* Auto fold is when on smaller breakpoints, nav menu auto collapses. */\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\n\t\t@media (min-width: #{ (breakpoints.$break-large + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t/* Sidebar manually collapsed. */\n\t.folded #{$selector} {\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\t}\n\n\tbody.is-fullscreen-mode #{$selector} {\n\t\tleft: 0 !important;\n\t}\n}\n\n/**\n * Styles that are reused verbatim in a few places\n */\n\n// These are additional styles for all captions, when the theme opts in to block styles.\n@mixin caption-style() {\n\tmargin-top: 0.5em;\n\tmargin-bottom: 1em;\n}\n\n@mixin caption-style-theme() {\n\tcolor: #555;\n\tfont-size: variables.$default-font-size;\n\ttext-align: center;\n\n\t.is-dark-theme & {\n\t\tcolor: colors.$light-gray-placeholder;\n\t}\n}\n\n/**\n * Allows users to opt-out of animations via OS-level preferences.\n */\n\n@mixin reduce-motion($property: \"\") {\n\n\t@if $property == \"transition\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t}\n\t} @else if $property == \"animation\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t} @else {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t}\n}\n\n@mixin input-control($accent-color: var(--wp-admin-theme-color)) {\n\tfont-family: variables.$default-font;\n\tpadding: 6px 8px;\n\t/* Fonts smaller than 16px causes mobile safari to zoom. */\n\tfont-size: variables.$mobile-text-min-font-size;\n\t/* Override core line-height. To be reviewed. */\n\tline-height: normal;\n\t@include input-style__neutral();\n\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size;\n\t\t/* Override core line-height. To be reviewed. */\n\t\tline-height: normal;\n\t}\n\n\t&:focus {\n\t\t@include input-style__focus($accent-color);\n\t}\n\n\t// Use opacity to work in various editor styles.\n\t&::-webkit-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&::-moz-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&:-ms-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n}\n\n@mixin checkbox-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-small;\n\t@include input-control;\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t// Hide default checkbox styles in IE.\n\t\t&::-ms-check {\n\t\t\topacity: 0;\n\t\t}\n\t}\n\n\t&:checked::before,\n\t&[aria-checked=\"mixed\"]::before {\n\t\tmargin: -3px -5px;\n\t\tcolor: colors.$white;\n\n\t\t@include break-medium() {\n\t\t\tmargin: -4px 0 0 -5px;\n\t\t}\n\t}\n\n\t&[aria-checked=\"mixed\"] {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t&::before {\n\t\t\t// Inherited from `forms.css`.\n\t\t\t// See: https://github.com/WordPress/wordpress-develop/tree/5.1.1/src/wp-admin/css/forms.css#L122-L132\n\t\t\tcontent: \"\\f460\";\n\t\t\tfloat: left;\n\t\t\tdisplay: inline-block;\n\t\t\tvertical-align: middle;\n\t\t\twidth: 16px;\n\t\t\t/* stylelint-disable-next-line font-family-no-missing-generic-family-keyword -- dashicons don't need a generic family keyword. */\n\t\t\tfont: normal 30px/1 dashicons;\n\t\t\tspeak: none;\n\t\t\t-webkit-font-smoothing: antialiased;\n\t\t\t-moz-osx-font-smoothing: grayscale;\n\n\t\t\t@include break-medium() {\n\t\t\t\tfloat: none;\n\t\t\t\tfont-size: 21px;\n\t\t\t}\n\t\t}\n\t}\n\n\t&[aria-disabled=\"true\"],\n\t&:disabled {\n\t\tbackground: colors.$gray-100;\n\t\tborder-color: colors.$gray-300;\n\t\tcursor: default;\n\n\t\t// Override style inherited from wp-admin. Required to avoid degraded appearance on different backgrounds.\n\t\topacity: 1;\n\t}\n}\n\n@mixin radio-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-round;\n\twidth: variables.$radio-input-size-sm;\n\theight: variables.$radio-input-size-sm;\n\tmin-width: variables.$radio-input-size-sm;\n\tmax-width: variables.$radio-input-size-sm;\n\tposition: relative;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n\n\t@include break-small() {\n\t\theight: variables.$radio-input-size;\n\t\twidth: variables.$radio-input-size;\n\t\tmin-width: variables.$radio-input-size;\n\t\tmax-width: variables.$radio-input-size;\n\t}\n\n\t&:checked::before {\n\t\tbox-sizing: inherit;\n\t\twidth: math.div(variables.$radio-input-size-sm, 2);\n\t\theight: math.div(variables.$radio-input-size-sm, 2);\n\t\tposition: absolute;\n\t\ttop: 50%;\n\t\tleft: 50%;\n\t\ttransform: translate(-50%, -50%);\n\t\tmargin: 0;\n\t\tbackground-color: colors.$white;\n\n\t\t// This border serves as a background color in Windows High Contrast mode.\n\t\tborder: 4px solid colors.$white;\n\n\t\t@include break-small() {\n\t\t\twidth: math.div(variables.$radio-input-size, 2);\n\t\t\theight: math.div(variables.$radio-input-size, 2);\n\t\t}\n\t}\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder: none;\n\t}\n}\n\n/**\n * Reset default styles for JavaScript UI based pages.\n * This is a WP-admin agnostic reset\n */\n\n@mixin reset {\n\tbox-sizing: border-box;\n\n\t*,\n\t*::before,\n\t*::after {\n\t\tbox-sizing: inherit;\n\t}\n}\n\n@mixin link-reset {\n\t&:focus {\n\t\tcolor: var(--wp-admin-theme-color--rgb);\n\t\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color, #007cba);\n\t\tborder-radius: variables.$radius-small;\n\t}\n}\n\n// The editor input reset with increased specificity to avoid theme styles bleeding in.\n@mixin editor-input-reset() {\n\tfont-family: variables.$editor-html-font !important;\n\tcolor: colors.$gray-900 !important;\n\tbackground: colors.$white !important;\n\tpadding: variables.$grid-unit-15 !important;\n\tborder: variables.$border-width solid colors.$gray-900 !important;\n\tbox-shadow: none !important;\n\tborder-radius: variables.$radius-small !important;\n\n\t// Fonts smaller than 16px causes mobile safari to zoom.\n\tfont-size: variables.$mobile-text-min-font-size !important;\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size !important;\n\t}\n\n\t&:focus {\n\t\tborder-color: var(--wp-admin-theme-color) !important;\n\t\tbox-shadow: 0 0 0 (variables.$border-width-focus-fallback - variables.$border-width) var(--wp-admin-theme-color) !important;\n\n\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\toutline: 2px solid transparent !important;\n\t}\n}\n\n/**\n * Reset the WP Admin page styles for Gutenberg-like pages.\n */\n\n@mixin wp-admin-reset( $content-container ) {\n\tbackground: colors.$white;\n\n\t#wpcontent {\n\t\tpadding-left: 0;\n\t}\n\n\t#wpbody-content {\n\t\tpadding-bottom: 0;\n\t}\n\n\t/* We hide legacy notices in Gutenberg Based Pages, because they were not designed in a way that scaled well.\n\t   Plugins can use Gutenberg notices if they need to pass on information to the user when they are editing. */\n\t#wpbody-content > div:not(#{ $content-container }):not(#screen-meta) {\n\t\tdisplay: none;\n\t}\n\n\t#wpfooter {\n\t\tdisplay: none;\n\t}\n\n\t.a11y-speak-region {\n\t\tleft: -1px;\n\t\ttop: -1px;\n\t}\n\n\tul#adminmenu a.wp-has-current-submenu::after,\n\tul#adminmenu > li.current > a.current::after {\n\t\tborder-right-color: colors.$white;\n\t}\n\n\t.media-frame select.attachment-filters:last-of-type {\n\t\twidth: auto;\n\t\tmax-width: 100%;\n\t}\n}\n\n@mixin admin-scheme($color-primary) {\n\t// Define RGB equivalents for use in rgba function.\n\t// Hexadecimal css vars do not work in the rgba function.\n\t--wp-admin-theme-color: #{$color-primary};\n\t--wp-admin-theme-color--rgb: #{functions.hex-to-rgb($color-primary)};\n\t// Darker shades.\n\t--wp-admin-theme-color-darker-10: #{color.adjust($color-primary, $lightness: -5%)};\n\t--wp-admin-theme-color-darker-10--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -5%))};\n\t--wp-admin-theme-color-darker-20: #{color.adjust($color-primary, $lightness: -10%)};\n\t--wp-admin-theme-color-darker-20--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -10%))};\n\n\t// Focus style width.\n\t// Avoid rounding issues by showing a whole 2px for 1x screens, and 1.5px on high resolution screens.\n\t--wp-admin-border-width-focus: 2px;\n\t@media ( -webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {\n\t\t--wp-admin-border-width-focus: 1.5px;\n\t}\n}\n\n@mixin wordpress-admin-schemes() {\n\tbody.admin-color-light {\n\t\t@include admin-scheme(#0085ba);\n\t}\n\n\tbody.admin-color-modern {\n\t\t@include admin-scheme(#3858e9);\n\t}\n\n\tbody.admin-color-blue {\n\t\t@include admin-scheme(#096484);\n\t}\n\n\tbody.admin-color-coffee {\n\t\t@include admin-scheme(#46403c);\n\t}\n\n\tbody.admin-color-ectoplasm {\n\t\t@include admin-scheme(#523f6d);\n\t}\n\n\tbody.admin-color-midnight {\n\t\t@include admin-scheme(#e14d43);\n\t}\n\n\tbody.admin-color-ocean {\n\t\t@include admin-scheme(#627c83);\n\t}\n\n\tbody.admin-color-sunrise {\n\t\t@include admin-scheme(#dd823b);\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin background-colors-deprecated() {\n\t.has-very-light-gray-background-color {\n\t\tbackground-color: #eee;\n\t}\n\n\t.has-very-dark-gray-background-color {\n\t\tbackground-color: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin foreground-colors-deprecated() {\n\t.has-very-light-gray-color {\n\t\tcolor: #eee;\n\t}\n\n\t.has-very-dark-gray-color {\n\t\tcolor: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin gradient-colors-deprecated() {\n\t// Our classes uses the same values we set for gradient value attributes.\n\n\t/* stylelint-disable @stylistic/function-comma-space-after -- We can not use spacing because of WP multi site kses rule. */\n\t.has-vivid-green-cyan-to-vivid-cyan-blue-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgba(0,208,132,1) 0%,rgba(6,147,227,1) 100%);\n\t}\n\n\t.has-purple-crush-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(52,226,228) 0%,rgb(71,33,251) 50%,rgb(171,29,254) 100%);\n\t}\n\n\t.has-hazy-dawn-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,172,168) 0%,rgb(218,208,236) 100%);\n\t}\n\n\t.has-subdued-olive-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,250,225) 0%,rgb(103,166,113) 100%);\n\t}\n\n\t.has-atomic-cream-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(253,215,154) 0%,rgb(0,74,89) 100%);\n\t}\n\n\t.has-nightshade-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(51,9,104) 0%,rgb(49,205,207) 100%);\n\t}\n\n\t.has-midnight-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(2,3,129) 0%,rgb(40,116,252) 100%);\n\t}\n\t/* stylelint-enable @stylistic/function-comma-space-after */\n}\n\n@mixin custom-scrollbars-on-hover($handle-color, $handle-color-hover) {\n\n\t// WebKit\n\t&::-webkit-scrollbar {\n\t\twidth: 12px;\n\t\theight: 12px;\n\t}\n\t&::-webkit-scrollbar-track {\n\t\tbackground-color: transparent;\n\t}\n\t&::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color;\n\t\tborder-radius: 8px;\n\t\tborder: 3px solid transparent;\n\t\tbackground-clip: padding-box;\n\t}\n\t&:hover::-webkit-scrollbar-thumb, // This needs specificity.\n\t&:focus::-webkit-scrollbar-thumb,\n\t&:focus-within::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color-hover;\n\t}\n\n\t// Firefox 109+ and Chrome 111+\n\tscrollbar-width: thin;\n\tscrollbar-gutter: stable both-edges;\n\tscrollbar-color: $handle-color transparent; // Syntax, \"dark\", \"light\", or \"#handle-color #track-color\"\n\n\t&:hover,\n\t&:focus,\n\t&:focus-within {\n\t\tscrollbar-color: $handle-color-hover transparent;\n\t}\n\n\t// Needed to fix a Safari rendering issue.\n\twill-change: transform;\n\n\t// Always show scrollbar on Mobile devices.\n\t@media (hover: none) {\n\t\t& {\n\t\t\tscrollbar-color: $handle-color-hover transparent;\n\t\t}\n\t}\n}\n\n@mixin selected-block-outline($widthRatio: 1) {\n\toutline-color: var(--wp-admin-theme-color);\n\toutline-style: solid;\n\toutline-width: calc(#{$widthRatio} * (var(--wp-admin-border-width-focus) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n\toutline-offset: calc(#{$widthRatio} * ((-1 * var(--wp-admin-border-width-focus) ) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n}\n\n@mixin selected-block-focus($widthRatio: 1) {\n\tcontent: \"\";\n\tposition: absolute;\n\tpointer-events: none;\n\ttop: 0;\n\tright: 0;\n\tbottom: 0;\n\tleft: 0;\n\t@include selected-block-outline($widthRatio);\n}\n","/**\n * Breakpoints & Media Queries\n */\n\n// Most used breakpoints\n$break-xhuge: 1920px;\n$break-huge: 1440px;\n$break-wide: 1280px;\n$break-xlarge: 1080px;\n$break-large: 960px;\t// admin sidebar auto folds\n$break-medium: 782px;\t// adminbar goes big\n$break-small: 600px;\n$break-mobile: 480px;\n$break-zoomed-in: 280px;\n\n// All media queries currently in WordPress:\n//\n// min-width: 2000px\n// min-width: 1680px\n// min-width: 1250px\n// max-width: 1120px *\n// max-width: 1000px\n// min-width: 769px and max-width: 1000px\n// max-width: 960px *\n// max-width: 900px\n// max-width: 850px\n// min-width: 800px and max-width: 1499px\n// max-width: 800px\n// max-width: 799px\n// max-width: 782px *\n// max-width: 768px\n// max-width: 640px *\n// max-width: 600px *\n// max-width: 520px\n// max-width: 500px\n// max-width: 480px *\n// max-width: 400px *\n// max-width: 380px\n// max-width: 320px *\n//\n// Those marked * seem to be more commonly used than the others.\n// Let's try and use as few of these as possible, and be mindful about adding new ones, so we don't make the situation worse\n","/**\n*  Converts a hex value into the rgb equivalent.\n*\n* @param {string} hex - the hexadecimal value to convert\n* @return {string} comma separated rgb values\n*/\n\n@use \"sass:color\";\n@use \"sass:meta\";\n\n@function hex-to-rgb($hex) {\n\t/*\n\t * TODO: `color.{red|green|blue}` will trigger a deprecation warning in Dart Sass,\n\t * but the Sass used by the Gutenberg project doesn't support `color.channel()` yet,\n\t * so we can't migrate to it at this time.\n\t * In the future, after the Gutenberg project has been fully migrated to Dart Sass,\n\t * Remove this conditional statement and use only `color.channel()`.\n\t */\n\t@if meta.function-exists(\"channel\", \"color\") {\n\t\t@return color.channel($hex, \"red\"), color.channel($hex, \"green\"), color.channel($hex, \"blue\");\n\t} @else {\n\t\t@return color.red($hex), color.green($hex), color.blue($hex);\n\t}\n}\n","/**\n * Long content fade mixin\n *\n * Creates a fading overlay to signify that the content is longer\n * than the space allows.\n */\n\n@mixin long-content-fade($direction: right, $size: 20%, $color: #fff, $edge: 0, $z-index: false) {\n\tcontent: \"\";\n\tdisplay: block;\n\tposition: absolute;\n\t-webkit-touch-callout: none;\n\t-webkit-user-select: none;\n\t-khtml-user-select: none;\n\t-moz-user-select: none;\n\t-ms-user-select: none;\n\tuser-select: none;\n\tpointer-events: none;\n\n\t@if $z-index {\n\t\tz-index: $z-index;\n\t}\n\n\t@if $direction == \"bottom\" {\n\t\tbackground: linear-gradient(to top, transparent, $color 90%);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\ttop: $edge;\n\t\tbottom: calc(100% - $size);\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"top\" {\n\t\tbackground: linear-gradient(to bottom, transparent, $color 90%);\n\t\ttop: calc(100% - $size);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\tbottom: $edge;\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"left\" {\n\t\tbackground: linear-gradient(to left, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tleft: $edge;\n\t\tbottom: $edge;\n\t\tright: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n\n\t@if $direction == \"right\" {\n\t\tbackground: linear-gradient(to right, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tbottom: $edge;\n\t\tright: $edge;\n\t\tleft: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n}\n","@use \"@wordpress/base-styles/variables\";\n@use \"@wordpress/base-styles/mixins\";\n\n.boot-layout {\n\theight: 100%;\n\twidth: 100%;\n\tdisplay: flex;\n\tflex-direction: row;\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tisolation: isolate;\n\tbackground: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);\n}\n\n.boot-layout__sidebar-backdrop {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tbackground-color: rgba(0, 0, 0, 0.5);\n\tz-index: 100002;\n\tcursor: pointer;\n}\n\n.boot-layout__sidebar {\n\theight: 100%;\n\tflex-shrink: 0;\n\twidth: 240px;\n\tposition: relative;\n\toverflow: hidden;\n\n\t&.is-mobile {\n\t\tposition: fixed;\n\t\ttop: 0;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\twidth: 300px;\n\t\tmax-width: 85vw;\n\t\tbackground: var(--wpds-color-bg-surface-neutral-weak, #f0f0f0);\n\t\tz-index: 100003;\n\t\tbox-shadow: 2px 0 8px rgba(0, 0, 0, 0.2);\n\t}\n}\n\n.boot-layout__mobile-sidebar-drawer {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tz-index: 3;\n\tbackground: var(--wpds-color-bg-surface-neutral, #fff);\n\tpadding: variables.$grid-unit-20;\n\tborder-bottom: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);\n\tdisplay: flex;\n\tjustify-content: flex-start;\n\talign-items: center;\n}\n\n.boot-layout__canvas.has-mobile-drawer {\n\tposition: relative;\n\tpadding-top: 65px;\n}\n\n.boot-layout__surfaces {\n\tdisplay: flex;\n\tflex-grow: 1;\n\tmargin: 0;\n\tgap: variables.$grid-unit-10;\n\n\t@include mixins.break-medium {\n\t\tmargin: variables.$grid-unit-10;\n\n\t\t.boot-layout--single-page & {\n\t\t\tmargin-top: 0;\n\t\t\tmargin-left: 0;\n\t\t}\n\t}\n}\n\n.boot-layout__stage,\n.boot-layout__inspector {\n\tflex: 1;\n\toverflow-y: auto;\n\tbackground: var(--wpds-color-bg-surface-neutral, #fff);\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tbox-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);\n\tborder: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);\n\tposition: relative;\n\n\t// Mobile-first: surfaces take full screen with fixed positioning\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\twidth: 100vw;\n\theight: 100vh;\n\tborder-radius: 0;\n\tmargin: 0;\n\n\t// Desktop: restore original styles\n\t@include mixins.break-medium {\n\t\tposition: static;\n\t\twidth: auto;\n\t\theight: auto;\n\t\tborder-radius: 8px;\n\t\tmargin: 0;\n\t}\n}\n\n.boot-layout__stage {\n\tz-index: 2; // Highest surface priority on mobile\n\n\t@include mixins.break-medium {\n\t\tz-index: auto;\n\t}\n}\n\n.boot-layout__inspector {\n\tz-index: 3; // Medium surface priority on mobile\n\n\t@include mixins.break-medium {\n\t\tz-index: auto;\n\t}\n}\n\n.boot-layout__canvas {\n\tflex: 1;\n\toverflow-y: auto;\n\tbackground: var(--wpds-color-bg-surface-neutral, #fff);\n\tcolor: var(--wpds-color-fg-content-neutral, #1e1e1e);\n\tbox-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);\n\tborder: 1px solid var(--wpds-color-stroke-surface-neutral-weak, #ddd);\n\tposition: relative;\n\n\t// Mobile-first: full screen with lowest priority\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\twidth: 100vw;\n\theight: 100vh;\n\tz-index: 1; // Lowest surface priority\n\tborder-radius: 0;\n\tmargin: 0;\n\n\t// Desktop: restore original styles\n\t@include mixins.break-medium {\n\t\tposition: static;\n\t\twidth: auto;\n\t\theight: auto;\n\t\tborder-radius: 8px;\n\t\tz-index: auto;\n\t}\n}\n\n.boot-layout.has-canvas .boot-layout__stage,\n.boot-layout__inspector {\n\t@include mixins.break-medium {\n\t\tmax-width: 400px;\n\t}\n}\n\n.boot-layout__canvas .interface-interface-skeleton {\n\tposition: relative;\n\theight: 100%;\n\ttop: 0 !important;\n\tleft: 0 !important;\n}\n\n// Full-screen canvas mode\n.boot-layout.has-full-canvas .boot-layout__surfaces {\n\tmargin: 0;\n\tgap: 0;\n}\n\n.boot-layout.has-full-canvas .boot-layout__stage,\n.boot-layout.has-full-canvas .boot-layout__inspector {\n\tdisplay: none;\n}\n\n.boot-layout.has-full-canvas .boot-layout__canvas {\n\tposition: fixed;\n\ttop: 0;\n\tleft: 0;\n\tright: 0;\n\tbottom: 0;\n\tmax-width: none;\n\tmargin: 0;\n\tborder-radius: 0;\n\tborder: none;\n\tbox-shadow: none;\n\toverflow: hidden;\n}\n"]} */`;
3031  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css11));
3032  var { useMatches: useMatches4, Outlet: Outlet2 } = unlock(routePrivateApis7);
3033  function RootSinglePage() {
3034    const matches = useMatches4();
3035    const currentMatch = matches[matches.length - 1];
3036    const canvas = currentMatch?.loaderData?.canvas;
3037    const routeContentModule = currentMatch?.loaderData?.routeContentModule;
3038    const isFullScreen = canvas && !canvas.isPreview;
3039    useRouteTitle();
3040    return /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(UserThemeProvider, { isRoot: true, color: { bg: "#f8f8f8" }, children: /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(UserThemeProvider, { color: { bg: "#1d2327" }, children: /* @__PURE__ */ (0, import_jsx_runtime33.jsxs)(
3041      "div",
3042      {
3043        className: clsx_default("boot-layout boot-layout--single-page", {
3044          "has-canvas": !!canvas || canvas === null,
3045          "has-full-canvas": isFullScreen
3046        }),
3047        children: [
3048          /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(import_commands3.CommandMenu, {}),
3049          /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(SavePanel, {}),
3050          /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(import_editor5.EditorSnackbars, {}),
3051          /* @__PURE__ */ (0, import_jsx_runtime33.jsxs)("div", { className: "boot-layout__surfaces", children: [
3052            /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(UserThemeProvider, { color: { bg: "#ffffff" }, children: /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(Outlet2, {}) }),
3053            (canvas || canvas === null) && /* @__PURE__ */ (0, import_jsx_runtime33.jsx)("div", { className: "boot-layout__canvas", children: /* @__PURE__ */ (0, import_jsx_runtime33.jsx)(
3054              CanvasRenderer,
3055              {
3056                canvas,
3057                routeContentModule
3058              }
3059            ) })
3060          ] })
3061        ]
3062      }
3063    ) }) });
3064  }
3065  
3066  // packages/boot/build-module/components/app/index.js
3067  var import_jsx_runtime34 = __toESM(require_jsx_runtime());
3068  function App({ rootComponent }) {
3069    const routes = (0, import_data11.useSelect)((select) => select(store).getRoutes(), []);
3070    return /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(Router, { routes, rootComponent });
3071  }
3072  async function init({
3073    mountId,
3074    menuItems,
3075    routes,
3076    initModules
3077  }) {
3078    (menuItems ?? []).forEach((menuItem) => {
3079      (0, import_data11.dispatch)(store).registerMenuItem(menuItem.id, menuItem);
3080    });
3081    (routes ?? []).forEach((route) => {
3082      (0, import_data11.dispatch)(store).registerRoute(route);
3083    });
3084    for (const moduleId of initModules ?? []) {
3085      const module = await import(moduleId);
3086      await module.init();
3087    }
3088    const rootElement = document.getElementById(mountId);
3089    if (rootElement) {
3090      const root = (0, import_element15.createRoot)(rootElement);
3091      root.render(
3092        /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(import_element15.StrictMode, { children: /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(App, {}) })
3093      );
3094    }
3095  }
3096  async function initSinglePage({
3097    mountId,
3098    routes
3099  }) {
3100    (routes ?? []).forEach((route) => {
3101      (0, import_data11.dispatch)(store).registerRoute(route);
3102    });
3103    const rootElement = document.getElementById(mountId);
3104    if (rootElement) {
3105      const root = (0, import_element15.createRoot)(rootElement);
3106      root.render(
3107        /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(import_element15.StrictMode, { children: /* @__PURE__ */ (0, import_jsx_runtime34.jsx)(App, { rootComponent: RootSinglePage }) })
3108      );
3109    }
3110  }
3111  
3112  // packages/boot/build-module/index.js
3113  var css12 = `@charset "UTF-8";
3114  /* -------------------------------------------
3115   *  Autogenerated by \u26CB Terrazzo. DO NOT EDIT!
3116   * ------------------------------------------- */
3117  :root {
3118    --wpds-border-radius-surface-lg: 8px; /* Large radius for surfaces */
3119    --wpds-border-radius-surface-md: 4px; /* Medium radius for surfaces */
3120    --wpds-border-radius-surface-sm: 2px; /* Small radius for surfaces */
3121    --wpds-border-radius-surface-xs: 1px; /* Extra small radius for surfaces */
3122    --wpds-border-width-interactive-focus: 2px; /* Border width for focus ring */
3123    --wpds-border-width-surface-lg: 8px; /* Large width for surfaces */
3124    --wpds-border-width-surface-md: 4px; /* Medium width for surfaces */
3125    --wpds-border-width-surface-sm: 2px; /* Small width for surfaces */
3126    --wpds-border-width-surface-xs: 1px; /* Extra small width for surfaces */
3127    --wpds-color-bg-interactive-brand: #00000000; /* Background color for interactive elements with brand tone and normal emphasis. */
3128    --wpds-color-bg-interactive-brand-active: #f6f8fd; /* Background color for interactive elements with brand tone and normal emphasis that are hovered, focused, or active. */
3129    --wpds-color-bg-interactive-brand-disabled: #e2e2e2; /* Background color for interactive elements with brand tone and normal emphasis, in their disabled state. */
3130    --wpds-color-bg-interactive-brand-strong: #3858e9; /* Background color for interactive elements with brand tone and strong emphasis. */
3131    --wpds-color-bg-interactive-brand-strong-active: #2e49d9; /* Background color for interactive elements with brand tone and strong emphasis that are hovered, focused, or active. */
3132    --wpds-color-bg-interactive-brand-strong-disabled: #d2d2d2; /* Background color for interactive elements with brand tone and strong emphasis, in their disabled state. */
3133    --wpds-color-bg-interactive-brand-weak: #00000000; /* Background color for interactive elements with brand tone and weak emphasis. */
3134    --wpds-color-bg-interactive-brand-weak-active: #e6eaf4; /* Background color for interactive elements with brand tone and weak emphasis that are hovered, focused, or active. */
3135    --wpds-color-bg-interactive-brand-weak-disabled: #e2e2e2; /* Background color for interactive elements with brand tone and weak emphasis, in their disabled state. */
3136    --wpds-color-bg-interactive-error: #00000000; /* Background color for interactive elements with error tone and normal emphasis. */
3137    --wpds-color-bg-interactive-error-active: #fff6f4; /* Background color for interactive elements with error tone and normal emphasis that are hovered, focused, or active. */
3138    --wpds-color-bg-interactive-error-disabled: #e2e2e2; /* Background color for interactive elements with error tone and normal emphasis, in their disabled state. */
3139    --wpds-color-bg-interactive-error-strong: #cc1818; /* Background color for interactive elements with error tone and strong emphasis. */
3140    --wpds-color-bg-interactive-error-strong-active: #b90000; /* Background color for interactive elements with error tone and strong emphasis that are hovered, focused, or active. */
3141    --wpds-color-bg-interactive-error-strong-disabled: #d2d2d2; /* Background color for interactive elements with error tone and strong emphasis, in their disabled state. */
3142    --wpds-color-bg-interactive-error-weak: #00000000; /* Background color for interactive elements with error tone and weak emphasis. */
3143    --wpds-color-bg-interactive-error-weak-active: #f6e6e3; /* Background color for interactive elements with error tone and weak emphasis that are hovered, focused, or active. */
3144    --wpds-color-bg-interactive-error-weak-disabled: #e2e2e2; /* Background color for interactive elements with error tone and weak emphasis, in their disabled state. */
3145    --wpds-color-bg-interactive-neutral: #00000000; /* Background color for interactive elements with neutral tone and normal emphasis. */
3146    --wpds-color-bg-interactive-neutral-active: #eaeaea; /* Background color for interactive elements with neutral tone and normal emphasis that are hovered, focused, or active. */
3147    --wpds-color-bg-interactive-neutral-disabled: #e2e2e2; /* Background color for interactive elements with neutral tone and normal emphasis, in their disabled state. */
3148    --wpds-color-bg-interactive-neutral-strong: #2d2d2d; /* Background color for interactive elements with neutral tone and strong emphasis. */
3149    --wpds-color-bg-interactive-neutral-strong-active: #1e1e1e; /* Background color for interactive elements with neutral tone and strong emphasis that are hovered, focused, or active. */
3150    --wpds-color-bg-interactive-neutral-strong-disabled: #d2d2d2; /* Background color for interactive elements with neutral tone and strong emphasis, in their disabled state. */
3151    --wpds-color-bg-interactive-neutral-weak: #00000000; /* Background color for interactive elements with neutral tone and weak emphasis. */
3152    --wpds-color-bg-interactive-neutral-weak-active: #eaeaea; /* Background color for interactive elements with neutral tone and weak emphasis that are hovered, focused, or active. */
3153    --wpds-color-bg-interactive-neutral-weak-disabled: #e2e2e2; /* Background color for interactive elements with neutral tone and weak emphasis, in their disabled state. */
3154    --wpds-color-bg-surface-brand: #ecf0f9; /* Background color for surfaces with brand tone and normal emphasis. */
3155    --wpds-color-bg-surface-caution: #fee994; /* Background color for surfaces with caution tone and normal emphasis. */
3156    --wpds-color-bg-surface-caution-weak: #fff9c9; /* Background color for surfaces with caution tone and weak emphasis. */
3157    --wpds-color-bg-surface-error: #f6e6e3; /* Background color for surfaces with error tone and normal emphasis. */
3158    --wpds-color-bg-surface-error-weak: #fff6f4; /* Background color for surfaces with error tone and weak emphasis. */
3159    --wpds-color-bg-surface-info: #deebfa; /* Background color for surfaces with info tone and normal emphasis. */
3160    --wpds-color-bg-surface-info-weak: #f3f9ff; /* Background color for surfaces with info tone and weak emphasis. */
3161    --wpds-color-bg-surface-neutral: #f8f8f8; /* Background color for surfaces with normal emphasis. */
3162    --wpds-color-bg-surface-neutral-strong: #ffffff; /* Background color for surfaces with strong emphasis. */
3163    --wpds-color-bg-surface-neutral-weak: #f0f0f0; /* Background color for surfaces with weak emphasis. */
3164    --wpds-color-bg-surface-success: #c5f7cc; /* Background color for surfaces with success tone and normal emphasis. */
3165    --wpds-color-bg-surface-success-weak: #eaffed; /* Background color for surfaces with success tone and weak emphasis. */
3166    --wpds-color-bg-surface-warning: #fde6bd; /* Background color for surfaces with warning tone and normal emphasis. */
3167    --wpds-color-bg-surface-warning-weak: #fff7e0; /* Background color for surfaces with warning tone and weak emphasis. */
3168    --wpds-color-bg-thumb-brand: #3858e9; /* Background color for thumbs with a brand tone and normal emphasis (eg. slider thumb and filled track). */
3169    --wpds-color-bg-thumb-brand-active: #3858e9; /* Background color for thumbs with a brand tone and normal emphasis (eg. slider thumb and filled track) that are hovered, focused, or active. */
3170    --wpds-color-bg-thumb-brand-disabled: #d8d8d8; /* Background color for thumbs with a brand tone and normal emphasis (eg. slider thumb and filled track), in their disabled state. */
3171    --wpds-color-bg-thumb-neutral-weak: #8a8a8a; /* Background color for thumbs with a neutral tone and weak emphasis (eg. scrollbar thumb). */
3172    --wpds-color-bg-thumb-neutral-weak-active: #6c6c6c; /* Background color for thumbs with a neutral tone and weak emphasis (eg. scrollbar thumb) that are hovered, focused, or active. */
3173    --wpds-color-bg-track-neutral: #d8d8d8; /* Background color for tracks with a neutral tone and normal emphasis (eg. slider or progressbar track). */
3174    --wpds-color-bg-track-neutral-weak: #e0e0e0; /* Background color for tracks with a neutral tone and weak emphasis (eg. scrollbar track). */
3175    --wpds-color-fg-content-caution: #281d00; /* Foreground color for content like text with caution tone and normal emphasis. */
3176    --wpds-color-fg-content-caution-weak: #826a00; /* Foreground color for content like text with caution tone and weak emphasis. */
3177    --wpds-color-fg-content-error: #470000; /* Foreground color for content like text with error tone and normal emphasis. */
3178    --wpds-color-fg-content-error-weak: #cc1818; /* Foreground color for content like text with error tone and weak emphasis. */
3179    --wpds-color-fg-content-info: #001b4f; /* Foreground color for content like text with info tone and normal emphasis. */
3180    --wpds-color-fg-content-info-weak: #006bd7; /* Foreground color for content like text with info tone and weak emphasis. */
3181    --wpds-color-fg-content-neutral: #1e1e1e; /* Foreground color for content like text with normal emphasis. */
3182    --wpds-color-fg-content-neutral-weak: #6d6d6d; /* Foreground color for content like text with weak emphasis. */
3183    --wpds-color-fg-content-success: #002900; /* Foreground color for content like text with success tone and normal emphasis. */
3184    --wpds-color-fg-content-success-weak: #007f30; /* Foreground color for content like text with success tone and weak emphasis. */
3185    --wpds-color-fg-content-warning: #2e1900; /* Foreground color for content like text with warning tone and normal emphasis. */
3186    --wpds-color-fg-content-warning-weak: #926300; /* Foreground color for content like text with warning tone and weak emphasis. */
3187    --wpds-color-fg-interactive-brand: #3858e9; /* Foreground color for interactive elements with brand tone and normal emphasis. */
3188    --wpds-color-fg-interactive-brand-active: #3858e9; /* Foreground color for interactive elements with brand tone and normal emphasis that are hovered, focused, or active. */
3189    --wpds-color-fg-interactive-brand-disabled: #8a8a8a; /* Foreground color for interactive elements with brand tone and normal emphasis, in their disabled state. */
3190    --wpds-color-fg-interactive-brand-strong: #eff0f2; /* Foreground color for interactive elements with brand tone and strong emphasis. */
3191    --wpds-color-fg-interactive-brand-strong-active: #eff0f2; /* Foreground color for interactive elements with brand tone and strong emphasis that are hovered, focused, or active. */
3192    --wpds-color-fg-interactive-brand-strong-disabled: #6d6d6d; /* Foreground color for interactive elements with brand tone and strong emphasis, in their disabled state. */
3193    --wpds-color-fg-interactive-error: #cc1818; /* Foreground color for interactive elements with error tone and normal emphasis. */
3194    --wpds-color-fg-interactive-error-active: #cc1818; /* Foreground color for interactive elements with error tone and normal emphasis that are hovered, focused, or active. */
3195    --wpds-color-fg-interactive-error-disabled: #8a8a8a; /* Foreground color for interactive elements with error tone and normal emphasis, in their disabled state. */
3196    --wpds-color-fg-interactive-error-strong: #f2efef; /* Foreground color for interactive elements with error tone and strong emphasis. */
3197    --wpds-color-fg-interactive-error-strong-active: #f2efef; /* Foreground color for interactive elements with error tone and strong emphasis that are hovered, focused, or active. */
3198    --wpds-color-fg-interactive-error-strong-disabled: #6d6d6d; /* Foreground color for interactive elements with error tone and strong emphasis, in their disabled state. */
3199    --wpds-color-fg-interactive-neutral: #1e1e1e; /* Foreground color for interactive elements with neutral tone and normal emphasis. */
3200    --wpds-color-fg-interactive-neutral-active: #1e1e1e; /* Foreground color for interactive elements with neutral tone and normal emphasis that are hovered, focused, or active. */
3201    --wpds-color-fg-interactive-neutral-disabled: #8a8a8a; /* Foreground color for interactive elements with neutral tone and normal emphasis, in their disabled state. */
3202    --wpds-color-fg-interactive-neutral-strong: #f0f0f0; /* Foreground color for interactive elements with neutral tone and strong emphasis. */
3203    --wpds-color-fg-interactive-neutral-strong-active: #f0f0f0; /* Foreground color for interactive elements with neutral tone and strong emphasis that are hovered, focused, or active. */
3204    --wpds-color-fg-interactive-neutral-strong-disabled: #6d6d6d; /* Foreground color for interactive elements with neutral tone and strong emphasis, in their disabled state. */
3205    --wpds-color-fg-interactive-neutral-weak: #6d6d6d; /* Foreground color for interactive elements with neutral tone and weak emphasis. */
3206    --wpds-color-fg-interactive-neutral-weak-disabled: #8a8a8a; /* Foreground color for interactive elements with neutral tone and weak emphasis, in their disabled state. */
3207    --wpds-color-stroke-focus-brand: #3858e9; /* Accessible stroke color applied to focus rings. */
3208    --wpds-color-stroke-interactive-brand: #3858e9; /* Accessible stroke color used for interactive brand-toned elements with normal emphasis. */
3209    --wpds-color-stroke-interactive-brand-active: #2337c8; /* Accessible stroke color used for interactive brand-toned elements with normal emphasis that are hovered, focused, or active. */
3210    --wpds-color-stroke-interactive-error: #cc1818; /* Accessible stroke color used for interactive error-toned elements with normal emphasis. */
3211    --wpds-color-stroke-interactive-error-active: #9d0000; /* Accessible stroke color used for interactive error-toned elements with normal emphasis that are hovered, focused, or active. */
3212    --wpds-color-stroke-interactive-error-strong: #cc1818; /* Accessible stroke color used for interactive error-toned elements with strong emphasis. */
3213    --wpds-color-stroke-interactive-neutral: #8a8a8a; /* Accessible stroke color used for interactive neutrally-toned elements with normal emphasis. */
3214    --wpds-color-stroke-interactive-neutral-active: #6c6c6c; /* Accessible stroke color used for interactive neutrally-toned elements with normal emphasis that are hovered, focused, or active. */
3215    --wpds-color-stroke-interactive-neutral-disabled: #d8d8d8; /* Accessible stroke color used for interactive neutrally-toned elements with normal emphasis, in their disabled state. */
3216    --wpds-color-stroke-interactive-neutral-strong: #6c6c6c; /* Accessible stroke color used for interactive neutrally-toned elements with strong emphasis. */
3217    --wpds-color-stroke-surface-brand: #a3b1d4; /* Decorative stroke color used to define brand-toned surface boundaries with normal emphasis. */
3218    --wpds-color-stroke-surface-brand-strong: #3858e9; /* Decorative stroke color used to define brand-toned surface boundaries with strong emphasis. */
3219    --wpds-color-stroke-surface-error: #daa39b; /* Decorative stroke color used to define error-toned surface boundaries with normal emphasis. */
3220    --wpds-color-stroke-surface-error-strong: #cc1818; /* Decorative stroke color used to define error-toned surface boundaries with strong emphasis. */
3221    --wpds-color-stroke-surface-info: #9fbcdc; /* Decorative stroke color used to define info-toned surface boundaries with normal emphasis. */
3222    --wpds-color-stroke-surface-info-strong: #006bd7; /* Decorative stroke color used to define info-toned surface boundaries with strong emphasis. */
3223    --wpds-color-stroke-surface-neutral: #d8d8d8; /* Decorative stroke color used to define neutrally-toned surface boundaries with normal emphasis. */
3224    --wpds-color-stroke-surface-neutral-strong: #8a8a8a; /* Decorative stroke color used to define neutrally-toned surface boundaries with strong emphasis. */
3225    --wpds-color-stroke-surface-neutral-weak: #e0e0e0; /* Decorative stroke color used to define neutrally-toned surface boundaries with weak emphasis. */
3226    --wpds-color-stroke-surface-success: #8ac894; /* Decorative stroke color used to define success-toned surface boundaries with normal emphasis. */
3227    --wpds-color-stroke-surface-success-strong: #007f30; /* Decorative stroke color used to define success-toned surface boundaries with strong emphasis. */
3228    --wpds-color-stroke-surface-warning: #d0b381; /* Decorative stroke color used to define warning-toned surface boundaries with normal emphasis. */
3229    --wpds-color-stroke-surface-warning-strong: #926300; /* Decorative stroke color used to define warning-toned surface boundaries with strong emphasis. */
3230    --wpds-dimension-base: 4px; /* Base dimension unit */
3231    --wpds-dimension-gap-2xs: 4px; /* 2x extra small gap */
3232    --wpds-dimension-gap-lg: 24px; /* Large gap */
3233    --wpds-dimension-gap-md: 16px; /* Medium gap */
3234    --wpds-dimension-gap-sm: 12px; /* Small gap */
3235    --wpds-dimension-gap-xl: 40px; /* Extra large gap */
3236    --wpds-dimension-gap-xs: 8px; /* Extra small gap */
3237    --wpds-dimension-padding-surface-2xs: 4px; /* 2x extra small spacing for surfaces */
3238    --wpds-dimension-padding-surface-lg: 32px; /* Large spacing for surfaces */
3239    --wpds-dimension-padding-surface-md: 24px; /* Medium spacing for surfaces */
3240    --wpds-dimension-padding-surface-sm: 16px; /* Small spacing for surfaces */
3241    --wpds-dimension-padding-surface-xs: 8px; /* Extra small spacing for surfaces */
3242    --wpds-elevation-large: 0 5px 15px 0 #00000014, 0 15px 27px 0 #00000012,
3243        0 30px 36px 0 #0000000a, 0 50px 43px 0 #00000005; /* For components that confirm decisions or handle necessary interruptions. Example: Modals. */
3244    --wpds-elevation-medium: 0 2px 3px 0 #0000000d, 0 4px 5px 0 #0000000a,
3245        0 12px 12px 0 #00000008, 0 16px 16px 0 #00000005; /* For components that offer additional actions. Example: Menus, Command Palette */
3246    --wpds-elevation-small: 0 1px 2px 0 #0000000d, 0 2px 3px 0 #0000000a,
3247        0 6px 6px 0 #00000008, 0 8px 8px 0 #00000005; /* For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar. */
3248    --wpds-elevation-x-small: 0 1px 1px 0 #00000008, 0 1px 2px 0 #00000005,
3249        0 3px 3px 0 #00000005, 0 4px 4px 0 #00000003; /* For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame. */
3250    --wpds-font-family-body: -apple-system, system-ui, "Segoe UI", "Roboto",
3251        "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", sans-serif; /* Body font family */
3252    --wpds-font-family-heading: -apple-system, system-ui, "Segoe UI", "Roboto",
3253        "Oxygen-Sans", "Ubuntu", "Cantarell", "Helvetica Neue", sans-serif; /* Headings font family */
3254    --wpds-font-family-mono: "Menlo", "Consolas", monaco, monospace; /* Monospace font family */
3255    --wpds-font-line-height-2x-large: 40px; /* 2X large line height */
3256    --wpds-font-line-height-large: 28px; /* Large line height */
3257    --wpds-font-line-height-medium: 24px; /* Medium line height */
3258    --wpds-font-line-height-small: 20px; /* Small line height */
3259    --wpds-font-line-height-x-large: 32px; /* Extra large line height */
3260    --wpds-font-line-height-x-small: 16px; /* Extra small line height */
3261    --wpds-font-size-2x-large: 32px; /* 2X large font size */
3262    --wpds-font-size-large: 15px; /* Large font size */
3263    --wpds-font-size-medium: 13px; /* Medium font size */
3264    --wpds-font-size-small: 12px; /* Small font size */
3265    --wpds-font-size-x-large: 20px; /* Extra large font size */
3266    --wpds-font-size-x-small: 11px; /* Extra small font size */
3267  }
3268  
3269  [data-wpds-theme-provider-id][data-wpds-density=default] {
3270    --wpds-dimension-base: 4px; /* Base dimension unit */
3271    --wpds-dimension-gap-2xs: 4px; /* 2x extra small gap */
3272    --wpds-dimension-gap-lg: 24px; /* Large gap */
3273    --wpds-dimension-gap-md: 16px; /* Medium gap */
3274    --wpds-dimension-gap-sm: 12px; /* Small gap */
3275    --wpds-dimension-gap-xl: 40px; /* Extra large gap */
3276    --wpds-dimension-gap-xs: 8px; /* Extra small gap */
3277    --wpds-dimension-padding-surface-2xs: 4px; /* 2x extra small spacing for surfaces */
3278    --wpds-dimension-padding-surface-lg: 32px; /* Large spacing for surfaces */
3279    --wpds-dimension-padding-surface-md: 24px; /* Medium spacing for surfaces */
3280    --wpds-dimension-padding-surface-sm: 16px; /* Small spacing for surfaces */
3281    --wpds-dimension-padding-surface-xs: 8px; /* Extra small spacing for surfaces */
3282  }
3283  
3284  [data-wpds-theme-provider-id][data-wpds-density=compact] {
3285    --wpds-dimension-gap-2xs: 4px; /* 2x extra small gap */
3286    --wpds-dimension-gap-lg: 20px; /* Large gap */
3287    --wpds-dimension-gap-md: 12px; /* Medium gap */
3288    --wpds-dimension-gap-sm: 8px; /* Small gap */
3289    --wpds-dimension-gap-xl: 32px; /* Extra large gap */
3290    --wpds-dimension-gap-xs: 4px; /* Extra small gap */
3291    --wpds-dimension-padding-surface-2xs: 4px; /* 2x extra small spacing for surfaces */
3292    --wpds-dimension-padding-surface-lg: 24px; /* Large spacing for surfaces */
3293    --wpds-dimension-padding-surface-md: 20px; /* Medium spacing for surfaces */
3294    --wpds-dimension-padding-surface-sm: 12px; /* Small spacing for surfaces */
3295    --wpds-dimension-padding-surface-xs: 4px; /* Extra small spacing for surfaces */
3296  }
3297  
3298  [data-wpds-theme-provider-id][data-wpds-density=comfortable] {
3299    --wpds-dimension-gap-2xs: 8px; /* 2x extra small gap */
3300    --wpds-dimension-gap-lg: 32px; /* Large gap */
3301    --wpds-dimension-gap-md: 20px; /* Medium gap */
3302    --wpds-dimension-gap-sm: 16px; /* Small gap */
3303    --wpds-dimension-gap-xl: 48px; /* Extra large gap */
3304    --wpds-dimension-gap-xs: 12px; /* Extra small gap */
3305    --wpds-dimension-padding-surface-2xs: 8px; /* 2x extra small spacing for surfaces */
3306    --wpds-dimension-padding-surface-lg: 40px; /* Large spacing for surfaces */
3307    --wpds-dimension-padding-surface-md: 32px; /* Medium spacing for surfaces */
3308    --wpds-dimension-padding-surface-sm: 20px; /* Small spacing for surfaces */
3309    --wpds-dimension-padding-surface-xs: 12px; /* Extra small spacing for surfaces */
3310  }
3311  
3312  @media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
3313    :root {
3314      --wpds-border-width-interactive-focus: 1.5px; /* Border width for focus ring */
3315    }
3316  }
3317  /**
3318   * Colors
3319   */
3320  /**
3321   * SCSS Variables.
3322   *
3323   * Please use variables from this sheet to ensure consistency across the UI.
3324   * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
3325   * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
3326   */
3327  /**
3328   * Fonts & basic variables.
3329   */
3330  /**
3331   * Typography
3332   */
3333  /**
3334   * Grid System.
3335   * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
3336   */
3337  /**
3338   * Radius scale.
3339   */
3340  /**
3341   * Elevation scale.
3342   */
3343  /**
3344   * Dimensions.
3345   */
3346  /**
3347   * Mobile specific styles
3348   */
3349  /**
3350   * Editor styles.
3351   */
3352  /**
3353   * Block & Editor UI.
3354   */
3355  /**
3356   * Block paddings.
3357   */
3358  /**
3359   * React Native specific.
3360   * These variables do not appear to be used anywhere else.
3361   */
3362  /**
3363   * Typography
3364   */
3365  /**
3366   * Breakpoints & Media Queries
3367   */
3368  /**
3369  *  Converts a hex value into the rgb equivalent.
3370  *
3371  * @param {string} hex - the hexadecimal value to convert
3372  * @return {string} comma separated rgb values
3373  */
3374  /**
3375   * Long content fade mixin
3376   *
3377   * Creates a fading overlay to signify that the content is longer
3378   * than the space allows.
3379   */
3380  /**
3381   * Breakpoint mixins
3382   */
3383  /**
3384   * Focus styles.
3385   */
3386  /**
3387   * Applies editor left position to the selector passed as argument
3388   */
3389  /**
3390   * Styles that are reused verbatim in a few places
3391   */
3392  /**
3393   * Allows users to opt-out of animations via OS-level preferences.
3394   */
3395  /**
3396   * Reset default styles for JavaScript UI based pages.
3397   * This is a WP-admin agnostic reset
3398   */
3399  /**
3400   * Reset the WP Admin page styles for Gutenberg-like pages.
3401   */
3402  .admin-ui-page {
3403    display: flex;
3404    height: 100%;
3405    background-color: #fff;
3406    color: #2f2f2f;
3407    position: relative;
3408    z-index: 1;
3409    flex-flow: column;
3410  }
3411  
3412  .admin-ui-page__header {
3413    padding: 16px 24px;
3414    border-bottom: 1px solid #f0f0f0;
3415    background: #fff;
3416    position: sticky;
3417    top: 0;
3418    z-index: 1;
3419  }
3420  
3421  .admin-ui-page__sidebar-toggle-slot:empty {
3422    display: none;
3423  }
3424  
3425  .admin-ui-page__header-subtitle {
3426    padding-block-end: 8px;
3427    color: #757575;
3428    font-family: -apple-system, "system-ui", "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
3429    font-weight: 400;
3430    font-size: 13px;
3431    line-height: 20px;
3432    margin: 0;
3433  }
3434  
3435  .admin-ui-page__content {
3436    flex-grow: 1;
3437    overflow: auto;
3438    display: flex;
3439    flex-direction: column;
3440  }
3441  
3442  .admin-ui-page__content.has-padding {
3443    padding: 16px 24px;
3444  }
3445  
3446  .show-icon-labels .admin-ui-page__header-actions .components-button.has-icon {
3447    width: auto;
3448    padding: 0 8px;
3449  }
3450  
3451  .show-icon-labels .admin-ui-page__header-actions .components-button.has-icon svg {
3452    display: none;
3453  }
3454  
3455  .show-icon-labels .admin-ui-page__header-actions .components-button.has-icon::after {
3456    content: attr(aria-label);
3457    font-size: 12px;
3458  }
3459  
3460  .admin-ui-breadcrumbs__list {
3461    list-style: none;
3462    padding: 0;
3463    margin: 0;
3464    gap: 0;
3465    font-size: 15px;
3466    min-height: 32px;
3467    font-weight: 500;
3468  }
3469  
3470  .admin-ui-breadcrumbs__list li:not(:last-child)::after {
3471    content: "/";
3472    margin: 0 8px;
3473  }
3474  
3475  .admin-ui-breadcrumbs__list h1 {
3476    font-size: inherit;
3477    line-height: inherit;
3478  }
3479  
3480  /**
3481   * Typography
3482   */
3483  /**
3484   * SCSS Variables.
3485   *
3486   * Please use variables from this sheet to ensure consistency across the UI.
3487   * Don't add to this sheet unless you're pretty sure the value will be reused in many places.
3488   * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.
3489   */
3490  /**
3491   * Colors
3492   */
3493  /**
3494   * Fonts & basic variables.
3495   */
3496  /**
3497   * Typography
3498   */
3499  /**
3500   * Grid System.
3501   * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/
3502   */
3503  /**
3504   * Radius scale.
3505   */
3506  /**
3507   * Elevation scale.
3508   */
3509  /**
3510   * Dimensions.
3511   */
3512  /**
3513   * Mobile specific styles
3514   */
3515  /**
3516   * Editor styles.
3517   */
3518  /**
3519   * Block & Editor UI.
3520   */
3521  /**
3522   * Block paddings.
3523   */
3524  /**
3525   * React Native specific.
3526   * These variables do not appear to be used anywhere else.
3527   */
3528  /**
3529   * Breakpoints & Media Queries
3530   */
3531  /**
3532  *  Converts a hex value into the rgb equivalent.
3533  *
3534  * @param {string} hex - the hexadecimal value to convert
3535  * @return {string} comma separated rgb values
3536  */
3537  /**
3538   * Long content fade mixin
3539   *
3540   * Creates a fading overlay to signify that the content is longer
3541   * than the space allows.
3542   */
3543  /**
3544   * Breakpoint mixins
3545   */
3546  /**
3547   * Focus styles.
3548   */
3549  /**
3550   * Applies editor left position to the selector passed as argument
3551   */
3552  /**
3553   * Styles that are reused verbatim in a few places
3554   */
3555  /**
3556   * Allows users to opt-out of animations via OS-level preferences.
3557   */
3558  /**
3559   * Reset default styles for JavaScript UI based pages.
3560   * This is a WP-admin agnostic reset
3561   */
3562  /**
3563   * Reset the WP Admin page styles for Gutenberg-like pages.
3564   */
3565  @media (min-width: 600px) {
3566    .boot-layout-container .boot-layout {
3567      position: absolute;
3568      top: 0;
3569      right: 0;
3570      bottom: 0;
3571      left: 0;
3572      min-height: calc(100vh - 46px);
3573    }
3574  }
3575  @media (min-width: 782px) {
3576    .boot-layout-container .boot-layout {
3577      min-height: calc(100vh - 32px);
3578    }
3579    body:has(.boot-layout.has-full-canvas) .boot-layout-container .boot-layout {
3580      min-height: 100vh;
3581    }
3582  }
3583  .boot-layout-container .boot-layout img {
3584    max-width: 100%;
3585    height: auto;
3586  }
3587  
3588  .boot-layout .components-editor-notices__snackbar {
3589    position: fixed;
3590    right: 0;
3591    bottom: 16px;
3592    padding-left: 16px;
3593    padding-right: 16px;
3594  }
3595  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src","sources":["../../../node_modules/@wordpress/theme/src/prebuilt/css/design-tokens.css","../../../node_modules/@wordpress/admin-ui/build-style/style.css","../../../node_modules/@wordpress/base-styles/_mixins.scss","../../../node_modules/@wordpress/base-styles/_variables.scss","../../../node_modules/@wordpress/base-styles/_colors.scss","../../../node_modules/@wordpress/base-styles/_breakpoints.scss","../../../node_modules/@wordpress/base-styles/_functions.scss","../../../node_modules/@wordpress/base-styles/_long-content-fade.scss","style.scss"],"names":[],"mappings":";AAAA;AAAA;AAAA;AAIA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAAA,qDACmD;EACnD;AAAA,qDACmD;EACnD;AAAA,iDAC+C;EAC/C;AAAA,iDAC+C;EAC/C;AAAA,uEACqE;EACrE;AAAA,uEACqE;EACrE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;IACC;;;ACzMF;AAAA;AAAA;AAGA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAAA;AAIA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAAA;AAIA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAGA;AAAA;AAAA;AAAA;AAIA;AAAA;AAAA;AAGA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;;;AAEF;EACE;;;AAGF;EACE;EACA;;;AAEF;EACE;;;AAEF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;;AAEF;EACE;EACA;;;AAEF;EACE;EACA;;;AC3JF;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;ADUA;AAAA;AAAA;AAOA;AAAA;AAAA;AA6BA;AAAA;AAAA;AAAA;AAiBA;AAAA;AAAA;AAWA;AAAA;AAAA;AAgBA;AAAA;AAAA;AAyBA;AAAA;AAAA;AAKA;AAAA;AAAA;AAeA;AAAA;AAAA;AAmBA;AAAA;AAAA;AASA;AAAA;AAAA;AAAA;AEnKA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AL4EA;AAAA;AAAA;AA0DA;AAAA;AAAA;AAgDA;AAAA;AAAA;AAqCA;AAAA;AAAA;AAoBA;AAAA;AAAA;AAwLA;AAAA;AAAA;AAAA;AAgDA;AAAA;AAAA;AAlWC;EMhHD;IAIE;IACA;IACA;IACA;IACA;IACA;;;ANiGD;EM1GD;IAcE;;EAEA;IACC;;;AAIF;EACC;EACA;;;AAIF;EACC;EACA;EACA;EACA;EACA","sourcesContent":["/* -------------------------------------------\n *  Autogenerated by ⛋ Terrazzo. DO NOT EDIT!\n * ------------------------------------------- */\n\n:root {\n\t--wpds-border-radius-surface-lg: 8px; /* Large radius for surfaces */\n\t--wpds-border-radius-surface-md: 4px; /* Medium radius for surfaces */\n\t--wpds-border-radius-surface-sm: 2px; /* Small radius for surfaces */\n\t--wpds-border-radius-surface-xs: 1px; /* Extra small radius for surfaces */\n\t--wpds-border-width-interactive-focus: 2px; /* Border width for focus ring */\n\t--wpds-border-width-surface-lg: 8px; /* Large width for surfaces */\n\t--wpds-border-width-surface-md: 4px; /* Medium width for surfaces */\n\t--wpds-border-width-surface-sm: 2px; /* Small width for surfaces */\n\t--wpds-border-width-surface-xs: 1px; /* Extra small width for surfaces */\n\t--wpds-color-bg-interactive-brand: #00000000; /* Background color for interactive elements with brand tone and normal emphasis. */\n\t--wpds-color-bg-interactive-brand-active: #f6f8fd; /* Background color for interactive elements with brand tone and normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-brand-disabled: #e2e2e2; /* Background color for interactive elements with brand tone and normal emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-brand-strong: #3858e9; /* Background color for interactive elements with brand tone and strong emphasis. */\n\t--wpds-color-bg-interactive-brand-strong-active: #2e49d9; /* Background color for interactive elements with brand tone and strong emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-brand-strong-disabled: #d2d2d2; /* Background color for interactive elements with brand tone and strong emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-brand-weak: #00000000; /* Background color for interactive elements with brand tone and weak emphasis. */\n\t--wpds-color-bg-interactive-brand-weak-active: #e6eaf4; /* Background color for interactive elements with brand tone and weak emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-brand-weak-disabled: #e2e2e2; /* Background color for interactive elements with brand tone and weak emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-error: #00000000; /* Background color for interactive elements with error tone and normal emphasis. */\n\t--wpds-color-bg-interactive-error-active: #fff6f4; /* Background color for interactive elements with error tone and normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-error-disabled: #e2e2e2; /* Background color for interactive elements with error tone and normal emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-error-strong: #cc1818; /* Background color for interactive elements with error tone and strong emphasis. */\n\t--wpds-color-bg-interactive-error-strong-active: #b90000; /* Background color for interactive elements with error tone and strong emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-error-strong-disabled: #d2d2d2; /* Background color for interactive elements with error tone and strong emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-error-weak: #00000000; /* Background color for interactive elements with error tone and weak emphasis. */\n\t--wpds-color-bg-interactive-error-weak-active: #f6e6e3; /* Background color for interactive elements with error tone and weak emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-error-weak-disabled: #e2e2e2; /* Background color for interactive elements with error tone and weak emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-neutral: #00000000; /* Background color for interactive elements with neutral tone and normal emphasis. */\n\t--wpds-color-bg-interactive-neutral-active: #eaeaea; /* Background color for interactive elements with neutral tone and normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-neutral-disabled: #e2e2e2; /* Background color for interactive elements with neutral tone and normal emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-neutral-strong: #2d2d2d; /* Background color for interactive elements with neutral tone and strong emphasis. */\n\t--wpds-color-bg-interactive-neutral-strong-active: #1e1e1e; /* Background color for interactive elements with neutral tone and strong emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-neutral-strong-disabled: #d2d2d2; /* Background color for interactive elements with neutral tone and strong emphasis, in their disabled state. */\n\t--wpds-color-bg-interactive-neutral-weak: #00000000; /* Background color for interactive elements with neutral tone and weak emphasis. */\n\t--wpds-color-bg-interactive-neutral-weak-active: #eaeaea; /* Background color for interactive elements with neutral tone and weak emphasis that are hovered, focused, or active. */\n\t--wpds-color-bg-interactive-neutral-weak-disabled: #e2e2e2; /* Background color for interactive elements with neutral tone and weak emphasis, in their disabled state. */\n\t--wpds-color-bg-surface-brand: #ecf0f9; /* Background color for surfaces with brand tone and normal emphasis. */\n\t--wpds-color-bg-surface-caution: #fee994; /* Background color for surfaces with caution tone and normal emphasis. */\n\t--wpds-color-bg-surface-caution-weak: #fff9c9; /* Background color for surfaces with caution tone and weak emphasis. */\n\t--wpds-color-bg-surface-error: #f6e6e3; /* Background color for surfaces with error tone and normal emphasis. */\n\t--wpds-color-bg-surface-error-weak: #fff6f4; /* Background color for surfaces with error tone and weak emphasis. */\n\t--wpds-color-bg-surface-info: #deebfa; /* Background color for surfaces with info tone and normal emphasis. */\n\t--wpds-color-bg-surface-info-weak: #f3f9ff; /* Background color for surfaces with info tone and weak emphasis. */\n\t--wpds-color-bg-surface-neutral: #f8f8f8; /* Background color for surfaces with normal emphasis. */\n\t--wpds-color-bg-surface-neutral-strong: #ffffff; /* Background color for surfaces with strong emphasis. */\n\t--wpds-color-bg-surface-neutral-weak: #f0f0f0; /* Background color for surfaces with weak emphasis. */\n\t--wpds-color-bg-surface-success: #c5f7cc; /* Background color for surfaces with success tone and normal emphasis. */\n\t--wpds-color-bg-surface-success-weak: #eaffed; /* Background color for surfaces with success tone and weak emphasis. */\n\t--wpds-color-bg-surface-warning: #fde6bd; /* Background color for surfaces with warning tone and normal emphasis. */\n\t--wpds-color-bg-surface-warning-weak: #fff7e0; /* Background color for surfaces with warning tone and weak emphasis. */\n\t--wpds-color-bg-thumb-brand: #3858e9; /* Background color for thumbs with a brand tone and normal emphasis (eg. slider thumb and filled track). */\n\t--wpds-color-bg-thumb-brand-active: #3858e9; /* Background color for thumbs with a brand tone and normal emphasis (eg. slider thumb and filled track) that are hovered, focused, or active. */\n\t--wpds-color-bg-thumb-brand-disabled: #d8d8d8; /* Background color for thumbs with a brand tone and normal emphasis (eg. slider thumb and filled track), in their disabled state. */\n\t--wpds-color-bg-thumb-neutral-weak: #8a8a8a; /* Background color for thumbs with a neutral tone and weak emphasis (eg. scrollbar thumb). */\n\t--wpds-color-bg-thumb-neutral-weak-active: #6c6c6c; /* Background color for thumbs with a neutral tone and weak emphasis (eg. scrollbar thumb) that are hovered, focused, or active. */\n\t--wpds-color-bg-track-neutral: #d8d8d8; /* Background color for tracks with a neutral tone and normal emphasis (eg. slider or progressbar track). */\n\t--wpds-color-bg-track-neutral-weak: #e0e0e0; /* Background color for tracks with a neutral tone and weak emphasis (eg. scrollbar track). */\n\t--wpds-color-fg-content-caution: #281d00; /* Foreground color for content like text with caution tone and normal emphasis. */\n\t--wpds-color-fg-content-caution-weak: #826a00; /* Foreground color for content like text with caution tone and weak emphasis. */\n\t--wpds-color-fg-content-error: #470000; /* Foreground color for content like text with error tone and normal emphasis. */\n\t--wpds-color-fg-content-error-weak: #cc1818; /* Foreground color for content like text with error tone and weak emphasis. */\n\t--wpds-color-fg-content-info: #001b4f; /* Foreground color for content like text with info tone and normal emphasis. */\n\t--wpds-color-fg-content-info-weak: #006bd7; /* Foreground color for content like text with info tone and weak emphasis. */\n\t--wpds-color-fg-content-neutral: #1e1e1e; /* Foreground color for content like text with normal emphasis. */\n\t--wpds-color-fg-content-neutral-weak: #6d6d6d; /* Foreground color for content like text with weak emphasis. */\n\t--wpds-color-fg-content-success: #002900; /* Foreground color for content like text with success tone and normal emphasis. */\n\t--wpds-color-fg-content-success-weak: #007f30; /* Foreground color for content like text with success tone and weak emphasis. */\n\t--wpds-color-fg-content-warning: #2e1900; /* Foreground color for content like text with warning tone and normal emphasis. */\n\t--wpds-color-fg-content-warning-weak: #926300; /* Foreground color for content like text with warning tone and weak emphasis. */\n\t--wpds-color-fg-interactive-brand: #3858e9; /* Foreground color for interactive elements with brand tone and normal emphasis. */\n\t--wpds-color-fg-interactive-brand-active: #3858e9; /* Foreground color for interactive elements with brand tone and normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-fg-interactive-brand-disabled: #8a8a8a; /* Foreground color for interactive elements with brand tone and normal emphasis, in their disabled state. */\n\t--wpds-color-fg-interactive-brand-strong: #eff0f2; /* Foreground color for interactive elements with brand tone and strong emphasis. */\n\t--wpds-color-fg-interactive-brand-strong-active: #eff0f2; /* Foreground color for interactive elements with brand tone and strong emphasis that are hovered, focused, or active. */\n\t--wpds-color-fg-interactive-brand-strong-disabled: #6d6d6d; /* Foreground color for interactive elements with brand tone and strong emphasis, in their disabled state. */\n\t--wpds-color-fg-interactive-error: #cc1818; /* Foreground color for interactive elements with error tone and normal emphasis. */\n\t--wpds-color-fg-interactive-error-active: #cc1818; /* Foreground color for interactive elements with error tone and normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-fg-interactive-error-disabled: #8a8a8a; /* Foreground color for interactive elements with error tone and normal emphasis, in their disabled state. */\n\t--wpds-color-fg-interactive-error-strong: #f2efef; /* Foreground color for interactive elements with error tone and strong emphasis. */\n\t--wpds-color-fg-interactive-error-strong-active: #f2efef; /* Foreground color for interactive elements with error tone and strong emphasis that are hovered, focused, or active. */\n\t--wpds-color-fg-interactive-error-strong-disabled: #6d6d6d; /* Foreground color for interactive elements with error tone and strong emphasis, in their disabled state. */\n\t--wpds-color-fg-interactive-neutral: #1e1e1e; /* Foreground color for interactive elements with neutral tone and normal emphasis. */\n\t--wpds-color-fg-interactive-neutral-active: #1e1e1e; /* Foreground color for interactive elements with neutral tone and normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-fg-interactive-neutral-disabled: #8a8a8a; /* Foreground color for interactive elements with neutral tone and normal emphasis, in their disabled state. */\n\t--wpds-color-fg-interactive-neutral-strong: #f0f0f0; /* Foreground color for interactive elements with neutral tone and strong emphasis. */\n\t--wpds-color-fg-interactive-neutral-strong-active: #f0f0f0; /* Foreground color for interactive elements with neutral tone and strong emphasis that are hovered, focused, or active. */\n\t--wpds-color-fg-interactive-neutral-strong-disabled: #6d6d6d; /* Foreground color for interactive elements with neutral tone and strong emphasis, in their disabled state. */\n\t--wpds-color-fg-interactive-neutral-weak: #6d6d6d; /* Foreground color for interactive elements with neutral tone and weak emphasis. */\n\t--wpds-color-fg-interactive-neutral-weak-disabled: #8a8a8a; /* Foreground color for interactive elements with neutral tone and weak emphasis, in their disabled state. */\n\t--wpds-color-stroke-focus-brand: #3858e9; /* Accessible stroke color applied to focus rings. */\n\t--wpds-color-stroke-interactive-brand: #3858e9; /* Accessible stroke color used for interactive brand-toned elements with normal emphasis. */\n\t--wpds-color-stroke-interactive-brand-active: #2337c8; /* Accessible stroke color used for interactive brand-toned elements with normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-stroke-interactive-error: #cc1818; /* Accessible stroke color used for interactive error-toned elements with normal emphasis. */\n\t--wpds-color-stroke-interactive-error-active: #9d0000; /* Accessible stroke color used for interactive error-toned elements with normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-stroke-interactive-error-strong: #cc1818; /* Accessible stroke color used for interactive error-toned elements with strong emphasis. */\n\t--wpds-color-stroke-interactive-neutral: #8a8a8a; /* Accessible stroke color used for interactive neutrally-toned elements with normal emphasis. */\n\t--wpds-color-stroke-interactive-neutral-active: #6c6c6c; /* Accessible stroke color used for interactive neutrally-toned elements with normal emphasis that are hovered, focused, or active. */\n\t--wpds-color-stroke-interactive-neutral-disabled: #d8d8d8; /* Accessible stroke color used for interactive neutrally-toned elements with normal emphasis, in their disabled state. */\n\t--wpds-color-stroke-interactive-neutral-strong: #6c6c6c; /* Accessible stroke color used for interactive neutrally-toned elements with strong emphasis. */\n\t--wpds-color-stroke-surface-brand: #a3b1d4; /* Decorative stroke color used to define brand-toned surface boundaries with normal emphasis. */\n\t--wpds-color-stroke-surface-brand-strong: #3858e9; /* Decorative stroke color used to define brand-toned surface boundaries with strong emphasis. */\n\t--wpds-color-stroke-surface-error: #daa39b; /* Decorative stroke color used to define error-toned surface boundaries with normal emphasis. */\n\t--wpds-color-stroke-surface-error-strong: #cc1818; /* Decorative stroke color used to define error-toned surface boundaries with strong emphasis. */\n\t--wpds-color-stroke-surface-info: #9fbcdc; /* Decorative stroke color used to define info-toned surface boundaries with normal emphasis. */\n\t--wpds-color-stroke-surface-info-strong: #006bd7; /* Decorative stroke color used to define info-toned surface boundaries with strong emphasis. */\n\t--wpds-color-stroke-surface-neutral: #d8d8d8; /* Decorative stroke color used to define neutrally-toned surface boundaries with normal emphasis. */\n\t--wpds-color-stroke-surface-neutral-strong: #8a8a8a; /* Decorative stroke color used to define neutrally-toned surface boundaries with strong emphasis. */\n\t--wpds-color-stroke-surface-neutral-weak: #e0e0e0; /* Decorative stroke color used to define neutrally-toned surface boundaries with weak emphasis. */\n\t--wpds-color-stroke-surface-success: #8ac894; /* Decorative stroke color used to define success-toned surface boundaries with normal emphasis. */\n\t--wpds-color-stroke-surface-success-strong: #007f30; /* Decorative stroke color used to define success-toned surface boundaries with strong emphasis. */\n\t--wpds-color-stroke-surface-warning: #d0b381; /* Decorative stroke color used to define warning-toned surface boundaries with normal emphasis. */\n\t--wpds-color-stroke-surface-warning-strong: #926300; /* Decorative stroke color used to define warning-toned surface boundaries with strong emphasis. */\n\t--wpds-dimension-base: 4px; /* Base dimension unit */\n\t--wpds-dimension-gap-2xs: 4px; /* 2x extra small gap */\n\t--wpds-dimension-gap-lg: 24px; /* Large gap */\n\t--wpds-dimension-gap-md: 16px; /* Medium gap */\n\t--wpds-dimension-gap-sm: 12px; /* Small gap */\n\t--wpds-dimension-gap-xl: 40px; /* Extra large gap */\n\t--wpds-dimension-gap-xs: 8px; /* Extra small gap */\n\t--wpds-dimension-padding-surface-2xs: 4px; /* 2x extra small spacing for surfaces */\n\t--wpds-dimension-padding-surface-lg: 32px; /* Large spacing for surfaces */\n\t--wpds-dimension-padding-surface-md: 24px; /* Medium spacing for surfaces */\n\t--wpds-dimension-padding-surface-sm: 16px; /* Small spacing for surfaces */\n\t--wpds-dimension-padding-surface-xs: 8px; /* Extra small spacing for surfaces */\n\t--wpds-elevation-large: 0 5px 15px 0 #00000014, 0 15px 27px 0 #00000012,\n\t\t0 30px 36px 0 #0000000a, 0 50px 43px 0 #00000005; /* For components that confirm decisions or handle necessary interruptions. Example: Modals. */\n\t--wpds-elevation-medium: 0 2px 3px 0 #0000000d, 0 4px 5px 0 #0000000a,\n\t\t0 12px 12px 0 #00000008, 0 16px 16px 0 #00000005; /* For components that offer additional actions. Example: Menus, Command Palette */\n\t--wpds-elevation-small: 0 1px 2px 0 #0000000d, 0 2px 3px 0 #0000000a,\n\t\t0 6px 6px 0 #00000008, 0 8px 8px 0 #00000005; /* For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar. */\n\t--wpds-elevation-x-small: 0 1px 1px 0 #00000008, 0 1px 2px 0 #00000005,\n\t\t0 3px 3px 0 #00000005, 0 4px 4px 0 #00000003; /* For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame. */\n\t--wpds-font-family-body: -apple-system, system-ui, 'Segoe UI', 'Roboto',\n\t\t'Oxygen-Sans', 'Ubuntu', 'Cantarell', 'Helvetica Neue', sans-serif; /* Body font family */\n\t--wpds-font-family-heading: -apple-system, system-ui, 'Segoe UI', 'Roboto',\n\t\t'Oxygen-Sans', 'Ubuntu', 'Cantarell', 'Helvetica Neue', sans-serif; /* Headings font family */\n\t--wpds-font-family-mono: 'Menlo', 'Consolas', monaco, monospace; /* Monospace font family */\n\t--wpds-font-line-height-2x-large: 40px; /* 2X large line height */\n\t--wpds-font-line-height-large: 28px; /* Large line height */\n\t--wpds-font-line-height-medium: 24px; /* Medium line height */\n\t--wpds-font-line-height-small: 20px; /* Small line height */\n\t--wpds-font-line-height-x-large: 32px; /* Extra large line height */\n\t--wpds-font-line-height-x-small: 16px; /* Extra small line height */\n\t--wpds-font-size-2x-large: 32px; /* 2X large font size */\n\t--wpds-font-size-large: 15px; /* Large font size */\n\t--wpds-font-size-medium: 13px; /* Medium font size */\n\t--wpds-font-size-small: 12px; /* Small font size */\n\t--wpds-font-size-x-large: 20px; /* Extra large font size */\n\t--wpds-font-size-x-small: 11px; /* Extra small font size */\n}\n\n[data-wpds-theme-provider-id][data-wpds-density='default'] {\n\t--wpds-dimension-base: 4px; /* Base dimension unit */\n\t--wpds-dimension-gap-2xs: 4px; /* 2x extra small gap */\n\t--wpds-dimension-gap-lg: 24px; /* Large gap */\n\t--wpds-dimension-gap-md: 16px; /* Medium gap */\n\t--wpds-dimension-gap-sm: 12px; /* Small gap */\n\t--wpds-dimension-gap-xl: 40px; /* Extra large gap */\n\t--wpds-dimension-gap-xs: 8px; /* Extra small gap */\n\t--wpds-dimension-padding-surface-2xs: 4px; /* 2x extra small spacing for surfaces */\n\t--wpds-dimension-padding-surface-lg: 32px; /* Large spacing for surfaces */\n\t--wpds-dimension-padding-surface-md: 24px; /* Medium spacing for surfaces */\n\t--wpds-dimension-padding-surface-sm: 16px; /* Small spacing for surfaces */\n\t--wpds-dimension-padding-surface-xs: 8px; /* Extra small spacing for surfaces */\n}\n\n[data-wpds-theme-provider-id][data-wpds-density='compact'] {\n\t--wpds-dimension-gap-2xs: 4px; /* 2x extra small gap */\n\t--wpds-dimension-gap-lg: 20px; /* Large gap */\n\t--wpds-dimension-gap-md: 12px; /* Medium gap */\n\t--wpds-dimension-gap-sm: 8px; /* Small gap */\n\t--wpds-dimension-gap-xl: 32px; /* Extra large gap */\n\t--wpds-dimension-gap-xs: 4px; /* Extra small gap */\n\t--wpds-dimension-padding-surface-2xs: 4px; /* 2x extra small spacing for surfaces */\n\t--wpds-dimension-padding-surface-lg: 24px; /* Large spacing for surfaces */\n\t--wpds-dimension-padding-surface-md: 20px; /* Medium spacing for surfaces */\n\t--wpds-dimension-padding-surface-sm: 12px; /* Small spacing for surfaces */\n\t--wpds-dimension-padding-surface-xs: 4px; /* Extra small spacing for surfaces */\n}\n\n[data-wpds-theme-provider-id][data-wpds-density='comfortable'] {\n\t--wpds-dimension-gap-2xs: 8px; /* 2x extra small gap */\n\t--wpds-dimension-gap-lg: 32px; /* Large gap */\n\t--wpds-dimension-gap-md: 20px; /* Medium gap */\n\t--wpds-dimension-gap-sm: 16px; /* Small gap */\n\t--wpds-dimension-gap-xl: 48px; /* Extra large gap */\n\t--wpds-dimension-gap-xs: 12px; /* Extra small gap */\n\t--wpds-dimension-padding-surface-2xs: 8px; /* 2x extra small spacing for surfaces */\n\t--wpds-dimension-padding-surface-lg: 40px; /* Large spacing for surfaces */\n\t--wpds-dimension-padding-surface-md: 32px; /* Medium spacing for surfaces */\n\t--wpds-dimension-padding-surface-sm: 20px; /* Small spacing for surfaces */\n\t--wpds-dimension-padding-surface-xs: 12px; /* Extra small spacing for surfaces */\n}\n\n@media ( -webkit-min-device-pixel-ratio: 2 ), ( min-resolution: 192dpi ) {\n\t:root {\n\t\t--wpds-border-width-interactive-focus: 1.5px; /* Border width for focus ring */\n\t}\n}\n","/**\n * Colors\n */\n/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n/**\n * Fonts & basic variables.\n */\n/**\n * Typography\n */\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n/**\n * Radius scale.\n */\n/**\n * Elevation scale.\n */\n/**\n * Dimensions.\n */\n/**\n * Mobile specific styles\n */\n/**\n * Editor styles.\n */\n/**\n * Block & Editor UI.\n */\n/**\n * Block paddings.\n */\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n/**\n * Typography\n */\n/**\n * Breakpoints & Media Queries\n */\n/**\n*  Converts a hex value into the rgb equivalent.\n*\n* @param {string} hex - the hexadecimal value to convert\n* @return {string} comma separated rgb values\n*/\n/**\n * Long content fade mixin\n *\n * Creates a fading overlay to signify that the content is longer\n * than the space allows.\n */\n/**\n * Breakpoint mixins\n */\n/**\n * Focus styles.\n */\n/**\n * Applies editor left position to the selector passed as argument\n */\n/**\n * Styles that are reused verbatim in a few places\n */\n/**\n * Allows users to opt-out of animations via OS-level preferences.\n */\n/**\n * Reset default styles for JavaScript UI based pages.\n * This is a WP-admin agnostic reset\n */\n/**\n * Reset the WP Admin page styles for Gutenberg-like pages.\n */\n.admin-ui-page {\n  display: flex;\n  height: 100%;\n  background-color: #fff;\n  color: #2f2f2f;\n  position: relative;\n  z-index: 1;\n  flex-flow: column;\n}\n\n.admin-ui-page__header {\n  padding: 16px 24px;\n  border-bottom: 1px solid #f0f0f0;\n  background: #fff;\n  position: sticky;\n  top: 0;\n  z-index: 1;\n}\n\n.admin-ui-page__sidebar-toggle-slot:empty {\n  display: none;\n}\n\n.admin-ui-page__header-subtitle {\n  padding-block-end: 8px;\n  color: #757575;\n  font-family: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n  font-weight: 400;\n  font-size: 13px;\n  line-height: 20px;\n  margin: 0;\n}\n\n.admin-ui-page__content {\n  flex-grow: 1;\n  overflow: auto;\n  display: flex;\n  flex-direction: column;\n}\n.admin-ui-page__content.has-padding {\n  padding: 16px 24px;\n}\n\n.show-icon-labels .admin-ui-page__header-actions .components-button.has-icon {\n  width: auto;\n  padding: 0 8px;\n}\n.show-icon-labels .admin-ui-page__header-actions .components-button.has-icon svg {\n  display: none;\n}\n.show-icon-labels .admin-ui-page__header-actions .components-button.has-icon::after {\n  content: attr(aria-label);\n  font-size: 12px;\n}\n\n.admin-ui-breadcrumbs__list {\n  list-style: none;\n  padding: 0;\n  margin: 0;\n  gap: 0;\n  font-size: 15px;\n  min-height: 32px;\n  font-weight: 500;\n}\n.admin-ui-breadcrumbs__list li:not(:last-child)::after {\n  content: \"/\";\n  margin: 0 8px;\n}\n.admin-ui-breadcrumbs__list h1 {\n  font-size: inherit;\n  line-height: inherit;\n}","/**\n * Typography\n */\n\n@use \"sass:color\";\n@use \"sass:math\";\n@use \"./variables\";\n@use \"./colors\";\n@use \"./breakpoints\";\n@use \"./functions\";\n@use \"./long-content-fade\";\n\n@mixin _text-heading() {\n\tfont-family: variables.$font-family-headings;\n\tfont-weight: variables.$font-weight-medium;\n}\n\n@mixin _text-body() {\n\tfont-family: variables.$font-family-body;\n\tfont-weight: variables.$font-weight-regular;\n}\n\n@mixin heading-small() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin heading-medium() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin heading-x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin heading-2x-large() {\n\t@include _text-heading();\n\tfont-size: variables.$font-size-2x-large;\n\tline-height: variables.$font-line-height-2x-large;\n}\n\n@mixin body-small() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-small;\n\tline-height: variables.$font-line-height-x-small;\n}\n\n@mixin body-medium() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-medium;\n\tline-height: variables.$font-line-height-small;\n}\n\n@mixin body-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-large;\n\tline-height: variables.$font-line-height-medium;\n}\n\n@mixin body-x-large() {\n\t@include _text-body();\n\tfont-size: variables.$font-size-x-large;\n\tline-height: variables.$font-line-height-x-large;\n}\n\n/**\n * Breakpoint mixins\n */\n\n@mixin break-xhuge() {\n\t@media (min-width: #{ (breakpoints.$break-xhuge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-huge() {\n\t@media (min-width: #{ (breakpoints.$break-huge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-wide() {\n\t@media (min-width: #{ (breakpoints.$break-wide) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-xlarge() {\n\t@media (min-width: #{ (breakpoints.$break-xlarge) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-large() {\n\t@media (min-width: #{ (breakpoints.$break-large) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-medium() {\n\t@media (min-width: #{ (breakpoints.$break-medium) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-small() {\n\t@media (min-width: #{ (breakpoints.$break-small) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-mobile() {\n\t@media (min-width: #{ (breakpoints.$break-mobile) }) {\n\t\t@content;\n\t}\n}\n\n@mixin break-zoomed-in() {\n\t@media (min-width: #{ (breakpoints.$break-zoomed-in) }) {\n\t\t@content;\n\t}\n}\n\n/**\n * Focus styles.\n */\n\n@mixin block-toolbar-button-style__focus() {\n\tbox-shadow: inset 0 0 0 variables.$border-width colors.$white, 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n// Tabs, Inputs, Square buttons.\n@mixin input-style__neutral() {\n\tbox-shadow: 0 0 0 transparent;\n\tborder-radius: variables.$radius-small;\n\tborder: variables.$border-width solid colors.$gray-600;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n}\n\n\n@mixin input-style__focus($accent-color: var(--wp-admin-theme-color)) {\n\tborder-color: $accent-color;\n\t// Expand the default border focus style by .5px to be a total of 1.5px.\n\tbox-shadow: 0 0 0 0.5px $accent-color;\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n@mixin button-style__focus() {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n}\n\n\n@mixin button-style-outset__focus($focus-color) {\n\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) colors.$white, 0 0 0 calc(2 * var(--wp-admin-border-width-focus)) $focus-color;\n\n\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\toutline: 2px solid transparent;\n\toutline-offset: 2px;\n}\n\n\n/**\n * Applies editor left position to the selector passed as argument\n */\n\n@mixin editor-left($selector) {\n\t#{$selector} { /* Set left position when auto-fold is not on the body element. */\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t.auto-fold #{$selector} { /* Auto fold is when on smaller breakpoints, nav menu auto collapses. */\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\n\t\t@media (min-width: #{ (breakpoints.$break-large + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width;\n\t\t}\n\t}\n\n\t/* Sidebar manually collapsed. */\n\t.folded #{$selector} {\n\t\tleft: 0;\n\n\t\t@media (min-width: #{ (breakpoints.$break-medium + 1) }) {\n\t\t\tleft: variables.$admin-sidebar-width-collapsed;\n\t\t}\n\t}\n\n\tbody.is-fullscreen-mode #{$selector} {\n\t\tleft: 0 !important;\n\t}\n}\n\n/**\n * Styles that are reused verbatim in a few places\n */\n\n// These are additional styles for all captions, when the theme opts in to block styles.\n@mixin caption-style() {\n\tmargin-top: 0.5em;\n\tmargin-bottom: 1em;\n}\n\n@mixin caption-style-theme() {\n\tcolor: #555;\n\tfont-size: variables.$default-font-size;\n\ttext-align: center;\n\n\t.is-dark-theme & {\n\t\tcolor: colors.$light-gray-placeholder;\n\t}\n}\n\n/**\n * Allows users to opt-out of animations via OS-level preferences.\n */\n\n@mixin reduce-motion($property: \"\") {\n\n\t@if $property == \"transition\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t}\n\t} @else if $property == \"animation\" {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t} @else {\n\t\t@media (prefers-reduced-motion: reduce) {\n\t\t\ttransition-duration: 0s;\n\t\t\ttransition-delay: 0s;\n\t\t\tanimation-duration: 1ms;\n\t\t\tanimation-delay: 0s;\n\t\t}\n\t}\n}\n\n@mixin input-control($accent-color: var(--wp-admin-theme-color)) {\n\tfont-family: variables.$default-font;\n\tpadding: 6px 8px;\n\t/* Fonts smaller than 16px causes mobile safari to zoom. */\n\tfont-size: variables.$mobile-text-min-font-size;\n\t/* Override core line-height. To be reviewed. */\n\tline-height: normal;\n\t@include input-style__neutral();\n\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size;\n\t\t/* Override core line-height. To be reviewed. */\n\t\tline-height: normal;\n\t}\n\n\t&:focus {\n\t\t@include input-style__focus($accent-color);\n\t}\n\n\t// Use opacity to work in various editor styles.\n\t&::-webkit-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&::-moz-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n\n\t&:-ms-input-placeholder {\n\t\tcolor: colors.$dark-gray-placeholder;\n\t}\n}\n\n@mixin checkbox-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-small;\n\t@include input-control;\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t// Hide default checkbox styles in IE.\n\t\t&::-ms-check {\n\t\t\topacity: 0;\n\t\t}\n\t}\n\n\t&:checked::before,\n\t&[aria-checked=\"mixed\"]::before {\n\t\tmargin: -3px -5px;\n\t\tcolor: colors.$white;\n\n\t\t@include break-medium() {\n\t\t\tmargin: -4px 0 0 -5px;\n\t\t}\n\t}\n\n\t&[aria-checked=\"mixed\"] {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder-color: var(--wp-admin-theme-color);\n\n\t\t&::before {\n\t\t\t// Inherited from `forms.css`.\n\t\t\t// See: https://github.com/WordPress/wordpress-develop/tree/5.1.1/src/wp-admin/css/forms.css#L122-L132\n\t\t\tcontent: \"\\f460\";\n\t\t\tfloat: left;\n\t\t\tdisplay: inline-block;\n\t\t\tvertical-align: middle;\n\t\t\twidth: 16px;\n\t\t\t/* stylelint-disable-next-line font-family-no-missing-generic-family-keyword -- dashicons don't need a generic family keyword. */\n\t\t\tfont: normal 30px/1 dashicons;\n\t\t\tspeak: none;\n\t\t\t-webkit-font-smoothing: antialiased;\n\t\t\t-moz-osx-font-smoothing: grayscale;\n\n\t\t\t@include break-medium() {\n\t\t\t\tfloat: none;\n\t\t\t\tfont-size: 21px;\n\t\t\t}\n\t\t}\n\t}\n\n\t&[aria-disabled=\"true\"],\n\t&:disabled {\n\t\tbackground: colors.$gray-100;\n\t\tborder-color: colors.$gray-300;\n\t\tcursor: default;\n\n\t\t// Override style inherited from wp-admin. Required to avoid degraded appearance on different backgrounds.\n\t\topacity: 1;\n\t}\n}\n\n@mixin radio-control {\n\tborder: variables.$border-width solid colors.$gray-900;\n\tmargin-right: variables.$grid-unit-15;\n\ttransition: none;\n\tborder-radius: variables.$radius-round;\n\twidth: variables.$radio-input-size-sm;\n\theight: variables.$radio-input-size-sm;\n\tmin-width: variables.$radio-input-size-sm;\n\tmax-width: variables.$radio-input-size-sm;\n\tposition: relative;\n\n\t@media not (prefers-reduced-motion) {\n\t\ttransition: box-shadow 0.1s linear;\n\t}\n\n\t@include break-small() {\n\t\theight: variables.$radio-input-size;\n\t\twidth: variables.$radio-input-size;\n\t\tmin-width: variables.$radio-input-size;\n\t\tmax-width: variables.$radio-input-size;\n\t}\n\n\t&:checked::before {\n\t\tbox-sizing: inherit;\n\t\twidth: math.div(variables.$radio-input-size-sm, 2);\n\t\theight: math.div(variables.$radio-input-size-sm, 2);\n\t\tposition: absolute;\n\t\ttop: 50%;\n\t\tleft: 50%;\n\t\ttransform: translate(-50%, -50%);\n\t\tmargin: 0;\n\t\tbackground-color: colors.$white;\n\n\t\t// This border serves as a background color in Windows High Contrast mode.\n\t\tborder: 4px solid colors.$white;\n\n\t\t@include break-small() {\n\t\t\twidth: math.div(variables.$radio-input-size, 2);\n\t\t\theight: math.div(variables.$radio-input-size, 2);\n\t\t}\n\t}\n\n\t&:focus {\n\t\tbox-shadow: 0 0 0 (variables.$border-width * 2) colors.$white, 0 0 0 (variables.$border-width * 2 + variables.$border-width-focus-fallback) var(--wp-admin-theme-color);\n\n\t\t// Only visible in Windows High Contrast mode.\n\t\toutline: 2px solid transparent;\n\t}\n\n\t&:checked {\n\t\tbackground: var(--wp-admin-theme-color);\n\t\tborder: none;\n\t}\n}\n\n/**\n * Reset default styles for JavaScript UI based pages.\n * This is a WP-admin agnostic reset\n */\n\n@mixin reset {\n\tbox-sizing: border-box;\n\n\t*,\n\t*::before,\n\t*::after {\n\t\tbox-sizing: inherit;\n\t}\n}\n\n@mixin link-reset {\n\t&:focus {\n\t\tcolor: var(--wp-admin-theme-color--rgb);\n\t\tbox-shadow: 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color, #007cba);\n\t\tborder-radius: variables.$radius-small;\n\t}\n}\n\n// The editor input reset with increased specificity to avoid theme styles bleeding in.\n@mixin editor-input-reset() {\n\tfont-family: variables.$editor-html-font !important;\n\tcolor: colors.$gray-900 !important;\n\tbackground: colors.$white !important;\n\tpadding: variables.$grid-unit-15 !important;\n\tborder: variables.$border-width solid colors.$gray-900 !important;\n\tbox-shadow: none !important;\n\tborder-radius: variables.$radius-small !important;\n\n\t// Fonts smaller than 16px causes mobile safari to zoom.\n\tfont-size: variables.$mobile-text-min-font-size !important;\n\t@include break-small {\n\t\tfont-size: variables.$default-font-size !important;\n\t}\n\n\t&:focus {\n\t\tborder-color: var(--wp-admin-theme-color) !important;\n\t\tbox-shadow: 0 0 0 (variables.$border-width-focus-fallback - variables.$border-width) var(--wp-admin-theme-color) !important;\n\n\t\t// Windows High Contrast mode will show this outline, but not the box-shadow.\n\t\toutline: 2px solid transparent !important;\n\t}\n}\n\n/**\n * Reset the WP Admin page styles for Gutenberg-like pages.\n */\n\n@mixin wp-admin-reset( $content-container ) {\n\tbackground: colors.$white;\n\n\t#wpcontent {\n\t\tpadding-left: 0;\n\t}\n\n\t#wpbody-content {\n\t\tpadding-bottom: 0;\n\t}\n\n\t/* We hide legacy notices in Gutenberg Based Pages, because they were not designed in a way that scaled well.\n\t   Plugins can use Gutenberg notices if they need to pass on information to the user when they are editing. */\n\t#wpbody-content > div:not(#{ $content-container }):not(#screen-meta) {\n\t\tdisplay: none;\n\t}\n\n\t#wpfooter {\n\t\tdisplay: none;\n\t}\n\n\t.a11y-speak-region {\n\t\tleft: -1px;\n\t\ttop: -1px;\n\t}\n\n\tul#adminmenu a.wp-has-current-submenu::after,\n\tul#adminmenu > li.current > a.current::after {\n\t\tborder-right-color: colors.$white;\n\t}\n\n\t.media-frame select.attachment-filters:last-of-type {\n\t\twidth: auto;\n\t\tmax-width: 100%;\n\t}\n}\n\n@mixin admin-scheme($color-primary) {\n\t// Define RGB equivalents for use in rgba function.\n\t// Hexadecimal css vars do not work in the rgba function.\n\t--wp-admin-theme-color: #{$color-primary};\n\t--wp-admin-theme-color--rgb: #{functions.hex-to-rgb($color-primary)};\n\t// Darker shades.\n\t--wp-admin-theme-color-darker-10: #{color.adjust($color-primary, $lightness: -5%)};\n\t--wp-admin-theme-color-darker-10--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -5%))};\n\t--wp-admin-theme-color-darker-20: #{color.adjust($color-primary, $lightness: -10%)};\n\t--wp-admin-theme-color-darker-20--rgb: #{functions.hex-to-rgb(color.adjust($color-primary, $lightness: -10%))};\n\n\t// Focus style width.\n\t// Avoid rounding issues by showing a whole 2px for 1x screens, and 1.5px on high resolution screens.\n\t--wp-admin-border-width-focus: 2px;\n\t@media ( -webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {\n\t\t--wp-admin-border-width-focus: 1.5px;\n\t}\n}\n\n@mixin wordpress-admin-schemes() {\n\tbody.admin-color-light {\n\t\t@include admin-scheme(#0085ba);\n\t}\n\n\tbody.admin-color-modern {\n\t\t@include admin-scheme(#3858e9);\n\t}\n\n\tbody.admin-color-blue {\n\t\t@include admin-scheme(#096484);\n\t}\n\n\tbody.admin-color-coffee {\n\t\t@include admin-scheme(#46403c);\n\t}\n\n\tbody.admin-color-ectoplasm {\n\t\t@include admin-scheme(#523f6d);\n\t}\n\n\tbody.admin-color-midnight {\n\t\t@include admin-scheme(#e14d43);\n\t}\n\n\tbody.admin-color-ocean {\n\t\t@include admin-scheme(#627c83);\n\t}\n\n\tbody.admin-color-sunrise {\n\t\t@include admin-scheme(#dd823b);\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin background-colors-deprecated() {\n\t.has-very-light-gray-background-color {\n\t\tbackground-color: #eee;\n\t}\n\n\t.has-very-dark-gray-background-color {\n\t\tbackground-color: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin foreground-colors-deprecated() {\n\t.has-very-light-gray-color {\n\t\tcolor: #eee;\n\t}\n\n\t.has-very-dark-gray-color {\n\t\tcolor: #313131;\n\t}\n}\n\n// Deprecated from UI, kept for back-compat.\n@mixin gradient-colors-deprecated() {\n\t// Our classes uses the same values we set for gradient value attributes.\n\n\t/* stylelint-disable @stylistic/function-comma-space-after -- We can not use spacing because of WP multi site kses rule. */\n\t.has-vivid-green-cyan-to-vivid-cyan-blue-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgba(0,208,132,1) 0%,rgba(6,147,227,1) 100%);\n\t}\n\n\t.has-purple-crush-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(52,226,228) 0%,rgb(71,33,251) 50%,rgb(171,29,254) 100%);\n\t}\n\n\t.has-hazy-dawn-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,172,168) 0%,rgb(218,208,236) 100%);\n\t}\n\n\t.has-subdued-olive-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(250,250,225) 0%,rgb(103,166,113) 100%);\n\t}\n\n\t.has-atomic-cream-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(253,215,154) 0%,rgb(0,74,89) 100%);\n\t}\n\n\t.has-nightshade-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(51,9,104) 0%,rgb(49,205,207) 100%);\n\t}\n\n\t.has-midnight-gradient-background {\n\t\tbackground: linear-gradient(135deg,rgb(2,3,129) 0%,rgb(40,116,252) 100%);\n\t}\n\t/* stylelint-enable @stylistic/function-comma-space-after */\n}\n\n@mixin custom-scrollbars-on-hover($handle-color, $handle-color-hover) {\n\n\t// WebKit\n\t&::-webkit-scrollbar {\n\t\twidth: 12px;\n\t\theight: 12px;\n\t}\n\t&::-webkit-scrollbar-track {\n\t\tbackground-color: transparent;\n\t}\n\t&::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color;\n\t\tborder-radius: 8px;\n\t\tborder: 3px solid transparent;\n\t\tbackground-clip: padding-box;\n\t}\n\t&:hover::-webkit-scrollbar-thumb, // This needs specificity.\n\t&:focus::-webkit-scrollbar-thumb,\n\t&:focus-within::-webkit-scrollbar-thumb {\n\t\tbackground-color: $handle-color-hover;\n\t}\n\n\t// Firefox 109+ and Chrome 111+\n\tscrollbar-width: thin;\n\tscrollbar-gutter: stable both-edges;\n\tscrollbar-color: $handle-color transparent; // Syntax, \"dark\", \"light\", or \"#handle-color #track-color\"\n\n\t&:hover,\n\t&:focus,\n\t&:focus-within {\n\t\tscrollbar-color: $handle-color-hover transparent;\n\t}\n\n\t// Needed to fix a Safari rendering issue.\n\twill-change: transform;\n\n\t// Always show scrollbar on Mobile devices.\n\t@media (hover: none) {\n\t\t& {\n\t\t\tscrollbar-color: $handle-color-hover transparent;\n\t\t}\n\t}\n}\n\n@mixin selected-block-outline($widthRatio: 1) {\n\toutline-color: var(--wp-admin-theme-color);\n\toutline-style: solid;\n\toutline-width: calc(#{$widthRatio} * (var(--wp-admin-border-width-focus) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n\toutline-offset: calc(#{$widthRatio} * ((-1 * var(--wp-admin-border-width-focus) ) / var(--wp-block-editor-iframe-zoom-out-scale, 1)));\n}\n\n@mixin selected-block-focus($widthRatio: 1) {\n\tcontent: \"\";\n\tposition: absolute;\n\tpointer-events: none;\n\ttop: 0;\n\tright: 0;\n\tbottom: 0;\n\tleft: 0;\n\t@include selected-block-outline($widthRatio);\n}\n","/**\n * SCSS Variables.\n *\n * Please use variables from this sheet to ensure consistency across the UI.\n * Don't add to this sheet unless you're pretty sure the value will be reused in many places.\n * For example, don't add rules to this sheet that affect block visuals. It's purely for UI.\n */\n\n@use \"./colors\";\n\n/**\n * Fonts & basic variables.\n */\n\n$default-font: -apple-system, BlinkMacSystemFont,\"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell,\"Helvetica Neue\", sans-serif; // Todo: deprecate in favor of $family variables\n$default-line-height: 1.4; // Todo: deprecate in favor of $line-height tokens\n\n/**\n * Typography\n */\n\n// Sizes\n$font-size-x-small: 11px;\n$font-size-small: 12px;\n$font-size-medium: 13px;\n$font-size-large: 15px;\n$font-size-x-large: 20px;\n$font-size-2x-large: 32px;\n\n// Line heights\n$font-line-height-x-small: 16px;\n$font-line-height-small: 20px;\n$font-line-height-medium: 24px;\n$font-line-height-large: 28px;\n$font-line-height-x-large: 32px;\n$font-line-height-2x-large: 40px;\n\n// Weights\n$font-weight-regular: 400;\n$font-weight-medium: 499; // ensures fallback to 400 (instead of 600)\n\n// Families\n$font-family-headings: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-body: -apple-system, \"system-ui\", \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n$font-family-mono: Menlo, Consolas, monaco, monospace;\n\n/**\n * Grid System.\n * https://make.wordpress.org/design/2019/10/31/proposal-a-consistent-spacing-system-for-wordpress/\n */\n\n$grid-unit: 8px;\n$grid-unit-05: 0.5 * $grid-unit;\t// 4px\n$grid-unit-10: 1 * $grid-unit;\t\t// 8px\n$grid-unit-15: 1.5 * $grid-unit;\t// 12px\n$grid-unit-20: 2 * $grid-unit;\t\t// 16px\n$grid-unit-30: 3 * $grid-unit;\t\t// 24px\n$grid-unit-40: 4 * $grid-unit;\t\t// 32px\n$grid-unit-50: 5 * $grid-unit;\t\t// 40px\n$grid-unit-60: 6 * $grid-unit;\t\t// 48px\n$grid-unit-70: 7 * $grid-unit;\t\t// 56px\n$grid-unit-80: 8 * $grid-unit;\t\t// 64px\n\n/**\n * Radius scale.\n */\n\n$radius-x-small: 1px;   // Applied to elements like buttons nested within primitives like inputs.\n$radius-small: 2px;     // Applied to most primitives.\n$radius-medium: 4px;    // Applied to containers with smaller padding.\n$radius-large: 8px;     // Applied to containers with larger padding.\n$radius-full: 9999px;   // For pills.\n$radius-round: 50%;     // For circles and ovals.\n\n/**\n * Elevation scale.\n */\n\n// For sections and containers that group related content and controls, which may overlap other content. Example: Preview Frame.\n$elevation-x-small: 0 1px 1px rgba(colors.$black, 0.03), 0 1px 2px rgba(colors.$black, 0.02), 0 3px 3px rgba(colors.$black, 0.02), 0 4px 4px rgba(colors.$black, 0.01);\n\n// For components that provide contextual feedback without being intrusive. Generally non-interruptive. Example: Tooltips, Snackbar.\n$elevation-small: 0 1px 2px rgba(colors.$black, 0.05), 0 2px 3px rgba(colors.$black, 0.04), 0 6px 6px rgba(colors.$black, 0.03), 0 8px 8px rgba(colors.$black, 0.02);\n\n// For components that offer additional actions. Example: Menus, Command Palette\n$elevation-medium: 0 2px 3px rgba(colors.$black, 0.05), 0 4px 5px rgba(colors.$black, 0.04), 0 12px 12px rgba(colors.$black, 0.03), 0 16px 16px rgba(colors.$black, 0.02);\n\n// For components that confirm decisions or handle necessary interruptions. Example: Modals.\n$elevation-large: 0 5px 15px rgba(colors.$black, 0.08), 0 15px 27px rgba(colors.$black, 0.07), 0 30px 36px rgba(colors.$black, 0.04), 0 50px 43px rgba(colors.$black, 0.02);\n\n/**\n * Dimensions.\n */\n\n$icon-size: 24px;\n$button-size: 36px;\n$button-size-next-default-40px: 40px; // transitionary variable for next default button size\n$button-size-small: 24px;\n$button-size-compact: 32px;\n$header-height: 64px;\n$panel-header-height: $grid-unit-60;\n$nav-sidebar-width: 300px;\n$admin-bar-height: 32px;\n$admin-bar-height-big: 46px;\n$admin-sidebar-width: 160px;\n$admin-sidebar-width-big: 190px;\n$admin-sidebar-width-collapsed: 36px;\n$modal-min-width: 350px;\n$modal-width-small: 384px;\n$modal-width-medium: 512px;\n$modal-width-large: 840px;\n$spinner-size: 16px;\n$canvas-padding: $grid-unit-20;\n$palette-max-height: 368px;\n\n/**\n * Mobile specific styles\n */\n$mobile-text-min-font-size: 16px; // Any font size below 16px will cause Mobile Safari to \"zoom in\".\n\n/**\n * Editor styles.\n */\n\n$sidebar-width: 280px;\n$content-width: 840px;\n$wide-content-width: 1100px;\n$widget-area-width: 700px;\n$secondary-sidebar-width: 350px;\n$editor-font-size: 16px;\n$default-block-margin: 28px; // This value provides a consistent, contiguous spacing between blocks.\n$text-editor-font-size: 15px;\n$editor-line-height: 1.8;\n$editor-html-font: $font-family-mono;\n\n/**\n * Block & Editor UI.\n */\n\n$block-toolbar-height: $grid-unit-60;\n$border-width: 1px;\n$border-width-focus-fallback: 2px; // This exists as a fallback, and is ideally overridden by var(--wp-admin-border-width-focus) unless in some SASS math cases.\n$border-width-tab: 1.5px;\n$helptext-font-size: 12px;\n$radio-input-size: 16px;\n$radio-input-size-sm: 24px; // Width & height for small viewports.\n\n// Deprecated, please avoid using these.\n$block-padding: 14px; // Used to define space between block footprint and surrounding borders.\n$radius-block-ui: $radius-small;\n$shadow-popover: $elevation-x-small;\n$shadow-modal: $elevation-large;\n$default-font-size: $font-size-medium;\n\n/**\n * Block paddings.\n */\n\n// Padding for blocks with a background color (e.g. paragraph or group).\n$block-bg-padding--v: 1.25em;\n$block-bg-padding--h: 2.375em;\n\n\n/**\n * React Native specific.\n * These variables do not appear to be used anywhere else.\n */\n\n// Dimensions.\n$mobile-header-toolbar-height: 44px;\n$mobile-header-toolbar-expanded-height: 52px;\n$mobile-floating-toolbar-height: 44px;\n$mobile-floating-toolbar-margin: 8px;\n$mobile-color-swatch: 48px;\n\n// Block UI.\n$mobile-block-toolbar-height: 44px;\n$dimmed-opacity: 1;\n$block-edge-to-content: 16px;\n$solid-border-space: 12px;\n$dashed-border-space: 6px;\n$block-selected-margin: 3px;\n$block-selected-border-width: 1px;\n$block-selected-padding: 0;\n$block-selected-child-margin: 5px;\n$block-selected-to-content: $block-edge-to-content - $block-selected-margin - $block-selected-border-width;\n","/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","/**\n * Breakpoints & Media Queries\n */\n\n// Most used breakpoints\n$break-xhuge: 1920px;\n$break-huge: 1440px;\n$break-wide: 1280px;\n$break-xlarge: 1080px;\n$break-large: 960px;\t// admin sidebar auto folds\n$break-medium: 782px;\t// adminbar goes big\n$break-small: 600px;\n$break-mobile: 480px;\n$break-zoomed-in: 280px;\n\n// All media queries currently in WordPress:\n//\n// min-width: 2000px\n// min-width: 1680px\n// min-width: 1250px\n// max-width: 1120px *\n// max-width: 1000px\n// min-width: 769px and max-width: 1000px\n// max-width: 960px *\n// max-width: 900px\n// max-width: 850px\n// min-width: 800px and max-width: 1499px\n// max-width: 800px\n// max-width: 799px\n// max-width: 782px *\n// max-width: 768px\n// max-width: 640px *\n// max-width: 600px *\n// max-width: 520px\n// max-width: 500px\n// max-width: 480px *\n// max-width: 400px *\n// max-width: 380px\n// max-width: 320px *\n//\n// Those marked * seem to be more commonly used than the others.\n// Let's try and use as few of these as possible, and be mindful about adding new ones, so we don't make the situation worse\n","/**\n*  Converts a hex value into the rgb equivalent.\n*\n* @param {string} hex - the hexadecimal value to convert\n* @return {string} comma separated rgb values\n*/\n\n@use \"sass:color\";\n@use \"sass:meta\";\n\n@function hex-to-rgb($hex) {\n\t/*\n\t * TODO: `color.{red|green|blue}` will trigger a deprecation warning in Dart Sass,\n\t * but the Sass used by the Gutenberg project doesn't support `color.channel()` yet,\n\t * so we can't migrate to it at this time.\n\t * In the future, after the Gutenberg project has been fully migrated to Dart Sass,\n\t * Remove this conditional statement and use only `color.channel()`.\n\t */\n\t@if meta.function-exists(\"channel\", \"color\") {\n\t\t@return color.channel($hex, \"red\"), color.channel($hex, \"green\"), color.channel($hex, \"blue\");\n\t} @else {\n\t\t@return color.red($hex), color.green($hex), color.blue($hex);\n\t}\n}\n","/**\n * Long content fade mixin\n *\n * Creates a fading overlay to signify that the content is longer\n * than the space allows.\n */\n\n@mixin long-content-fade($direction: right, $size: 20%, $color: #fff, $edge: 0, $z-index: false) {\n\tcontent: \"\";\n\tdisplay: block;\n\tposition: absolute;\n\t-webkit-touch-callout: none;\n\t-webkit-user-select: none;\n\t-khtml-user-select: none;\n\t-moz-user-select: none;\n\t-ms-user-select: none;\n\tuser-select: none;\n\tpointer-events: none;\n\n\t@if $z-index {\n\t\tz-index: $z-index;\n\t}\n\n\t@if $direction == \"bottom\" {\n\t\tbackground: linear-gradient(to top, transparent, $color 90%);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\ttop: $edge;\n\t\tbottom: calc(100% - $size);\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"top\" {\n\t\tbackground: linear-gradient(to bottom, transparent, $color 90%);\n\t\ttop: calc(100% - $size);\n\t\tleft: $edge;\n\t\tright: $edge;\n\t\tbottom: $edge;\n\t\twidth: auto;\n\t}\n\n\t@if $direction == \"left\" {\n\t\tbackground: linear-gradient(to left, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tleft: $edge;\n\t\tbottom: $edge;\n\t\tright: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n\n\t@if $direction == \"right\" {\n\t\tbackground: linear-gradient(to right, transparent, $color 90%);\n\t\ttop: $edge;\n\t\tbottom: $edge;\n\t\tright: $edge;\n\t\tleft: auto;\n\t\twidth: $size;\n\t\theight: auto;\n\t}\n}\n","@use \"@wordpress/theme/src/prebuilt/css/design-tokens.css\" as *;\n@use \"@wordpress/admin-ui/build-style/style.css\" as *;\n@use \"@wordpress/base-styles/mixins\" as *;\n@use \"@wordpress/base-styles/variables\" as *;\n\n.boot-layout-container .boot-layout {\n\t// On mobile the main content area has to scroll, otherwise you can invoke\n\t// the overscroll bounce on the non-scrolling container, for a bad experience.\n\t@include break-small {\n\t\tposition: absolute;\n\t\ttop: 0;\n\t\tright: 0;\n\t\tbottom: 0;\n\t\tleft: 0;\n\t\tmin-height: calc(100vh - #{$admin-bar-height-big});\n\t}\n\n\t// The WP header height changes at this breakpoint.\n\t@include break-medium {\n\t\tmin-height: calc(100vh - #{$admin-bar-height});\n\n\t\tbody:has(.boot-layout.has-full-canvas) & {\n\t\t\tmin-height: 100vh;\n\t\t}\n\t}\n\n\timg {\n\t\tmax-width: 100%;\n\t\theight: auto;\n\t}\n}\n\n.boot-layout .components-editor-notices__snackbar {\n\tposition: fixed;\n\tright: 0;\n\tbottom: 16px;\n\tpadding-left: 16px;\n\tpadding-right: 16px;\n}\n"]} */`;
3596  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css12));
3597  var css22 = `/**
3598   * Colors
3599   */
3600  @media (max-width: 782px) {
3601    * {
3602      view-transition-name: none !important;
3603    }
3604  }
3605  ::view-transition-old(root),
3606  ::view-transition-new(root) {
3607    animation-duration: 250ms;
3608  }
3609  
3610  @media not (prefers-reduced-motion: reduce) {
3611    .boot-layout__canvas .interface-interface-skeleton__header {
3612      view-transition-name: boot--canvas-header;
3613    }
3614    .boot-layout__canvas .interface-interface-skeleton__sidebar {
3615      view-transition-name: boot--canvas-sidebar;
3616    }
3617    .boot-layout.has-full-canvas .boot-layout__canvas .boot-site-icon-link,
3618    .boot-layout:not(.has-full-canvas) .boot-site-hub .boot-site-icon-link {
3619      view-transition-name: boot--site-icon-link;
3620    }
3621    .boot-layout__stage {
3622      view-transition-name: boot--stage;
3623    }
3624    .boot-layout__inspector {
3625      view-transition-name: boot--inspector;
3626    }
3627    .boot-layout__canvas:not(.is-full-canvas),
3628    .boot-layout__canvas.is-full-canvas .interface-interface-skeleton__content {
3629      view-transition-name: boot--canvas;
3630    }
3631    @supports (-webkit-hyphens: none) and (not (-moz-appearance: none)) {
3632      .boot-layout__stage {
3633        view-transition-name: boot-safari--stage;
3634      }
3635      .boot-layout__inspector {
3636        view-transition-name: boot-safari--inspector;
3637      }
3638      .boot-layout__canvas:not(.is-full-canvas),
3639      .boot-layout__canvas.is-full-canvas .interface-interface-skeleton__content {
3640        view-transition-name: boot-safari--canvas;
3641      }
3642    }
3643    .components-popover:first-of-type {
3644      view-transition-name: boot--components-popover;
3645    }
3646  }
3647  ::view-transition-group(boot--canvas-header),
3648  ::view-transition-group(boot--canvas-sidebar),
3649  ::view-transition-group(boot-safari--canvas),
3650  ::view-transition-group(boot--canvas) {
3651    z-index: 1;
3652  }
3653  
3654  ::view-transition-group(boot--site-icon-link) {
3655    z-index: 2;
3656  }
3657  
3658  ::view-transition-new(boot--site-icon-link),
3659  ::view-transition-old(boot--site-icon-link) {
3660    animation: none;
3661  }
3662  
3663  ::view-transition-new(boot-safari--canvas),
3664  ::view-transition-old(boot-safari--canvas),
3665  ::view-transition-new(boot-safari--stage),
3666  ::view-transition-old(boot-safari--stage),
3667  ::view-transition-old(boot-safari--inspector),
3668  ::view-transition-new(boot-safari--inspector) {
3669    width: auto;
3670  }
3671  
3672  ::view-transition-new(boot--canvas),
3673  ::view-transition-old(boot--canvas),
3674  ::view-transition-new(boot--stage),
3675  ::view-transition-old(boot--stage),
3676  ::view-transition-new(boot--inspector),
3677  ::view-transition-old(boot--inspector) {
3678    background: #fff;
3679    border-radius: 8px;
3680    width: 100%;
3681    height: 100%;
3682    object-fit: none;
3683    object-position: left top;
3684    overflow: hidden;
3685  }
3686  
3687  ::view-transition-new(boot--canvas),
3688  ::view-transition-old(boot--canvas) {
3689    object-position: center top;
3690  }
3691  
3692  ::view-transition-old(boot-safari--inspector):only-child,
3693  ::view-transition-old(boot--inspector):only-child,
3694  ::view-transition-old(boot-safari--stage):only-child,
3695  ::view-transition-old(boot--stage):only-child {
3696    animation-name: zoomOut;
3697    will-change: transform, opacity;
3698  }
3699  
3700  ::view-transition-new(boot-safari--inspector):only-child,
3701  ::view-transition-new(boot--inspector):only-child,
3702  ::view-transition-new(boot-safari--stage):only-child,
3703  ::view-transition-new(boot--stage):only-child {
3704    animation-name: zoomIn;
3705    will-change: transform, opacity;
3706  }
3707  
3708  @keyframes zoomOut {
3709    from {
3710      transform: scale(1);
3711      opacity: 1;
3712    }
3713    to {
3714      transform: scale(0.9);
3715      opacity: 0;
3716    }
3717  }
3718  @keyframes zoomIn {
3719    from {
3720      transform: scale(0.95);
3721      opacity: 0;
3722    }
3723    to {
3724      transform: scale(1);
3725      opacity: 1;
3726    }
3727  }
3728  ::view-transition-new(boot-safari--canvas):only-child,
3729  ::view-transition-new(boot--canvas):only-child {
3730    animation-name: slideFromRight;
3731    will-change: transform;
3732  }
3733  
3734  ::view-transition-old(boot-safari--canvas):only-child,
3735  ::view-transition-old(boot--canvas):only-child {
3736    animation-name: slideToRight;
3737    will-change: transform;
3738  }
3739  
3740  @keyframes slideFromRight {
3741    from {
3742      transform: translateX(100vw);
3743    }
3744    to {
3745      transform: translateX(0);
3746    }
3747  }
3748  @keyframes slideToRight {
3749    from {
3750      transform: translateX(0);
3751    }
3752    to {
3753      transform: translateX(100vw);
3754    }
3755  }
3756  ::view-transition-new(boot--canvas-header):only-child {
3757    animation-name: slideHeaderFromTop;
3758    will-change: transform;
3759  }
3760  
3761  ::view-transition-old(boot--canvas-header):only-child {
3762    animation-name: slideHeaderToTop;
3763    will-change: transform;
3764  }
3765  
3766  @keyframes slideHeaderFromTop {
3767    from {
3768      transform: translateY(-100%);
3769    }
3770  }
3771  @keyframes slideHeaderToTop {
3772    to {
3773      transform: translateY(-100%);
3774    }
3775  }
3776  ::view-transition-new(boot--canvas-sidebar):only-child {
3777    animation-name: slideSidebarFromRight;
3778    will-change: transform;
3779  }
3780  
3781  ::view-transition-old(boot--canvas-sidebar):only-child {
3782    animation-name: slideSidebarToRight;
3783    will-change: transform;
3784  }
3785  
3786  @keyframes slideSidebarFromRight {
3787    from {
3788      transform: translateX(100%);
3789    }
3790  }
3791  @keyframes slideSidebarToRight {
3792    to {
3793      transform: translateX(100%);
3794    }
3795  }
3796  /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/home/svn/checkouts/develop.svn.wordpress.org/trunk/gutenberg/packages/boot/src","sources":["../../../node_modules/@wordpress/base-styles/_colors.scss","view-transitions.scss"],"names":[],"mappings":"AAAA;AAAA;AAAA;ACIA;EACC;IACC;;;AAIF;AAAA;EAEC;;;AAGD;EACC;IACC;;EAGD;IACC;;EAGD;AAAA;IAMC;;EAID;IACC;;EAGD;IACC;;EAGD;AAAA;IAGC;;EAKD;IACC;MACC;;IAGD;MACC;;IAGD;AAAA;MAGC;;;EAMF;IACC;;;AAIF;AAAA;AAAA;AAAA;EAIC;;;AAGD;EACC;;;AAGD;AAAA;EAEC;;;AAID;AAAA;AAAA;AAAA;AAAA;AAAA;EAMC;;;AAKD;AAAA;AAAA;AAAA;AAAA;AAAA;EAMC,YD7FO;EC8FP;EACA;EACA;EACA;EACA;EACA;;;AAGD;AAAA;EAEC;;;AAGD;AAAA;AAAA;AAAA;EAIC;EACA;;;AAGD;AAAA;AAAA;AAAA;EAIC;EACA;;;AAGD;EACC;IACC;IACA;;EAGD;IACC;IACA;;;AAIF;EACC;IACC;IACA;;EAGD;IACC;IACA;;;AAIF;AAAA;EAEC;EACA;;;AAGD;AAAA;EAEC;EACA;;;AAGD;EACC;IAIC;;EAGD;IACC;;;AAIF;EACC;IACC;;EAGD;IACC;;;AAIF;EACC;EACA;;;AAGD;EACC;EACA;;;AAGD;EACC;IACC;;;AAIF;EACC;IACC;;;AAIF;EACC;EACA;;;AAGD;EACC;EACA;;;AAGD;EACC;IACC;;;AAIF;EACC;IACC","sourcesContent":["/**\n * Colors\n */\n\n// WordPress grays.\n$black: #000;\t\t\t// Use only when you truly need pure black. For UI, use $gray-900.\n$gray-900: #1e1e1e;\n$gray-800: #2f2f2f;\n$gray-700: #757575;\t\t// Meets 4.6:1 (4.5:1 is minimum) text contrast against white.\n$gray-600: #949494;\t\t// Meets 3:1 UI or large text contrast against white.\n$gray-400: #ccc;\n$gray-300: #ddd;\t\t// Used for most borders.\n$gray-200: #e0e0e0;\t\t// Used sparingly for light borders.\n$gray-100: #f0f0f0;\t\t// Used for light gray backgrounds.\n$white: #fff;\n\n// Opacities & additional colors.\n$dark-gray-placeholder: rgba($gray-900, 0.62);\n$medium-gray-placeholder: rgba($gray-900, 0.55);\n$light-gray-placeholder: rgba($white, 0.65);\n\n// Alert colors.\n$alert-yellow: #f0b849;\n$alert-red: #cc1818;\n$alert-green: #4ab866;\n\n// Deprecated, please avoid using these.\n$dark-theme-focus: $white;\t// Focus color when the theme is dark.\n","@use \"@wordpress/base-styles/colors\";\n\n// Disable view transitions on mobile devices\n// to avoid conflicts with sidebar navigation.\n@media (max-width: 782px) {\n\t* {\n\t\tview-transition-name: none !important;\n\t}\n}\n\n::view-transition-old(root),\n::view-transition-new(root) {\n\tanimation-duration: 250ms;\n}\n\n@media not (prefers-reduced-motion: reduce) {\n\t.boot-layout__canvas .interface-interface-skeleton__header {\n\t\tview-transition-name: boot--canvas-header;\n\t}\n\n\t.boot-layout__canvas .interface-interface-skeleton__sidebar {\n\t\tview-transition-name: boot--canvas-sidebar;\n\t}\n\n\t.boot-layout.has-full-canvas\n\t.boot-layout__canvas\n\t.boot-site-icon-link,\n\t.boot-layout:not(.has-full-canvas)\n\t.boot-site-hub\n\t.boot-site-icon-link {\n\t\tview-transition-name: boot--site-icon-link;\n\t}\n\n\t// Default (non-Safari) view transition names\n\t.boot-layout__stage {\n\t\tview-transition-name: boot--stage;\n\t}\n\n\t.boot-layout__inspector {\n\t\tview-transition-name: boot--inspector;\n\t}\n\n\t.boot-layout__canvas:not(.is-full-canvas),\n\t.boot-layout__canvas.is-full-canvas\n\t.interface-interface-skeleton__content {\n\t\tview-transition-name: boot--canvas;\n\t}\n\n\t// Safari-specific view transition names\n\t// Uses CSS feature detection instead of .is-safari class\n\t@supports (-webkit-hyphens:none) and (not (-moz-appearance:none)) {\n\t\t.boot-layout__stage {\n\t\t\tview-transition-name: boot-safari--stage;\n\t\t}\n\n\t\t.boot-layout__inspector {\n\t\t\tview-transition-name: boot-safari--inspector;\n\t\t}\n\n\t\t.boot-layout__canvas:not(.is-full-canvas),\n\t\t.boot-layout__canvas.is-full-canvas\n\t\t.interface-interface-skeleton__content {\n\t\t\tview-transition-name: boot-safari--canvas;\n\t\t}\n\t}\n\n\t// For any popover that stays open across a query change.\n\t// Naming it avoids the stage overlaying it.\n\t.components-popover:first-of-type {\n\t\tview-transition-name: boot--components-popover;\n\t}\n}\n\n::view-transition-group(boot--canvas-header),\n::view-transition-group(boot--canvas-sidebar),\n::view-transition-group(boot-safari--canvas),\n::view-transition-group(boot--canvas) {\n\tz-index: 1;\n}\n\n::view-transition-group(boot--site-icon-link) {\n\tz-index: 2;\n}\n\n::view-transition-new(boot--site-icon-link),\n::view-transition-old(boot--site-icon-link) {\n\tanimation: none;\n}\n\n// Safari-specific pseudo-element styles with width: auto fix\n::view-transition-new(boot-safari--canvas),\n::view-transition-old(boot-safari--canvas),\n::view-transition-new(boot-safari--stage),\n::view-transition-old(boot-safari--stage),\n::view-transition-old(boot-safari--inspector),\n::view-transition-new(boot-safari--inspector) {\n\twidth: auto;\n}\n\n// Safari trips up with using object fit on the pseudo images and filling out\n// background.\n::view-transition-new(boot--canvas),\n::view-transition-old(boot--canvas),\n::view-transition-new(boot--stage),\n::view-transition-old(boot--stage),\n::view-transition-new(boot--inspector),\n::view-transition-old(boot--inspector) {\n\tbackground: colors.$white;\n\tborder-radius: 8px;\n\twidth: 100%;\n\theight: 100%;\n\tobject-fit: none;\n\tobject-position: left top;\n\toverflow: hidden;\n}\n\n::view-transition-new(boot--canvas),\n::view-transition-old(boot--canvas) {\n\tobject-position: center top;\n}\n\n::view-transition-old(boot-safari--inspector):only-child,\n::view-transition-old(boot--inspector):only-child,\n::view-transition-old(boot-safari--stage):only-child,\n::view-transition-old(boot--stage):only-child {\n\tanimation-name: zoomOut;\n\twill-change: transform, opacity;\n}\n\n::view-transition-new(boot-safari--inspector):only-child,\n::view-transition-new(boot--inspector):only-child,\n::view-transition-new(boot-safari--stage):only-child,\n::view-transition-new(boot--stage):only-child {\n\tanimation-name: zoomIn;\n\twill-change: transform, opacity;\n}\n\n@keyframes zoomOut {\n\tfrom {\n\t\ttransform: scale(1);\n\t\topacity: 1;\n\t}\n\n\tto {\n\t\ttransform: scale(0.9);\n\t\topacity: 0;\n\t}\n}\n\n@keyframes zoomIn {\n\tfrom {\n\t\ttransform: scale(0.95);\n\t\topacity: 0;\n\t}\n\n\tto {\n\t\ttransform: scale(1);\n\t\topacity: 1;\n\t}\n}\n\n::view-transition-new(boot-safari--canvas):only-child,\n::view-transition-new(boot--canvas):only-child {\n\tanimation-name: slideFromRight;\n\twill-change: transform;\n}\n\n::view-transition-old(boot-safari--canvas):only-child,\n::view-transition-old(boot--canvas):only-child {\n\tanimation-name: slideToRight;\n\twill-change: transform;\n}\n\n@keyframes slideFromRight {\n\tfrom {\n\t\t// Should ideally be 100% + 16px, but we also need to take into account\n\t\t// that the canvas can be the editor-interface-skeleton__content, which\n\t\t// not placed on the right side.\n\t\ttransform: translateX(100vw);\n\t}\n\n\tto {\n\t\ttransform: translateX(0);\n\t}\n}\n\n@keyframes slideToRight {\n\tfrom {\n\t\ttransform: translateX(0);\n\t}\n\n\tto {\n\t\ttransform: translateX(100vw);\n\t}\n}\n\n::view-transition-new(boot--canvas-header):only-child {\n\tanimation-name: slideHeaderFromTop;\n\twill-change: transform;\n}\n\n::view-transition-old(boot--canvas-header):only-child {\n\tanimation-name: slideHeaderToTop;\n\twill-change: transform;\n}\n\n@keyframes slideHeaderFromTop {\n\tfrom {\n\t\ttransform: translateY(-100%);\n\t}\n}\n\n@keyframes slideHeaderToTop {\n\tto {\n\t\ttransform: translateY(-100%);\n\t}\n}\n\n::view-transition-new(boot--canvas-sidebar):only-child {\n\tanimation-name: slideSidebarFromRight;\n\twill-change: transform;\n}\n\n::view-transition-old(boot--canvas-sidebar):only-child {\n\tanimation-name: slideSidebarToRight;\n\twill-change: transform;\n}\n\n@keyframes slideSidebarFromRight {\n\tfrom {\n\t\ttransform: translateX(100%);\n\t}\n}\n\n@keyframes slideSidebarToRight {\n\tto {\n\t\ttransform: translateX(100%);\n\t}\n}\n"]} */`;
3797  document.head.appendChild(document.createElement("style")).appendChild(document.createTextNode(css22));
3798  export {
3799    init,
3800    initSinglePage,
3801    store
3802  };


Generated : Wed Apr 15 08:20:10 2026 Cross-referenced by PHPXref