@import "https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary:#1a1917;--bg-secondary:#222019;--bg-card:#2a2820;--bg-elevated:#322f26;--bg-hover:#3a372e;--text-primary:#f5f2eb;--text-secondary:#b8b2a3;--text-muted:#7a7467;--text-dim:#4d493f;--accent:#e07b54;--accent-light:#f09b76;--accent-dim:#e07b541f;--accent-glow:#e07b5440;--border:#3d3a32;--border-light:#2e2c25;--border-dark:#151412;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 8px 24px #00000059;--shadow-lg:0 16px 48px #0006;--font-display:"Playfair Display", Georgia, serif;--font-body:"DM Sans", -apple-system, sans-serif;--font-mono:"JetBrains Mono", "SF Mono", monospace;--content-max:1440px;--header-h:72px;--gap:24px;--gap-sm:16px;--gap-lg:40px;--ease-smooth:cubic-bezier(.4, 0, .2, 1);--ease-bounce:cubic-bezier(.175, .885, .32, 1.275);--duration:.35s}[data-theme=light]{--bg-primary:#f8f5ef;--bg-secondary:#fffef9;--bg-card:#fff;--bg-elevated:#fff;--bg-hover:#f5f2eb;--text-primary:#1a1917;--text-secondary:#5c574d;--text-muted:#8c8578;--text-dim:#b8b2a3;--accent:#c75a38;--accent-light:#d97a58;--accent-dim:#c75a381a;--accent-glow:#c75a3826;--border:#e8e4dc;--border-light:#f0ece4;--border-dark:#d4d0c8;--shadow-sm:0 2px 8px #1a19170f;--shadow-md:0 8px 24px #1a191714;--shadow-lg:0 16px 48px #1a19171f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;overflow-x:hidden}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);background-image:radial-gradient(ellipse at 20% 0%, var(--accent-dim) 0%, transparent 50%), radial-gradient(ellipse at 80% 100%, var(--accent-dim) 0%, transparent 50%);width:100%;max-width:100vw;min-height:100vh;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:-.02em;font-weight:500;line-height:1.2}.header{z-index:100;background:var(--bg-secondary);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(20px);position:sticky;top:0}.header-inner{max-width:var(--content-max);padding:0 var(--gap-lg);height:var(--header-h);justify-content:space-between;align-items:center;gap:var(--gap);width:100%;max-width:100vw;margin:0 auto;display:flex}.logo{flex-shrink:0;align-items:baseline;gap:12px;display:flex}.logo-mark{background:var(--accent);color:#fff;width:36px;height:36px;font-family:var(--font-display);border-radius:4px;justify-content:center;align-items:center;font-size:20px;font-weight:600;display:flex;position:relative;&:after{content:"";border:1px solid #ffffff4d;border-radius:2px;position:absolute;inset:2px}}.logo-text{font-family:var(--font-display);letter-spacing:-.03em;color:var(--text-primary);font-size:22px;font-weight:500;& span{color:var(--accent)}}.header-actions{align-items:center;gap:10px;display:flex}.search-box{flex-shrink:1;position:relative}.search-icon{color:var(--text-muted);pointer-events:none;opacity:.7;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.search-box input{border:1px solid var(--border);background:var(--bg-primary);width:240px;color:var(--text-primary);font-family:var(--font-body);transition:border-color var(--duration) var(--ease-smooth), background var(--duration) var(--ease-smooth);border-left:3px solid var(--accent);border-radius:2px;outline:none;padding:12px 16px 12px 46px;font-size:14px}.search-box input:focus{border-color:var(--text-muted);background:var(--bg-secondary)}.search-box input::placeholder{color:var(--text-muted);font-style:italic}.icon-btn{border:1px solid var(--border);height:44px;color:var(--text-secondary);font-family:var(--font-body);letter-spacing:.02em;cursor:pointer;transition:all var(--duration) var(--ease-smooth);border-left:3px solid var(--border);background:0 0;border-radius:2px;justify-content:center;align-items:center;gap:6px;padding:0 16px;font-size:13px;font-weight:500;display:flex;position:relative}.icon-btn:hover{border-color:var(--text-muted);border-left-color:var(--accent);color:var(--text-primary);background:var(--bg-card)}.icon-btn svg{opacity:.8}.icon-btn .fav-count{background:var(--accent);color:#fff;min-width:20px;height:20px;font-size:11px;font-weight:600;font-family:var(--font-mono);border-radius:2px;justify-content:center;align-items:center;padding:0 6px;line-height:1;display:flex;position:absolute;top:-5px;right:-5px}.icon-btn .fav-count:empty,.icon-btn .fav-count[style*="0"]{display:none}#langToggle{width:auto;min-width:56px}[data-theme=dark] .theme-icon-light,[data-theme=light] .theme-icon-dark{display:none}.filter-bar{top:var(--header-h);z-index:90;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:var(--gap-sm) 0;position:sticky}.filter-scroll{max-width:var(--content-max);padding:0 var(--gap-lg);scrollbar-width:none;align-items:center;gap:10px;margin:0 auto;display:flex;overflow-x:auto;&::-webkit-scrollbar{display:none}}.filter-tag{border:1px solid var(--border);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;transition:all var(--duration) var(--ease-smooth);white-space:nowrap;background:0 0;border-radius:2px;flex-shrink:0;padding:8px 18px;font-size:13px;font-weight:500;position:relative;& .tag-count{background:var(--bg-elevated);font-size:11px;font-family:var(--font-mono);color:var(--text-muted);border-radius:2px;margin-left:6px;padding:2px 6px}}.filter-tag:hover{border-color:var(--accent);color:var(--text-primary);& .tag-count{background:var(--accent-dim);color:var(--accent)}}.filter-tag.active{background:var(--text-primary);border-color:var(--text-primary);color:var(--bg-primary);& .tag-count{color:inherit;background:#ffffff26}}.gallery-main{max-width:var(--content-max);padding:var(--gap-lg);box-sizing:border-box;width:100%;margin:0 auto}.gallery-grid{gap:var(--gap);grid-template-columns:repeat(3,1fr);display:grid;@media (width<=1200px){grid-template-columns:repeat(2,1fr)}@media (width<=700px){grid-template-columns:1fr}}.card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;transition:all var(--duration) var(--ease-smooth);border-radius:2px;position:relative;overflow:hidden;&:before{content:"";background:linear-gradient(90deg, var(--accent) 0%, transparent 50%);opacity:0;height:4px;transition:opacity var(--duration) var(--ease-smooth);position:absolute;top:0;left:0;right:0}}.card:hover{border-color:var(--text-muted);box-shadow:var(--shadow-md);transform:translateY(-4px);&:before{opacity:1}}.card-image{aspect-ratio:4/3;background:var(--bg-primary);width:100%;position:relative;overflow:hidden;&:after{content:"";border-right:1px solid var(--text-dim);border-bottom:1px solid var(--text-dim);opacity:.4;width:24px;height:24px;position:absolute;bottom:8px;right:8px}}.card-image img{object-fit:cover;width:100%;height:100%;transition:transform .6s var(--ease-smooth)}.card:hover .card-image img{transform:scale(1.05)}.card-fav{background:var(--bg-elevated);border:1px solid var(--border);width:36px;height:36px;color:var(--text-muted);cursor:pointer;transition:all var(--duration) var(--ease-smooth);z-index:2;box-shadow:2px 2px 0 var(--bg-primary);border-radius:2px;justify-content:center;align-items:center;display:flex;position:absolute;top:12px;right:12px}.card-fav:hover{border-color:var(--text-muted);color:var(--text-primary)}.card-fav.active{color:#fff;background:#d9534f;border-color:#d9534f}.card-fav.active:hover{color:#fff;background:#c9302c;border-color:#c9302c}.card-body{border-top:1px solid var(--border-light);padding:16px 18px 20px}.card-title{font-family:var(--font-display);color:var(--text-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:10px;font-size:16px;font-weight:500;line-height:1.35;display:-webkit-box;overflow:hidden}.card-tags{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.card-category{background:var(--accent-dim);color:var(--accent);text-transform:uppercase;letter-spacing:.05em;border-radius:2px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:500;display:inline-flex;&:before{content:"◦";font-size:8px}}.card-size{font-size:11px;font-family:var(--font-mono);color:var(--text-muted);border:1px solid var(--border-light);border-radius:2px;padding:3px 8px}.modal-overlay{z-index:200;padding:var(--gap);-webkit-backdrop-filter:blur(8px);opacity:0;transition:opacity .3s var(--ease-smooth);background:#000000d9;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.active{opacity:1;display:flex}.modal{background:var(--bg-secondary);border:1px solid var(--border);width:100%;max-width:1000px;max-height:90vh;box-shadow:var(--shadow-lg);transition:transform .4s var(--ease-bounce);border-radius:4px;position:relative;overflow-y:auto;transform:scale(.95)}.modal-overlay.active .modal{transform:scale(1)}.modal-close{border:1px solid var(--border);background:var(--bg-card);width:44px;height:44px;color:var(--text-secondary);cursor:pointer;z-index:10;transition:all var(--duration) var(--ease-smooth);border-radius:2px;justify-content:center;align-items:center;font-size:24px;display:flex;position:absolute;top:20px;right:20px;&:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--accent)}}.modal-body{grid-template-columns:1.2fr 1fr;min-height:60vh;display:grid;@media (width<=768px){grid-template-columns:1fr}}.modal-image{background:var(--bg-primary);justify-content:center;align-items:center;min-height:300px;display:flex;position:relative;&:before,&:after{content:"";border-color:var(--text-dim);opacity:.3;border-style:solid;border-width:0;width:40px;height:40px;position:absolute}&:before{border-top-width:1px;border-left-width:1px;top:16px;left:16px}&:after{border-bottom-width:1px;border-right-width:1px;bottom:16px;right:16px}}.modal-image img{object-fit:contain;max-width:95%;max-height:70vh;box-shadow:var(--shadow-md)}.modal-info{padding:var(--gap);border-left:1px solid var(--border);background:var(--bg-secondary);flex-direction:column;display:flex;@media (width<=768px){border-left:none;border-top:1px solid var(--border)}}.modal-header{margin-bottom:var(--gap-sm);& h2{margin-bottom:12px;font-size:26px;font-weight:500;line-height:1.3}}.modal-meta{flex-wrap:wrap;gap:8px;display:flex;& span{font-size:11px;font-family:var(--font-mono);color:var(--text-muted);border:1px solid var(--border-light);text-transform:uppercase;letter-spacing:.05em;border-radius:2px;padding:4px 10px}}.prompt-section{margin-bottom:var(--gap-sm);flex-direction:column;flex:1;display:flex}.prompt-header{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:11px;font-weight:600;display:flex;&:before{content:"§";color:var(--accent);margin-right:8px}}.copy-btn{border:1px solid var(--border);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;transition:all var(--duration) var(--ease-smooth);border-left:3px solid var(--border);background:0 0;border-radius:2px;padding:6px 14px;font-size:12px;font-weight:500}.copy-btn:hover{border-color:var(--accent);border-left-color:var(--accent);color:var(--accent)}.copy-btn.copied{background:var(--accent);border-color:var(--accent);color:#fff}.prompt-text{background:var(--bg-primary);border:1px solid var(--border-light);font-family:var(--font-mono);white-space:pre-wrap;word-break:break-word;color:var(--text-secondary);border-left:3px solid var(--accent-dim);border-radius:2px;flex:1;min-height:150px;max-height:250px;padding:16px;font-size:13px;line-height:1.7;overflow-y:auto}.modal-actions{padding-top:var(--gap-sm);border-top:1px solid var(--border-light);gap:12px;margin-top:auto;display:flex}.action-btn{border:1px solid var(--border);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;transition:all var(--duration) var(--ease-smooth);border-left:3px solid var(--border);background:0 0;border-radius:2px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px 20px;font-size:14px;font-weight:500;display:flex}.action-btn:hover{border-color:var(--accent);border-left-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.action-btn.fav-btn.active{background:var(--accent-dim);border-color:var(--accent);border-left-color:var(--accent);color:var(--accent)}.action-btn.gen-btn{background:var(--accent);border-color:var(--accent);border-left-color:var(--accent);color:#fff}.action-btn.gen-btn:hover{background:var(--accent-light);border-color:var(--accent-light);border-left-color:var(--accent-light)}.panel-overlay{z-index:180;-webkit-backdrop-filter:blur(4px);background:#0009;display:none;position:fixed;inset:0}.panel-overlay.active{display:block}.fav-panel{background:var(--bg-secondary);border-left:1px solid var(--border);z-index:190;width:420px;max-width:92vw;height:100vh;transition:right .4s var(--ease-smooth);flex-direction:column;display:flex;position:fixed;top:0;right:-440px;&:before{content:"";background:var(--accent);width:4px;position:absolute;top:0;bottom:0;left:0}}.fav-panel.active{right:0}.fav-panel-header{padding:var(--gap);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex;& h2{font-size:20px}}.fav-panel-actions{align-items:center;gap:10px;display:flex}.fav-list{padding:var(--gap-sm);flex:1;overflow-y:auto}.fav-item{cursor:pointer;transition:background var(--duration) var(--ease-smooth);border:1px solid #0000;border-radius:4px;align-items:center;gap:14px;padding:12px;display:flex;&:hover{background:var(--bg-card);border-color:var(--border)}}.fav-item img{object-fit:cover;border:1px solid var(--border-light);border-radius:2px;width:64px;height:48px}.fav-item-info{flex:1;min-width:0}.fav-item-title{font-family:var(--font-display);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:14px;font-weight:500;overflow:hidden}.fav-item-category{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px}.fav-item-remove{width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:all var(--duration) var(--ease-smooth);background:0 0;border:none;border-radius:2px;justify-content:center;align-items:center;font-size:18px;display:flex}.fav-item-remove:hover{color:#d9534f;background:#d9534f26}.fav-empty{padding:60px var(--gap);text-align:center;color:var(--text-muted);font-size:14px;font-style:italic}.gen-modal{max-width:580px}.gen-body{padding:var(--gap-lg)}.gen-body h2{margin-bottom:var(--gap);border-bottom:1px solid var(--border-light);padding-bottom:12px;font-size:24px}.gen-api-key{margin-bottom:var(--gap);& label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:12px;font-weight:600;display:block}& input{border:1px solid var(--border);background:var(--bg-primary);width:100%;color:var(--text-primary);font-family:var(--font-mono);transition:border-color var(--duration) var(--ease-smooth);border-radius:2px;outline:none;padding:12px 16px;font-size:13px;&:focus{border-color:var(--accent)}}}.gen-hint{color:var(--text-muted);margin-top:8px;font-size:12px;font-style:italic}.gen-preview{margin-bottom:var(--gap)}.gen-preview .prompt-text{max-height:180px}.gen-options{margin-bottom:var(--gap);grid-template-columns:1fr 1fr;gap:16px;display:grid;& label{display:block}& span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:12px;font-weight:600;display:block}& select{border:1px solid var(--border);background:var(--bg-primary);width:100%;color:var(--text-primary);font-family:var(--font-body);cursor:pointer;border-radius:2px;outline:none;padding:10px 14px;font-size:14px}}.gen-submit{justify-content:center;width:100%;padding:16px;font-size:15px;font-weight:600}.gen-result{margin-top:var(--gap);text-align:center;padding:var(--gap-sm);border:1px dashed var(--border);background:var(--bg-card);border-radius:4px;& img{border-radius:2px;max-width:100%;max-height:350px}}.download-btn{background:var(--accent);color:#fff;font-family:var(--font-body);transition:background var(--duration) var(--ease-smooth);border-radius:2px;align-items:center;gap:6px;margin-top:16px;padding:10px 24px;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex;&:hover{background:var(--accent-light)}}.gen-error{margin-top:var(--gap);color:#d9534f;background:#d9534f1a;border:1px solid #d9534f4d;border-radius:2px;padding:14px;font-size:13px}.gen-loading{margin-top:var(--gap);color:var(--text-muted);justify-content:center;align-items:center;gap:12px;font-size:14px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:100px var(--gap);color:var(--text-muted);& p{font-family:var(--font-display);font-size:22px;font-style:italic}}#modalGenBtn,#genModalOverlay{display:none!important}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px;&:hover{background:var(--text-muted)}}@media (width<=900px){:root{--gap:16px;--gap-lg:24px}.header-inner{padding:0 var(--gap)}.logo-text{font-size:18px}.search-box input{width:160px;transition:none;&:focus{width:160px}}.filter-scroll{padding:0 var(--gap)}.gallery-main{padding:var(--gap)}}@media (width<=550px){.logo-mark{display:none}.logo-text{font-size:15px}.search-box{display:none}.icon-btn{gap:0;min-width:44px;height:44px;padding:0 12px}.icon-btn span:not(.fav-count){display:none}#langToggle{min-width:44px}}.footer{text-align:center;padding:40px var(--gap-lg);border-top:1px solid var(--border);color:var(--text-muted);margin-top:auto;font-size:13px}.footer p{margin:0}@keyframes cardEnter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.card{animation:cardEnter .5s var(--ease-smooth) forwards;opacity:0}.card:first-child{animation-delay:50ms}.card:nth-child(2){animation-delay:.1s}.card:nth-child(3){animation-delay:.15s}.card:nth-child(4){animation-delay:.2s}.card:nth-child(5){animation-delay:.25s}.card:nth-child(6){animation-delay:.3s}.card:nth:nth-child(n+7){animation-delay:.35s}