:root{--bg-primary: #f5f0e8;--bg-secondary: #ebe5d8;--bg-card: #faf7f0;--bg-card-hover: #fff9ee;--text-primary: #3d3425;--text-secondary: #6b5d4d;--text-muted: #706352;--border: #d4c9b8;--border-light: #e5ddd0;--accent: #8b6914;--accent-light: #c49a2a;--shadow: rgba(60, 45, 20, .08);--shadow-hover: rgba(60, 45, 20, .15);--header-bg: rgba(245, 240, 232, .92);--badge-bg: #e8e0d0;--badge-text: #6b5d4d;--star-color: #c49a2a;--input-bg: #faf7f0;--spinner-color: #8b6914;--overlay-gradient: linear-gradient(to top, rgba(30,25,15,.85) 0%, rgba(30,25,15,.4) 50%, transparent 100%)}[data-theme=dark]{--bg-primary: #1a1714;--bg-secondary: #231f1b;--bg-card: #2a2520;--bg-card-hover: #332d26;--text-primary: #e8dcc8;--text-secondary: #b8a88e;--text-muted: #9a8b78;--border: #3d352a;--border-light: #4a4035;--accent: #d4a83a;--accent-light: #e8c45a;--shadow: rgba(0, 0, 0, .25);--shadow-hover: rgba(0, 0, 0, .4);--header-bg: rgba(26, 23, 20, .92);--badge-bg: #3d352a;--badge-text: #b8a88e;--star-color: #e8c45a;--input-bg: #2a2520;--spinner-color: #d4a83a;--overlay-gradient: linear-gradient(to top, rgba(10,8,5,.9) 0%, rgba(10,8,5,.45) 50%, transparent 100%)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{font-family:Crimson Text,"Noto Serif SC",Georgia,serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;transition:background .4s ease,color .4s ease}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");pointer-events:none;z-index:0}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-light)}.site-header{position:sticky;top:0;z-index:100;background:var(--header-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-light);transition:background .4s ease}.header-inner{max-width:1400px;margin:0 auto;padding:16px 24px;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:12px}.logo-icon{color:var(--accent)}.logo h1{font-size:1.5rem;font-weight:600;letter-spacing:.02em;color:var(--text-primary)}.tagline{font-size:.85rem;color:var(--text-muted);font-style:italic;margin-left:4px}.icon-btn{width:40px;height:40px;border:1px solid var(--border);border-radius:10px;background:var(--bg-card);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.icon-btn:hover{background:var(--bg-card-hover);border-color:var(--accent);color:var(--accent)}.lang-toggle-btn{font-family:inherit;font-size:.82rem;font-weight:600;letter-spacing:.04em;width:auto!important;padding:0 14px}.header-controls{display:flex;gap:8px}.moon-icon,[data-theme=dark] .sun-icon{display:none}[data-theme=dark] .moon-icon{display:block}.filters-bar{background:var(--bg-secondary);border-bottom:1px solid var(--border-light);position:relative;z-index:50}.filters-inner{max-width:1400px;margin:0 auto;padding:14px 24px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:8px;background:var(--input-bg);border:1px solid var(--border);border-radius:10px;padding:8px 14px;flex:0 1 280px;min-width:200px;transition:border-color .2s ease}.search-box:focus-within{border-color:var(--accent)}.search-box svg{color:var(--text-muted);flex-shrink:0}.search-box input{border:none;background:transparent;font-family:inherit;font-size:.95rem;color:var(--text-primary);outline:none;width:100%}.search-box input::placeholder{color:var(--text-muted)}.period-filters{display:flex;gap:6px}.period-btn{font-family:inherit;font-size:.82rem;padding:10px 16px;min-height:44px;border:1px solid var(--border);border-radius:22px;background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap}.period-btn:hover{border-color:var(--accent);color:var(--accent)}.period-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px #8b5a2b66;transform:scale(1.05);animation:filterPulse .3s ease;font-weight:600}.language-filters{display:flex;gap:6px;flex-wrap:wrap;flex:1}.lang-btn{font-family:inherit;font-size:.82rem;padding:10px 16px;min-height:44px;border:1px solid var(--border);border-radius:22px;background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;white-space:nowrap}.lang-btn:hover{border-color:var(--accent);color:var(--accent)}.lang-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 8px #8b5a2b66;transform:scale(1.05);animation:filterPulse .3s ease;font-weight:600}.sort-control{display:flex;align-items:center}.sort-select{font-family:inherit;font-size:.82rem;padding:10px 32px 10px 12px;min-height:44px;border:1px solid var(--border);border-radius:22px;background:var(--bg-card) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M2 4l4 4 4-4'/%3E%3C/svg%3E") no-repeat right 12px center;color:var(--text-secondary);cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none}.sort-select:hover{border-color:var(--accent)}.sort-select:focus{outline:none;border-color:var(--accent)}.filter-summary{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.filter-summary:empty{display:none}.filter-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--accent);color:#fff;border-radius:12px;font-size:.75rem;font-weight:500}.filter-tag .remove-filter{cursor:pointer;opacity:.8;font-size:1em}.filter-tag .remove-filter:hover{opacity:1}.card-count{font-size:.82rem;color:var(--text-muted);white-space:nowrap;font-style:italic}.gallery{max-width:1400px;margin:0 auto;padding:32px 24px 60px;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px;position:relative;z-index:1;min-height:50vh}.card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:16px;overflow:hidden;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;box-shadow:0 2px 8px var(--shadow);position:relative}.card:hover{transform:translateY(-4px);box-shadow:0 8px 28px var(--shadow-hover);border-color:var(--accent)}.card-image-wrapper,.card-image{position:relative;width:100%;aspect-ratio:1 / 1.1;overflow:hidden;background:var(--bg-secondary)}.card-image-wrapper img,.card-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.card:hover .card-image-wrapper img,.card:hover .card-image img{transform:scale(1.03)}.active-badge{position:absolute;top:10px;right:10px;background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;font-size:.7rem;font-weight:600;padding:4px 8px;border-radius:12px;z-index:2}.hot-badge{position:absolute;top:10px;left:10px;background:linear-gradient(135deg,gold,#fa0);color:#333;font-size:.7rem;font-weight:600;padding:4px 8px;border-radius:12px;z-index:2;box-shadow:0 2px 6px #fa06;box-shadow:0 2px 8px #ff6b3566;animation:pulse-badge 2s infinite}@keyframes pulse-badge{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.card-overlay{display:none}.card-title-bar{padding:10px 18px 4px;display:flex;flex-direction:column;gap:2px}.card-author{font-size:.72rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.card-name{font-size:1.1rem;font-weight:600;color:var(--text-primary);line-height:1.3}.card-meta{padding:14px 18px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.card-stars{display:flex;align-items:center;gap:5px;font-size:.88rem;color:var(--star-color);font-weight:600}.card-stars svg{width:15px;height:15px;fill:var(--star-color)}.card-language{font-size:.75rem;padding:3px 10px;border-radius:12px;background:var(--badge-bg);color:var(--badge-text);font-weight:600;letter-spacing:.02em}.card-desc{font-size:.8rem;color:var(--text-muted);font-style:italic;margin-left:auto;text-align:right;max-width:50%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lang-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px}.loading-state{grid-column:1 / -1;width:100%}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;width:100%}.skeleton-card{background:var(--bg-card);border-radius:12px;overflow:hidden;box-shadow:0 2px 8px var(--shadow)}.skeleton-image{width:100%;aspect-ratio:1 / 1.1;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-card) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton-title{height:20px;margin:12px 16px 8px;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-card) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px;width:60%}.skeleton-meta{height:14px;margin:0 16px 16px;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-card) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px;width:40%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes filterPulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1.05)}}.modal-spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border:3px solid var(--border-light);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;z-index:1}.modal-spinner.hidden{display:none}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}.modal-image-wrapper{position:relative}.no-results{grid-column:1 / -1;text-align:center;padding:60px 20px 80px;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:16px}.no-results-icon{width:100px;height:100px;color:var(--text-muted);opacity:.7}.no-results p{font-size:1.1rem;font-style:italic;margin:0}.no-results-hint{font-size:.9rem!important;opacity:.7;margin-top:8px!important}.clear-filters-btn{margin-top:16px;padding:10px 20px;font-family:inherit;font-size:.9rem;background:var(--accent);color:#fff;border:none;border-radius:22px;cursor:pointer;transition:all .2s ease}.clear-filters-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #8b5a2b66}.site-footer{background:var(--bg-secondary);border-top:1px solid var(--border-light);position:relative;z-index:1}.footer-inner{max-width:1400px;margin:0 auto;padding:28px 24px;text-align:center}.footer-inner p{font-size:.9rem;color:var(--text-secondary);font-style:italic}.footer-sub{margin-top:8px;font-size:.8rem;color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .3s ease}.modal-overlay.active{opacity:1;pointer-events:auto}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;max-width:960px;width:100%;max-height:90vh;overflow:hidden;position:relative;box-shadow:0 20px 60px #0000004d;transform:scale(.95) translateY(10px);transition:transform .3s ease}.modal-overlay.active .modal{transform:scale(1) translateY(0)}.modal-close{position:absolute;top:14px;right:14px;z-index:10;width:38px;height:38px;border:1px solid var(--border);border-radius:50%;background:var(--bg-card);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.modal-close:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.modal-body{display:flex;max-height:90vh;overflow-y:auto}.modal-image-col{flex:0 0 45%;max-width:45%;background:var(--bg-secondary)}.modal-image-wrapper{position:sticky;top:0;padding:24px;display:flex;align-items:center;justify-content:center;min-height:300px}.modal-image-wrapper img{width:100%;height:auto;border-radius:12px;box-shadow:0 4px 20px var(--shadow);transition:opacity .2s ease-out}.modal-info-col{flex:1;padding:32px 28px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.modal-header{display:flex;flex-direction:column;gap:6px}.modal-author{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em}.modal-title{font-size:1.6rem;font-weight:600;color:var(--text-primary);line-height:1.3}.modal-description{font-size:.95rem;color:var(--text-secondary);line-height:1.6;font-style:italic}.modal-description.truncated{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.read-more-btn{background:none;border:none;color:var(--accent);font-size:.85rem;cursor:pointer;padding:4px 0;margin-top:4px;font-family:inherit}.read-more-btn:hover{text-decoration:underline}.modal-stats{display:flex;gap:24px;padding:16px 0;border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;padding:8px 0}.stat-item svg{color:var(--star-color)}.stat-item span:not(.stat-label){font-size:1.2rem;font-weight:600;color:var(--text-primary)}.stat-label{font-size:.7rem!important;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)!important;font-weight:400!important}.stat-item:first-child svg{color:var(--star-color)}.stat-item:nth-child(2) svg{color:var(--accent)}.stat-item:nth-child(3) svg{color:var(--text-muted)}.modal-meta-details{border:1px solid var(--border);border-radius:8px;overflow:hidden}.meta-summary{padding:12px 16px;background:var(--bg-secondary);cursor:pointer;font-size:.9rem;font-weight:600;color:var(--text-primary);list-style:none;display:flex;align-items:center;justify-content:space-between}.meta-summary::-webkit-details-marker{display:none}.meta-summary:after{content:"▼";font-size:.7rem;color:var(--text-muted);transition:transform .2s ease}.modal-meta-details[open] .meta-summary:after{transform:rotate(180deg)}.meta-content{padding:12px 16px;display:flex;flex-direction:column;gap:10px}.meta-row{display:flex;align-items:center;gap:12px}.meta-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;min-width:70px;flex-shrink:0}.meta-value{font-size:.9rem;color:var(--text-primary);display:flex;align-items:center;gap:4px;flex-wrap:wrap}.topic-tag{font-size:.75rem;padding:2px 10px;border-radius:12px;background:var(--badge-bg);color:var(--badge-text);font-weight:600;margin:1px 0}.modal-summary{padding:16px 0;border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light)}.modal-summary h3{font-size:.95rem;color:var(--text-primary);margin-bottom:14px;font-weight:600}.summary-row{margin-bottom:12px}.summary-row:last-child{margin-bottom:0}.summary-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:4px;font-weight:600}.summary-text{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin:0}.summary-code{font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.8rem;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:8px;padding:10px 14px;white-space:pre-wrap;word-break:break-word;line-height:1.5;margin:0;max-height:150px;overflow-y:auto}.summary-pros{list-style:none;display:flex;flex-direction:column;gap:4px;padding:0;margin:0}.summary-pros li{font-size:.85rem;color:var(--text-secondary);line-height:1.4;padding-left:16px;position:relative}.summary-pros li:before{content:"✓";position:absolute;left:0;color:#4caf50;font-weight:700;font-size:.85em}.modal-close-bottom{display:none;width:100%;border:none;border-top:1px solid var(--border-light);background:var(--bg-secondary);color:var(--text-primary);font-family:inherit;font-size:.95rem;font-weight:600;min-height:48px;padding:12px 0 16px;cursor:pointer;flex-direction:column;align-items:center;gap:4px;transition:background .15s ease;letter-spacing:.3px}.modal-close-bottom:hover,.modal-close-bottom:active{background:var(--bg-secondary);color:var(--accent)}.swipe-indicator{display:block;width:36px;height:4px;border-radius:2px;background:var(--border)}.modal-features{padding-top:16px;margin-top:16px;border-top:1px solid var(--border-light)}.modal-features h3{font-size:.95rem;color:var(--text-primary);margin-bottom:10px;font-weight:600}.modal-features ul{list-style:none;display:flex;flex-direction:column;gap:8px}.modal-features li{font-size:.88rem;color:var(--text-secondary);line-height:1.5;padding-left:18px;position:relative}.modal-features li:before{content:"·";position:absolute;left:4px;color:var(--accent);font-weight:700;font-size:1.2em}.modal-actions{padding-top:16px;border-top:1px solid var(--border-light);margin-top:auto}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:var(--text-primary);color:var(--bg-primary);border-radius:12px;font-family:inherit;font-size:.9rem;font-weight:600;letter-spacing:.02em;transition:all .2s ease;cursor:pointer;text-decoration:none}.btn-primary:hover{background:var(--accent);color:#fff;transform:translateY(-1px);box-shadow:0 4px 16px var(--shadow-hover)}@media (max-width: 900px){.gallery{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;padding:24px 16px 48px}.header-inner,.filters-inner{padding:12px 16px}.tagline{display:none}.modal-body{flex-direction:column}.modal-image-col{flex:none;max-width:100%}.modal-image-wrapper{padding:16px;min-height:auto;position:static;max-height:50vh;overflow:hidden}.modal-image-wrapper img{max-height:48vh;width:auto;max-width:100%;object-fit:contain}.modal-info-col{padding:20px 16px}.modal{max-height:100vh;max-height:100dvh;border-radius:16px 16px 0 0;margin:0;display:flex;flex-direction:column}.modal-overlay{padding:40px 0 0;align-items:flex-end}.modal-close{width:44px;height:44px}.modal-close-bottom{display:flex}.modal-body{flex:1;overflow-y:auto;position:relative}.modal-info-col{position:relative}.modal-info-col:after{content:"";position:sticky;bottom:0;left:0;right:0;display:block;height:40px;background:linear-gradient(to bottom,transparent,var(--bg-card));pointer-events:none;transition:opacity .3s}.modal-info-col.scrolled-bottom:after{opacity:0}}@media (max-width: 600px){.gallery{grid-template-columns:1fr;gap:18px;padding:18px 12px 40px}.card{max-height:520px!important;overflow:hidden}.card-image-wrapper,.card-image{aspect-ratio:3 / 4!important;height:auto!important;max-height:400px!important}.card-image-wrapper img,.card-image img{object-fit:contain!important;object-position:top center!important;width:100%!important;height:100%!important}.filters-inner{flex-direction:column;align-items:stretch}.search-box{flex:1}.language-filters{justify-content:flex-start}.logo h1{font-size:1.25rem}.card-count{text-align:center}.modal-overlay{padding:24px 0 0}.modal{border-radius:16px 16px 0 0;max-height:100%;width:100%}.modal-close{top:10px;right:10px;width:48px;height:48px}.modal-close-bottom{padding:10px 0 max(14px,env(safe-area-inset-bottom));font-size:.9rem}.modal-info-col{padding:16px 14px 60px}.modal-image-wrapper{padding:12px}}.fade-in{animation:fadeIn .4s ease forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.back-to-top{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:50%;background:var(--accent);color:#fff;border:none;cursor:pointer;opacity:0;visibility:hidden;transform:translateY(20px);transition:all .3s ease;z-index:999;box-shadow:0 4px 12px #8b5a2b66;display:flex;align-items:center;justify-content:center}.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}.back-to-top:hover{transform:translateY(-4px);box-shadow:0 6px 16px #8b5a2b80}.tab-header{display:flex;align-items:center;gap:1rem}.tab-title{font-size:1.4rem;font-weight:600;color:var(--text-primary);font-family:Crimson Text,serif}.filters-inner{justify-content:space-between}
