diff --git a/assets/style.css b/assets/style.css index 0407264..87cbf38 100644 --- a/assets/style.css +++ b/assets/style.css @@ -3,10 +3,10 @@ box-sizing: border-box; margin: 0; padding: 0; -} - -/* Variables */ -:root { + } + + /* Variables */ + :root { /* Colors */ --background: 200 30% 97%; --foreground: 200 50% 20%; @@ -17,7 +17,7 @@ --muted: 200 30% 96%; --muted-foreground: 200 30% 40%; --border: 200 30% 90%; - + /* Spacing */ --space-1: 0.25rem; --space-2: 0.5rem; @@ -28,165 +28,164 @@ --space-8: 2rem; --space-10: 2.5rem; --space-12: 3rem; - + /* Radius */ --radius-sm: 0.375rem; --radius-md: 0.5rem; --radius-lg: 0.75rem; - - /* Container */ + + /* Container Width */ --container-width: 64rem; -} - -/* Dark mode */ -@media (prefers-color-scheme: dark) { + } + + /* Dark mode */ + @media (prefers-color-scheme: dark) { :root { - --background: 200 30% 8%; - --foreground: 200 20% 96%; - --card: 200 25% 15%; - --card-foreground: 200 15% 85%; - --primary: 200 70% 40%; - --primary-foreground: 0 0% 100%; - --muted: 200 30% 20%; - --muted-foreground: 200 30% 65%; - --border: 200 30% 20%; + --background: 200 30% 8%; + --foreground: 200 20% 96%; + --card: 200 25% 15%; + --card-foreground: 200 15% 85%; + --primary: 200 70% 40%; + --primary-foreground: 0 0% 100%; + --muted: 200 30% 20%; + --muted-foreground: 200 30% 65%; + --border: 200 30% 20%; } -} - -/* Base styles */ -html { - font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, - "Helvetica Neue", Arial, sans-serif; + } + + /* Base styles */ + html { + font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; line-height: 1.5; -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; -} - -body { + } + + body { color: hsl(var(--foreground)); background: hsl(var(--background)); min-height: 100vh; position: relative; isolation: isolate; -} - -/* Background */ -body::before { + } + + /* Background */ + body::before { content: ''; position: fixed; inset: 0; z-index: -2; background: linear-gradient( - to bottom, - hsl(var(--background)), - hsl(var(--primary) / 0.1), - hsl(var(--background)) + to bottom, + hsl(var(--background)), + hsl(var(--primary) / 0.1), + hsl(var(--background)) ); -} - -body::after { + } + + body::after { content: ''; position: fixed; inset: 0; z-index: -1; opacity: 0.35; background-image: radial-gradient( - circle at 1px 1px, - hsl(var(--primary) / 0.5) 1px, - transparent 0 + circle at 1px 1px, + hsl(var(--primary) / 0.5) 1px, + transparent 0 ); background-size: 32px 32px; mask-image: linear-gradient( - to bottom, - transparent, - black 10%, - black 90%, - transparent + to bottom, + transparent, + black 10%, + black 90%, + transparent ); -} - -/* Grid System */ -.container { + } + + /* Grid System */ + .container { width: min(var(--container-width), 100% - var(--space-8)); margin-inline: auto; padding-block: var(--space-8); -} - -.grid { + } + + .grid { display: grid; gap: var(--space-6); -} - -.grid-cols-1 { grid-template-columns: repeat(1, 1fr); } -.grid-cols-2 { grid-template-columns: repeat(2, 1fr); } -.grid-cols-3 { grid-template-columns: repeat(3, 1fr); } -.grid-cols-4 { grid-template-columns: repeat(4, 1fr); } - -@media (max-width: 768px) { + } + + .grid-cols-1 { grid-template-columns: repeat(1, 1fr); } + .grid-cols-2 { grid-template-columns: repeat(2, 1fr); } + .grid-cols-3 { grid-template-columns: repeat(3, 1fr); } + .grid-cols-4 { grid-template-columns: repeat(4, 1fr); } + + @media (max-width: 768px) { .grid-cols-2, .grid-cols-3, .grid-cols-4 { - grid-template-columns: 1fr; + grid-template-columns: 1fr; } -} - -/* Card Components */ -.card { + } + + /* Card Components */ + .card { position: relative; background: hsl(var(--card) / 0.5); border: 1px solid hsl(var(--border)); border-radius: var(--radius-lg); overflow: hidden; backdrop-filter: blur(8px); -} - -.card-header { + } + + .card-header { padding: var(--space-6); border-bottom: 1px solid hsl(var(--border)); -} - -.card-title { + } + + .card-title { font-size: 1.25rem; font-weight: 600; line-height: 1.2; letter-spacing: -0.025em; -} - -.card-description { + } + + .card-description { margin-top: var(--space-2); font-size: 0.875rem; color: hsl(var(--muted-foreground)); -} - -.card-content { + } + + .card-content { padding: var(--space-6); -} - -/* Typography */ -h1 { + } + + /* Typography */ + h1 { font-size: 2rem; font-weight: 600; line-height: 1.2; letter-spacing: -0.025em; -} - -h2 { + } + + h2 { font-size: 1.5rem; font-weight: 600; line-height: 1.2; letter-spacing: -0.025em; -} - -h3 { + } + + h3 { font-size: 1.25rem; font-weight: 600; line-height: 1.2; letter-spacing: -0.025em; -} - -/* Icons */ -.icon { + } + + /* Icons */ + .icon { width: 1.25rem; height: 1.25rem; stroke: currentColor; @@ -194,10 +193,10 @@ h3 { stroke-linecap: round; stroke-linejoin: round; fill: none; -} - -/* Badges */ -.badge { + } + + /* Badges */ + .badge { display: inline-flex; align-items: center; height: 1.5rem; @@ -209,243 +208,104 @@ h3 { background: hsl(var(--primary)); color: hsl(var(--primary-foreground)); white-space: nowrap; -} - -.badge-secondary { + } + + .badge-secondary { background: hsl(var(--muted)); color: hsl(var(--muted-foreground)); -} - -/* Loading State */ -.loading { + } + + /* Loading State */ + .loading { display: flex; align-items: center; justify-content: center; min-height: 20rem; font-size: 1rem; color: hsl(var(--muted-foreground)); -} - -/* Utilities */ -.hidden { + } + + /* Utilities */ + .hidden { display: none; -} - -.flex { + } + + .flex { display: flex; -} - -.items-center { + } + + .items-center { align-items: center; -} - -.justify-between { + } + + .justify-between { justify-content: space-between; -} - -.gap-2 { gap: var(--space-2); } -.gap-3 { gap: var(--space-3); } -.gap-4 { gap: var(--space-4); } -.gap-6 { gap: var(--space-6); } - -.mb-2 { margin-bottom: var(--space-2); } -.mb-4 { margin-bottom: var(--space-4); } -.mb-6 { margin-bottom: var(--space-6); } -.mb-8 { margin-bottom: var(--space-8); } - -.mt-2 { margin-top: var(--space-2); } -.mt-4 { margin-top: var(--space-4); } -.mt-6 { margin-top: var(--space-6); } -.mt-8 { margin-top: var(--space-8); } - -/* Header */ -.header { + } + + .gap-2 { gap: var(--space-2); } + .gap-3 { gap: var(--space-3); } + .gap-4 { gap: var(--space-4); } + .gap-6 { gap: var(--space-6); } + + .mb-2 { margin-bottom: var(--space-2); } + .mb-4 { margin-bottom: var(--space-4); } + .mb-6 { margin-bottom: var(--space-6); } + .mb-8 { margin-bottom: var(--space-8); } + + .mt-2 { margin-top: var(--space-2); } + .mt-4 { margin-top: var(--space-4); } + .mt-6 { margin-top: var(--space-6); } + .mt-8 { margin-top: var(--space-8); } + + /* Header */ + .header { text-align: center; - margin-bottom: 1rem; -} - -.header-content { + margin-bottom: var(--space-4); + } + + .header-content { display: inline-flex; align-items: center; - gap: 1.5rem; - padding: 1.5rem 2rem; + gap: var(--space-6); + padding: var(--space-6) var(--space-8); background: hsl(var(--card) / 0.5); border: 1px solid hsl(var(--border)); border-radius: var(--radius-lg); backdrop-filter: blur(8px); -} - -.header-icon { + } + + .header-icon { width: 4rem; height: 4rem; border-radius: var(--radius-lg); object-fit: contain; background: hsl(var(--muted)); - padding: 0.5rem; -} - -.header-text { + padding: var(--space-2); + } + + .header-text { text-align: left; -} - -.header-title { + } + + .header-title { font-size: 1.875rem; font-weight: 600; line-height: 1.2; letter-spacing: -0.025em; - margin-bottom: 0.5rem; -} - -.header-description { + margin-bottom: var(--space-2); + } + + .header-description { color: hsl(var(--muted-foreground)); font-size: 1.125rem; -} - -/* Banner */ -.banner { + } + + /* Banner */ + .banner { width: 100%; height: 16rem; border-radius: var(--radius-lg); object-fit: cover; border: 1px solid hsl(var(--border)); background: hsl(var(--muted)); -} - -/* Stats */ -.stats { - display: grid; - gap: 1.5rem; - grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); -} - -.stat { - display: flex; - align-items: center; - gap: 1rem; - padding: 1.5rem; - background: hsl(var(--card) / 0.5); - border: 1px solid hsl(var(--border)); - border-radius: var(--radius-lg); - backdrop-filter: blur(8px); -} - -.stat-icon { - width: 2rem; - height: 2rem; - color: hsl(var(--primary)); -} - -.stat-content { - display: flex; - flex-direction: column; - gap: 0.25rem; -} - -.stat-label { - font-size: 0.875rem; - color: hsl(var(--muted-foreground)); -} - -.stat-value { - font-size: 1.5rem; - font-weight: 600; - line-height: 1; -} - -/* Info Lists */ -.info-list { - display: flex; - flex-direction: column; - gap: 1.5rem; -} - -.info-group { - display: flex; - flex-direction: column; - gap: 1rem; -} - -.info-group:not(:last-child) { - padding-bottom: 1.5rem; - border-bottom: 1px solid hsl(var(--border)); -} - -.info-group-header { - display: flex; - align-items: center; - gap: 0.75rem; -} - -.info-group-title { - font-size: 1rem; - font-weight: 600; -} - -.info { - display: flex; - align-items: flex-start; - gap: 0.75rem; -} - -.info-icon { - width: 1.25rem; - height: 1.25rem; - color: hsl(var(--muted-foreground)); - flex-shrink: 0; - margin-top: 0.125rem; -} - -.info-content { - flex: 1; - min-width: 0; -} - -.info-label { - font-size: 0.875rem; - color: hsl(var(--muted-foreground)); - margin-bottom: 0.25rem; -} - -.info-value { - font-size: 0.875rem; -} - -.info-link { - color: hsl(var(--primary)); - text-decoration: none; - font-size: 0.875rem; -} - -.info-link:hover { - text-decoration: underline; -} - -/* Badges and Tags */ -.badge-list, -.tag-list { - display: flex; - flex-wrap: wrap; - gap: 0.5rem; -} - -.tag { - display: inline-flex; - align-items: center; - height: 1.5rem; - padding: 0 0.75rem; - border-radius: 9999px; - font-size: 0.75rem; - font-weight: 500; - background: hsl(var(--muted)); - color: hsl(var(--muted-foreground)); - white-space: nowrap; -} - -/* Code */ -code { - font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace; - font-size: 0.875rem; - background: hsl(var(--muted)); - padding: 0.25rem 0.5rem; - border-radius: calc(var(--radius-lg) - 0.25rem); -} \ No newline at end of file + } \ No newline at end of file diff --git a/index.html b/index.html index 6a002f9..df29ec5 100644 --- a/index.html +++ b/index.html @@ -1,270 +1,267 @@ - - - HRIStudio Robot Plugins - + + + HRIStudio Robot Plugins + -
-
Loading repository data...
- -