Spaces:
Sleeping
Sleeping
| /* | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| Civic Issue Urgency Classifier - iOS 26 Liquid Design | |
| Inspired by Apple's latest design language | |
| βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| */ | |
| /* ============================================ | |
| ROOT VARIABLES - Black, White & Gray Palette | |
| ============================================ */ | |
| :root { | |
| /* Primary Colors - Black, White & Gray */ | |
| --primary-gradient: linear-gradient(135deg, #333333 0%, #1a1a1a 100%); | |
| --secondary-gradient: linear-gradient(135deg, #666666 0%, #4d4d4d 100%); | |
| --success-gradient: linear-gradient(135deg, #555555 0%, #404040 100%); | |
| --danger-gradient: linear-gradient(135deg, #2a2a2a 0%, #1f1f1f 100%); | |
| /* Glass Colors */ | |
| --glass-white: rgba(255, 255, 255, 0.08); | |
| --glass-white-hover: rgba(255, 255, 255, 0.12); | |
| --glass-dark: rgba(0, 0, 0, 0.3); | |
| --glass-border: rgba(255, 255, 255, 0.12); | |
| /* Text Colors */ | |
| --text-primary: #f5f5f5; | |
| --text-secondary: #a0a0a0; | |
| --text-white: #ffffff; | |
| --text-muted: rgba(255, 255, 255, 0.6); | |
| /* Background */ | |
| --bg-primary: #0a0a0a; | |
| --bg-secondary: #161616; | |
| --bg-card: rgba(255, 255, 255, 0.04); | |
| /* Shadows */ | |
| --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.2); | |
| --shadow-md: 0 4px 16px rgba(0, 0, 0, 0.25); | |
| --shadow-lg: 0 8px 32px rgba(0, 0, 0, 0.3); | |
| --shadow-xl: 0 16px 64px rgba(0, 0, 0, 0.35); | |
| /* Urgency Colors - Grayscale */ | |
| --urgency-high: #2a2a2a; | |
| --urgency-medium: #4d4d4d; | |
| --urgency-low: #707070; | |
| /* Radius */ | |
| --radius-sm: 12px; | |
| --radius-md: 20px; | |
| --radius-lg: 28px; | |
| --radius-xl: 40px; | |
| /* Spacing */ | |
| --spacing-xs: 8px; | |
| --spacing-sm: 16px; | |
| --spacing-md: 24px; | |
| --spacing-lg: 32px; | |
| --spacing-xl: 48px; | |
| /* Animation */ | |
| --transition-fast: 0.2s ease; | |
| --transition-normal: 0.3s ease; | |
| --transition-slow: 0.5s ease; | |
| } | |
| /* ============================================ | |
| GLOBAL RESET & BASE STYLES | |
| ============================================ */ | |
| * { | |
| margin: 0; | |
| padding: 0; | |
| box-sizing: border-box; | |
| } | |
| html { | |
| scroll-behavior: smooth; | |
| font-size: 16px; | |
| } | |
| body { | |
| font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Segoe UI', | |
| Roboto, Oxygen, Ubuntu, Cantarell, sans-serif; | |
| background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 50%, #2a2a2a 100%); | |
| background-attachment: fixed; | |
| color: var(--text-white); | |
| line-height: 1.6; | |
| overflow-x: hidden; | |
| min-height: 100vh; | |
| } | |
| /* ============================================ | |
| GLASSMORPHISM EFFECTS | |
| ============================================ */ | |
| .glass { | |
| background: var(--glass-white); | |
| backdrop-filter: blur(20px); | |
| -webkit-backdrop-filter: blur(20px); | |
| border: 1px solid var(--glass-border); | |
| box-shadow: var(--shadow-lg); | |
| } | |
| .glass-dark { | |
| background: var(--glass-dark); | |
| backdrop-filter: blur(20px); | |
| -webkit-backdrop-filter: blur(20px); | |
| border: 1px solid var(--glass-border); | |
| } | |
| .glass-card { | |
| background: rgba(255, 255, 255, 0.08); | |
| backdrop-filter: blur(30px) saturate(180%); | |
| -webkit-backdrop-filter: blur(30px) saturate(180%); | |
| border: 1px solid rgba(255, 255, 255, 0.125); | |
| border-radius: var(--radius-lg); | |
| padding: var(--spacing-lg); | |
| transition: all var(--transition-normal); | |
| } | |
| .glass-card:hover { | |
| background: rgba(255, 255, 255, 0.12); | |
| transform: translateY(-4px); | |
| box-shadow: var(--shadow-xl); | |
| } | |
| /* ============================================ | |
| NAVIGATION BAR | |
| ============================================ */ | |
| .navbar { | |
| position: fixed; | |
| top: 0; | |
| left: 0; | |
| right: 0; | |
| z-index: 1000; | |
| padding: var(--spacing-sm) var(--spacing-lg); | |
| background: rgba(255, 255, 255, 0.05); | |
| backdrop-filter: blur(40px) saturate(150%); | |
| -webkit-backdrop-filter: blur(40px) saturate(150%); | |
| border-bottom: 1px solid rgba(255, 255, 255, 0.1); | |
| transition: all var(--transition-normal); | |
| } | |
| .navbar.scrolled { | |
| background: rgba(255, 255, 255, 0.1); | |
| box-shadow: var(--shadow-md); | |
| } | |
| .navbar-container { | |
| max-width: 1400px; | |
| margin: 0 auto; | |
| display: flex; | |
| justify-content: space-between; | |
| align-items: center; | |
| } | |
| .navbar-brand { | |
| display: flex; | |
| align-items: center; | |
| gap: var(--spacing-sm); | |
| font-size: 1.5rem; | |
| font-weight: 700; | |
| color: var(--text-white); | |
| text-decoration: none; | |
| transition: transform var(--transition-fast); | |
| } | |
| .navbar-brand:hover { | |
| transform: scale(1.05); | |
| } | |
| .navbar-menu { | |
| display: flex; | |
| gap: var(--spacing-md); | |
| list-style: none; | |
| } | |
| .navbar-link { | |
| color: var(--text-muted); | |
| text-decoration: none; | |
| font-weight: 500; | |
| padding: var(--spacing-xs) var(--spacing-sm); | |
| border-radius: var(--radius-sm); | |
| transition: all var(--transition-fast); | |
| position: relative; | |
| } | |
| .navbar-link:hover { | |
| color: var(--text-white); | |
| background: rgba(255, 255, 255, 0.1); | |
| } | |
| .navbar-link.active::after { | |
| content: ''; | |
| position: absolute; | |
| bottom: 0; | |
| left: 50%; | |
| transform: translateX(-50%); | |
| width: 30px; | |
| height: 3px; | |
| background: var(--primary-gradient); | |
| border-radius: 2px; | |
| } | |
| /* ============================================ | |
| HERO SECTION | |
| ============================================ */ | |
| .hero { | |
| min-height: 100vh; | |
| display: flex; | |
| align-items: center; | |
| justify-content: center; | |
| padding: var(--spacing-xl) var(--spacing-lg); | |
| padding-top: 100px; | |
| position: relative; | |
| overflow: hidden; | |
| } | |
| .hero::before { | |
| content: ''; | |
| position: absolute; | |
| top: 0; | |
| left: 0; | |
| right: 0; | |
| bottom: 0; | |
| background: radial-gradient(circle at 20% 50%, rgba(100, 100, 100, 0.15), transparent 50%), | |
| radial-gradient(circle at 80% 80%, rgba(80, 80, 80, 0.15), transparent 50%); | |
| animation: float 20s ease-in-out infinite; | |
| } | |
| @keyframes float { | |
| 0%, 100% { transform: translateY(0); } | |
| 50% { transform: translateY(-20px); } | |
| } | |
| .hero-content { | |
| text-align: center; | |
| max-width: 900px; | |
| position: relative; | |
| z-index: 1; | |
| } | |
| .hero-title { | |
| font-size: clamp(2.5rem, 8vw, 5rem); | |
| font-weight: 800; | |
| line-height: 1.1; | |
| margin-bottom: var(--spacing-md); | |
| background: linear-gradient(135deg, #ffffff 0%, #d0d0d0 100%); | |
| -webkit-background-clip: text; | |
| -webkit-text-fill-color: transparent; | |
| background-clip: text; | |
| animation: fadeInUp 0.8s ease; | |
| } | |
| .hero-subtitle { | |
| font-size: clamp(1.1rem, 3vw, 1.5rem); | |
| color: var(--text-muted); | |
| margin-bottom: var(--spacing-xl); | |
| font-weight: 400; | |
| animation: fadeInUp 1s ease; | |
| } | |
| .hero-buttons { | |
| display: flex; | |
| gap: var(--spacing-sm); | |
| justify-content: center; | |
| flex-wrap: wrap; | |
| animation: fadeInUp 1.2s ease; | |
| } | |
| /* ============================================ | |
| BUTTONS - iOS 26 Style | |
| ============================================ */ | |
| .btn { | |
| display: inline-flex; | |
| align-items: center; | |
| gap: var(--spacing-xs); | |
| padding: 16px 32px; | |
| border: none; | |
| border-radius: var(--radius-md); | |
| font-size: 1.05rem; | |
| font-weight: 600; | |
| text-decoration: none; | |
| cursor: pointer; | |
| transition: all var(--transition-normal); | |
| position: relative; | |
| overflow: hidden; | |
| } | |
| .btn::before { | |
| content: ''; | |
| position: absolute; | |
| top: 50%; | |
| left: 50%; | |
| width: 0; | |
| height: 0; | |
| border-radius: 50%; | |
| background: rgba(255, 255, 255, 0.2); | |
| transform: translate(-50%, -50%); | |
| transition: width 0.6s, height 0.6s; | |
| } | |
| .btn:hover::before { | |
| width: 300px; | |
| height: 300px; | |
| } | |
| .btn-primary { | |
| background: var(--primary-gradient); | |
| color: var(--text-white); | |
| box-shadow: 0 8px 24px rgba(50, 50, 50, 0.4); | |
| } | |
| .btn-primary:hover { | |
| transform: translateY(-2px); | |
| box-shadow: 0 12px 32px rgba(50, 50, 50, 0.6); | |
| } | |
| .btn-secondary { | |
| background: rgba(255, 255, 255, 0.1); | |
| color: var(--text-white); | |
| border: 2px solid rgba(255, 255, 255, 0.2); | |
| backdrop-filter: blur(10px); | |
| } | |
| .btn-secondary:hover { | |
| background: rgba(255, 255, 255, 0.15); | |
| border-color: rgba(255, 255, 255, 0.3); | |
| transform: translateY(-2px); | |
| } | |
| .btn-large { | |
| padding: 20px 40px; | |
| font-size: 1.15rem; | |
| } | |
| /* ============================================ | |
| FEATURE CARDS | |
| ============================================ */ | |
| .features { | |
| padding: var(--spacing-xl) var(--spacing-lg); | |
| max-width: 1400px; | |
| margin: 0 auto; | |
| } | |
| .features-grid { | |
| display: grid; | |
| grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); | |
| gap: var(--spacing-lg); | |
| margin-top: var(--spacing-xl); | |
| } | |
| .feature-card { | |
| padding: var(--spacing-lg); | |
| border-radius: var(--radius-lg); | |
| background: rgba(255, 255, 255, 0.05); | |
| backdrop-filter: blur(20px); | |
| border: 1px solid rgba(255, 255, 255, 0.1); | |
| transition: all var(--transition-normal); | |
| cursor: pointer; | |
| } | |
| .feature-card:hover { | |
| background: rgba(255, 255, 255, 0.08); | |
| transform: translateY(-8px); | |
| box-shadow: 0 16px 48px rgba(0, 0, 0, 0.3); | |
| } | |
| .feature-icon { | |
| font-size: 3rem; | |
| margin-bottom: var(--spacing-sm); | |
| display: inline-block; | |
| animation: bounce 2s infinite; | |
| } | |
| .feature-title { | |
| font-size: 1.5rem; | |
| font-weight: 700; | |
| margin-bottom: var(--spacing-xs); | |
| color: var(--text-white); | |
| } | |
| .feature-description { | |
| color: var(--text-muted); | |
| line-height: 1.7; | |
| } | |
| @keyframes bounce { | |
| 0%, 100% { transform: translateY(0); } | |
| 50% { transform: translateY(-10px); } | |
| } | |
| /* ============================================ | |
| CLASSIFICATION FORM | |
| ============================================ */ | |
| .classifier-section { | |
| padding: var(--spacing-xl) var(--spacing-lg); | |
| max-width: 900px; | |
| margin: 0 auto; | |
| } | |
| .form-container { | |
| background: rgba(255, 255, 255, 0.08); | |
| backdrop-filter: blur(30px) saturate(180%); | |
| border: 1px solid rgba(255, 255, 255, 0.125); | |
| border-radius: var(--radius-xl); | |
| padding: var(--spacing-xl); | |
| box-shadow: var(--shadow-xl); | |
| } | |
| .form-group { | |
| margin-bottom: var(--spacing-lg); | |
| } | |
| .form-label { | |
| display: block; | |
| font-weight: 600; | |
| margin-bottom: var(--spacing-xs); | |
| color: var(--text-white); | |
| font-size: 1.05rem; | |
| } | |
| .form-input, | |
| .form-textarea { | |
| width: 100%; | |
| padding: 16px 20px; | |
| border-radius: var(--radius-md); | |
| border: 2px solid rgba(255, 255, 255, 0.1); | |
| background: rgba(255, 255, 255, 0.05); | |
| color: var(--text-white); | |
| font-size: 1rem; | |
| font-family: inherit; | |
| transition: all var(--transition-normal); | |
| backdrop-filter: blur(10px); | |
| } | |
| .form-input:focus, | |
| .form-textarea:focus { | |
| outline: none; | |
| border-color: rgba(200, 200, 200, 0.5); | |
| background: rgba(255, 255, 255, 0.08); | |
| box-shadow: 0 0 0 4px rgba(150, 150, 150, 0.1); | |
| } | |
| .form-textarea { | |
| min-height: 150px; | |
| resize: vertical; | |
| } | |
| .form-input::placeholder, | |
| .form-textarea::placeholder { | |
| color: rgba(255, 255, 255, 0.4); | |
| } | |
| .char-count { | |
| text-align: right; | |
| font-size: 0.9rem; | |
| color: var(--text-muted); | |
| margin-top: var(--spacing-xs); | |
| } | |
| /* ============================================ | |
| RESULT DISPLAY | |
| ============================================ */ | |
| .result-container { | |
| margin-top: var(--spacing-xl); | |
| animation: slideInUp 0.5s ease; | |
| } | |
| .result-card { | |
| background: rgba(255, 255, 255, 0.08); | |
| backdrop-filter: blur(30px); | |
| border-radius: var(--radius-xl); | |
| padding: var(--spacing-xl); | |
| border: 1px solid rgba(255, 255, 255, 0.15); | |
| } | |
| .urgency-badge { | |
| display: inline-flex; | |
| align-items: center; | |
| gap: var(--spacing-xs); | |
| padding: 12px 24px; | |
| border-radius: var(--radius-lg); | |
| font-size: 1.25rem; | |
| font-weight: 700; | |
| text-transform: uppercase; | |
| letter-spacing: 1px; | |
| margin-bottom: var(--spacing-md); | |
| animation: pulse 2s infinite; | |
| } | |
| .urgency-high { | |
| background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%); | |
| box-shadow: 0 8px 24px rgba(42, 42, 42, 0.5); | |
| } | |
| .urgency-medium { | |
| background: linear-gradient(135deg, #4d4d4d 0%, #3a3a3a 100%); | |
| box-shadow: 0 8px 24px rgba(77, 77, 77, 0.4); | |
| } | |
| .urgency-low { | |
| background: linear-gradient(135deg, #707070 0%, #5a5a5a 100%); | |
| box-shadow: 0 8px 24px rgba(112, 112, 112, 0.3); | |
| } | |
| @keyframes pulse { | |
| 0%, 100% { transform: scale(1); } | |
| 50% { transform: scale(1.05); } | |
| } | |
| .result-details { | |
| display: grid; | |
| grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); | |
| gap: var(--spacing-md); | |
| margin-top: var(--spacing-lg); | |
| } | |
| .detail-item { | |
| padding: var(--spacing-md); | |
| background: rgba(255, 255, 255, 0.05); | |
| border-radius: var(--radius-md); | |
| border: 1px solid rgba(255, 255, 255, 0.1); | |
| } | |
| .detail-label { | |
| font-size: 0.9rem; | |
| color: var(--text-muted); | |
| margin-bottom: var(--spacing-xs); | |
| text-transform: uppercase; | |
| letter-spacing: 1px; | |
| font-weight: 600; | |
| } | |
| .detail-value { | |
| font-size: 1.5rem; | |
| font-weight: 700; | |
| color: var(--text-white); | |
| } | |
| .progress-bar { | |
| height: 8px; | |
| background: rgba(255, 255, 255, 0.1); | |
| border-radius: 4px; | |
| overflow: hidden; | |
| margin-top: var(--spacing-xs); | |
| } | |
| .progress-fill { | |
| height: 100%; | |
| background: var(--primary-gradient); | |
| border-radius: 4px; | |
| transition: width 1s ease; | |
| animation: shimmer 2s infinite; | |
| } | |
| @keyframes shimmer { | |
| 0% { background-position: -1000px 0; } | |
| 100% { background-position: 1000px 0; } | |
| } | |
| /* ============================================ | |
| LOADING ANIMATION | |
| ============================================ */ | |
| .loading { | |
| display: flex; | |
| justify-content: center; | |
| align-items: center; | |
| padding: var(--spacing-xl); | |
| } | |
| .loading-spinner { | |
| width: 60px; | |
| height: 60px; | |
| border: 4px solid rgba(255, 255, 255, 0.1); | |
| border-top: 4px solid var(--text-white); | |
| border-radius: 50%; | |
| animation: spin 1s linear infinite; | |
| } | |
| @keyframes spin { | |
| 0% { transform: rotate(0deg); } | |
| 100% { transform: rotate(360deg); } | |
| } | |
| /* ============================================ | |
| ANIMATIONS | |
| ============================================ */ | |
| @keyframes fadeInUp { | |
| from { | |
| opacity: 0; | |
| transform: translateY(30px); | |
| } | |
| to { | |
| opacity: 1; | |
| transform: translateY(0); | |
| } | |
| } | |
| @keyframes slideInUp { | |
| from { | |
| opacity: 0; | |
| transform: translateY(50px); | |
| } | |
| to { | |
| opacity: 1; | |
| transform: translateY(0); | |
| } | |
| } | |
| /* ============================================ | |
| RESPONSIVE DESIGN | |
| ============================================ */ | |
| @media (max-width: 768px) { | |
| .navbar-menu { | |
| display: none; | |
| } | |
| .hero { | |
| padding: var(--spacing-lg) var(--spacing-sm); | |
| padding-top: 80px; | |
| } | |
| .hero-title { | |
| font-size: 2.5rem; | |
| } | |
| .hero-buttons { | |
| flex-direction: column; | |
| } | |
| .btn { | |
| width: 100%; | |
| justify-content: center; | |
| } | |
| .features-grid { | |
| grid-template-columns: 1fr; | |
| } | |
| .form-container { | |
| padding: var(--spacing-md); | |
| } | |
| .result-details { | |
| grid-template-columns: 1fr; | |
| } | |
| } | |
| /* ============================================ | |
| UTILITY CLASSES | |
| ============================================ */ | |
| .text-center { | |
| text-align: center; | |
| } | |
| .mt-lg { | |
| margin-top: var(--spacing-lg); | |
| } | |
| .mb-lg { | |
| margin-bottom: var(--spacing-lg); | |
| } | |
| .hidden { | |
| display: none ; | |
| } | |
| .fade-in { | |
| animation: fadeInUp 0.6s ease; | |
| } | |