Spaces:
Sleeping
Sleeping
| /* static/style.css – tambahan ringkas biar mirip SS */ | |
| body { font-family: system-ui, Segoe UI, Roboto, Arial, sans-serif; background:#f5f7fb; margin:0; } | |
| .container { max-width: 980px; margin: 0 auto; padding: 24px; } | |
| .hero { background:#4a6ea9; color:#fff; padding:28px 24px; border-radius:12px; } | |
| .hero h1 { margin:0 0 8px; letter-spacing:1px; } | |
| .nav a { color:#e8eefc; margin-right:16px; text-decoration:none; font-weight:600; } | |
| .nav a[aria-disabled="true"] { opacity:.6; pointer-events:none; } | |
| .welcome { text-align:center; padding:28px 0; } | |
| .welcome h2 { margin:0 0 8px; color:#2b3852; } | |
| .subjects h3 { text-align:center; color:#2b3852; margin-bottom:16px; } | |
| .grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:18px; } | |
| .card { display:block; background:linear-gradient(180deg,#6b86bd,#5575b1); color:#fff; padding:22px; border-radius:12px; text-decoration:none; box-shadow:0 6px 16px rgba(0,0,0,.08); } | |
| .card h4 { margin:0 0 8px; letter-spacing:.5px; } | |
| .card p { margin:0; opacity:.95; } | |
| .header { display:flex; justify-content:space-between; align-items:center; margin-bottom:14px; color:#fff; | |
| background:#6b86bd; padding:12px 16px; border-radius:10px; } | |
| .header .link { color:#fff; text-decoration:none; } | |
| .main { background:#fff; border-radius:12px; padding:16px; box-shadow:0 6px 16px rgba(0,0,0,.06); } | |
| .chat-box { height:420px; overflow:auto; padding:8px; background:#f6f8fc; border-radius:10px; } | |
| .msg { max-width:70%; margin:8px 0; padding:10px 12px; border-radius:14px; line-height:1.3; } | |
| .msg.user { margin-left:auto; background:#4a6ea9; color:#fff; } | |
| .msg.bot { background:#e9eef8; color:#2b3852; } | |
| .input-row { display:flex; gap:8px; margin-top:12px; } | |
| .input-row input { flex:1; padding:10px 12px; border-radius:10px; border:1px solid #cbd5e1; } | |
| .btn { background:#4a6ea9; color:#fff; border:none; padding:10px 14px; border-radius:10px; cursor:pointer; } | |
| .btn:hover { filter:brightness(.95); } | |
| .about { line-height:1.6; color:#2b3852; } | |
| .about h3 { color:#4a6ea9; margin-bottom:8px; } | |
| .about h4 { margin-top:24px; color:#344767; } | |
| .bio { list-style:none; padding:0; margin:0; } | |
| .bio li { margin-bottom:4px; } | |
| /* =========================================== | |
| AUTH UI — Login & Register | |
| Fokus: tampilan saja (tanpa ubah HTML) | |
| =========================================== */ | |
| /* ---------- Design tokens ---------- */ | |
| :root { | |
| --auth-bg1: #6c8bd6; | |
| --auth-bg2: #405eae; | |
| --auth-card: #ffffff; | |
| --auth-text: #1f2937; | |
| --auth-muted:#6b7280; | |
| --auth-primary: #4f6fd0; | |
| --auth-primary-2: #3e5cc2; | |
| --auth-success-bg:#e8f7ee; | |
| --auth-success-fg:#11623c; | |
| --auth-error-bg: #fdeaea; | |
| --auth-error-fg: #8f1d1d; | |
| --auth-border: #e5e7eb; | |
| --shadow-1: 0 6px 20px rgba(0,0,0,.12); | |
| --shadow-2: 0 16px 48px rgba(0,0,0,.18); | |
| --radius-lg: 16px; | |
| --radius-md: 12px; | |
| } | |
| /* Dark mode otomatis */ | |
| @media (prefers-color-scheme: dark) { | |
| :root { | |
| --auth-bg1: #0f1b3a; | |
| --auth-bg2: #0b1330; | |
| --auth-card: #0f172a; | |
| --auth-text: #e5e7eb; | |
| --auth-muted:#a3a9b5; | |
| --auth-primary: #6d8cff; | |
| --auth-primary-2: #5876f3; | |
| --auth-success-bg:#0f2b20; | |
| --auth-success-fg:#a6f3c7; | |
| --auth-error-bg: #2a1212; | |
| --auth-error-fg: #ffb3b3; | |
| --auth-border: #1f2937; | |
| --shadow-1: 0 8px 26px rgba(0,0,0,.35); | |
| --shadow-2: 0 24px 60px rgba(0,0,0,.45); | |
| } | |
| } | |
| /* ---------- Background full ---------- */ | |
| .auth-bg { | |
| min-height: 100vh; | |
| padding: 32px 18px; | |
| display: grid; | |
| place-items: center; | |
| background: radial-gradient(1200px 800px at 10% 10%, rgba(255,255,255,.18), transparent 40%), | |
| radial-gradient(1000px 700px at 90% 20%, rgba(255,255,255,.12), transparent 45%), | |
| linear-gradient(160deg, var(--auth-bg1) 0%, var(--auth-bg2) 100%); | |
| position: relative; | |
| overflow: hidden; | |
| } | |
| /* Decorative blobs */ | |
| .auth-bg::before, .auth-bg::after { | |
| content: ""; | |
| position: absolute; | |
| filter: blur(60px); | |
| opacity: .35; | |
| animation: floaty 14s ease-in-out infinite alternate; | |
| } | |
| .auth-bg::before { | |
| width: 480px; height: 480px; | |
| left: -120px; bottom: -120px; | |
| background: radial-gradient(circle at 30% 30%, #ffffff66, transparent 60%); | |
| } | |
| .auth-bg::after { | |
| width: 520px; height: 520px; | |
| right: -140px; top: -140px; | |
| background: radial-gradient(circle at 70% 70%, #ffffff55, transparent 60%); | |
| animation-duration: 18s; | |
| } | |
| @keyframes floaty { | |
| from { transform: translateY(-6px) translateX(0); } | |
| to { transform: translateY(6px) translateX(4px); } | |
| } | |
| /* ---------- Card ---------- */ | |
| .auth-card { | |
| width: 100%; | |
| max-width: 440px; | |
| background: color-mix(in oklab, var(--auth-card) 92%, transparent); | |
| -webkit-backdrop-filter: blur(10px); | |
| backdrop-filter: blur(10px); | |
| border: 1px solid color-mix(in oklab, var(--auth-border) 70%, transparent); | |
| border-radius: var(--radius-lg); | |
| box-shadow: var(--shadow-1); | |
| padding: 26px 22px; | |
| position: relative; | |
| overflow: hidden; | |
| transform: translateZ(0); | |
| } | |
| .auth-card::after{ | |
| /* top accent line */ | |
| content:""; | |
| position:absolute; | |
| inset: 0 0 auto 0; | |
| height: 3px; | |
| background: linear-gradient(90deg, var(--auth-primary), var(--auth-primary-2)); | |
| opacity: .9; | |
| } | |
| /* micro-hover lift */ | |
| .auth-card:hover{ | |
| box-shadow: var(--shadow-2); | |
| transform: translateY(-1px); | |
| } | |
| /* ---------- Titles ---------- */ | |
| .auth-title{ | |
| margin: 2px 0 6px; | |
| font-size: 24px; | |
| font-weight: 800; | |
| letter-spacing: .2px; | |
| color: var(--auth-text); | |
| } | |
| .auth-subtitle{ | |
| margin: 0 0 16px; | |
| color: var(--auth-muted); | |
| font-size: 14px; | |
| } | |
| /* ---------- Form ---------- */ | |
| .auth-card form{ | |
| display: grid; | |
| gap: 12px; | |
| margin-top: 10px; | |
| } | |
| /* Input wrapper (adds subtle focus ring) */ | |
| .auth-input{ | |
| position: relative; | |
| } | |
| .auth-card input{ | |
| width: 100%; | |
| padding: 12px 14px; | |
| border-radius: var(--radius-md); | |
| border: 1px solid var(--auth-border); | |
| background: color-mix(in oklab, var(--auth-card) 98%, transparent); | |
| color: var(--auth-text); | |
| font-size: 14px; | |
| transition: border-color .15s ease, box-shadow .2s ease, background .2s ease; | |
| } | |
| .auth-card input::placeholder{ | |
| color: color-mix(in oklab, var(--auth-muted) 80%, transparent); | |
| } | |
| .auth-card input:focus{ | |
| outline: none; | |
| border-color: color-mix(in oklab, var(--auth-primary) 70%, #000 0%); | |
| box-shadow: 0 0 0 4px color-mix(in oklab, var(--auth-primary) 18%, transparent); | |
| background: color-mix(in oklab, var(--auth-card) 100%, transparent); | |
| } | |
| /* ---------- Button ---------- */ | |
| .auth-card .btn{ | |
| width: 100%; | |
| padding: 12px 16px; | |
| border-radius: var(--radius-md); | |
| font-weight: 700; | |
| letter-spacing: .2px; | |
| border: none; | |
| cursor: pointer; | |
| background: linear-gradient(180deg, var(--auth-primary), var(--auth-primary-2)); | |
| color: #fff; | |
| box-shadow: 0 8px 24px color-mix(in oklab, var(--auth-primary) 35%, transparent); | |
| transition: transform .06s ease, filter .2s ease, box-shadow .2s ease; | |
| } | |
| .auth-card .btn:hover{ | |
| filter: brightness(.98); | |
| box-shadow: 0 10px 30px color-mix(in oklab, var(--auth-primary) 45%, transparent); | |
| } | |
| .auth-card .btn:active{ | |
| transform: translateY(1px); | |
| } | |
| /* ---------- Helper text & links ---------- */ | |
| .muted{ | |
| margin-top: 14px; | |
| text-align: center; | |
| color: var(--auth-muted); | |
| font-size: 13px; | |
| } | |
| .muted a{ | |
| color: var(--auth-primary); | |
| text-decoration: none; | |
| font-weight: 600; | |
| } | |
| .muted a:hover{ text-decoration: underline; } | |
| /* ---------- Flash messages ---------- */ | |
| .flash{ | |
| margin: 8px 0 4px; | |
| padding: 10px 12px; | |
| border-radius: var(--radius-md); | |
| font-size: 13px; | |
| border: 1px solid transparent; | |
| } | |
| .flash.success{ | |
| background: var(--auth-success-bg); | |
| color: var(--auth-success-fg); | |
| border-color: color-mix(in oklab, var(--auth-success-fg) 24%, transparent); | |
| } | |
| .flash.error{ | |
| background: var(--auth-error-bg); | |
| color: var(--auth-error-fg); | |
| border-color: color-mix(in oklab, var(--auth-error-fg) 24%, transparent); | |
| } | |
| /* ---------- Small divider (opsional, jika nanti butuh) ---------- */ | |
| .auth-divider{ | |
| display: grid; | |
| grid-template-columns: 1fr auto 1fr; | |
| align-items: center; | |
| gap: 10px; | |
| color: var(--auth-muted); | |
| font-size: 12px; | |
| } | |
| .auth-divider::before, | |
| .auth-divider::after{ | |
| content:""; | |
| height: 1px; | |
| background: color-mix(in oklab, var(--auth-border) 80%, transparent); | |
| } | |
| /* ---------- Responsive ---------- */ | |
| @media (max-width: 560px){ | |
| .auth-card{ padding: 22px 18px; border-radius: 14px; } | |
| .auth-title{ font-size: 22px; } | |
| } | |
| /* ---------- Reduced motion ---------- */ | |
| @media (prefers-reduced-motion: reduce){ | |
| .auth-bg::before, .auth-bg::after{ animation: none; } | |
| .auth-card, .auth-card .btn{ transition: none; } | |
| } | |
| /* inset kanan–kiri untuk semua field di login & register */ | |
| .auth-card form{ | |
| padding-inline: 10px; /* kiri–kanan 10px */ | |
| } | |
| .auth-card input, | |
| .auth-card .btn{ | |
| width: 100%; | |
| box-sizing: border-box; /* pastikan hitung padding/border */ | |
| } | |