/* css/pages/_article.css */ /* ========================================================================== Single Article/Project Page Specific Styles ========================================================================== */ /** * Ta datoteka vsebuje stile, ki se uporabljajo izključno na strani s * posameznim člankom ali projektom. * * 1. Glavna postavitev strani članka (z levo navigacijo) * 2. Lepljiva leva navigacija (Scrollspy - Desktop) * 3. Lepljiva zgornja vrstica z naslovom in progress barom (Mobile) * 4. Glava članka (naslov, podnaslov, datum) * 5. Glavna slika in slike v vsebini * 6. Telo članka (vsebina, tipografija, citati) * 7. Noga članka (avtor, deljenje) * 8. Poziv k prijavi na novice (CTA) * 9. Stili za stran s člankom na mobilnih napravah */ /* ========================================================================== 1. Glavna postavitev strani članka ========================================================================== */ .article-page { padding-top: 80px; background: #FFFFFF; } .article-layout-container { display: flex; max-width: 1280px; margin: 0 auto; padding: 0 32px; gap: 64px; align-items: flex-start; } .article-container { flex-grow: 1; min-width: 0; padding: 96px 0; } /* ========================================================================== 2. Lepljiva leva navigacija (Scrollspy - Desktop) - POSODOBLJENO ========================================================================== */ .article-sidebar { width: 288px; flex-shrink: 0; position: sticky; top: 120px; height: calc(100vh - 140px); margin-top: 48px; /* NOVO: Doda začetni odmik od vrha */ } .scrollspy-nav { height: 100%; overflow-y: auto; } .scrollspy-nav ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 20px; border-left: 2px solid #EAECF0; } .scrollspy-nav li a { display: block; padding: 12px 24px; text-decoration: none; font-size: 16px; font-weight: 500; color: #667085; border-left: 2px solid transparent; margin-left: -2px; transition: all 0.2s ease-in-out; } .scrollspy-nav li a:hover { color: #101828; background-color: #F9FAFB; } .scrollspy-nav li a.active { color: #2D738C; font-weight: 600; border-left-color: #2D738C; background-color: transparent; } /* ========================================================================== 3. Lepljiva zgornja vrstica (Mobile) ========================================================================== */ .mobile-article-header { display: none; position: sticky; top: 60px; background-color: #FFFFFF; z-index: 900; border-bottom: 1px solid #EAECF0; padding: 12px 24px; cursor: pointer; justify-content: space-between; align-items: center; -webkit-tap-highlight-color: transparent; } .mobile-article-header .fa-chevron-down { transition: transform 0.3s ease-in-out; } .mobile-article-header.open .fa-chevron-down { transform: rotate(180deg); } #mobile-article-title { font-size: 14px; font-weight: 600; color: #101828; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex-grow: 1; padding-right: 16px; } .progress-bar-container { width: 100%; height: 3px; background-color: #EAECF0; position: absolute; bottom: -1px; left: 0; } .progress-bar { width: 0%; height: 100%; background-color: #2D738C; transition: width 0.1s linear; } .mobile-scrollspy-dropdown { position: absolute; top: 100%; left: 0; width: 100%; background: #FFFFFF; border-top: 1px solid #EAECF0; box-shadow: 0 4px 6px rgba(0,0,0,0.05); max-height: 0; overflow: hidden; opacity: 0; visibility: hidden; transition: max-height 0.3s ease-in-out, opacity 0.3s ease-in-out, visibility 0.3s; } .mobile-scrollspy-dropdown.open { max-height: 50vh; opacity: 1; visibility: visible; overflow-y: auto; } .mobile-scrollspy-dropdown ul { list-style: none; padding: 8px; margin: 0; } .mobile-scrollspy-dropdown a { display: block; padding: 12px 16px; text-decoration: none; color: #344054; font-size: 16px; font-weight: 500; border-radius: 6px; white-space: normal; } .mobile-scrollspy-dropdown a:hover, .mobile-scrollspy-dropdown a.active { background-color: #F9FAFB; color: #2D738C; } /* ========================================================================== 4. Glava članka ========================================================================== */ .article-header { text-align: center; margin-bottom: 64px; } .article-publish-date { font-size: 16px; font-weight: 600; color: #FA7850; margin-bottom: 12px; } .article-header h1 { font-size: 48px; font-weight: 600; line-height: 60px; letter-spacing: -0.02em; color: #101828; margin: 0; } .article-subtitle { font-size: 20px; line-height: 30px; color: #667085; margin-top: 24px; max-width: 960px; margin-left: auto; margin-right: auto; } /* ========================================================================== 5. Glavna slika in slike v vsebini ========================================================================== */ .article-main-image { margin: 0 0 64px 0; } .article-main-image img { width: 100%; height: auto; max-height: 516px; object-fit: cover; border-radius: 24px; display: block; margin: 0 auto; } .article-inline-image { margin: 16px 0; display: flex; flex-direction: column; gap: 16px; } .article-inline-image img { width: 100%; border-radius: 16px; } .article-inline-image figcaption { font-size: 14px; color: #667085; text-align: center; } /* ========================================================================== 6. Telo članka ========================================================================== */ .article-body { max-width: 720px; margin: 0 auto; display: flex; flex-direction: column; gap: 32px; } .article-body p, .article-body ol li { font-size: 18px; line-height: 28px; color: #667085; margin: 0; } .article-body h2 { font-size: 30px; font-weight: 600; line-height: 38px; color: #101828; margin: 16px 0; scroll-margin-top: 120px; } .article-body ol { padding-left: 24px; display: flex; flex-direction: column; gap: 12px; } .article-quote { margin: 16px 0; padding-left: 20px; border-left: 2px solid #D0D5DD; display: flex; flex-direction: column; gap: 32px; background: transparent; } .article-quote p { font-family: 'Inter', sans-serif; font-style: italic; font-weight: 500; font-size: 24px; line-height: 36px; color: #101828; margin: 0; } .article-quote footer { font-style: normal; font-weight: 400; font-size: 16px; line-height: 24px; color: #FA7850; background: transparent; } /* ========================================================================== 7. Noga članka ========================================================================== */ .article-footer { max-width: 720px; margin: 48px auto 0; background: transparent; } .article-footer hr { border: 0; height: 1px; background-color: #EAECF0; margin: 0 0 24px 0; } .author-share-section { display: flex; justify-content: space-between; align-items: center; } .author-details { display: flex; align-items: center; gap: 16px; } .author-details img { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; } .author-name { font-size: 18px; font-weight: 600; color: #101828; margin: 0; } .author-title { font-size: 16px; color: #667085; margin: 0; } .share-buttons { display: flex; align-items: center; gap: 12px; } /* ========================================================================== 8. Poziv k prijavi na novice (CTA) ========================================================================== */ .newsletter-cta { padding: 0 32px 96px 32px; } .newsletter-cta .container { padding: 64px; background: #F9FAFB; border-radius: 16px; display: flex; justify-content: space-between; align-items: center; max-width: 1216px; gap: 32px; } .newsletter-cta .cta-content { display: flex; flex-direction: column; align-items: flex-start; gap: 16px; flex: 1; } .newsletter-cta h2 { font-size: 30px; font-weight: 600; line-height: 38px; color: #101828; margin: 0; } .newsletter-cta p { font-size: 20px; line-height: 30px; color: #667085; margin: 0; } .newsletter-cta .subscribe-form-bottom { display: flex; gap: 16px; align-items: flex-start; } .subscribe-form-bottom .input-wrapper { display: flex; flex-direction: column; gap: 8px; } .subscribe-form-bottom input { width: 360px; height: 48px; padding: 12px 16px; border: 1px solid #D0D5DD; border-radius: 8px; box-shadow: 0px 1px 2px rgba(16, 24, 40, 0.05); font-size: 16px; box-sizing: border-box; } .subscribe-form-bottom .btn-primary-orange { height: 48px; padding-top: 12px; padding-bottom: 12px; } /* ========================================================================== 9. Mobile Article Page Styles ========================================================================== */ @media (max-width: 768px) { .article-page { padding-top: 60px; } .article-layout-container { flex-direction: column; padding: 0; gap: 0; } .article-sidebar { display: none; } .mobile-article-header { display: flex; } .article-container { padding: 48px 24px; } .article-header { margin-bottom: 32px; } .article-header h1 { font-size: 32px; line-height: 40px; } .article-subtitle { font-size: 18px; line-height: 28px; } .article-main-image { margin: 0 0 32px 0; width: 100%; position: static; left: auto; right: auto; } .article-main-image img { border-radius: 16px; } .article-body { gap: 32px; } .article-body p { font-size: 16px; line-height: 26px; } .article-body h2 { font-size: 24px; line-height: 32px; scroll-margin-top: 120px; } .article-quote p { font-size: 20px; line-height: 30px; } .author-share-section { flex-direction: column; align-items: flex-start; gap: 24px; } .newsletter-cta { padding: 0 24px 64px 24px; } .newsletter-cta .container { flex-direction: column; padding: 32px; gap: 32px; } .newsletter-cta .cta-content, .newsletter-cta .cta-content p { align-items: center; text-align: center; } .newsletter-cta .subscribe-form-bottom { flex-direction: column; width: 100%; align-items: stretch; } .subscribe-form-bottom .input-wrapper { width: 100%; } .subscribe-form-bottom input { width: 100%; } .newsletter-cta .privacy-note { text-align: center; } }