/*
Theme Name: ClassiCore Canvas
Theme URI: https://singlebuck.ca/
Author: SingleBuck
Author URI: https://singlebuck.ca/
Description: A blank app-canvas WordPress theme for ClassiCore. It removes boxed theme containers so ClassiCore verticals can use the full available browser width and height.
Version: 1.0.10
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
Text Domain: classicore-canvas
*/

:root {
  --classicore-canvas-vh: 100vh;
  --classicore-canvas-logo-size: 26px;
}

@supports (height: 100dvh) {
  :root {
    --classicore-canvas-vh: 100dvh;
  }
}

html,
body {
  margin: 0;
  padding: 0;
  width: 100%;
  min-width: 320px;
  min-height: var(--classicore-canvas-vh);
  background: #f6f8fb;
}

html {
  box-sizing: border-box;
  -webkit-text-size-adjust: 100%;
}

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

body {
  overflow-x: hidden;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: #111827;
}

a {
  color: inherit;
}

img,
svg,
video,
canvas {
  max-width: 100%;
}

.classicore-canvas-site,
.classicore-canvas-app,
.classicore-canvas-content {
  width: 100%;
  min-height: var(--classicore-canvas-vh);
  margin: 0;
  padding: 0;
}

body.admin-bar .classicore-canvas-site,
body.admin-bar .classicore-canvas-app,
body.admin-bar .classicore-canvas-content {
  min-height: calc(var(--classicore-canvas-vh) - 32px);
}

@media (max-width: 782px) {
  body.admin-bar .classicore-canvas-site,
  body.admin-bar .classicore-canvas-app,
  body.admin-bar .classicore-canvas-content {
    min-height: calc(var(--classicore-canvas-vh) - 46px);
  }
}

.classicore-canvas-empty {
  max-width: 760px;
  margin: 0 auto;
  padding: 48px 20px;
}


/* ClassiCore app pages should not inherit Elementor/theme boxed page widths. */
body.classicore-canvas-theme.classicore-app-page .entry-content,
body.classicore-canvas-theme.classicore-app-page .page-content,
body.classicore-canvas-theme.classicore-app-page .wp-block-post-content,
body.classicore-canvas-theme.classicore-app-page .classicore-canvas-app,
body.classicore-canvas-theme.classicore-app-page .classicore-canvas-content,
body.classicore-canvas-theme.classicore-app-page .elementor,
body.classicore-canvas-theme.classicore-app-page .elementor-section,
body.classicore-canvas-theme.classicore-app-page .elementor-container,
body.classicore-canvas-theme.classicore-app-page .elementor-column,
body.classicore-canvas-theme.classicore-app-page .elementor-widget-wrap,
body.classicore-canvas-theme.classicore-app-page .elementor-widget,
body.classicore-canvas-theme.classicore-app-page .elementor-widget-container,
body.classicore-canvas-theme.classicore-app-page .e-con,
body.classicore-canvas-theme.classicore-app-page .e-con-inner {
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

body.classicore-canvas-theme.classicore-app-page .elementor-section.elementor-section-boxed > .elementor-container,
body.classicore-canvas-theme.classicore-app-page .e-con > .e-con-inner {
  max-width: none !important;
}

/* Rentals map pages should behave like an app canvas, not a centered WP page. */
@media (min-width: 769px) {
  body:has(.kh-wrapper.kh-index-rentals.kh-rentals-map-view),
  body:has(.kh-wrapper.kh-index-rentals.kh-rentals-map-view) .classicore-canvas-site,
  body:has(.kh-wrapper.kh-index-rentals.kh-rentals-map-view) .classicore-canvas-app,
  body:has(.kh-wrapper.kh-index-rentals.kh-rentals-map-view) .classicore-canvas-content,
  body:has(.kh-wrapper.kh-index-rentals.kh-rentals-map-view) .kh-layout,
  body:has(.kh-wrapper.kh-index-rentals.kh-rentals-map-view) .kh-main {
    width: 100vw !important;
    max-width: none !important;
    margin: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    overflow: hidden !important;
  }

  .kh-wrapper.kh-index-rentals.kh-rentals-map-view {
    width: 100vw !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
  }
}


/* --------------------------------------------------------------------------
   ClassiCore Canvas top application bar
   -------------------------------------------------------------------------- */
:root {
  --classicore-canvas-topbar-h: 42px;
}

.classicore-canvas-topbar {
  position: sticky;
  top: 0;
  z-index: 9990;
  width: 100%;
  min-height: var(--classicore-canvas-topbar-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 0 18px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(16px);
  box-shadow: 0 1px 0 rgba(255,255,255,0.75);
}

body.admin-bar .classicore-canvas-topbar {
  top: 32px;
}

.classicore-canvas-brand-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 32px;
  color: #111827;
  text-decoration: none;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: -0.01em;
  white-space: nowrap;
}

.classicore-canvas-brand-logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--classicore-canvas-logo-size, 26px) !important;
  height: var(--classicore-canvas-logo-size, 26px) !important;
  flex: 0 0 var(--classicore-canvas-logo-size, 26px) !important;
  overflow: hidden;
}

.classicore-canvas-brand-logo-img {
  display: block;
  width: var(--classicore-canvas-logo-size, 26px) !important;
  height: var(--classicore-canvas-logo-size, 26px) !important;
  max-width: var(--classicore-canvas-logo-size, 26px) !important;
  max-height: var(--classicore-canvas-logo-size, 26px) !important;
  object-fit: contain;
}

.classicore-canvas-brand-logo .custom-logo,
.classicore-canvas-brand-link img.custom-logo,
.classicore-canvas-brand-link .classicore-canvas-brand-logo-img {
  width: var(--classicore-canvas-logo-size, 26px) !important;
  height: var(--classicore-canvas-logo-size, 26px) !important;
  max-width: var(--classicore-canvas-logo-size, 26px) !important;
  max-height: var(--classicore-canvas-logo-size, 26px) !important;
  min-width: 0 !important;
  min-height: 0 !important;
  object-fit: contain !important;
}

.classicore-canvas-brand-text {
  display: inline-flex;
  align-items: center;
}

.classicore-canvas-nav {
  min-width: 0;
  overflow-x: auto;
  scrollbar-width: none;
}
.classicore-canvas-nav::-webkit-scrollbar { display: none; }

.classicore-canvas-menu {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 4px;
  margin: 0;
  padding: 0;
  list-style: none;
  white-space: nowrap;
}

.classicore-canvas-menu li { margin: 0; padding: 0; }

.classicore-canvas-menu a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  color: #334155;
  text-decoration: none;
  font-size: 12px;
  font-weight: 750;
}

.classicore-canvas-menu a:hover,
.classicore-canvas-menu .current-menu-item > a {
  background: rgba(37, 99, 235, 0.08);
  color: #0f172a;
}

.classicore-canvas-site,
.classicore-canvas-app,
.classicore-canvas-content {
  min-height: calc(var(--classicore-canvas-vh) - var(--classicore-canvas-topbar-h));
}

body.admin-bar .classicore-canvas-site,
body.admin-bar .classicore-canvas-app,
body.admin-bar .classicore-canvas-content {
  min-height: calc(var(--classicore-canvas-vh) - var(--classicore-canvas-topbar-h) - 32px);
}

body.classicore-canvas-theme.classicore-app-page .kh-wrapper.kh-index-rentals.kh-rentals-map-view,
body.classicore-canvas-theme:has(.kh-wrapper.kh-index-rentals.kh-rentals-map-view) .kh-wrapper.kh-index-rentals.kh-rentals-map-view {
  height: calc(var(--classicore-canvas-vh) - var(--classicore-canvas-topbar-h)) !important;
  min-height: calc(var(--classicore-canvas-vh) - var(--classicore-canvas-topbar-h)) !important;
}

body.admin-bar.classicore-canvas-theme.classicore-app-page .kh-wrapper.kh-index-rentals.kh-rentals-map-view,
body.admin-bar.classicore-canvas-theme:has(.kh-wrapper.kh-index-rentals.kh-rentals-map-view) .kh-wrapper.kh-index-rentals.kh-rentals-map-view {
  height: calc(var(--classicore-canvas-vh) - var(--classicore-canvas-topbar-h) - 32px) !important;
  min-height: calc(var(--classicore-canvas-vh) - var(--classicore-canvas-topbar-h) - 32px) !important;
}

@media (max-width: 782px) {
  body.admin-bar .classicore-canvas-topbar { top: 46px; }
  body.admin-bar .classicore-canvas-site,
  body.admin-bar .classicore-canvas-app,
  body.admin-bar .classicore-canvas-content {
    min-height: calc(var(--classicore-canvas-vh) - var(--classicore-canvas-topbar-h) - 46px);
  }
  body.admin-bar.classicore-canvas-theme.classicore-app-page .kh-wrapper.kh-index-rentals.kh-rentals-map-view,
  body.admin-bar.classicore-canvas-theme:has(.kh-wrapper.kh-index-rentals.kh-rentals-map-view) .kh-wrapper.kh-index-rentals.kh-rentals-map-view {
    height: calc(var(--classicore-canvas-vh) - var(--classicore-canvas-topbar-h) - 46px) !important;
    min-height: calc(var(--classicore-canvas-vh) - var(--classicore-canvas-topbar-h) - 46px) !important;
  }
}

@media (max-width: 640px) {
  .classicore-canvas-topbar {
    padding: 0 10px;
    gap: 10px;
  }
  .classicore-canvas-brand-link { font-size: 12px; gap: 6px; }
  .classicore-canvas-brand-logo,
  .classicore-canvas-brand-logo-img {
    width: var(--classicore-canvas-logo-size, 26px) !important;
    height: var(--classicore-canvas-logo-size, 26px) !important;
    max-width: var(--classicore-canvas-logo-size, 26px) !important;
    max-height: var(--classicore-canvas-logo-size, 26px) !important;
    flex-basis: var(--classicore-canvas-logo-size, 26px) !important;
  }
  .classicore-canvas-menu a { padding: 0 8px; font-size: 12px; }
}


/* Internal ClassiCore menu can hold more app links, so keep it compact and scrollable. */
.classicore-canvas-menu--internal a {
  padding-left: 9px;
  padding-right: 9px;
}

@media (max-width: 900px) {
  .classicore-canvas-menu--internal a {
    padding-left: 7px;
    padding-right: 7px;
    font-size: 11.5px;
  }
}


/* --------------------------------------------------------------------------
   Mobile top menu behavior

   Logged-in users already have the ClassiCore mobile bottom navigation, so the
   desktop-style account links should not consume vertical space at the top.
   Logged-out users do not have that bottom app nav, so keep Home / Log in /
   Register visible.
   -------------------------------------------------------------------------- */
@media (max-width: 768px) {
  body.logged-in .classicore-canvas-topbar {
    min-height: 38px;
    padding-left: 14px;
    padding-right: 14px;
  }

  body.logged-in .classicore-canvas-nav {
    display: none !important;
  }

  body:not(.logged-in) .classicore-canvas-topbar {
    min-height: 38px;
    padding-left: 14px;
    padding-right: 10px;
    gap: 10px;
  }

  body:not(.logged-in) .classicore-canvas-brand-link {
    font-size: 12px;
    gap: 6px;
  }

  body:not(.logged-in) .classicore-canvas-nav {
    display: block;
    flex: 1 1 auto;
  }

  body:not(.logged-in) .classicore-canvas-menu {
    justify-content: flex-end;
    gap: 2px;
  }

  body:not(.logged-in) .classicore-canvas-menu a {
    min-height: 28px;
    padding-left: 8px;
    padding-right: 8px;
    font-size: 11.5px;
  }
}

/* Mobile logged-in app pages: leave room for the ClassiCore bottom nav and
   never viewport-lock rentals split view on phones. */
@media (max-width: 768px) {
  body.classicore-canvas-theme.kh-rentals-map-view,
  body.classicore-canvas-theme.kh-rentals-map-view .classicore-canvas-site,
  body.classicore-canvas-theme.kh-rentals-map-view .classicore-canvas-app,
  body.classicore-canvas-theme.kh-rentals-map-view .classicore-canvas-content {
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
  }

  body.classicore-canvas-theme.kh-bottom-actions-active .classicore-canvas-site {
    padding-bottom: calc(96px + env(safe-area-inset-bottom, 0px));
  }
}


/* Reserve room for the fixed ClassiCore footer strip so it never appears
   inside account/listing content on the Canvas theme. */
.classicore-canvas-content {
  padding-bottom: 30px;
}

@media (max-width: 768px) {
  .classicore-canvas-content {
    padding-bottom: 34px;
  }
  body.kh-bottom-actions-active .classicore-canvas-content {
    padding-bottom: 82px;
  }
}

/* --------------------------------------------------------------------------
   Mobile account menu / confirmed logout
   -------------------------------------------------------------------------- */
.classicore-canvas-account-toggle,
.classicore-canvas-account-modal {
  display: none;
}

@media (max-width: 768px) {
  body.logged-in .classicore-canvas-account-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    min-width: 34px;
    min-height: 32px;
    padding: 0 4px 0 8px;
    border: 0;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.06);
    color: #0f172a;
    font: inherit;
    font-size: 12px;
    font-weight: 800;
    cursor: pointer;
  }

  body.logged-in .classicore-canvas-account-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border-radius: 999px;
    background: #2563eb;
    color: #fff;
    font-size: 12px;
    line-height: 1;
  }

  body.logged-in .classicore-canvas-account-label {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
  }

  body.logged-in .classicore-canvas-account-modal.is-open {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 100000;
  }

  .classicore-canvas-account-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.38);
    backdrop-filter: blur(3px);
  }

  .classicore-canvas-account-panel {
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    border: 1px solid rgba(15, 23, 42, 0.1);
    border-radius: 24px;
    background: #fff;
    box-shadow: 0 24px 70px rgba(15, 23, 42, 0.25);
    padding: 16px;
  }

  .classicore-canvas-account-panel-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
  }

  .classicore-canvas-account-kicker {
    color: #64748b;
    font-size: 12px;
    font-weight: 750;
  }

  .classicore-canvas-account-name {
    color: #0f172a;
    font-size: 17px;
    font-weight: 850;
  }

  .classicore-canvas-account-close {
    width: 34px;
    height: 34px;
    border: 0;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.06);
    color: #0f172a;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
  }

  .classicore-canvas-account-links {
    display: grid;
    gap: 8px;
    padding: 12px 0;
  }

  .classicore-canvas-account-links a,
  .classicore-canvas-logout-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 44px;
    padding: 0 13px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 14px;
    background: #f8fafc;
    color: #0f172a;
    text-decoration: none;
    font: inherit;
    font-size: 14px;
    font-weight: 800;
    cursor: pointer;
  }

  .classicore-canvas-logout-trigger {
    justify-content: center;
    background: #fff1f2;
    color: #be123c;
  }

  .classicore-canvas-logout-confirm {
    margin-top: 12px;
    padding: 12px;
    border-radius: 18px;
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, 0.08);
  }

  .classicore-canvas-logout-title {
    margin-bottom: 10px;
    text-align: center;
    color: #0f172a;
    font-size: 15px;
    font-weight: 850;
  }

  .classicore-canvas-logout-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .classicore-canvas-cancel-logout,
  .classicore-canvas-confirm-logout {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, 0.1);
    text-decoration: none;
    font: inherit;
    font-size: 14px;
    font-weight: 850;
    cursor: pointer;
  }

  .classicore-canvas-cancel-logout {
    background: #fff;
    color: #0f172a;
  }

  .classicore-canvas-confirm-logout {
    background: #dc2626;
    color: #fff;
    border-color: #dc2626;
  }
}
