Files
notebrook-notes/frontend-vue/src/style.css
2025-09-02 22:35:24 +02:00

86 lines
2.5 KiB
CSS

/* CSS Custom Properties for iOS Safe Areas and Dynamic Viewport */
:root {
--safe-area-inset-top: env(safe-area-inset-top, 0);
--safe-area-inset-right: env(safe-area-inset-right, 0);
--safe-area-inset-bottom: env(safe-area-inset-bottom, 0);
--safe-area-inset-left: env(safe-area-inset-left, 0);
/* Dynamic viewport height that accounts for iOS Safari UI changes */
--vh-actual: 100vh;
--vh-small: 100vh; /* Fallback for browsers without svh support */
--vh-large: 100vh; /* Fallback for browsers without lvh support */
--vh-dynamic: 100vh; /* Fallback for browsers without dvh support */
/* Use newer viewport units where supported */
--vh-small: 100svh; /* Small viewport height - excludes browser UI */
--vh-large: 100lvh; /* Large viewport height - includes browser UI */
--vh-dynamic: 100dvh; /* Dynamic viewport height - changes with browser UI */
/* Header height calculations */
--header-base-height: 4rem; /* Base header height */
--header-total-height: calc(var(--header-base-height) + var(--safe-area-inset-top, 0px));
}
/* Minimal reset styles only */
* {
box-sizing: border-box;
}
body {
margin: 0;
padding: 0;
width: 100vw;
height: var(--vh-dynamic, 100vh);
overflow: hidden;
font-family: Inter, system-ui, Avenir, Helvetica, Arial, sans-serif;
line-height: 1.5;
font-weight: 400;
font-synthesis: none;
text-rendering: optimizeLegibility;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
/* iOS-specific optimizations */
-webkit-text-size-adjust: 100%;
-webkit-tap-highlight-color: transparent;
}
#app {
width: 100%;
height: 100%;
margin: 0;
padding: 0;
overflow: hidden;
}
/* iOS-specific touch and interaction optimizations */
* {
/* Disable callouts on iOS for better touch interactions */
-webkit-touch-callout: none;
/* Enable momentum scrolling globally for iOS */
-webkit-overflow-scrolling: touch;
}
/* Disable text selection only on UI elements, not form elements */
button, [role="button"], .no-select {
-webkit-user-select: none;
user-select: none;
}
/* Ensure text selection works in content and form areas */
input, textarea, [contenteditable="true"], .allow-select, p, span, div:not([role]), article, section {
-webkit-user-select: text;
user-select: text;
}
/* Accessibility helpers */
.sr-only {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
border: 0;
}