:root{--color-primary: #1e3a5f;--color-primary-light: #2a5a8f;--color-primary-dark: #0f2640;--color-accent: #c9a84c;--color-accent-light: #e0c871;--color-accent-dark: #a88b32;--color-bg: #faf9f7;--color-bg-white: #ffffff;--color-bg-card: #ffffff;--color-bg-section: #f3f1ee;--color-text: #2c2c2c;--color-text-light: #6b6b6b;--color-text-muted: #999999;--color-text-white: #ffffff;--color-border: #e0ddd8;--color-border-light: #f0ede8;--color-success: #27ae60;--color-error: #e74c3c;--color-warning: #f5a623;--color-info: #667eea;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .12);--shadow-xl: 0 16px 50px rgba(0, 0, 0, .15);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--font-display: "Playfair Display", Georgia, serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--transition: .2s ease;--max-width: 1200px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--color-text);background-color:var(--color-bg);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}ul{list-style:none}img{max-width:100%;display:block}h1,h2,h3,h4{font-family:var(--font-display);line-height:1.3}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border:none;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--transition);white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:var(--color-text-white)}.btn-primary:hover{background:linear-gradient(135deg,var(--color-primary-light),var(--color-primary));box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-outline:hover{background:var(--color-primary);color:var(--color-text-white)}.btn-lg{padding:14px 32px;font-size:1.05rem;border-radius:var(--radius-md)}.btn-sm{padding:6px 14px;font-size:.85rem}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.navbar{background:var(--color-primary-dark);position:sticky;top:0;z-index:1000;box-shadow:var(--shadow-md)}.navbar-container{max-width:var(--max-width);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:68px}.navbar-brand{display:flex;align-items:center;gap:10px;color:var(--color-text-white);font-weight:600;font-size:1.15rem}.brand-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--color-accent);color:var(--color-primary-dark);border-radius:var(--radius-sm);font-family:var(--font-display);font-size:1.3rem;font-weight:700}.brand-text{font-family:var(--font-display)}.navbar-toggle{display:none;background:none;border:none;color:var(--color-text-white);cursor:pointer;padding:4px}.navbar-links{display:flex;align-items:center;gap:4px}.nav-link{color:#ffffffbf;padding:8px 16px;border-radius:var(--radius-sm);font-size:.95rem;font-weight:500;transition:all var(--transition)}.nav-link:hover{color:var(--color-text-white);background:#ffffff1a}.nav-link.active{color:var(--color-accent);background:#c9a84c1f}@media(max-width:768px){.navbar-toggle{display:block}.navbar-links{display:none;position:absolute;top:68px;left:0;right:0;flex-direction:column;background:var(--color-primary-dark);padding:12px 24px 20px;border-top:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-lg)}.navbar-links.active{display:flex}.nav-link{width:100%;padding:12px 16px}}.footer{background:var(--color-primary-dark);color:#fffc;margin-top:auto}.footer-container{max-width:var(--max-width);margin:0 auto;padding:0 24px}.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding:48px 0 32px}.footer-logo{display:flex;align-items:center;gap:10px;color:var(--color-text-white);font-family:var(--font-display);font-size:1.15rem;font-weight:600;margin-bottom:12px}.footer-tagline{font-size:.9rem;line-height:1.7;max-width:360px;color:#fff9}.footer-links-group h4{color:var(--color-accent);font-family:var(--font-body);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px}.footer-links-group ul{display:flex;flex-direction:column;gap:10px}.footer-links-group a{font-size:.9rem;color:#ffffffa6;transition:color var(--transition)}.footer-links-group a:hover{color:var(--color-text-white)}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;text-align:center;font-size:.85rem;color:#ffffff80}.footer-disclaimer{margin-top:4px;font-size:.78rem;font-style:italic}@media(max-width:768px){.footer-top{grid-template-columns:1fr;gap:32px;padding:32px 0 24px}}.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary) 50%,var(--color-primary-light) 100%);color:var(--color-text-white);padding:100px 24px 110px;text-align:center}.hero-content{position:relative;z-index:2;max-width:720px;margin:0 auto}.hero-title{font-size:3.2rem;font-weight:700;margin-bottom:20px;line-height:1.15}.hero-highlight{color:var(--color-accent)}.hero-subtitle{font-size:1.15rem;color:#fffc;margin-bottom:36px;line-height:1.7}.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.hero-actions .btn-primary{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-dark));color:var(--color-primary-dark);font-weight:600}.hero-actions .btn-primary:hover{background:linear-gradient(135deg,var(--color-accent-light),var(--color-accent))}.hero-actions .btn-outline{border-color:#ffffff80;color:var(--color-text-white)}.hero-actions .btn-outline:hover{background:#ffffff26;border-color:var(--color-text-white)}.hero-decoration{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.hero-circle{position:absolute;border-radius:50%;border:1px solid rgba(201,168,76,.15)}.hero-circle-1{width:500px;height:500px;top:-150px;right:-100px}.hero-circle-2{width:300px;height:300px;bottom:-80px;left:-60px}.hero-circle-3{width:200px;height:200px;top:50%;left:15%;background:#c9a84c0a}.section-header{text-align:center;margin-bottom:48px}.section-header h2{font-size:2.2rem;color:var(--color-primary-dark);margin-bottom:12px}.section-header p{font-size:1.05rem;color:var(--color-text-light);max-width:520px;margin:0 auto}.tools-section{padding:80px 24px;max-width:var(--max-width);margin:0 auto}.tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:32px}.tool-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:36px;transition:all var(--transition)}.tool-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.tool-icon-wrapper{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:#fff;margin-bottom:20px}.tool-card h3{font-size:1.5rem;color:var(--color-primary-dark);margin-bottom:12px}.tool-card p{color:var(--color-text-light);font-size:.95rem;line-height:1.7;margin-bottom:20px}.tool-link{display:inline-flex;align-items:center;gap:6px;color:var(--color-primary);font-weight:600;font-size:.95rem;transition:gap var(--transition)}.tool-link:hover{gap:10px;color:var(--color-primary-light)}.how-section{padding:80px 24px;background:var(--color-bg-section)}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:32px;max-width:var(--max-width);margin:0 auto}.step-card{text-align:center;padding:32px}.step-number{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:var(--color-text-white);font-family:var(--font-display);font-size:1.5rem;font-weight:700;margin-bottom:16px}.step-card h4{font-size:1.2rem;color:var(--color-primary-dark);margin-bottom:10px}.step-card p{color:var(--color-text-light);font-size:.93rem;line-height:1.7}.cta-section{padding:80px 24px;text-align:center}.cta-content{max-width:560px;margin:0 auto}.cta-content h2{font-size:2rem;color:var(--color-primary-dark);margin-bottom:16px}.cta-content p{color:var(--color-text-light);font-size:1.05rem;line-height:1.7;margin-bottom:28px}@media(max-width:768px){.hero{padding:60px 20px 70px}.hero-title{font-size:2.2rem}.hero-subtitle{font-size:1rem}.section-header h2{font-size:1.8rem}}.sunday-harmony-page{padding-bottom:60px}.page-hero{background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary) 100%);color:var(--color-text-white);text-align:center;padding:60px 24px 70px}.page-hero-icon{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:50%;background:#c9a84c33;color:var(--color-accent);margin-bottom:20px}.page-hero h1{font-size:2.5rem;margin-bottom:12px}.page-hero-subtitle{font-size:1.05rem;color:#fffc;max-width:640px;margin:0 auto;line-height:1.7}.harmony-container{max-width:800px;margin:-30px auto 0;padding:0 24px;position:relative;z-index:2}.harmony-form{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-lg)}.harmony-form .form-group label{display:block;font-weight:600;margin-bottom:8px;color:var(--color-primary-dark);font-size:.95rem}.harmony-form textarea{width:100%;padding:14px 16px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:1rem;color:var(--color-text);resize:vertical;transition:border-color var(--transition)}.harmony-form textarea:focus{outline:none;border-color:var(--color-primary)}.harmony-form textarea::placeholder{color:var(--color-text-muted)}.btn-generate{width:100%;justify-content:center;margin-top:16px;padding:14px;font-size:1.05rem}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hymn-results{margin-top:36px}.results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.results-header h2{font-size:1.6rem;color:var(--color-primary-dark)}.hymn-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}.hymn-card{background:var(--color-bg-card);border-radius:var(--radius-md);padding:24px;box-shadow:var(--shadow-sm);border-left:4px solid var(--card-accent, var(--color-primary));transition:all var(--transition)}.hymn-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.hymn-card-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.hymn-icon{color:var(--card-accent, var(--color-primary));font-size:1.1rem}.hymn-label{font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--card-accent, var(--color-primary))}.hymn-number{font-size:.85rem;color:var(--color-text-muted);font-weight:500;margin-bottom:4px;display:block}.hymn-title{font-size:1.15rem;color:var(--color-primary-dark);line-height:1.4}.hymn-tip{display:flex;gap:12px;margin-top:28px;padding:16px 20px;background:#667eea14;border-radius:var(--radius-md);color:var(--color-text-light);font-size:.88rem;line-height:1.6;align-items:flex-start}.hymn-tip svg{color:var(--color-info);flex-shrink:0;margin-top:2px}@media(max-width:600px){.hymn-grid{grid-template-columns:1fr}.page-hero h1{font-size:2rem}}.talkshare-page{padding-bottom:60px}.talkshare-container{max-width:860px;margin:0 auto;padding:0 24px}.talkshare-controls{display:flex;gap:16px;margin-top:32px;margin-bottom:20px;align-items:center}.search-bar{flex:1;position:relative}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--color-text-muted)}.search-bar input{width:100%;padding:12px 16px 12px 44px;border:2px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.95rem;color:var(--color-text);background:var(--color-bg-card);transition:border-color var(--transition)}.search-bar input:focus{outline:none;border-color:var(--color-primary)}.search-bar input::placeholder{color:var(--color-text-muted)}.btn-submit-talk{flex-shrink:0}.tag-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}.tag-filter-btn{padding:6px 16px;border:1px solid var(--color-border);border-radius:20px;background:var(--color-bg-card);color:var(--color-text-light);font-family:var(--font-body);font-size:.85rem;cursor:pointer;transition:all var(--transition)}.tag-filter-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.tag-filter-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-white)}.talks-list{display:flex;flex-direction:column;gap:20px}.talk-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:28px;transition:all var(--transition)}.talk-card:hover{box-shadow:var(--shadow-md)}.talk-card-header{margin-bottom:14px}.talk-title{font-size:1.35rem;color:var(--color-primary-dark);margin-bottom:10px}.talk-meta{display:flex;flex-wrap:wrap;gap:16px;align-items:center}.talk-author{font-weight:600;color:var(--color-primary);font-size:.93rem}.talk-detail{display:flex;align-items:center;gap:5px;font-size:.85rem;color:var(--color-text-muted)}.talk-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.talk-tag{display:inline-block;padding:3px 12px;background:#667eea1a;color:var(--color-info);border-radius:20px;font-size:.78rem;font-weight:500}.talk-summary{color:var(--color-text-light);font-size:.93rem;line-height:1.7;margin-bottom:6px}.talk-content{margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border-light)}.talk-content p{margin-bottom:14px;color:var(--color-text);font-size:.95rem;line-height:1.8}.talk-actions{display:flex;align-items:center;justify-content:space-between;margin-top:18px;padding-top:16px;border-top:1px solid var(--color-border-light)}.talk-action-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.88rem;color:var(--color-text-light);cursor:pointer;transition:all var(--transition)}.talk-action-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#1e3a5f0a}.talk-action-right{display:flex;gap:8px}.like-btn:hover{border-color:var(--color-error);color:var(--color-error);background:#e74c3c0d}.share-btn:hover{border-color:var(--color-info);color:var(--color-info);background:#667eea0d}.no-results{text-align:center;padding:60px 24px;color:var(--color-text-muted)}.no-results svg{margin-bottom:16px;opacity:.3}.no-results h3{font-size:1.3rem;color:var(--color-text-light);margin-bottom:8px}@media(max-width:768px){.talkshare-controls{flex-direction:column}.btn-submit-talk{width:100%;justify-content:center}.talk-actions{flex-direction:column;gap:12px;align-items:stretch}.talk-action-right{justify-content:flex-end}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--color-bg-card);border-radius:var(--radius-lg);max-width:640px;width:100%;max-height:90vh;overflow-y:auto;padding:36px;position:relative;box-shadow:var(--shadow-xl)}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px;transition:color var(--transition)}.modal-close:hover{color:var(--color-text)}.modal-title{font-size:1.6rem;color:var(--color-primary-dark);margin-bottom:8px}.modal-description{color:var(--color-text-light);font-size:.93rem;line-height:1.7;margin-bottom:28px}.submit-form .form-group{margin-bottom:18px}.submit-form label{display:block;font-weight:600;font-size:.88rem;color:var(--color-primary-dark);margin-bottom:6px}.submit-form input,.submit-form textarea{width:100%;padding:10px 14px;border:2px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.93rem;color:var(--color-text);transition:border-color var(--transition)}.submit-form input:focus,.submit-form textarea:focus{outline:none;border-color:var(--color-primary)}.submit-form input::placeholder,.submit-form textarea::placeholder{color:var(--color-text-muted)}.submit-form textarea{resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.btn-submit{width:100%;justify-content:center;padding:14px;font-size:1rem;margin-top:8px}.modal-success{text-align:center;padding:20px 0}.success-icon{color:var(--color-success);margin-bottom:20px}.modal-success h2{font-size:1.6rem;color:var(--color-primary-dark);margin-bottom:12px}.modal-success p{color:var(--color-text-light);font-size:.95rem;line-height:1.7;margin-bottom:28px;max-width:400px;margin-left:auto;margin-right:auto}@media(max-width:600px){.form-row{grid-template-columns:1fr}.modal-content{padding:24px}}.about-page{padding-bottom:60px}.about-container{max-width:860px;margin:0 auto;padding:0 24px}.about-section{margin-top:52px}.about-section h2{font-size:1.8rem;color:var(--color-primary-dark);margin-bottom:20px;position:relative;padding-bottom:12px}.about-section h2:after{content:"";position:absolute;bottom:0;left:0;width:48px;height:3px;background:var(--color-accent);border-radius:2px}.about-section>p{color:var(--color-text-light);font-size:1rem;line-height:1.8;margin-bottom:16px}.about-tools-grid{display:flex;flex-direction:column;gap:24px;margin-top:8px}.about-tool-card{display:flex;gap:24px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:28px;transition:all var(--transition)}.about-tool-card:hover{box-shadow:var(--shadow-md)}.about-tool-icon{flex-shrink:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:#fff}.about-tool-info h3{font-size:1.25rem;color:var(--color-primary-dark);margin-bottom:8px}.about-tool-info p{color:var(--color-text-light);font-size:.93rem;line-height:1.7;margin-bottom:12px}.about-coming-soon{display:flex;align-items:center;gap:12px;margin-top:24px;padding:16px 20px;background:#c9a84c1a;border-radius:var(--radius-md);border-left:4px solid var(--color-accent)}.about-coming-soon svg{color:var(--color-accent-dark);flex-shrink:0}.about-coming-soon p{color:var(--color-text-light);font-size:.93rem;line-height:1.6}.developer-card{display:flex;gap:36px;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:36px;box-shadow:var(--shadow-sm)}.developer-avatar{flex-shrink:0}.avatar-placeholder{width:160px;height:160px;border-radius:50%;overflow:hidden;background:var(--color-bg-section);border:4px solid var(--color-border);display:flex;align-items:center;justify-content:center}.avatar-svg{width:100%;height:100%}.avatar-img{width:100%;height:100%;object-fit:cover}.developer-info h3{font-size:1.5rem;color:var(--color-primary-dark);margin-bottom:4px}.developer-role{font-size:.93rem;color:var(--color-accent-dark);font-weight:600;margin-bottom:16px}.developer-bio{color:var(--color-text-light);font-size:.95rem;line-height:1.8;margin-bottom:12px}.developer-bio a{color:var(--color-primary);font-weight:500;text-decoration:underline;text-underline-offset:2px;transition:color var(--transition)}.developer-bio a:hover{color:var(--color-primary-light)}.developer-links{display:flex;gap:16px;margin-top:20px;flex-wrap:wrap}.dev-link{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;color:var(--color-text-light);transition:all var(--transition)}.dev-link:hover{border-color:var(--color-primary);color:var(--color-primary);background:#1e3a5f0a}.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;margin-top:8px}.value-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:28px;text-align:center;transition:all var(--transition)}.value-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.value-icon{font-size:2rem;margin-bottom:12px;color:var(--color-accent)}.value-card h4{font-size:1.1rem;color:var(--color-primary-dark);margin-bottom:8px}.value-card p{color:var(--color-text-light);font-size:.88rem;line-height:1.7}@media(max-width:768px){.developer-card{flex-direction:column;align-items:center;text-align:center;padding:28px}.developer-links{justify-content:center}.about-tool-card{flex-direction:column;align-items:flex-start}.about-section h2{font-size:1.5rem}.about-section h2:after{left:50%;transform:translate(-50%)}.footer-top{grid-template-columns:1fr}}.nav-separator{width:1px;height:24px;background:#ffffff26;margin:0 4px;align-self:center}.nav-link-user,.nav-link-admin,.nav-link-signin{display:flex;align-items:center;gap:6px}.nav-link-admin{color:var(--color-accent)!important;background:#c9a84c26;border-radius:var(--radius-sm);font-weight:600}.nav-link-admin:hover{background:#c9a84c40!important}.nav-logout-btn{display:flex;align-items:center;gap:6px;background:none;border:none;color:#ffffffbf;padding:8px 16px;border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.nav-logout-btn:hover{color:#ff6b6b;background:#ff6b6b1a}.nav-link-signin{background:#c9a84c26;color:var(--color-accent)!important;border-radius:var(--radius-sm)}.nav-link-signin:hover{background:#c9a84c40!important}@media(max-width:768px){.nav-separator{width:100%;height:1px;margin:8px 0}}.auth-page{min-height:calc(100vh - 200px);display:flex;align-items:center;justify-content:center;padding:40px 24px;background:var(--color-bg-section)}.auth-card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:44px 40px;max-width:440px;width:100%;box-shadow:var(--shadow-lg)}.auth-header{text-align:center;margin-bottom:28px}.auth-icon{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff;margin-bottom:16px}.auth-header h1{font-size:1.6rem;color:var(--color-primary-dark);margin-bottom:6px}.auth-header p{color:var(--color-text-muted);font-size:.93rem}.auth-error{background:#e74c3c14;color:var(--color-error);padding:12px 16px;border-radius:var(--radius-sm);font-size:.9rem;margin-bottom:20px;border-left:3px solid var(--color-error)}.auth-form{display:flex;flex-direction:column;gap:14px}.auth-field{position:relative}.field-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);font-size:1rem}.auth-field input{width:100%;padding:12px 14px 12px 42px;border:2px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.95rem;color:var(--color-text);transition:border-color var(--transition)}.auth-field input:focus{outline:none;border-color:var(--color-primary)}.auth-btn{width:100%;justify-content:center;padding:13px;font-size:1rem;margin-top:4px}.auth-switch{text-align:center;margin-top:24px;font-size:.9rem;color:var(--color-text-muted)}.auth-switch a{color:var(--color-primary);font-weight:600;text-decoration:underline;text-underline-offset:2px}.auth-switch a:hover{color:var(--color-primary-light)}@media(max-width:480px){.auth-card{padding:32px 24px}}.dashboard-page{padding-bottom:60px}.dashboard-container{max-width:900px;margin:0 auto;padding:0 24px}.dash-section{margin-top:36px}.dash-section-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--color-border-light)}.dash-section-header svg{color:var(--color-primary)}.dash-section-header h2{font-size:1.3rem;color:var(--color-primary-dark);flex:1}.dash-count{background:var(--color-primary);color:#fff;font-size:.8rem;font-weight:600;padding:2px 10px;border-radius:12px}.dash-empty{background:var(--color-bg-section);border-radius:var(--radius-md);padding:32px;text-align:center;color:var(--color-text-muted)}.dash-empty strong{color:var(--color-primary)}.saved-hymns-list{display:flex;flex-direction:column;gap:16px}.saved-hymn-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:20px}.saved-hymn-theme{font-size:.93rem;color:var(--color-text-light);margin-bottom:14px}.saved-label{font-weight:600;color:var(--color-primary-dark)}.saved-hymn-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.saved-hymn-item{display:flex;flex-direction:column;gap:2px}.sh-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.sh-title{font-size:.88rem;color:var(--color-text)}.saved-hymn-actions{display:flex;gap:10px;padding-top:12px;border-top:1px solid var(--color-border-light)}.btn-danger-outline{border:1px solid var(--color-error);color:var(--color-error);background:none}.btn-danger-outline:hover{background:#e74c3c14}.submissions-list{display:flex;flex-direction:column;gap:12px}.submission-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:18px 20px}.submission-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.submission-header h4{font-size:1.05rem;color:var(--color-primary-dark)}.submission-meta{display:flex;gap:16px;margin-top:8px;font-size:.85rem;color:var(--color-text-muted)}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;white-space:nowrap}.status-pending{background:#f5a6231f;color:#b8860b}.status-approved{background:#27ae601f;color:var(--color-success)}.status-rejected{background:#e74c3c1f;color:var(--color-error)}@media(max-width:600px){.saved-hymn-grid{grid-template-columns:1fr}.saved-hymn-actions{flex-direction:column}}.admin-page{padding-bottom:60px}.page-hero-admin{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.admin-container{max-width:940px;margin:0 auto;padding:0 24px}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-top:32px}.stat-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:20px;display:flex;align-items:center;gap:16px}.stat-card svg{color:var(--color-primary)}.stat-info{display:flex;flex-direction:column}.stat-number{font-size:1.8rem;font-weight:700;font-family:var(--font-display);color:var(--color-primary-dark);line-height:1}.stat-label{font-size:.82rem;color:var(--color-text-muted);margin-top:2px}.admin-section{margin-top:36px}.admin-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--color-border-light)}.admin-section-title{display:flex;align-items:center;gap:10px}.admin-section-title svg{color:var(--color-primary)}.admin-section-title h2{font-size:1.3rem;color:var(--color-primary-dark)}.admin-add-form{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:28px}.admin-add-form .form-group{margin-bottom:14px}.admin-add-form label{display:block;font-weight:600;font-size:.85rem;color:var(--color-primary-dark);margin-bottom:6px}.admin-add-form input,.admin-add-form textarea{width:100%;padding:10px 14px;border:2px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.93rem;color:var(--color-text);transition:border-color var(--transition)}.admin-add-form input:focus,.admin-add-form textarea:focus{outline:none;border-color:var(--color-primary)}.admin-add-form textarea{resize:vertical}.admin-submissions-list{display:flex;flex-direction:column;gap:14px}.admin-sub-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:20px}.admin-sub-reviewed{opacity:.75}.admin-sub-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.admin-sub-header h4{font-size:1.1rem;color:var(--color-primary-dark);margin-bottom:4px}.admin-sub-meta{font-size:.85rem;color:var(--color-text-muted)}.admin-sub-preview{margin-top:16px;padding:16px;background:var(--color-bg-section);border-radius:var(--radius-sm);max-height:300px;overflow-y:auto}.admin-sub-preview p{font-size:.9rem;color:var(--color-text);line-height:1.7;margin-bottom:10px}.admin-sub-actions{display:flex;gap:10px;margin-top:16px;padding-top:14px;border-top:1px solid var(--color-border-light)}.btn-success{background:var(--color-success);color:#fff;border:none}.btn-success:hover{background:#219653;box-shadow:var(--shadow-sm)}.btn-danger{background:var(--color-error);color:#fff;border:none}.btn-danger:hover{background:#c0392b;box-shadow:var(--shadow-sm)}.results-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.like-btn.liked{border-color:var(--color-error);color:var(--color-error);background:#e74c3c14}.like-btn.liked svg{fill:var(--color-error)}.admin-users-list{display:flex;flex-direction:column;gap:10px}.admin-user-card{display:flex;align-items:center;justify-content:space-between;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px 20px;gap:16px}.admin-user-info{display:flex;align-items:center;gap:14px;flex:1;min-width:0}.admin-user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.admin-user-info h4{font-size:.97rem;color:var(--color-primary-dark);display:flex;align-items:center;gap:8px}.admin-user-info p{font-size:.84rem;color:var(--color-text-muted);margin-top:1px}.you-badge{font-size:.7rem;font-weight:600;font-family:var(--font-body);background:#667eea1f;color:var(--color-info);padding:1px 8px;border-radius:10px}.admin-user-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}@media(max-width:600px){.admin-user-card{flex-direction:column;align-items:flex-start}.admin-user-actions{width:100%;justify-content:space-between;padding-top:10px;border-top:1px solid var(--color-border-light)}}.loading-spinner{width:40px;height:40px;border:4px solid var(--color-border-light, #e0e0e0);border-top-color:var(--color-primary, #1e3a5f);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px}@keyframes spin{to{transform:rotate(360deg)}}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:var(--color-text-secondary, #6b7280);font-size:1rem}
