code-search-engine / shared /styles.css
sammoftah's picture
Deploy Code Search Engine
a6356f4 verified
/* HF-Master Shared Styles
Light research-studio system inspired by MCP Video Localizer. */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');
:root {
--peach: #ffad7a;
--peach-dark: #e8935c;
--lavender: #b8a9d9;
--sky-blue: #7accff;
--ink: #1f2937;
--slate: #4b5563;
--muted: #6b7280;
--bg-light: #f9fafb;
--surface: #ffffff;
--surface-soft: #fff7f1;
--border-default: #e5e7eb;
--border-subtle: #f3f4f6;
--accent-subtle: rgba(255, 173, 122, 0.14);
--shadow-sm: 0 1px 2px rgba(31, 41, 55, 0.05);
--shadow-md: 0 8px 24px rgba(31, 41, 55, 0.08);
--shadow-lg: 0 18px 48px rgba(31, 41, 55, 0.12);
--radius: 8px;
}
html {
scroll-behavior: smooth;
}
body,
.gradio-container {
background:
radial-gradient(circle at 7% 4%, rgba(255, 173, 122, 0.22), transparent 28%),
radial-gradient(circle at 88% 8%, rgba(122, 204, 255, 0.20), transparent 30%),
linear-gradient(180deg, #ffffff 0%, var(--bg-light) 44%, #f7f2fb 100%) !important;
color: var(--ink) !important;
font-family: Inter, "Helvetica Neue", "Segoe UI", system-ui, -apple-system, sans-serif !important;
font-weight: 400;
letter-spacing: 0;
-webkit-font-smoothing: antialiased;
}
.gradio-container {
max-width: 1180px !important;
margin: 0 auto !important;
}
.main,
.block-container {
background: transparent !important;
}
.block-container {
max-width: 1180px;
padding-top: 2rem;
padding-bottom: 2rem;
}
/* Shared hero used by Gradio helpers and Streamlit HTML. */
.hf-hero,
.hero {
position: relative;
overflow: hidden;
background:
radial-gradient(circle at 20% 8%, rgba(255, 255, 255, 0.52), transparent 26%),
linear-gradient(135deg, var(--peach) 0%, var(--lavender) 54%, var(--sky-blue) 100%);
border: 1px solid rgba(255, 255, 255, 0.72);
border-radius: 16px;
box-shadow: var(--shadow-lg), 0 0 34px rgba(255, 173, 122, 0.18);
color: #ffffff;
margin: 1rem 0 1.25rem 0;
padding: clamp(1.25rem, 3vw, 2.25rem);
}
.hf-hero::after,
.hero::after {
content: "";
position: absolute;
inset: auto -12% -45% auto;
width: 360px;
height: 360px;
background: rgba(255, 255, 255, 0.22);
border-radius: 999px;
pointer-events: none;
}
.hf-hero-grid,
.hf-hero-copy {
position: relative;
z-index: 1;
}
.hf-hero-copy {
display: flex;
align-items: flex-start;
gap: 1rem;
}
.hf-icon {
align-items: center;
background: rgba(255, 255, 255, 0.24);
border: 1px solid rgba(255, 255, 255, 0.45);
border-radius: 8px;
box-shadow: var(--shadow-sm);
display: inline-flex;
flex: 0 0 auto;
font-size: 1.7rem;
height: 3.75rem;
justify-content: center;
width: 3.75rem;
}
.hf-badge {
background: rgba(255, 255, 255, 0.22);
border: 1px solid rgba(255, 255, 255, 0.42);
border-radius: 999px;
color: rgba(255, 255, 255, 0.96);
display: inline-flex;
font-size: 0.76rem;
font-weight: 800;
letter-spacing: 0.06em;
margin-bottom: 0.7rem;
padding: 0.34rem 0.7rem;
text-transform: uppercase;
}
.hf-hero h1,
.hero h1 {
color: #ffffff !important;
font-size: clamp(2rem, 4vw, 3.35rem);
font-weight: 800;
letter-spacing: 0;
line-height: 1.04;
margin: 0 0 0.45rem 0;
text-shadow: 0 2px 12px rgba(31, 41, 55, 0.18);
}
.hf-hero p,
.hero p {
color: rgba(255, 255, 255, 0.96) !important;
font-size: 1.03rem;
line-height: 1.65;
margin: 0;
max-width: 68ch;
}
.hf-chip-row,
.pill-row {
display: flex;
flex-wrap: wrap;
gap: 0.55rem;
margin-top: 1.15rem;
position: relative;
z-index: 1;
}
.hf-chip,
.badge,
.tech-tag {
background: rgba(255, 255, 255, 0.24);
border: 1px solid rgba(255, 255, 255, 0.45);
border-radius: 999px;
color: #ffffff;
display: inline-flex;
font-size: 0.86rem;
font-weight: 700;
padding: 0.42rem 0.75rem;
}
.hf-method-grid {
display: grid;
gap: 0.9rem;
grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
margin: 1rem 0;
}
.hf-method-card,
.glass-card,
.project-card,
.info-card,
.metric-card,
.stat-box,
.gradio-container .form,
.gradio-container .panel {
background: rgba(255, 255, 255, 0.88) !important;
border: 1px solid var(--border-default) !important;
border-radius: var(--radius) !important;
box-shadow: var(--shadow-md) !important;
}
.hf-method-card {
padding: 1rem;
}
.hf-method-card span {
color: var(--peach-dark);
display: block;
font-size: 0.78rem;
font-weight: 800;
letter-spacing: 0.04em;
margin-bottom: 0.35rem;
text-transform: uppercase;
}
.hf-method-card p {
color: var(--slate);
line-height: 1.55;
margin: 0;
}
.project-card,
.info-card,
.metric-card,
.stat-box {
padding: 1rem;
}
h1,
h2,
h3,
h4,
.markdown-text h1,
.markdown-text h2,
.markdown-text h3 {
color: var(--ink) !important;
font-family: Inter, "Helvetica Neue", system-ui, sans-serif !important;
letter-spacing: 0;
}
p,
li,
label,
.markdown-text,
.markdown-text p,
.markdown-text span {
color: var(--slate) !important;
font-family: Inter, "Helvetica Neue", system-ui, sans-serif !important;
}
strong {
color: var(--ink);
font-weight: 700;
}
input,
select,
textarea,
.gr-textbox,
.gr-dropdown {
background: #ffffff !important;
border: 1px solid var(--border-default) !important;
border-radius: var(--radius) !important;
color: var(--ink) !important;
font-family: Inter, "Helvetica Neue", system-ui, sans-serif !important;
transition: border-color 0.15s ease, box-shadow 0.15s ease !important;
}
input:focus,
select:focus,
textarea:focus,
.gr-textbox:focus {
border-color: var(--peach) !important;
box-shadow: 0 0 0 3px var(--accent-subtle) !important;
outline: none !important;
}
button.primary,
button[class*="primary"],
div[data-testid="stButton"] > button {
background: linear-gradient(135deg, var(--peach) 0%, var(--peach-dark) 100%) !important;
border: 0 !important;
border-radius: var(--radius) !important;
box-shadow: 0 8px 20px rgba(255, 173, 122, 0.28) !important;
color: #ffffff !important;
font-family: Inter, "Helvetica Neue", system-ui, sans-serif !important;
font-weight: 800 !important;
padding: 0.72rem 1.1rem !important;
transition: transform 0.18s ease, box-shadow 0.18s ease !important;
}
button.primary:hover,
button[class*="primary"]:hover,
div[data-testid="stButton"] > button:hover {
box-shadow: 0 12px 26px rgba(255, 173, 122, 0.36) !important;
transform: translateY(-1px) !important;
}
button.secondary,
button[class*="secondary"] {
background: #ffffff !important;
border: 1px solid var(--border-default) !important;
border-radius: var(--radius) !important;
color: var(--ink) !important;
font-weight: 700 !important;
}
code,
pre {
border-radius: var(--radius) !important;
}
code {
background: #fff2e8 !important;
color: #9a4f1f !important;
}
pre {
background: #111827 !important;
border: 1px solid #273244 !important;
color: #f9fafb !important;
}
table {
border-collapse: collapse;
width: 100%;
}
th {
background: #fff2e8;
color: var(--ink);
font-weight: 800;
}
td,
th {
border-bottom: 1px solid var(--border-default);
padding: 0.7rem;
}
blockquote,
.markdown-text blockquote {
background: #faf9fc !important;
border-left: 3px solid var(--lavender) !important;
border-radius: 0 var(--radius) var(--radius) 0 !important;
color: var(--slate) !important;
margin: 0.5rem 0 !important;
padding: 0.75rem 1rem !important;
}
a {
color: #2774a9 !important;
font-weight: 700;
}
.hf-footer {
border-top: 1px solid var(--border-default);
color: var(--muted);
font-size: 0.92rem;
margin-top: 1.5rem;
padding: 1rem 0;
text-align: center;
}
.hf-footer strong {
color: var(--ink);
}
/* Streamlit shell polish. */
div[data-testid="stHeader"],
div[data-testid="stToolbar"] {
background: transparent !important;
}
div[data-testid="stSidebar"] {
background: rgba(255, 255, 255, 0.82) !important;
border-right: 1px solid var(--border-default);
}
div[data-baseweb="input"],
div[data-baseweb="textarea"],
div[data-baseweb="select"] {
background: #ffffff !important;
}
div[data-testid="stTextInput"] input,
div[data-testid="stTextArea"] textarea,
div[data-testid="stSelectbox"] div {
border-radius: var(--radius) !important;
border-color: var(--border-default) !important;
}
div[data-testid="stMetric"] {
background: rgba(255, 255, 255, 0.9);
border: 1px solid var(--border-default);
border-radius: var(--radius);
box-shadow: var(--shadow-md);
padding: 0.8rem 1rem;
}
.stPlotlyChart {
background: rgba(255, 255, 255, 0.86);
border: 1px solid var(--border-default);
border-radius: var(--radius);
box-shadow: var(--shadow-sm);
padding: 0.3rem;
}
@keyframes fadeIn {
from {
opacity: 0;
transform: translateY(8px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.hf-hero,
.hf-method-card,
.metric-card,
.info-card {
animation: fadeIn 0.28s ease-out;
}
@media (max-width: 720px) {
.hf-hero-copy {
flex-direction: column;
}
.hf-icon {
height: 3.2rem;
width: 3.2rem;
}
}