﻿* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
.splash-screen {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100vh;
background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 50%, #1a1a1a 100%);
display: flex;
align-items: center;
justify-content: center;
z-index: 10000;
overflow: hidden;
transition: opacity 0.5s ease-out, visibility 0.5s ease-out;
}
.splash-screen.hidden {
opacity: 0;
visibility: hidden;
}
.splash-content {
text-align: center;
color: #ffffff;
z-index: 2;
position: relative;
animation: splashFadeIn 1s ease-out;
background: rgba(0, 0, 0, 0.3);
padding: 2rem;
border-radius: 20px;
backdrop-filter: blur(10px);
border: 1px solid rgba(255, 255, 255, 0.1);
transition: all 0.3s ease;
cursor: pointer;
}
.splash-content:hover {
background: rgba(0, 0, 0, 0.4);
border: 1px solid rgba(66, 165, 245, 0.3);
transform: scale(1.02);
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}
.splash-logo {
width: 120px;
height: 120px;
margin: 0 auto 2rem;
animation: splashLogoFloat 2s ease-in-out infinite;
}
.splash-logo-img {
width: 100%;
height: 100%;
object-fit: contain;
filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.3));
background: transparent !important;
border-radius: 50%;
}
.splash-title h1 {
font-size: 2.5rem;
font-weight: 700;
margin-bottom: 0.5rem;
text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5), 0 0 20px rgba(25, 118, 210, 0.3);
animation: splashTitleSlide 1s ease-out 0.5s both;
background: linear-gradient(135deg, #ffffff, #e3f2fd);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.splash-subtitle {
font-size: 1.2rem;
opacity: 0.9;
font-weight: 300;
margin-bottom: 1rem;
animation: splashSubtitleSlide 1s ease-out 0.7s both;
}
.splash-tagline {
margin-bottom: 2rem;
animation: splashTaglineSlide 1s ease-out 0.9s both;
}
.splash-tagline p {
font-size: 1rem;
opacity: 0.8;
font-weight: 400;
}
.splash-progress {
margin-bottom: 2rem;
animation: splashProgressSlide 1s ease-out 1.1s both;
}
.progress-bar {
width: 200px;
height: 6px;
background: rgba(255, 255, 255, 0.2);
border-radius: 3px;
margin: 0 auto 0.5rem;
overflow: hidden;
border: 1px solid rgba(255, 255, 255, 0.1);
}
.progress-fill {
height: 100%;
background: linear-gradient(90deg, #1976d2, #42a5f5, #1976d2);
border-radius: 3px;
width: 0%;
transition: width 0.3s ease;
animation: progressGlow 2s ease-in-out infinite;
box-shadow: 0 0 10px rgba(25, 118, 210, 0.5);
}
.progress-text {
font-size: 0.9rem;
opacity: 0.8;
font-weight: 300;
}
.splash-features {
display: flex;
justify-content: center;
gap: 2rem;
animation: splashFeaturesSlide 1s ease-out 1.3s both;
}
.feature-item {
display: flex;
flex-direction: column;
align-items: center;
gap: 0.5rem;
opacity: 0.8;
transition: opacity 0.3s ease;
}
.feature-item:hover {
opacity: 1;
}
.feature-item .material-icons {
font-size: 1.5rem;
filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.5));
color: #42a5f5;
background: rgba(25, 118, 210, 0.1);
padding: 0.5rem;
border-radius: 50%;
border: 1px solid rgba(66, 165, 245, 0.3);
}
.feature-item span:last-child {
font-size: 0.8rem;
font-weight: 300;
}
.splash-background {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 1;
}
.splash-particles {
position: absolute;
width: 100%;
height: 100%;
background-image:
radial-gradient(2px 2px at 20px 30px, rgba(25,118,210,0.4), transparent),
radial-gradient(2px 2px at 40px 70px, rgba(66,165,245,0.3), transparent),
radial-gradient(1px 1px at 90px 40px, rgba(25,118,210,0.5), transparent),
radial-gradient(1px 1px at 130px 80px, rgba(66,165,245,0.4), transparent),
radial-gradient(2px 2px at 160px 30px, rgba(25,118,210,0.3), transparent),
radial-gradient(1px 1px at 200px 50px, rgba(255,255,255,0.2), transparent),
radial-gradient(1px 1px at 250px 20px, rgba(255,255,255,0.1), transparent);
background-repeat: repeat;
background-size: 300px 150px;
animation: splashParticles 25s linear infinite;
}
@keyframes splashFadeIn {
from {
opacity: 0;
transform: scale(0.9);
}
to {
opacity: 1;
transform: scale(1);
}
}
@keyframes splashLogoFloat {
0%, 100% {
transform: translateY(0px);
}
50% {
transform: translateY(-10px);
}
}
@keyframes splashTitleSlide {
from {
opacity: 0;
transform: translateY(30px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes splashSubtitleSlide {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 0.9;
transform: translateY(0);
}
}
@keyframes splashTaglineSlide {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 0.8;
transform: translateY(0);
}
}
@keyframes splashProgressSlide {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes splashFeaturesSlide {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 0.8;
transform: translateY(0);
}
}
@keyframes progressGlow {
0%, 100% {
box-shadow: 0 0 10px rgba(25, 118, 210, 0.5);
}
50% {
box-shadow: 0 0 20px rgba(25, 118, 210, 0.8), 0 0 30px rgba(66, 165, 245, 0.6);
}
}
@keyframes splashParticles {
from {
transform: translateY(0);
}
to {
transform: translateY(-100px);
}
}
@media (max-width: 768px) {
.splash-title h1 {
font-size: 2rem;
}
.splash-subtitle {
font-size: 1rem;
}
.splash-features {
gap: 1rem;
}
.feature-item .material-icons {
font-size: 1.2rem;
}
.feature-item span:last-child {
font-size: 0.7rem;
}
.progress-bar {
width: 150px;
}
}
:root {
--primary: #1976d2;
--primary-container: #e3f2fd;
--secondary: #03dac6;
--secondary-container: #e0f7fa;
--surface: #ffffff;
--surface-variant: #f5f5f5;
--background: #fafafa;
--error: #b00020;
--on-primary: #ffffff;
--on-secondary: #000000;
--on-surface: #1c1b1f;
--on-background: #1c1b1f;
--outline: #79747e;
--outline-variant: #cac4d0;
--font-family: 'Tajawal', sans-serif;
--font-size-xs: 0.75rem;
--font-size-sm: 0.875rem;
--font-size-base: 1rem;
--font-size-lg: 1.125rem;
--font-size-xl: 1.25rem;
--font-size-2xl: 1.5rem;
--font-size-3xl: 1.875rem;
--spacing-xs: 0.25rem;
--spacing-sm: 0.5rem;
--spacing-md: 1rem;
--spacing-lg: 1.5rem;
--spacing-xl: 2rem;
--header-height: 64px;
--bottom-nav-height: 70px;
--spacing-2xl: 3rem;
--radius-sm: 0.5rem;
--radius-md: 0.75rem;
--radius-lg: 1rem;
--radius-xl: 1.5rem;
--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
--transition-fast: 0.15s ease-in-out;
--transition-normal: 0.3s ease-in-out;
--transition-slow: 0.5s ease-in-out;
}
body {
font-family: var(--font-family);
background-color: var(--background);
color: var(--on-background);
line-height: 1.6;
direction: rtl;
text-align: right;
overflow-x: hidden;
}
.header {
position: fixed;
top: 0;
left: 0;
right: 0;
background: var(--surface-container);
backdrop-filter: blur(20px);
-webkit-backdrop-filter: blur(20px);
border-bottom: 1px solid var(--outline-variant);
z-index: 1000;
padding: var(--spacing-sm) var(--spacing-md);
transition: all var(--transition-fast);
height: var(--header-height);
}
@media (display-mode: standalone) and (display-mode: window-controls-overlay) {
.header {
padding-left: env(titlebar-area-x, var(--spacing-md));
padding-right: calc(env(titlebar-area-width, 100vw) - env(titlebar-area-x, 0px) - env(titlebar-area-width, 100vw));
}
.header-content {
max-width: none;
height: 100%;
}
}
@media (display-mode: tabbed) {
.header {
background: var(--surface-container);
border-bottom: 1px solid var(--outline-variant);
}
.main-content {
padding-top: calc(var(--header-height) + var(--spacing-md));
}
.header-content {
height: 100%;
}
}
@media (display-mode: standalone) {
.header {
background: var(--surface-container);
backdrop-filter: blur(20px);
-webkit-backdrop-filter: blur(20px);
border-bottom: 1px solid var(--outline-variant);
box-shadow: 0 2px 20px rgba(0, 0, 0, 0.1);
}
.logo:hover {
background: var(--surface-variant);
transform: translateY(-1px);
}
.status-indicator:hover {
transform: translateY(-1px);
box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
}
.header-content {
height: 100%;
}
}
.header-content {
display: flex;
justify-content: space-between;
align-items: center;
max-width: 1200px;
margin: 0 auto;
gap: var(--spacing-md);
height: 100%;
width: 100%;
padding: 0 var(--spacing-md);
}
.logo {
display: flex;
align-items: center;
gap: var(--spacing-md);
color: var(--primary);
flex-shrink: 0;
min-width: 0;
cursor: pointer;
transition: all var(--transition-fast);
padding: var(--spacing-xs);
border-radius: var(--radius-md);
order: 1;
}
.logo:hover {
background: var(--surface-variant);
transform: translateY(-1px);
}
.logo:hover .logo-icon {
transform: scale(1.05);
}
.logo:hover .logo-icon::before {
background: linear-gradient(45deg, transparent 30%, rgba(25, 118, 210, 0.4) 50%, transparent 70%);
}
.logo:hover .logo-text h1 {
background: linear-gradient(135deg, var(--primary), var(--secondary));
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.logo:hover .logo-subtitle {
opacity: 1;
color: var(--primary);
}
.logo:hover .logo-icon::before {
transform: translateX(100%);
}
.logo-icon {
width: 40px;
height: 40px;
display: flex;
align-items: center;
justify-content: center;
background: transparent;
border-radius: var(--radius-md);
transition: all var(--transition-fast);
position: relative;
overflow: hidden;
}
.logo-icon::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: linear-gradient(45deg, transparent 30%, rgba(25, 118, 210, 0.3) 50%, transparent 70%);
transform: translateX(-100%);
transition: transform 0.6s;
border-radius: var(--radius-md);
}
.logo:hover .logo-icon::before {
transform: translateX(100%);
}
.logo-img {
width: 100%;
height: 100%;
object-fit: contain;
filter: drop-shadow(0 2px 4px rgba(25, 118, 210, 0.3));
transition: all var(--transition-normal);
z-index: 1;
position: relative;
}
.logo:hover .logo-img {
transform: scale(1.05);
filter: drop-shadow(0 4px 8px rgba(25, 118, 210, 0.5));
}
.logo-text {
min-width: 0;
flex-shrink: 1;
display: flex;
flex-direction: column;
gap: 2px;
}
.logo-text h1 {
font-size: var(--font-size-xl);
font-weight: 700;
margin: 0;
color: var(--on-surface);
line-height: 1.2;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
background: linear-gradient(135deg, var(--primary), var(--secondary));
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
transition: all var(--transition-fast);
}
.logo-subtitle {
font-size: var(--font-size-sm);
color: var(--outline);
font-weight: 500;
display: block;
margin-top: -2px;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
opacity: 0.8;
transition: all var(--transition-fast);
}
.header-actions {
display: flex;
align-items: center;
gap: var(--spacing-sm);
flex-shrink: 0;
order: 3;
}
.connection-status {
display: flex;
align-items: center;
flex-shrink: 0;
order: 2;
}
.status-indicator {
display: flex;
align-items: center;
gap: var(--spacing-xs);
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-full);
font-size: var(--font-size-xs);
font-weight: 500;
transition: all 0.3s ease;
cursor: pointer;
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
box-shadow: var(--shadow-sm);
}
.status-indicator.online {
background: rgba(76, 175, 80, 0.15);
color: var(--success);
border: 1px solid rgba(76, 175, 80, 0.3);
box-shadow: 0 0 10px rgba(76, 175, 80, 0.2);
}
.status-indicator.offline {
background: rgba(244, 67, 54, 0.15);
color: var(--error);
border: 1px solid rgba(244, 67, 54, 0.3);
box-shadow: 0 0 10px rgba(244, 67, 54, 0.2);
}
.status-indicator.slow {
background: rgba(255, 152, 0, 0.15);
color: var(--warning);
border: 1px solid rgba(255, 152, 0, 0.3);
box-shadow: 0 0 10px rgba(255, 152, 0, 0.2);
}
.status-icon {
font-size: 14px;
animation: pulse 2s infinite;
}
.status-indicator.offline .status-icon {
animation: none;
}
.status-indicator.slow .status-icon {
animation: slow-pulse 1.5s infinite;
}
@keyframes pulse {
0%, 100% { opacity: 1; }
50% { opacity: 0.5; }
}
@keyframes slow-pulse {
0%, 100% { opacity: 1; }
50% { opacity: 0.7; }
}
.offline-banner {
position: fixed;
top: 0;
left: 0;
right: 0;
background: var(--error);
color: var(--on-error);
padding: var(--spacing-sm);
text-align: center;
font-size: var(--font-size-sm);
font-weight: 500;
z-index: 1000;
transform: translateY(-100%);
transition: transform 0.3s ease;
}
.offline-banner.show {
transform: translateY(0);
}
.offline-banner .banner-content {
display: flex;
align-items: center;
justify-content: center;
gap: var(--spacing-sm);
}
.offline-banner .banner-icon {
font-size: 18px;
}
.offline-overlay {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: rgba(0, 0, 0, 0.8);
display: flex;
align-items: center;
justify-content: center;
z-index: 999;
opacity: 0;
visibility: hidden;
transition: all 0.3s ease;
}
.offline-overlay.show {
opacity: 1;
visibility: visible;
}
.offline-content {
background: var(--surface);
border-radius: var(--radius-lg);
padding: var(--spacing-xl);
text-align: center;
max-width: 400px;
margin: var(--spacing-lg);
box-shadow: var(--shadow-lg);
position: relative;
}
.offline-content .offline-icon {
font-size: 48px;
margin-bottom: var(--spacing-md);
opacity: 0.7;
}
.offline-content h3 {
color: var(--on-surface);
margin-bottom: var(--spacing-sm);
}
.offline-content p {
color: var(--on-surface-variant);
margin-bottom: var(--spacing-lg);
line-height: 1.6;
}
.close-offline-btn {
position: absolute;
top: var(--spacing-sm);
right: var(--spacing-sm);
background: transparent;
border: none;
color: var(--on-surface-variant);
cursor: pointer;
padding: var(--spacing-xs);
border-radius: var(--radius-sm);
transition: all 0.3s ease;
display: flex;
align-items: center;
justify-content: center;
}
.close-offline-btn:hover {
background: var(--surface-variant);
color: var(--on-surface);
}
.close-offline-btn .material-icons {
font-size: 20px;
}
.offline-actions {
display: flex;
gap: var(--spacing-sm);
justify-content: center;
flex-wrap: wrap;
}
.offline-content .retry-btn {
background: var(--primary);
color: var(--on-primary);
border: none;
padding: var(--spacing-sm) var(--spacing-lg);
border-radius: var(--radius-md);
font-size: var(--font-size-sm);
font-weight: 500;
cursor: pointer;
transition: all 0.3s ease;
flex: 1;
min-width: 120px;
}
.offline-content .retry-btn:hover {
background: var(--primary-dark);
transform: translateY(-1px);
}
.offline-content .retry-btn:disabled {
background: var(--surface-variant);
color: var(--on-surface-variant);
cursor: not-allowed;
transform: none;
}
.continue-btn {
background: var(--surface-variant);
color: var(--on-surface-variant);
border: none;
padding: var(--spacing-sm) var(--spacing-lg);
border-radius: var(--radius-md);
font-size: var(--font-size-sm);
font-weight: 500;
cursor: pointer;
transition: all 0.3s ease;
flex: 1;
min-width: 120px;
}
.continue-btn:hover {
background: var(--outline);
color: var(--on-surface);
transform: translateY(-1px);
}
img {
max-width: 100%;
height: auto;
image-rendering: -webkit-optimize-contrast;
image-rendering: crisp-edges;
image-rendering: pixelated;
image-rendering: auto;
}
.logo-img {
width: 100%;
height: 100%;
object-fit: contain;
image-rendering: -webkit-optimize-contrast;
image-rendering: crisp-edges;
image-rendering: auto;
}
img[loading="lazy"] {
opacity: 0;
transition: opacity 0.3s ease;
}
img[loading="lazy"].loaded {
opacity: 1;
}
.image-placeholder {
background: var(--surface-variant);
display: flex;
align-items: center;
justify-content: center;
color: var(--on-surface-variant);
font-size: var(--font-size-sm);
border-radius: var(--radius-md);
min-height: 120px;
}
.card-image {
width: 100%;
height: 120px;
object-fit: cover;
border-radius: var(--radius-md) var(--radius-md) 0 0;
background: var(--surface-variant);
display: flex;
align-items: center;
justify-content: center;
font-size: 2rem;
color: var(--on-surface-variant);
}
.material-icons {
font-display: swap;
text-rendering: optimizeLegibility;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
.emoji {
font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", "Android Emoji", "EmojiSymbols", "EmojiOne Mozilla", "Twemoji Mozilla", "Segoe UI Symbol";
font-style: normal;
font-variant: normal;
font-weight: normal;
line-height: 1;
text-transform: none;
display: inline-block;
vertical-align: middle;
}
.update-prompt {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: rgba(0, 0, 0, 0.8);
display: flex;
align-items: center;
justify-content: center;
z-index: 10000;
animation: fadeIn 0.3s ease;
}
.update-content {
background: var(--surface);
border-radius: var(--radius-lg);
padding: var(--spacing-xl);
text-align: center;
max-width: 400px;
margin: var(--spacing-lg);
box-shadow: var(--shadow-lg);
animation: slideUp 0.3s ease;
}
.update-icon {
font-size: 48px;
margin-bottom: var(--spacing-md);
animation: rotate 2s linear infinite;
}
.update-content h3 {
color: var(--on-surface);
margin-bottom: var(--spacing-sm);
font-size: var(--font-size-lg);
}
.update-content p {
color: var(--on-surface-variant);
margin-bottom: var(--spacing-lg);
line-height: 1.6;
}
.update-actions {
display: flex;
gap: var(--spacing-sm);
justify-content: center;
}
.update-btn {
padding: var(--spacing-sm) var(--spacing-lg);
border-radius: var(--radius-md);
font-size: var(--font-size-sm);
font-weight: 500;
cursor: pointer;
transition: all 0.3s ease;
border: none;
min-width: 100px;
}
.update-btn.primary {
background: var(--primary);
color: var(--on-primary);
}
.update-btn.primary:hover {
background: var(--primary-dark);
transform: translateY(-1px);
}
.update-btn.secondary {
background: var(--surface-variant);
color: var(--on-surface-variant);
}
.update-btn.secondary:hover {
background: var(--outline);
transform: translateY(-1px);
}
@keyframes fadeIn {
from { opacity: 0; }
to { opacity: 1; }
}
@keyframes slideUp {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes rotate {
from { transform: rotate(0deg); }
to { transform: rotate(360deg); }
}
.install-banner {
position: fixed;
bottom: 20px;
left: 20px;
right: 20px;
background: var(--surface);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-lg);
z-index: 10000;
animation: slideUp 0.3s ease;
max-width: 400px;
margin: 0 auto;
}
.install-content {
display: flex;
align-items: center;
gap: var(--spacing-md);
padding: var(--spacing-md);
}
.install-icon {
font-size: 24px;
flex-shrink: 0;
}
.install-text {
flex: 1;
min-width: 0;
}
.install-text h4 {
margin: 0 0 var(--spacing-xs) 0;
color: var(--on-surface);
font-size: var(--font-size-sm);
font-weight: 600;
}
.install-text p {
margin: 0;
color: var(--on-surface-variant);
font-size: var(--font-size-xs);
line-height: 1.4;
}
.install-actions {
display: flex;
gap: var(--spacing-xs);
flex-shrink: 0;
}
.install-btn {
background: var(--primary);
color: var(--on-primary);
border: none;
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-size: var(--font-size-xs);
font-weight: 500;
cursor: pointer;
transition: all 0.3s ease;
}
.install-btn:hover {
background: var(--primary-dark);
transform: translateY(-1px);
}
.dismiss-install-btn {
background: transparent;
color: var(--on-surface-variant);
border: 1px solid var(--outline);
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-size: var(--font-size-xs);
font-weight: 500;
cursor: pointer;
transition: all 0.3s ease;
}
.dismiss-install-btn:hover {
background: var(--surface-variant);
color: var(--on-surface);
}
.contact-btn {
display: flex;
align-items: center;
justify-content: center;
width: 40px;
height: 40px;
background: var(--primary);
color: var(--on-primary);
border-radius: var(--radius-sm);
text-decoration: none;
transition: all var(--transition-fast);
box-shadow: var(--shadow-sm);
}
.contact-btn:hover {
background: var(--primary);
transform: translateY(-2px);
box-shadow: var(--shadow-md);
color: var(--on-primary);
}
.contact-btn:active {
transform: translateY(0);
box-shadow: var(--shadow-sm);
}
.contact-btn .material-icons {
font-size: 1.2rem;
}
.menu-btn {
background: none;
border: none;
color: var(--on-surface);
cursor: pointer;
padding: var(--spacing-sm);
border-radius: var(--radius-sm);
transition: background-color var(--transition-fast);
width: 40px;
height: 40px;
display: flex;
align-items: center;
justify-content: center;
}
.menu-btn:hover {
background-color: var(--surface-variant);
}
.main-content {
margin-top: var(--header-height);
margin-bottom: var(--bottom-nav-height);
min-height: calc(100vh - var(--header-height) - var(--bottom-nav-height));
padding: var(--spacing-md);
max-width: 1200px;
margin-left: auto;
margin-right: auto;
}
.section {
display: none;
animation: fadeIn var(--transition-normal);
}
.section.active {
display: block;
}
@keyframes fadeIn {
from { opacity: 0; transform: translateY(20px); }
to { opacity: 1; transform: translateY(0); }
}
.hero-banner {
background: linear-gradient(135deg, #1a1a1a 0%, #2d2d2d 50%, #1a1a1a 100%);
color: #ffffff;
padding: var(--spacing-2xl);
border-radius: var(--radius-xl);
margin-bottom: var(--spacing-xl);
text-align: center;
position: relative;
overflow: hidden;
box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}
.hero-logo {
width: 120px;
height: 120px;
margin: 0 auto var(--spacing-lg);
display: flex;
align-items: center;
justify-content: center;
animation: float 3s ease-in-out infinite;
background: transparent !important;
border: none;
outline: none;
overflow: hidden;
border-radius: 50%;
padding: 0;
}
.hero-logo-img {
width: 100%;
height: 100%;
object-fit: contain;
filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.5)) brightness(1.1) contrast(1.1);
transition: all var(--transition-normal);
background: transparent !important;
border: none;
outline: none;
image-rendering: -webkit-optimize-contrast;
image-rendering: crisp-edges;
mix-blend-mode: normal;
border-radius: 50%;
}
.hero-logo:hover .hero-logo-img {
transform: scale(1.1) rotate(5deg);
filter: drop-shadow(0 12px 24px rgba(0, 0, 0, 0.7)) brightness(1.2) contrast(1.2);
}
.hero-logo img,
.hero-logo-img {
background-color: transparent !important;
background-image: none !important;
-webkit-background-clip: unset !important;
background-clip: unset !important;
}
.hero-banner .hero-logo img {
background: transparent !important;
mix-blend-mode: normal;
border-radius: 50%;
padding: 0;
margin: 0;
}
@keyframes float {
0%, 100% {
transform: translateY(0px);
}
50% {
transform: translateY(-10px);
}
}
.hero-content h2 {
font-size: var(--font-size-3xl);
font-weight: 700;
margin-bottom: var(--spacing-md);
}
.hero-content p {
font-size: var(--font-size-lg);
margin-bottom: var(--spacing-xl);
opacity: 0.9;
}
.hero-actions {
display: flex;
gap: var(--spacing-md);
justify-content: center;
flex-wrap: wrap;
}
.btn {
display: inline-flex;
align-items: center;
gap: var(--spacing-sm);
padding: var(--spacing-md) var(--spacing-lg);
border: none;
border-radius: var(--radius-md);
font-family: var(--font-family);
font-size: var(--font-size-base);
font-weight: 500;
cursor: pointer;
transition: all var(--transition-fast);
text-decoration: none;
min-height: 48px;
}
.btn-primary {
background-color: var(--primary);
color: var(--on-primary);
}
.btn-primary:hover {
background-color: #1565c0;
transform: translateY(-2px);
box-shadow: var(--shadow-lg);
}
.btn-secondary {
background-color: var(--secondary);
color: var(--on-secondary);
}
.btn-secondary:hover {
background-color: #00bcd4;
transform: translateY(-2px);
box-shadow: var(--shadow-lg);
}
.quick-links {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: var(--spacing-lg);
margin-bottom: var(--spacing-xl);
}
.link-card {
background: var(--surface);
padding: var(--spacing-xl);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-md);
text-align: center;
cursor: pointer;
transition: all var(--transition-normal);
border: 1px solid var(--outline-variant);
}
.link-card:hover {
transform: translateY(-4px);
box-shadow: var(--shadow-xl);
}
.link-card .material-icons {
font-size: 3rem;
color: var(--primary);
margin-bottom: var(--spacing-md);
}
.link-card h3 {
font-size: var(--font-size-xl);
font-weight: 600;
margin-bottom: var(--spacing-sm);
color: var(--on-surface);
}
.link-card p {
color: var(--outline);
font-size: var(--font-size-sm);
}
.section-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--spacing-xl);
flex-wrap: wrap;
gap: var(--spacing-md);
}
.section-header h2 {
font-size: var(--font-size-2xl);
font-weight: 700;
color: var(--on-surface);
}
.search-bar {
position: relative;
display: flex;
align-items: center;
background: var(--surface);
border: 1px solid var(--outline-variant);
border-radius: var(--radius-md);
padding: var(--spacing-sm) var(--spacing-md);
min-width: 250px;
}
.search-bar .material-icons {
color: var(--outline);
margin-left: var(--spacing-sm);
}
.search-bar input {
border: none;
outline: none;
background: none;
font-family: var(--font-family);
font-size: var(--font-size-base);
color: var(--on-surface);
width: 100%;
}
.search-bar input::placeholder {
color: var(--outline);
}
.filter-tabs {
display: flex;
gap: var(--spacing-sm);
margin-bottom: var(--spacing-xl);
flex-wrap: wrap;
}
.filter-tab {
padding: var(--spacing-sm) var(--spacing-lg);
border: 1px solid var(--outline-variant);
background: var(--surface);
color: var(--on-surface);
border-radius: var(--radius-md);
cursor: pointer;
transition: all var(--transition-fast);
font-family: var(--font-family);
font-size: var(--font-size-sm);
}
.filter-tab.active,
.filter-tab:hover {
background: var(--primary);
color: var(--on-primary);
border-color: var(--primary);
}
.marketplace-filters {
display: flex;
gap: 20px;
margin-bottom: 32px;
flex-wrap: wrap;
align-items: end;
background: var(--surface);
padding: 24px;
border-radius: 16px;
border: 1px solid var(--border-color);
box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
backdrop-filter: blur(10px);
position: relative;
overflow: hidden;
}
.marketplace-filters::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 3px;
background: linear-gradient(90deg, var(--primary), var(--secondary));
border-radius: 16px 16px 0 0;
}
@media (min-width: 769px) {
.marketplace-filters {
display: none;
}
#marketplace.filters-sheet-open .marketplace-filters {
display: block;
position: fixed;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
max-width: 650px;
width: 92%;
max-height: 85vh;
overflow-y: auto;
background: var(--surface);
border-radius: 20px;
box-shadow: 0 20px 60px rgba(0,0,0,0.25), 0 8px 32px rgba(0,0,0,0.15);
padding: 32px;
z-index: 1003;
animation: modal-in 300ms cubic-bezier(0.34, 1.56, 0.64, 1);
border: 1px solid rgba(255, 255, 255, 0.1);
backdrop-filter: blur(20px);
}
#marketplace.filters-sheet-open ~ #filterSheetBackdrop {
opacity: 1;
visibility: visible;
}
}
@keyframes modal-in {
0% {
transform: translate(-50%, -50%) scale(0.8) rotateY(10deg);
opacity: 0;
filter: blur(10px);
}
50% {
transform: translate(-50%, -50%) scale(1.02) rotateY(0deg);
filter: blur(2px);
}
100% {
transform: translate(-50%, -50%) scale(1) rotateY(0deg);
opacity: 1;
filter: blur(0px);
}
}
@keyframes fadeInUp {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
@keyframes slideInRight {
from {
opacity: 0;
transform: translateX(30px);
}
to {
opacity: 1;
transform: translateX(0);
}
}
@keyframes glow {
0%, 100% {
box-shadow: 0 0 5px rgba(var(--primary-rgb), 0.3);
}
50% {
box-shadow: 0 0 20px rgba(var(--primary-rgb), 0.6);
}
}
.filter-group {
display: flex;
flex-direction: column;
gap: 12px;
min-width: 160px;
background: rgba(255, 255, 255, 0.05);
padding: 16px;
border-radius: 12px;
border: 1px solid rgba(255, 255, 255, 0.1);
transition: all 0.3s ease;
position: relative;
animation: fadeInUp 0.6s ease forwards;
}
.filter-group:nth-child(1) { animation-delay: 0.1s; }
.filter-group:nth-child(2) { animation-delay: 0.2s; }
.filter-group:nth-child(3) { animation-delay: 0.3s; }
.filter-group:nth-child(4) { animation-delay: 0.4s; }
.filter-group:hover {
transform: translateY(-2px);
box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
border-color: rgba(var(--primary-rgb), 0.3);
}
.filter-group label {
font-size: 0.9rem;
font-weight: 600;
color: var(--text-primary);
margin-bottom: 6px;
display: flex;
align-items: center;
gap: 8px;
}
.filter-group label::before {
content: '';
width: 4px;
height: 4px;
background: var(--primary);
border-radius: 50%;
opacity: 0.7;
}
.filter-select {
padding: 12px 16px;
border: 2px solid transparent;
background: linear-gradient(var(--background), var(--background)) padding-box,
linear-gradient(135deg, rgba(var(--primary-rgb), 0.3), rgba(var(--secondary-rgb), 0.3)) border-box;
color: var(--text-primary);
border-radius: 10px;
font-size: 0.9rem;
font-weight: 500;
cursor: pointer;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
position: relative;
appearance: none;
background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
background-position: right 12px center;
background-repeat: no-repeat;
background-size: 16px;
padding-right: 40px;
}
.filter-select:hover {
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(var(--primary-rgb), 0.15);
background: linear-gradient(var(--surface), var(--surface)) padding-box,
linear-gradient(135deg, var(--primary), var(--secondary)) border-box;
}
.filter-select:focus {
outline: none;
transform: translateY(-1px);
box-shadow: 0 4px 20px rgba(var(--primary-rgb), 0.25);
background: linear-gradient(var(--surface), var(--surface)) padding-box,
linear-gradient(135deg, var(--primary), var(--secondary)) border-box;
}
.filter-select option {
background: var(--surface);
color: var(--text-primary);
padding: 8px;
}
.kun-guarantee-filter {
min-width: auto;
background: linear-gradient(135deg, rgba(76, 175, 80, 0.1), rgba(69, 160, 73, 0.05));
border: 2px solid rgba(76, 175, 80, 0.2);
position: relative;
overflow: hidden;
}
.kun-guarantee-filter::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 2px;
background: linear-gradient(90deg, #4CAF50, #45a049);
}
.checkbox-label {
display: flex;
align-items: center;
gap: 12px;
cursor: pointer;
font-size: 0.9rem;
font-weight: 600;
color: var(--text-primary);
padding: 4px;
border-radius: 8px;
transition: all 0.3s ease;
}
.checkbox-label:hover {
background: rgba(76, 175, 80, 0.1);
transform: scale(1.02);
}
.kun-guarantee-checkbox {
display: none;
}
.checkmark {
width: 24px;
height: 24px;
border: 2px solid rgba(76, 175, 80, 0.4);
border-radius: 6px;
display: flex;
align-items: center;
justify-content: center;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
background: var(--background);
position: relative;
overflow: hidden;
}
.checkmark::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: linear-gradient(135deg, #4CAF50, #45a049);
transform: scale(0);
transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
border-radius: 4px;
}
.kun-guarantee-checkbox:checked + .checkmark::before {
transform: scale(1);
}
.kun-guarantee-checkbox:checked + .checkmark {
border-color: #4CAF50;
box-shadow: 0 4px 12px rgba(76, 175, 80, 0.3);
}
.kun-guarantee-checkbox:checked + .checkmark .material-icons {
font-size: 16px;
opacity: 1;
color: white;
z-index: 1;
position: relative;
}
.checkmark .material-icons {
font-size: 16px;
opacity: 0;
transition: all 0.3s ease;
z-index: 1;
position: relative;
}
.label-text {
user-select: none;
}
.filters-actions {
margin-top: 24px;
padding-top: 20px;
border-top: 1px solid rgba(255, 255, 255, 0.1);
display: flex;
justify-content: center;
gap: 12px;
}
.filters-actions .btn {
min-height: 48px;
padding: 12px 24px;
border-radius: 12px;
font-weight: 600;
font-size: 0.95rem;
display: flex;
align-items: center;
gap: 8px;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
position: relative;
overflow: hidden;
border: none;
cursor: pointer;
}
.filters-actions .btn::before {
content: '';
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
transition: left 0.5s ease;
}
.filters-actions .btn:hover::before {
left: 100%;
}
.filters-actions .btn-primary {
background: linear-gradient(135deg, var(--primary), var(--secondary));
color: white;
box-shadow: 0 4px 15px rgba(var(--primary-rgb), 0.3);
animation: slideInRight 0.8s ease forwards;
animation-delay: 0.5s;
opacity: 0;
}
.filters-actions .btn-primary:hover {
transform: translateY(-2px);
box-shadow: 0 8px 25px rgba(var(--primary-rgb), 0.4);
background: linear-gradient(135deg, var(--secondary), var(--primary));
}
.filters-actions .btn-primary:active {
transform: translateY(0);
box-shadow: 0 4px 15px rgba(var(--primary-rgb), 0.3);
}
.filters-actions .btn .material-icons {
font-size: 20px;
transition: transform 0.3s ease;
}
.filters-actions .btn:hover .material-icons {
transform: scale(1.1);
}
.filters-header {
margin-bottom: 24px;
padding-bottom: 16px;
border-bottom: 2px solid rgba(255, 255, 255, 0.1);
display: flex;
align-items: center;
justify-content: space-between;
animation: fadeInUp 0.5s ease forwards;
}
.filters-title {
display: flex;
align-items: center;
gap: 12px;
color: var(--text-primary);
}
.filters-title h3 {
margin: 0;
font-size: 1.25rem;
font-weight: 700;
background: linear-gradient(135deg, var(--primary), var(--secondary));
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.filters-title .material-icons {
color: var(--primary);
font-size: 24px;
animation: pulse 2s infinite;
}
@keyframes pulse {
0%, 100% { transform: scale(1); }
50% { transform: scale(1.1); }
}
.close-sheet {
width: 40px;
height: 40px;
border-radius: 50%;
background: rgba(255, 255, 255, 0.1);
border: 1px solid rgba(255, 255, 255, 0.2);
color: var(--text-secondary);
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: all 0.3s ease;
}
.close-sheet:hover {
background: rgba(255, 0, 0, 0.1);
border-color: rgba(255, 0, 0, 0.3);
color: #ff4444;
transform: rotate(90deg);
}
.sheet-handle {
width: 40px;
height: 4px;
background: rgba(255, 255, 255, 0.3);
border-radius: 2px;
margin: 0 auto 16px;
}
.filters-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 20px;
margin-bottom: 20px;
}
@media (max-width: 768px) {
.filters-grid {
grid-template-columns: 1fr;
gap: 16px;
}
.filter-group {
min-width: auto;
}
}
}
.results-counter {
text-align: center;
padding: 12px;
background: var(--surface);
border: 1px solid var(--border-color);
border-radius: 8px;
margin-bottom: 16px;
font-size: 0.875rem;
color: var(--text-secondary);
font-weight: 500;
}
.marketplace-grid,
.articles-grid,
.courses-grid,
.tools-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
gap: var(--spacing-lg);
}
.card {
position: relative;
background: var(--surface);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-md);
overflow: hidden;
transition: all var(--transition-normal);
border: 1px solid var(--outline-variant);
}
.card:hover {
transform: translateY(-4px);
box-shadow: var(--shadow-xl);
}
.card-header {
padding: var(--spacing-lg);
border-bottom: 1px solid var(--outline-variant);
}
.card-title {
font-size: var(--font-size-lg);
font-weight: 600;
color: var(--on-surface);
margin-bottom: var(--spacing-sm);
}
.card-subtitle {
color: var(--outline);
font-size: var(--font-size-sm);
}
.card-content {
padding: var(--spacing-lg);
}
.card-description {
color: var(--on-surface);
margin-bottom: var(--spacing-md);
line-height: 1.6;
}
.rating {
display: flex;
align-items: center;
gap: var(--spacing-xs);
margin-bottom: var(--spacing-lg);
font-size: var(--font-size-sm);
color: var(--outline);
}
.card-actions {
display: flex;
gap: var(--spacing-sm);
justify-content: flex-end;
}
.btn-small {
padding: var(--spacing-sm) var(--spacing-md);
font-size: var(--font-size-sm);
min-height: 36px;
}
.btn-outline {
background: transparent;
border: 1px solid var(--primary);
color: var(--primary);
}
.mylist-controls {
background: var(--surface);
border-radius: var(--radius-lg);
padding: var(--spacing-xl);
margin-bottom: var(--spacing-xl);
border: 1px solid var(--outline-variant);
box-shadow: var(--shadow-sm);
}
.mylist-stats {
margin-bottom: var(--spacing-lg);
}
.stat-item {
display: inline-flex;
align-items: center;
gap: var(--spacing-sm);
background: linear-gradient(135deg, var(--primary), var(--secondary));
color: var(--on-primary);
padding: var(--spacing-md) var(--spacing-lg);
border-radius: var(--radius-md);
font-weight: 600;
box-shadow: var(--shadow-sm);
}
.stat-item .material-icons {
font-size: 1.25rem;
}
.stat-number {
font-size: 1.25rem;
font-weight: 700;
}
.stat-label {
font-size: var(--font-size-sm);
}
.mylist-actions {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-md);
align-items: center;
}
.mylist-search {
flex: 1;
min-width: 250px;
max-width: 400px;
position: relative;
}
.mylist-search input {
width: 100%;
padding: var(--spacing-md) var(--spacing-md) var(--spacing-md) 48px;
border: 2px solid var(--outline-variant);
border-radius: var(--radius-md);
font-size: var(--font-size-sm);
transition: all var(--transition-fast);
background: var(--surface-variant);
}
.mylist-search input:focus {
border-color: var(--primary);
box-shadow: 0 0 0 3px rgba(74, 144, 226, 0.1);
outline: none;
}
.mylist-search .material-icons {
position: absolute;
left: var(--spacing-md);
top: 50%;
transform: translateY(-50%);
color: var(--outline);
font-size: 1.25rem;
}
.mylist-filters {
display: flex;
gap: var(--spacing-sm);
flex-wrap: wrap;
}
.filter-btn {
display: flex;
align-items: center;
gap: var(--spacing-xs);
padding: var(--spacing-sm) var(--spacing-md);
border: 2px solid var(--outline-variant);
background: var(--surface);
color: var(--on-surface-variant);
border-radius: var(--radius-sm);
font-size: var(--font-size-sm);
font-weight: 500;
cursor: pointer;
transition: all var(--transition-fast);
}
.filter-btn:hover {
border-color: var(--primary);
color: var(--primary);
transform: translateY(-1px);
}
.filter-btn.active {
background: var(--primary);
border-color: var(--primary);
color: var(--on-primary);
box-shadow: var(--shadow-md);
}
.filter-btn .material-icons {
font-size: 1.125rem;
}
.mylist-sort {
position: relative;
}
.sort-btn {
display: flex;
align-items: center;
gap: var(--spacing-xs);
padding: var(--spacing-sm) var(--spacing-md);
border: 2px solid var(--outline-variant);
background: var(--surface);
color: var(--on-surface-variant);
border-radius: var(--radius-sm);
font-size: var(--font-size-sm);
font-weight: 500;
cursor: pointer;
transition: all var(--transition-fast);
}
.sort-btn:hover {
border-color: var(--primary);
color: var(--primary);
}
.sort-dropdown {
position: absolute;
top: 100%;
right: 0;
background: var(--surface);
border: 1px solid var(--outline-variant);
border-radius: var(--radius-md);
box-shadow: var(--shadow-lg);
z-index: 1000;
min-width: 150px;
opacity: 0;
visibility: hidden;
transform: translateY(-10px);
transition: all var(--transition-fast);
margin-top: var(--spacing-xs);
}
.sort-dropdown.show {
opacity: 1;
visibility: visible;
transform: translateY(0);
}
.sort-option {
display: block;
width: 100%;
padding: var(--spacing-md);
border: none;
background: none;
color: var(--on-surface-variant);
text-align: right;
cursor: pointer;
transition: all var(--transition-fast);
font-size: var(--font-size-sm);
}
.sort-option:hover {
background: var(--surface-variant);
color: var(--on-surface);
}
.sort-option.active {
background: var(--primary);
color: var(--on-primary);
}
.clear-all-btn {
padding: var(--spacing-sm);
border: 2px solid #ff4757;
background: transparent;
color: #ff4757;
border-radius: var(--radius-sm);
cursor: pointer;
transition: all var(--transition-fast);
}
.clear-all-btn:hover {
background: #ff4757;
color: white;
transform: translateY(-1px);
}
.mylist-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
gap: var(--spacing-lg);
margin-top: var(--spacing-xl);
}
.mylist-card {
background: var(--surface);
border: 1px solid var(--outline-variant);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-sm);
overflow: hidden;
transition: transform var(--transition-fast), box-shadow var(--transition-fast);
position: relative;
padding: var(--spacing-xl);
}
.mylist-card:hover {
transform: translateY(-4px);
box-shadow: var(--shadow-lg);
border-color: var(--primary);
}
.mylist-card::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 4px;
background: linear-gradient(90deg, var(--primary), var(--secondary));
}
.mylist-card .card-header {
display: flex;
align-items: center;
gap: var(--spacing-md);
margin-bottom: var(--spacing-md);
}
.mylist-card .card-icon {
width: 48px;
height: 48px;
border-radius: var(--radius-md);
display: flex;
align-items: center;
justify-content: center;
background: linear-gradient(135deg, var(--primary), var(--secondary));
color: var(--on-primary);
font-size: 1.5rem;
}
.mylist-card .card-info {
flex: 1;
}
.mylist-card .card-title {
font-size: 1.125rem;
font-weight: 700;
color: var(--on-surface);
margin: 0 0 var(--spacing-xs) 0;
line-height: 1.4;
}
.mylist-card .card-subtitle {
font-size: var(--font-size-sm);
color: var(--on-surface-variant);
margin: 0;
line-height: 1.4;
}
.mylist-card .card-meta {
display: flex;
align-items: center;
gap: var(--spacing-md);
margin: var(--spacing-md) 0;
font-size: var(--font-size-xs);
color: var(--on-surface-variant);
}
.mylist-card .card-type {
display: inline-flex;
align-items: center;
gap: var(--spacing-xs);
background: var(--surface-variant);
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-xs);
font-weight: 500;
}
.mylist-card .card-date {
display: flex;
align-items: center;
gap: var(--spacing-xs);
}
.mylist-card .card-actions {
display: flex;
gap: var(--spacing-sm);
justify-content: flex-end;
margin-top: var(--spacing-md);
}
.mylist-card .btn {
padding: var(--spacing-sm) var(--spacing-md);
border-radius: var(--radius-sm);
font-size: var(--font-size-sm);
font-weight: 500;
display: flex;
align-items: center;
gap: var(--spacing-xs);
min-height: 36px;
}
.mylist-card .btn-remove {
background: #ff4757;
color: white;
border: none;
}
.mylist-card .btn-remove:hover {
background: #ff3742;
transform: translateY(-1px);
}
.mylist-card.priority-high {
border-left: 4px solid #ff4757;
background: linear-gradient(135deg, #fff5f5 0%, #ffffff 100%);
}
.mylist-card.priority-low {
border-left: 4px solid #70a1ff;
background: linear-gradient(135deg, #f0f8ff 0%, #ffffff 100%);
}
.priority-indicator {
font-size: 16px !important;
margin-left: 8px;
opacity: 0.7;
}
.priority-high .priority-indicator {
color: #ff4757;
}
.priority-low .priority-indicator {
color: #70a1ff;
}
.card-category {
font-size: 12px;
color: #666;
background: #f1f2f6;
padding: 2px 8px;
border-radius: 12px;
display: inline-block;
margin-top: 4px;
}
.card-last-access {
font-size: 11px;
color: #888;
display: flex;
align-items: center;
gap: 4px;
margin-top: 4px;
}
.card-last-access .material-icons {
font-size: 14px;
}
.btn-secondary {
background: var(--surface-variant);
color: var(--on-surface-variant);
border: 1px solid var(--outline-variant);
}
.btn-secondary:hover {
background: var(--primary);
color: var(--on-primary);
border-color: var(--primary);
transform: translateY(-1px);
}
.mylist-pagination {
display: flex;
justify-content: center;
align-items: center;
gap: var(--spacing-sm);
margin: var(--spacing-xl) 0;
padding: var(--spacing-lg);
}
.pagination-btn {
display: flex;
align-items: center;
justify-content: center;
min-width: 40px;
height: 40px;
padding: var(--spacing-sm);
border: 2px solid var(--outline-variant);
background: var(--surface);
color: var(--on-surface-variant);
border-radius: var(--radius-sm);
font-size: var(--font-size-sm);
font-weight: 500;
cursor: pointer;
transition: all var(--transition-fast);
}
.pagination-btn:hover {
border-color: var(--primary);
color: var(--primary);
transform: translateY(-1px);
}
.pagination-btn.active {
background: var(--primary);
border-color: var(--primary);
color: var(--on-primary);
box-shadow: var(--shadow-md);
}
.pagination-btn .material-icons {
font-size: 1.25rem;
}
.mylist-empty {
text-align: center;
padding: var(--spacing-xxl) var(--spacing-lg);
background: var(--surface);
border-radius: var(--radius-lg);
border: 2px dashed var(--outline-variant);
margin-top: var(--spacing-xl);
}
.empty-illustration {
margin-bottom: var(--spacing-xl);
}
.empty-illustration .material-icons {
font-size: 4rem;
color: var(--on-surface-variant);
opacity: 0.5;
}
.mylist-empty h3 {
font-size: 1.5rem;
color: var(--on-surface);
margin: 0 0 var(--spacing-md) 0;
font-weight: 600;
}
.mylist-empty p {
color: var(--on-surface-variant);
margin: 0 0 var(--spacing-xl) 0;
font-size: 1rem;
line-height: 1.6;
}
.empty-actions {
display: flex;
gap: var(--spacing-md);
justify-content: center;
flex-wrap: wrap;
}
.empty-actions .btn {
display: flex;
align-items: center;
gap: var(--spacing-sm);
padding: var(--spacing-md) var(--spacing-xl);
border-radius: var(--radius-md);
font-weight: 500;
transition: all var(--transition-fast);
}
.empty-state { text-align: center; color: var(--text-secondary); padding: var(--spacing-lg); }
.btn-outline:hover {
background: var(--primary);
color: var(--on-primary);
}
.recommendations {
background: var(--surface);
padding: var(--spacing-xl);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-md);
margin-top: var(--spacing-xl);
border: 1px solid var(--outline-variant);
}
.recommendations h3 {
font-size: var(--font-size-xl);
font-weight: 600;
margin-bottom: var(--spacing-lg);
color: var(--on-surface);
text-align: center;
}
.recommendations-list {
display: grid;
gap: var(--spacing-lg);
}
.recommendation-item {
background: var(--surface-variant);
border-radius: var(--radius-lg);
border: 1px solid var(--outline-variant);
overflow: hidden;
transition: all var(--transition-normal);
}
.recommendation-item:hover {
transform: translateY(-2px);
box-shadow: var(--shadow-lg);
}
.recommendation-item.high {
border-right: 4px solid #f44336;
}
.recommendation-item.medium {
border-right: 4px solid #ff9800;
}
.recommendation-item.low {
border-right: 4px solid #4caf50;
}
.recommendation-item.inconsistency {
border-right: 4px solid #9c27b0;
}
.recommendation-item.security {
border-right: 4px solid #f44336;
}
.recommendation-item.privacy {
border-right: 4px solid #2196f3;
}
.recommendation-item.vpn {
border-right: 4px solid #ff5722;
}
.recommendation-item.network {
border-right: 4px solid #607d8b;
}
.recommendation-header {
display: flex;
align-items: flex-start;
gap: var(--spacing-md);
padding: var(--spacing-lg);
}
.recommendation-icon {
font-size: 1.5rem;
margin-top: var(--spacing-xs);
flex-shrink: 0;
}
.recommendation-item.high .recommendation-icon {
color: #f44336;
}
.recommendation-item.medium .recommendation-icon {
color: #ff9800;
}
.recommendation-item.low .recommendation-icon {
color: #4caf50;
}
.recommendation-item.inconsistency .recommendation-icon {
color: #9c27b0;
}
.recommendation-item.security .recommendation-icon {
color: #f44336;
}
.recommendation-item.privacy .recommendation-icon {
color: #2196f3;
}
.recommendation-item.vpn .recommendation-icon {
color: #ff5722;
}
.recommendation-item.network .recommendation-icon {
color: #607d8b;
}
.recommendation-content {
flex: 1;
}
.recommendation-content h4 {
font-size: var(--font-size-lg);
font-weight: 600;
margin-bottom: var(--spacing-sm);
color: var(--on-surface);
}
.recommendation-content p {
font-size: var(--font-size-sm);
color: var(--outline);
line-height: 1.6;
margin-bottom: 0;
}
.recommendation-priority {
flex-shrink: 0;
}
.priority-badge {
display: inline-block;
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-size: var(--font-size-xs);
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.priority-badge.high {
background: #ffebee;
color: #c62828;
border: 1px solid #ffcdd2;
}
.priority-badge.medium {
background: #fff3e0;
color: #ef6c00;
border: 1px solid #ffcc02;
}
.priority-badge.low {
background: #e8f5e8;
color: #2e7d32;
border: 1px solid #c8e6c9;
}
.recommendation-actions {
background: var(--surface);
padding: var(--spacing-md) var(--spacing-lg);
border-top: 1px solid var(--outline-variant);
}
.recommendation-actions h5 {
font-size: var(--font-size-sm);
font-weight: 600;
margin-bottom: var(--spacing-sm);
color: var(--on-surface);
}
.recommendation-actions ul {
list-style: none;
padding: 0;
margin: 0;
}
.recommendation-actions li {
font-size: var(--font-size-sm);
color: var(--outline);
padding: var(--spacing-xs) 0;
padding-right: var(--spacing-md);
position: relative;
}
.recommendation-actions li::before {
content: 'â€¢';
color: var(--primary);
font-weight: bold;
position: absolute;
right: 0;
}
.floating-connection-btn {
position: fixed;
bottom: calc(var(--bottom-nav-height) + 16px);
left: 16px;
width: 64px;
height: 64px;
background: rgba(255, 255, 255, 0.15);
backdrop-filter: blur(20px);
-webkit-backdrop-filter: blur(20px);
border: 2px solid rgba(76, 175, 80, 0.3);
border-radius: 50%;
box-shadow:
0 8px 32px rgba(76, 175, 80, 0.2),
inset 0 1px 0 rgba(255, 255, 255, 0.2),
inset 0 -1px 0 rgba(0, 0, 0, 0.1);
cursor: pointer;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
z-index: 999;
transition: all var(--transition-normal);
overflow: visible;
}
.floating-connection-btn:hover {
transform: translateY(-3px) scale(1.05);
background: rgba(255, 255, 255, 0.25);
backdrop-filter: blur(25px);
-webkit-backdrop-filter: blur(25px);
border-color: rgba(76, 175, 80, 0.5);
box-shadow:
0 12px 40px rgba(76, 175, 80, 0.3),
inset 0 1px 0 rgba(255, 255, 255, 0.3),
inset 0 -1px 0 rgba(0, 0, 0, 0.1);
}
.floating-connection-btn:active {
transform: translateY(-1px) scale(1.02);
background: rgba(255, 255, 255, 0.2);
backdrop-filter: blur(15px);
-webkit-backdrop-filter: blur(15px);
box-shadow:
0 6px 25px rgba(76, 175, 80, 0.25),
inset 0 1px 0 rgba(255, 255, 255, 0.2),
inset 0 -1px 0 rgba(0, 0, 0, 0.1);
}
.floating-connection-icon {
width: 28px;
height: 28px;
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 2px;
background: rgba(76, 175, 80, 0.1);
border-radius: 50%;
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
border: 1px solid rgba(76, 175, 80, 0.2);
}
.floating-connection-btn:hover .floating-connection-icon {
background: rgba(76, 175, 80, 0.2);
border-color: rgba(76, 175, 80, 0.4);
transform: scale(1.1);
}
.floating-connection-icon .status-icon {
font-size: 16px;
animation: pulse 2s infinite;
filter: drop-shadow(0 2px 4px rgba(76, 175, 80, 0.4));
transition: all var(--transition-fast);
}
.floating-connection-btn:hover .floating-connection-icon .status-icon {
filter: drop-shadow(0 3px 6px rgba(76, 175, 80, 0.6));
transform: scale(1.1);
}
.floating-connection-text {
display: flex;
align-items: center;
justify-content: center;
margin-top: 2px;
background: rgba(76, 175, 80, 0.1);
border-radius: 50%;
width: 20px;
height: 20px;
backdrop-filter: blur(5px);
-webkit-backdrop-filter: blur(5px);
border: 1px solid rgba(76, 175, 80, 0.2);
}
.floating-connection-btn:hover .floating-connection-text {
background: rgba(76, 175, 80, 0.2);
border-color: rgba(76, 175, 80, 0.4);
transform: scale(1.1);
}
.floating-connection-text .status-text {
font-size: 8px;
color: #4CAF50;
font-weight: 600;
transition: all var(--transition-fast);
text-shadow: 0 1px 2px rgba(76, 175, 80, 0.3);
}
.floating-connection-btn:hover .floating-connection-text .status-text {
color: #2E7D32;
text-shadow: 0 2px 4px rgba(76, 175, 80, 0.5);
}
.floating-connection-btn.offline {
border-color: rgba(244, 67, 54, 0.3);
box-shadow:
0 8px 32px rgba(244, 67, 54, 0.2),
inset 0 1px 0 rgba(255, 255, 255, 0.2),
inset 0 -1px 0 rgba(0, 0, 0, 0.1);
}
.floating-connection-btn.offline:hover {
border-color: rgba(244, 67, 54, 0.5);
box-shadow:
0 12px 40px rgba(244, 67, 54, 0.3),
inset 0 1px 0 rgba(255, 255, 255, 0.3),
inset 0 -1px 0 rgba(0, 0, 0, 0.1);
}
.floating-connection-btn.offline .floating-connection-icon {
background: rgba(244, 67, 54, 0.1);
border-color: rgba(244, 67, 54, 0.2);
}
.floating-connection-btn.offline .floating-connection-text {
background: rgba(244, 67, 54, 0.1);
border-color: rgba(244, 67, 54, 0.2);
}
.floating-connection-btn.offline .floating-connection-text .status-text {
color: #f44336;
}
.floating-connection-btn.slow {
border-color: rgba(255, 152, 0, 0.3);
box-shadow:
0 8px 32px rgba(255, 152, 0, 0.2),
inset 0 1px 0 rgba(255, 255, 255, 0.2),
inset 0 -1px 0 rgba(0, 0, 0, 0.1);
}
.floating-connection-btn.slow:hover {
border-color: rgba(255, 152, 0, 0.5);
box-shadow:
0 12px 40px rgba(255, 152, 0, 0.3),
inset 0 1px 0 rgba(255, 255, 255, 0.3),
inset 0 -1px 0 rgba(0, 0, 0, 0.1);
}
.floating-connection-btn.slow .floating-connection-icon {
background: rgba(255, 152, 0, 0.1);
border-color: rgba(255, 152, 0, 0.2);
}
.floating-connection-btn.slow .floating-connection-text {
background: rgba(255, 152, 0, 0.1);
border-color: rgba(255, 152, 0, 0.2);
}
.floating-connection-btn.slow .floating-connection-text .status-text {
color: #ff9800;
}
.floating-update-btn {
position: fixed;
bottom: calc(var(--bottom-nav-height) + 16px);
left: 16px;
width: 64px;
height: 64px;
background: rgba(255, 255, 255, 0.15);
backdrop-filter: blur(20px);
-webkit-backdrop-filter: blur(20px);
border: 2px solid rgba(25, 118, 210, 0.3);
border-radius: 50%;
box-shadow:
0 8px 32px rgba(25, 118, 210, 0.2),
inset 0 1px 0 rgba(255, 255, 255, 0.2),
inset 0 -1px 0 rgba(0, 0, 0, 0.1);
cursor: pointer;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
z-index: 1001;
transition: all var(--transition-normal);
overflow: visible;
}
.floating-update-btn:hover {
transform: translateY(-3px) scale(1.05);
background: rgba(255, 255, 255, 0.25);
backdrop-filter: blur(25px);
-webkit-backdrop-filter: blur(25px);
border-color: rgba(25, 118, 210, 0.5);
box-shadow:
0 12px 40px rgba(25, 118, 210, 0.3),
inset 0 1px 0 rgba(255, 255, 255, 0.3),
inset 0 -1px 0 rgba(0, 0, 0, 0.1);
}
.floating-update-btn:active {
transform: translateY(-1px) scale(1.02);
background: rgba(255, 255, 255, 0.2);
backdrop-filter: blur(15px);
-webkit-backdrop-filter: blur(15px);
box-shadow:
0 6px 25px rgba(25, 118, 210, 0.25),
inset 0 1px 0 rgba(255, 255, 255, 0.2),
inset 0 -1px 0 rgba(0, 0, 0, 0.1);
}
.floating-btn-icon {
width: 28px;
height: 28px;
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 2px;
background: rgba(25, 118, 210, 0.1);
border-radius: 50%;
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
border: 1px solid rgba(25, 118, 210, 0.2);
}
.floating-btn-img {
width: 20px;
height: 20px;
object-fit: contain;
filter: drop-shadow(0 2px 4px rgba(25, 118, 210, 0.4));
transition: all var(--transition-fast);
}
.floating-update-btn:hover .floating-btn-icon {
background: rgba(25, 118, 210, 0.2);
border-color: rgba(25, 118, 210, 0.4);
transform: scale(1.1);
}
.floating-update-btn:hover .floating-btn-img {
filter: drop-shadow(0 3px 6px rgba(25, 118, 210, 0.6));
transform: rotate(15deg) scale(1.1);
}
.floating-btn-text {
display: flex;
align-items: center;
justify-content: center;
margin-top: 2px;
background: rgba(25, 118, 210, 0.1);
border-radius: 50%;
width: 20px;
height: 20px;
backdrop-filter: blur(5px);
-webkit-backdrop-filter: blur(5px);
border: 1px solid rgba(25, 118, 210, 0.2);
}
.floating-btn-text .material-icons {
font-size: 12px;
color: var(--primary);
transition: all var(--transition-fast);
text-shadow: 0 1px 2px rgba(25, 118, 210, 0.3);
}
.floating-update-btn:hover .floating-btn-text {
background: rgba(25, 118, 210, 0.2);
border-color: rgba(25, 118, 210, 0.4);
transform: scale(1.1);
}
.floating-update-btn:hover .floating-btn-text .material-icons {
transform: rotate(180deg);
color: var(--primary);
text-shadow: 0 2px 4px rgba(25, 118, 210, 0.5);
}
@keyframes pulse {
0% {
box-shadow: 0 8px 25px rgba(25, 118, 210, 0.3);
}
50% {
box-shadow: 0 8px 25px rgba(25, 118, 210, 0.6);
}
100% {
box-shadow: 0 8px 25px rgba(25, 118, 210, 0.3);
}
}
.floating-update-btn {
animation: pulse 3s infinite;
}
.floating-update-btn:hover {
animation: none;
}
.floating-update-btn::before {
content: '';
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
transition: left 0.5s;
}
.floating-update-btn:hover::before {
left: 100%;
}
.floating-connection-btn::after {
content: 'ط­ط§ظ„ط© ط§ظ„ط§طھطµط§ظ„';
position: absolute;
right: -100px;
top: 50%;
transform: translateY(-50%);
background: rgba(255, 255, 255, 0.9);
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
color: #4CAF50;
padding: 8px 12px;
border-radius: 8px;
font-size: 0.75rem;
font-weight: 500;
white-space: nowrap;
opacity: 0;
visibility: hidden;
transition: all var(--transition-fast);
box-shadow: 0 4px 20px rgba(76, 175, 80, 0.2);
border: 1px solid rgba(76, 175, 80, 0.2);
}
.floating-connection-btn:hover::after {
opacity: 1;
visibility: visible;
right: -105px;
}
.floating-update-btn::after {
content: 'طھط­ط¯ظٹط« ط§ظ„ط¨ظٹط§ظ†ط§طھ';
position: absolute;
right: -120px;
top: 50%;
transform: translateY(-50%);
background: rgba(255, 255, 255, 0.9);
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
color: var(--primary);
padding: 8px 12px;
border-radius: 8px;
font-size: 0.75rem;
font-weight: 500;
white-space: nowrap;
opacity: 0;
visibility: hidden;
transition: all var(--transition-fast);
box-shadow: 0 4px 20px rgba(25, 118, 210, 0.2);
border: 1px solid rgba(25, 118, 210, 0.2);
}
.floating-update-btn:hover::after {
opacity: 1;
visibility: visible;
right: -125px;
}
@media (max-width: 768px) {
.floating-connection-btn::after {
display: none;
}
.floating-update-btn::after {
display: none;
}
}
@media (display-mode: standalone) and (max-width: 768px) {
.floating-connection-btn {
bottom: calc(var(--bottom-nav-height) + 90px);
right: 12px;
left: auto !important;
}
.floating-update-btn {
bottom: calc(var(--bottom-nav-height) + 20px);
right: 12px;
left: auto !important;
}
}
@media (max-width: 768px) and (display-mode: standalone) {
.floating-connection-btn, .floating-update-btn, .floating-filter-btn { right: 12px; left: auto !important; }
}
@media (display-mode: fullscreen) and (max-width: 768px) {
.floating-connection-btn {
bottom: calc(var(--bottom-nav-height) + 90px);
right: 12px;
left: auto !important;
}
.floating-update-btn {
bottom: calc(var(--bottom-nav-height) + 20px);
right: 12px;
left: auto !important;
}
body {
overflow: hidden;
height: 100vh;
width: 100vw;
}
.header {
position: fixed;
top: 0;
left: 0;
right: 0;
z-index: 1000;
}
.main-content {
margin-top: var(--header-height);
margin-bottom: var(--bottom-nav-height);
height: calc(100vh - var(--header-height) - var(--bottom-nav-height));
overflow-y: auto;
}
}
.fullscreen-mode {
overflow: hidden !important;
height: 100vh !important;
width: 100vw !important;
position: fixed !important;
top: 0 !important;
left: 0 !important;
right: 0 !important;
bottom: 0 !important;
}
.fullscreen-mode .header {
position: fixed !important;
top: 0 !important;
left: 0 !important;
right: 0 !important;
z-index: 1000 !important;
}
.fullscreen-mode .main-content {
margin-top: var(--header-height) !important;
margin-bottom: var(--bottom-nav-height) !important;
height: calc(100vh - var(--header-height) - var(--bottom-nav-height)) !important;
overflow-y: auto !important;
overflow-x: hidden !important;
}
.fullscreen-mode .bottom-nav {
position: fixed !important;
bottom: 0 !important;
left: 0 !important;
right: 0 !important;
z-index: 1000 !important;
}
.bottom-nav {
position: fixed;
bottom: 0;
left: 0;
right: 0;
background: var(--surface);
box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
display: flex;
justify-content: space-around;
padding: var(--spacing-sm) 0;
z-index: 1000;
border-top: 1px solid var(--outline-variant);
height: var(--bottom-nav-height);
align-items: center;
}
.bottom-nav .nav-item {
display: flex;
flex-direction: column;
align-items: center;
gap: var(--spacing-xs);
padding: var(--spacing-sm);
background: none;
border: none;
color: var(--outline);
cursor: pointer;
transition: all var(--transition-fast);
font-size: var(--font-size-xs);
min-width: 60px;
text-align: center;
justify-content: center;
flex: 1;
}
.bottom-nav .nav-item span:not(.material-icons) {
font-size: 0.75rem;
font-weight: 500;
line-height: 1.2;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
max-width: 100%;
display: block;
margin-top: 2px;
color: inherit;
}
.bottom-nav .nav-item.active {
color: var(--primary);
}
.bottom-nav .nav-item .material-icons {
font-size: 1.5rem;
color: inherit;
}
@media (max-width: 768px) {
.main-content {
padding: var(--spacing-sm);
margin-top: var(--header-height);
margin-bottom: var(--bottom-nav-height);
}
.header-content {
gap: var(--spacing-sm);
height: 100%;
}
.header {
backdrop-filter: blur(15px);
-webkit-backdrop-filter: blur(15px);
height: calc(var(--header-height) - 4px);
}
.logo {
gap: var(--spacing-sm);
}
.logo-icon {
width: 32px;
height: 32px;
}
.logo-text h1 {
font-size: var(--font-size-lg);
}
.logo-subtitle {
font-size: var(--font-size-xs);
}
.status-indicator {
padding: 4px var(--spacing-xs);
font-size: 10px;
}
.status-text {
display: none;
}
.header-actions {
gap: var(--spacing-xs);
}
.contact-btn {
width: 36px;
height: 36px;
}
.contact-btn .material-icons {
font-size: 1rem;
}
.menu-btn {
width: 36px;
height: 36px;
}
.mylist-btn .material-icons { font-size: 1.1rem; color: var(--primary); }
.hero-banner {
padding: var(--spacing-lg);
}
}
@media (min-width: 1024px) {
.floating-connection-btn, .floating-update-btn, .floating-filter-btn {
position: fixed;
left: 24px;
right: auto !important;
width: 60px;
height: 60px;
z-index: 999;
transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.floating-update-btn { bottom: calc(var(--bottom-nav-height) + 16px); }
.floating-connection-btn { bottom: calc(var(--bottom-nav-height) + 80px); }
.floating-filter-btn { bottom: calc(var(--bottom-nav-height) + 144px); display: none; }
.floating-connection-btn:hover, .floating-update-btn:hover, .floating-filter-btn:hover {
transform: translateY(-2px);
}
.floating-btn-icon { width: 24px; height: 24px; }
.floating-btn-text .material-icons { font-size: 18px; }
}
@media (min-width: 769px) {
.floating-connection-btn, .floating-update-btn, .floating-filter-btn {
position: fixed !important;
left: 24px !important;
right: auto !important;
z-index: 999 !important;
margin: 0 !important;
transform: none !important;
}
.floating-update-btn { bottom: calc(var(--bottom-nav-height) + 16px) !important; }
.floating-connection-btn { bottom: calc(var(--bottom-nav-height) + 80px) !important; }
.floating-filter-btn { bottom: calc(var(--bottom-nav-height) + 144px) !important; }
.floating-connection-btn, .floating-update-btn, .floating-filter-btn {
top: auto !important;
}
}
@media (min-width: 769px) and (display-mode: standalone),
@media (min-width: 769px) and (display-mode: fullscreen) {
.floating-connection-btn, .floating-update-btn, .floating-filter-btn {
position: fixed !important;
left: 24px !important;
right: auto !important;
z-index: 999 !important;
margin: 0 !important;
transform: none !important;
top: auto !important;
}
.floating-update-btn { bottom: calc(var(--bottom-nav-height) + 16px) !important; }
.floating-connection-btn { bottom: calc(var(--bottom-nav-height) + 80px) !important; }
.floating-filter-btn { bottom: calc(var(--bottom-nav-height) + 144px) !important; }
}
@media (min-width: 1200px) {
.floating-connection-btn, .floating-update-btn, .floating-filter-btn {
left: 32px !important;
}
}
.hero-content h2 {
font-size: var(--font-size-2xl);
}
.hero-actions {
flex-direction: column;
align-items: center;
}
.contact-links {
grid-template-columns: 1fr;
gap: var(--spacing-sm);
}
.contact-link {
padding: var(--spacing-md);
}
.contact-link .material-icons {
font-size: 1.5rem;
}
.contact-info h4 {
font-size: var(--font-size-base);
}
.section-header {
flex-direction: column;
align-items: stretch;
}
.search-bar {
min-width: 100%;
}
.quick-links {
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}
.marketplace-grid,
.articles-grid,
.tools-grid {
grid-template-columns: 1fr;
}
}
@media (max-width: 480px) {
.header {
padding: var(--spacing-xs) var(--spacing-sm);
backdrop-filter: blur(15px);
-webkit-backdrop-filter: blur(15px);
height: calc(var(--header-height) - 8px);
}
.header-content {
gap: var(--spacing-xs);
height: 100%;
}
.logo {
gap: var(--spacing-xs);
}
.logo-icon {
width: 28px;
height: 28px;
}
.logo-text h1 {
font-size: var(--font-size-md);
}
.logo-subtitle {
display: none;
}
.status-indicator {
padding: 2px 4px;
}
.status-icon {
font-size: 12px;
}
.contact-btn {
width: 32px;
height: 32px;
}
.contact-btn .material-icons {
font-size: 0.9rem;
}
.offline-content {
margin: var(--spacing-sm);
padding: var(--spacing-lg);
}
.offline-actions {
flex-direction: column;
gap: var(--spacing-xs);
}
.offline-content .retry-btn,
.continue-btn {
min-width: auto;
width: 100%;
}
.install-banner {
bottom: 10px;
left: 10px;
right: 10px;
}
.install-content {
flex-direction: column;
text-align: center;
gap: var(--spacing-sm);
}
.install-actions {
width: 100%;
justify-content: center;
}
.install-btn,
.dismiss-install-btn {
flex: 1;
min-width: 0;
}
.bottom-nav .nav-item span:not(.material-icons) {
font-size: 0.6rem;
line-height: 1;
font-weight: 400;
display: block;
}
.bottom-nav {
height: calc(var(--bottom-nav-height) - 8px);
}
.bottom-nav .nav-item {
min-width: 45px;
padding: 4px;
}
.bottom-nav .nav-item .material-icons {
font-size: 1.2rem;
}
.floating-connection-btn {
width: 56px;
height: 56px;
bottom: calc(var(--bottom-nav-height) + 80px);
left: 12px;
}
.floating-connection-icon {
width: 20px;
height: 20px;
}
.floating-connection-text .status-text {
font-size: 7px;
}
.floating-update-btn {
width: 56px;
height: 56px;
bottom: calc(var(--bottom-nav-height) + 12px);
left: 12px;
}
.floating-btn-icon {
width: 20px;
height: 20px;
}
.floating-btn-text .material-icons {
font-size: 12px;
}
.hero-content h2 {
font-size: var(--font-size-xl);
}
.quick-links {
grid-template-columns: 1fr;
}
.bottom-nav .nav-item span:not(.material-icons) {
font-size: 0.65rem;
line-height: 1;
font-weight: 400;
display: block;
}
.bottom-nav {
height: calc(var(--bottom-nav-height) - 4px);
}
.bottom-nav .nav-item {
min-width: 50px;
padding: var(--spacing-xs);
}
.bottom-nav .nav-item .material-icons {
font-size: 1.3rem;
color: inherit;
}
.floating-connection-btn {
width: 52px;
height: 52px;
bottom: calc(var(--bottom-nav-height) + 70px);
left: 8px;
}
.floating-connection-icon {
width: 18px;
height: 18px;
}
.floating-connection-text .status-text {
font-size: 6px;
}
.floating-update-btn {
width: 52px;
height: 52px;
bottom: calc(var(--bottom-nav-height) + 8px);
left: 8px;
}
.floating-btn-icon {
width: 18px;
height: 18px;
}
.floating-btn-text .material-icons {
font-size: 11px;
}
}
.loading {
display: inline-block;
width: 20px;
height: 20px;
border: 3px solid var(--outline-variant);
border-radius: 50%;
border-top-color: var(--primary);
animation: spin 1s ease-in-out infinite;
}
@keyframes spin {
to { transform: rotate(360deg); }
}
.text-center { text-align: center; }
.text-right { text-align: right; }
.text-left { text-align: left; }
.mb-sm { margin-bottom: var(--spacing-sm); }
.mb-md { margin-bottom: var(--spacing-md); }
.mb-lg { margin-bottom: var(--spacing-lg); }
.mb-xl { margin-bottom: var(--spacing-xl); }
.mt-sm { margin-top: var(--spacing-sm); }
.mt-md { margin-top: var(--spacing-md); }
.mt-lg { margin-top: var(--spacing-lg); }
.mt-xl { margin-top: var(--spacing-xl); }
.hidden { display: none !important; }
.visible { display: block !important; }
@keyframes pulse {
0%, 100% { transform: scale(1); }
50% { transform: scale(1.05); }
}
@keyframes bounce {
0%, 20%, 53%, 80%, 100% { transform: translate3d(0,0,0); }
40%, 43% { transform: translate3d(0,-8px,0); }
70% { transform: translate3d(0,-4px,0); }
90% { transform: translate3d(0,-2px,0); }
}
@keyframes slideInUp {
from { transform: translateY(30px); opacity: 0; }
to { transform: translateY(0); opacity: 1; }
}
@keyframes slideInRight {
from { transform: translateX(30px); opacity: 0; }
to { transform: translateX(0); opacity: 1; }
}
.card {
position: relative;
overflow: hidden;
}
.card::before {
content: '';
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
transition: left 0.5s;
}
.card:hover::before {
left: 100%;
}
.btn {
position: relative;
overflow: hidden;
}
.btn::after {
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 0;
height: 0;
background: rgba(255,255,255,0.3);
border-radius: 50%;
transform: translate(-50%, -50%);
transition: width 0.6s, height 0.6s;
}
.btn:active::after {
width: 300px;
height: 300px;
}
.loading-overlay {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: rgba(255,255,255,0.9);
display: flex;
align-items: center;
justify-content: center;
z-index: 9999;
}
.loading-spinner {
width: 50px;
height: 50px;
border: 4px solid var(--outline-variant);
border-top: 4px solid var(--primary);
border-radius: 50%;
animation: spin 1s linear infinite;
}
.search-bar:focus-within {
border-color: var(--primary);
box-shadow: 0 0 0 2px rgba(25, 118, 210, 0.2);
}
.filter-tab {
position: relative;
overflow: hidden;
}
.filter-tab::before {
content: '';
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
transition: left 0.3s;
}
.filter-tab:hover::before {
left: 100%;
}
.result-card {
position: relative;
overflow: hidden;
}
.result-card::after {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 4px;
background: linear-gradient(90deg, var(--primary), var(--secondary));
transform: scaleX(0);
transition: transform 0.3s;
}
.result-card:hover::after {
transform: scaleX(1);
}
.bottom-nav .nav-item {
position: relative;
}
.bottom-nav .nav-item::before {
content: '';
position: absolute;
top: 0;
left: 50%;
width: 0;
height: 3px;
background: var(--primary);
transform: translateX(-50%);
transition: width 0.3s;
}
.bottom-nav .nav-item.active::before {
width: 30px;
}
.hero-banner {
position: relative;
overflow: hidden;
}
.hero-banner::before {
content: '';
position: absolute;
top: -50%;
left: -50%;
width: 200%;
height: 200%;
background: radial-gradient(circle, rgba(25, 118, 210, 0.1) 0%, transparent 70%);
animation: pulse 4s ease-in-out infinite;
}
.contact-section {
margin-top: var(--spacing-2xl);
padding: var(--spacing-xl);
background: var(--surface);
border-radius: var(--radius-xl);
box-shadow: var(--shadow-md);
}
.contact-section h3 {
font-size: var(--font-size-2xl);
font-weight: 700;
color: var(--on-surface);
margin-bottom: var(--spacing-lg);
text-align: center;
}
.contact-links {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: var(--spacing-md);
}
.contact-link {
display: flex;
align-items: center;
gap: var(--spacing-md);
padding: var(--spacing-lg);
background: var(--surface-variant);
border-radius: var(--radius-lg);
text-decoration: none;
color: var(--on-surface);
transition: all var(--transition-normal);
border: 1px solid var(--outline-variant);
}
.contact-link:hover {
transform: translateY(-4px);
box-shadow: var(--shadow-lg);
background: var(--primary);
color: var(--on-primary);
border-color: var(--primary);
}
.contact-link .material-icons {
font-size: 2rem;
color: var(--primary);
transition: color var(--transition-normal);
}
.contact-link:hover .material-icons {
color: var(--on-primary);
}
.contact-info h4 {
font-size: var(--font-size-lg);
font-weight: 600;
margin: 0 0 var(--spacing-xs) 0;
}
.contact-info p {
font-size: var(--font-size-sm);
color: var(--outline);
margin: 0;
transition: color var(--transition-normal);
}
.contact-link:hover .contact-info p {
color: var(--on-primary);
}
.link-card {
position: relative;
overflow: hidden;
}
.link-card::after {
content: '';
position: absolute;
bottom: 0;
left: 0;
right: 0;
height: 4px;
background: linear-gradient(90deg, var(--primary), var(--secondary));
transform: scaleX(0);
transition: transform 0.3s;
}
.link-card:hover::after {
transform: scaleX(1);
}
.modal-overlay {
backdrop-filter: blur(5px);
}
@media (prefers-color-scheme: dark) {
:root {
--surface: #1c1b1f;
--surface-variant: #2b2930;
--background: #121212;
--on-surface: #e6e1e5;
--on-background: #e6e1e5;
--outline: #938f99;
--outline-variant: #49454f;
}
.loading-overlay {
background: rgba(18, 18, 18, 0.9);
}
}
.tool-card {
transition: all var(--transition-normal);
}
.tool-card:hover {
transform: translateY(-4px);
box-shadow: var(--shadow-lg);
}
.app-card {
transition: all var(--transition-normal);
}
.app-card:hover {
transform: translateY(-4px);
box-shadow: var(--shadow-lg);
}
.course-card {
transition: all var(--transition-normal);
}
.course-card:hover {
transform: translateY(-4px);
box-shadow: var(--shadow-lg);
}
.marketplace-card {
transition: all var(--transition-normal);
}
.marketplace-card:hover {
transform: translateY(-4px);
box-shadow: var(--shadow-lg);
}
.marketplace-review-preview {
margin: var(--spacing-md) 0;
padding: var(--spacing-md);
background: var(--secondary-container);
border-radius: var(--radius-md);
border: 1px solid var(--outline-variant);
}
.marketplace-review-preview h4 {
font-size: var(--font-size-base);
font-weight: 600;
color: var(--on-secondary-container);
margin: 0 0 var(--spacing-sm) 0;
}
.marketplace-review-header {
margin-bottom: var(--spacing-lg);
padding-bottom: var(--spacing-md);
border-bottom: 1px solid var(--outline-variant);
}
.item-basic-info h3 {
font-size: var(--font-size-lg);
font-weight: 600;
color: var(--on-surface);
margin: 0 0 var(--spacing-sm) 0;
}
.item-meta {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-md);
align-items: center;
}
.item-meta .rating {
background: var(--primary-container);
color: var(--on-primary-container);
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-weight: 600;
}
.item-meta .category {
background: var(--tertiary-container);
color: var(--on-tertiary-container);
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-weight: 600;
}
.item-meta .price {
background: var(--secondary-container);
color: var(--on-secondary-container);
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-weight: 500;
}
.kun-guarantee-badge {
display: inline-flex;
align-items: center;
gap: var(--spacing-xs);
background: linear-gradient(135deg, #4CAF50, #2E7D32);
color: white;
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-size: var(--font-size-xs);
font-weight: 600;
margin-right: var(--spacing-sm);
box-shadow: 0 2px 4px rgba(76, 175, 80, 0.3);
animation: guaranteeGlow 2s ease-in-out infinite alternate;
}
.kun-guarantee-badge .material-icons {
font-size: 16px;
}
@keyframes guaranteeGlow {
0% {
box-shadow: 0 2px 4px rgba(76, 175, 80, 0.3);
}
100% {
box-shadow: 0 4px 8px rgba(76, 175, 80, 0.5);
}
}
.kun-guarantee-tab {
background: linear-gradient(135deg, #4CAF50, #2E7D32);
color: white;
border: 2px solid #4CAF50;
position: relative;
overflow: hidden;
}
.kun-guarantee-tab::before {
content: '';
position: absolute;
top: 0;
left: -100%;
width: 100%;
height: 100%;
background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
transition: left 0.5s;
}
.kun-guarantee-tab:hover::before {
left: 100%;
}
.kun-guarantee-tab:hover {
background: linear-gradient(135deg, #2E7D32, #1B5E20);
transform: translateY(-2px);
box-shadow: 0 4px 8px rgba(76, 175, 80, 0.3);
}
.kun-guarantee-tab.active {
background: linear-gradient(135deg, #1B5E20, #0D3B0D);
box-shadow: 0 4px 12px rgba(76, 175, 80, 0.4);
}
.kun-guarantee-tab .material-icons {
font-size: 18px;
margin-left: var(--spacing-xs);
}
.marketplace-card .card-title {
display: flex;
align-items: center;
flex-wrap: wrap;
gap: var(--spacing-xs);
}
@media (max-width: 768px) {
.kun-guarantee-badge {
font-size: 10px;
padding: 2px var(--spacing-xs);
}
.kun-guarantee-badge .material-icons {
font-size: 14px;
}
.kun-guarantee-tab {
font-size: var(--font-size-sm);
padding: var(--spacing-xs) var(--spacing-sm);
}
.kun-guarantee-tab .material-icons {
font-size: 16px;
}
}
.promotions-section {
margin: var(--spacing-xl) 0;
padding: var(--spacing-lg);
background: var(--surface-container);
border-radius: var(--radius-lg);
border: 1px solid var(--outline-variant);
}
.promotions-section h3 {
font-size: var(--font-size-xl);
font-weight: 700;
color: var(--on-surface);
margin: 0 0 var(--spacing-lg) 0;
text-align: center;
background: linear-gradient(135deg, var(--primary), var(--secondary));
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.promotions-container {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
gap: var(--spacing-lg);
}
.promotion-card {
background: var(--surface);
border-radius: var(--radius-lg);
border: 1px solid var(--outline-variant);
overflow: hidden;
transition: all var(--transition-normal);
position: relative;
}
.promotion-card:hover {
transform: translateY(-4px);
box-shadow: var(--shadow-lg);
border-color: var(--primary);
}
.promotion-card.kun-guaranteed {
border: 2px solid #4CAF50;
background: linear-gradient(135deg, var(--surface), rgba(76, 175, 80, 0.05));
}
.promotion-card.kun-guaranteed::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 4px;
background: linear-gradient(90deg, #4CAF50, #2E7D32);
}
.promotion-header {
padding: var(--spacing-lg);
background: var(--surface-container);
border-bottom: 1px solid var(--outline-variant);
}
.promotion-title {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: var(--spacing-sm);
margin-bottom: var(--spacing-sm);
}
.promotion-title h4 {
font-size: var(--font-size-lg);
font-weight: 600;
color: var(--on-surface);
margin: 0;
flex: 1;
}
.promotion-type {
display: flex;
align-items: center;
}
.type-badge {
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-size: var(--font-size-xs);
font-weight: 600;
text-transform: uppercase;
}
.type-badge.bonus {
background: linear-gradient(135deg, #FF9800, #F57C00);
color: white;
}
.type-badge.discount {
background: linear-gradient(135deg, #E91E63, #C2185B);
color: white;
}
.type-badge.free {
background: linear-gradient(135deg, #4CAF50, #2E7D32);
color: white;
}
.type-badge.limited {
background: linear-gradient(135deg, #9C27B0, #7B1FA2);
color: white;
}
.promotion-content {
padding: var(--spacing-lg);
}
.promotion-description {
font-size: var(--font-size-base);
color: var(--on-surface);
line-height: 1.6;
margin: 0 0 var(--spacing-md) 0;
}
.promotion-provider {
display: flex;
align-items: center;
gap: var(--spacing-sm);
margin: var(--spacing-md) 0;
padding: var(--spacing-sm);
background: var(--surface-variant);
border-radius: var(--radius-md);
}
.provider-logo {
font-size: var(--font-size-lg);
}
.provider-name {
font-weight: 600;
color: var(--on-surface);
}
.promotion-meta {
margin: var(--spacing-md) 0;
}
.validity {
display: flex;
align-items: center;
gap: var(--spacing-sm);
font-size: var(--font-size-sm);
color: var(--on-surface-variant);
}
.validity .material-icons {
font-size: 18px;
color: var(--primary);
}
.promotion-actions {
padding: var(--spacing-lg);
background: var(--surface-container);
border-top: 1px solid var(--outline-variant);
}
.promotion-actions .btn {
width: 100%;
justify-content: center;
font-weight: 600;
background: linear-gradient(135deg, var(--primary), var(--secondary));
border: none;
color: white;
transition: all var(--transition-normal);
}
.promotion-actions .btn:hover {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(25, 118, 210, 0.3);
}
.no-promotions {
text-align: center;
color: var(--on-surface-variant);
font-style: italic;
padding: var(--spacing-xl);
background: var(--surface-variant);
border-radius: var(--radius-md);
border: 2px dashed var(--outline-variant);
}
@media (max-width: 768px) {
.promotions-section {
margin: var(--spacing-lg) 0;
padding: var(--spacing-md);
}
.promotions-container {
grid-template-columns: 1fr;
gap: var(--spacing-md);
}
.promotion-title {
flex-direction: column;
align-items: flex-start;
}
.promotion-header,
.promotion-content,
.promotion-actions {
padding: var(--spacing-md);
}
}
.course-info {
display: flex;
flex-direction: column;
gap: var(--spacing-sm);
margin: var(--spacing-md) 0;
padding: var(--spacing-md);
background: var(--surface-variant);
border-radius: var(--radius-md);
border: 1px solid var(--outline-variant);
}
.info-item {
display: flex;
align-items: center;
gap: var(--spacing-sm);
font-size: var(--font-size-sm);
color: var(--on-surface-variant);
}
.info-item .material-icons {
font-size: 18px;
color: var(--primary);
}
.course-review-preview {
margin: var(--spacing-md) 0;
padding: var(--spacing-md);
background: var(--secondary-container);
border-radius: var(--radius-md);
border: 1px solid var(--outline-variant);
}
.course-review-preview h4 {
font-size: var(--font-size-base);
font-weight: 600;
color: var(--on-secondary-container);
margin: 0 0 var(--spacing-sm) 0;
}
.review-excerpt {
font-size: var(--font-size-sm);
color: var(--on-secondary-container);
line-height: 1.5;
margin: 0 0 var(--spacing-md) 0;
}
.modal-overlay {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.5);
display: flex;
align-items: center;
justify-content: center;
z-index: 9999;
backdrop-filter: blur(4px);
}
.review-modal {
max-width: 800px;
max-height: 90vh;
overflow-y: auto;
background: var(--surface);
border-radius: var(--radius-lg);
box-shadow: var(--shadow-xl);
transform: scale(0.9);
opacity: 0;
transition: all 0.3s ease;
}
.modal-header {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--spacing-lg);
border-bottom: 1px solid var(--outline-variant);
background: var(--surface-container);
border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.modal-header h2 {
font-size: var(--font-size-lg);
font-weight: 600;
color: var(--on-surface);
margin: 0;
}
.close-btn {
background: none;
border: none;
color: var(--on-surface-variant);
cursor: pointer;
padding: var(--spacing-sm);
border-radius: var(--radius-sm);
transition: all var(--transition-normal);
display: flex;
align-items: center;
justify-content: center;
}
.close-btn:hover {
background: var(--surface-variant);
color: var(--on-surface);
}
.modal-body {
padding: var(--spacing-lg);
}
.course-review-header {
margin-bottom: var(--spacing-lg);
padding-bottom: var(--spacing-md);
border-bottom: 1px solid var(--outline-variant);
}
.course-basic-info h3 {
font-size: var(--font-size-lg);
font-weight: 600;
color: var(--on-surface);
margin: 0 0 var(--spacing-sm) 0;
}
.course-meta {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-md);
align-items: center;
}
.course-meta .rating {
background: var(--primary-container);
color: var(--on-primary-container);
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-weight: 600;
}
.course-meta .price {
background: var(--tertiary-container);
color: var(--on-tertiary-container);
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-weight: 600;
}
.course-meta .subscription {
background: var(--secondary-container);
color: var(--on-secondary-container);
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-weight: 500;
}
.review-content {
margin: var(--spacing-lg) 0;
}
.review-text {
font-size: var(--font-size-base);
line-height: 1.7;
color: var(--on-surface);
white-space: pre-line;
}
.review-footer {
margin-top: var(--spacing-lg);
padding-top: var(--spacing-md);
border-top: 1px solid var(--outline-variant);
}
.review-meta {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-md);
align-items: center;
font-size: var(--font-size-sm);
color: var(--on-surface-variant);
}
.review-author {
font-weight: 600;
color: var(--primary);
}
.review-date {
color: var(--on-surface-variant);
}
.review-rating {
background: var(--primary-container);
color: var(--on-primary-container);
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-weight: 600;
}
.modal-actions {
display: flex;
gap: var(--spacing-md);
justify-content: flex-end;
margin-top: var(--spacing-lg);
padding-top: var(--spacing-md);
border-top: 1px solid var(--outline-variant);
}
@media (max-width: 768px) {
.course-meta {
flex-direction: column;
align-items: flex-start;
gap: var(--spacing-sm);
}
.review-meta {
flex-direction: column;
align-items: flex-start;
gap: var(--spacing-sm);
}
.modal-actions {
flex-direction: column;
}
.review-modal {
max-width: 95vw;
margin: var(--spacing-md);
}
}
.app-features {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-xs);
margin: var(--spacing-md) 0;
}
#apps .search-container {
margin-bottom: var(--spacing-xl);
display: flex;
flex-direction: column;
gap: var(--spacing-md);
}
#apps .search-bar {
width: 100%;
max-width: 400px;
margin: 0 auto;
}
#apps .filter-tabs {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-sm);
justify-content: center;
margin-top: var(--spacing-md);
}
#appsGrid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
gap: var(--spacing-lg);
margin-top: var(--spacing-xl);
}
@media (max-width: 768px) {
.mylist-controls {
padding: var(--spacing-lg);
}
.mylist-actions {
flex-direction: column;
align-items: stretch;
}
.mylist-search {
min-width: auto;
max-width: none;
}
.mylist-filters {
justify-content: center;
}
.filter-btn {
flex: 1;
justify-content: center;
min-width: 0;
}
.mylist-grid {
grid-template-columns: 1fr;
gap: var(--spacing-md);
}
.mylist-card {
padding: var(--spacing-lg);
}
.empty-actions {
flex-direction: column;
align-items: center;
}
.empty-actions .btn {
width: 100%;
max-width: 250px;
}
}
@media (max-width: 480px) {
.mylist-controls {
padding: var(--spacing-md);
}
.stat-item {
padding: var(--spacing-sm) var(--spacing-md);
}
.filter-btn {
padding: var(--spacing-xs) var(--spacing-sm);
font-size: var(--font-size-xs);
}
.mylist-card {
padding: var(--spacing-md);
}
.mylist-card .card-icon {
width: 40px;
height: 40px;
font-size: 1.25rem;
}
.mylist-card .card-title {
font-size: 1rem;
}
.mylist-empty {
padding: var(--spacing-xl) var(--spacing-md);
}
.empty-illustration .material-icons {
font-size: 3rem;
}
}
#myListGrid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
gap: var(--spacing-lg);
margin-top: var(--spacing-xl);
}
@media (min-width: 768px) {
#myListGrid {
grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
}
}
@media (min-width: 1024px) {
#myListGrid {
grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
}
}
@media (min-width: 768px) {
#appsGrid {
grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
gap: var(--spacing-xl);
}
}
@media (min-width: 1024px) {
#appsGrid {
grid-template-columns: repeat(3, 1fr);
gap: var(--spacing-xl);
}
}
@media (min-width: 1200px) {
#appsGrid {
grid-template-columns: repeat(3, 1fr);
gap: var(--spacing-xl);
}
}
.rating-badge {
display: inline-block;
background: var(--primary);
color: var(--on-primary);
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-size: var(--font-size-xs);
font-weight: 600;
margin-left: var(--spacing-sm);
box-shadow: var(--shadow-sm);
vertical-align: middle;
}
.detailed-features {
margin: var(--spacing-md) 0;
padding: var(--spacing-md);
background: var(--surface-variant);
border-radius: var(--radius-md);
border: 1px solid var(--outline-variant);
}
.detailed-features h4 {
font-size: var(--font-size-base);
font-weight: 600;
color: var(--on-surface);
margin: 0 0 var(--spacing-sm) 0;
}
.detailed-features ul {
margin: 0;
padding-right: var(--spacing-lg);
list-style-type: disc;
}
.detailed-features li {
font-size: var(--font-size-sm);
color: var(--on-surface-variant);
margin-bottom: var(--spacing-xs);
line-height: 1.5;
}
.use-cases {
margin: var(--spacing-md) 0;
}
.use-cases h4 {
font-size: var(--font-size-base);
font-weight: 600;
color: var(--on-surface);
margin: 0 0 var(--spacing-sm) 0;
}
.use-cases-tags {
display: flex;
flex-wrap: wrap;
gap: var(--spacing-xs);
}
.use-case-tag {
background: var(--secondary-container);
color: var(--on-secondary-container);
padding: var(--spacing-xs) var(--spacing-sm);
border-radius: var(--radius-sm);
font-size: var(--font-size-xs);
font-weight: 500;
border: 1px solid var(--outline-variant);
}
@media (max-width: 768px) {
.detailed-features {
padding: var(--spacing-sm);
}
.detailed-features h4 {
font-size: var(--font-size-sm);
}
.detailed-features li {
font-size: var(--font-size-xs);
}
.use-cases h4 {
font-size: var(--font-size-sm);
}
.use-case-tag {
font-size: var(--font-size-xs);
padding: var(--spacing-xs);
}
#apps .search-container {
gap: var(--spacing-sm);
}
#apps .filter-tabs {
gap: var(--spacing-xs);
margin-top: var(--spacing-sm);
}
#apps .filter-tab {
font-size: var(--font-size-xs);
padding: var(--spacing-xs) var(--spacing-sm);
}
#appsGrid {
grid-template-columns: 1fr;
gap: var(--spacing-md);
margin-top: var(--spacing-lg);
}
.marketplace-filters {
flex-direction: column;
align-items: stretch;
}
.filter-group {
min-width: auto;
}
.kun-guarantee-filter {
align-self: flex-start;
}
.mylist-pagination {
gap: var(--spacing-xs);
padding: var(--spacing-md);
margin: var(--spacing-lg) 0;
}
.pagination-btn {
min-width: 36px;
height: 36px;
font-size: var(--font-size-xs);
}
.pagination-btn .material-icons {
font-size: 1rem;
}
}
@media (max-width: 480px) {
.mylist-pagination {
gap: var(--spacing-xs);
padding: var(--spacing-sm);
margin: var(--spacing-md) 0;
}
.pagination-btn {
min-width: 32px;
height: 32px;
font-size: var(--font-size-xs);
padding: var(--spacing-xs);
}
.pagination-btn .material-icons {
font-size: 0.875rem;
}
}
