:root{--bg: #f5f5f7;--surface: #ffffff;--border: #e5e7eb;--border-light: #f0f0f2;--text: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--primary: #3b82f6;--primary-hover: #2563eb;--primary-light: #eff6ff;--like-red: #ef4444;--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.06), 0 2px 4px -2px rgba(0,0,0,.04);--shadow-lg: 0 10px 25px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.04);--radius: 12px;--radius-lg: 16px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:var(--font)}img{display:block}#app{display:flex;flex-direction:column;min-height:100vh}.navbar{background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffeb}.nav-inner{max-width:1140px;margin:0 auto;padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between}.nav-left,.nav-right{display:flex;align-items:center;gap:8px}.nav-logo{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:700;color:var(--text);letter-spacing:-.02em;margin-right:24px}.nav-links{display:flex;gap:4px}.nav-link{font-size:13.5px;font-weight:500;color:var(--text-secondary);padding:6px 14px;border-radius:8px;transition:all .15s ease}.nav-link:hover,.nav-link.active{color:var(--text);background:var(--bg)}.nav-search{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid transparent;border-radius:10px;padding:8px 14px;transition:all .2s ease}.nav-search:focus-within{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 3px #3b82f61a}.nav-search svg{color:var(--text-muted);flex-shrink:0}.nav-search input{border:none;background:none;outline:none;font-size:13px;font-family:var(--font);color:var(--text);width:180px}.nav-search input::placeholder{color:var(--text-muted)}.nav-upload-btn{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#fff;background:var(--primary);border:none;border-radius:10px;padding:8px 16px;transition:all .15s ease}.nav-upload-btn:hover{background:var(--primary-hover)}.nav-avatar{width:34px;height:34px;border-radius:50%;overflow:hidden;cursor:pointer;border:2px solid var(--border);transition:border-color .15s ease}.nav-avatar:hover{border-color:var(--primary)}.nav-avatar img{width:100%;height:100%}.main-content{flex:1;display:flex;justify-content:center;padding:20px 24px 24px}.state{width:100%;max-width:800px;animation:fadeUp .4s ease}.state.hidden{display:none}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.shot-container{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;width:100%;max-width:1060px}.shot-image-area{background:linear-gradient(180deg,#f5f7fa,#edf0f5);display:flex;align-items:center;justify-content:center;padding:56px 40px;min-height:360px;position:relative;cursor:pointer;overflow:hidden}.shot-image-area img{max-width:65%;max-height:320px;width:auto;height:auto;display:block;object-fit:contain;border-radius:12px;box-shadow:0 4px 16px #00000014,0 12px 40px #0000000f;transition:transform .4s cubic-bezier(.25,.46,.45,.94),box-shadow .4s ease;position:relative;z-index:1}.shot-image-area:hover img{transform:scale(1.03);box-shadow:0 8px 24px #0000001f,0 16px 48px #0000001a}.zoom-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#00000026;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);opacity:0;transition:opacity .3s ease;z-index:2;pointer-events:none;gap:8px}.shot-image-area:hover .zoom-overlay{opacity:1}.zoom-icon{width:56px;height:56px;border-radius:50%;background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0000001a}.zoom-overlay span{color:#fff;font-size:13px;font-weight:600;text-shadow:0 1px 4px rgba(0,0,0,.3)}.download-toast{position:absolute;bottom:16px;left:50%;transform:translate(-50%) translateY(8px);display:flex;align-items:center;gap:8px;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:13px;font-weight:600;padding:10px 20px;border-radius:100px;opacity:0;pointer-events:none;transition:opacity .3s ease,transform .3s ease;z-index:3}.download-toast.show{opacity:1;transform:translate(-50%) translateY(0)}.download-indicator{position:fixed;top:8px;right:24px;display:flex;flex-direction:column;align-items:center;opacity:0;transform:translateY(6px) scale(.96);pointer-events:none;transition:opacity .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1);z-index:500}.download-indicator.show{opacity:1;transform:translateY(0) scale(1)}.download-indicator-pointer{display:flex;flex-direction:column;align-items:center;color:#22c55e;animation:floatUp 1.4s ease-in-out infinite}.download-indicator-stem{width:2px;height:10px;background:linear-gradient(to bottom,#22c55e 30%,transparent);border-radius:1px;margin-top:-4px}.download-indicator-badge{display:flex;align-items:center;gap:10px;background:#111827;color:#f3f4f6;font-size:12.5px;font-weight:600;letter-spacing:-.01em;padding:10px 16px;border-radius:10px;box-shadow:0 8px 24px #0000002e,0 2px 6px #00000014;white-space:nowrap;margin-top:2px}.download-indicator-check{width:20px;height:20px;border-radius:50%;background:#22c55e;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 0 3px #22c55e33}@keyframes floatUp{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.action-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border-light)}.action-bar-left,.action-bar-right{display:flex;align-items:center;gap:4px}.action-btn{display:inline-flex;align-items:center;gap:6px;border:none;background:none;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all .15s ease}.icon-btn{padding:8px 12px;border-radius:8px}.icon-btn:hover{background:var(--bg);color:var(--text)}.icon-btn svg{flex-shrink:0}.like-btn:hover{color:var(--like-red)}.like-btn:hover svg{stroke:var(--like-red)}.like-btn.liked{color:var(--like-red)}.like-btn.liked svg{fill:var(--like-red);stroke:var(--like-red)}.action-count{font-variant-numeric:tabular-nums}.primary-action{background:var(--primary);color:#fff!important;padding:8px 18px;border-radius:10px;font-weight:600;font-size:13px;box-shadow:var(--shadow-xs);transition:all .15s ease}.primary-action:hover{background:var(--primary-hover);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.primary-action:active{transform:translateY(0)}.primary-action svg{stroke:#fff}.shot-details{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light)}.shot-details-left{display:flex;align-items:center;gap:12px}.author-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0}.author-avatar img{width:100%;height:100%}.author-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.3}.author-handle{font-size:12.5px;color:var(--text-muted);margin-top:1px}.follow-btn{font-size:13px;font-weight:600;color:var(--primary);background:var(--primary-light);border:none;border-radius:10px;padding:8px 20px;transition:all .15s ease}.follow-btn:hover{background:#dbeafe}.shot-meta-section{padding:20px}.shot-description{margin-bottom:16px}.shot-description p{font-size:14px;color:var(--text-secondary);line-height:1.7}.shot-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}.tag{display:inline-block;font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--bg);padding:4px 12px;border-radius:100px;border:1px solid var(--border);transition:all .15s ease;cursor:default}.tag:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}.shot-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border-light);border:1px solid var(--border-light);border-radius:var(--radius);overflow:hidden}.info-item{background:var(--surface);padding:14px 16px;display:flex;flex-direction:column;gap:4px}.info-label{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:13px;font-weight:600;color:var(--text);font-variant-numeric:tabular-nums}.shot-meta-inline{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border-light)}.shot-desc-inline{font-size:13px;color:var(--text-secondary);line-height:1.5}.divider{height:1px;background:var(--border-light);margin:0 20px}.comments-section{padding:20px 20px 28px}.section-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:20px;display:flex;align-items:center;gap:8px}.comment-badge{font-size:11px;font-weight:600;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);padding:2px 8px;border-radius:100px}.comment-input-area{display:flex;gap:12px;margin-bottom:28px}.comment-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0}.comment-avatar img{width:100%;height:100%}.comment-input-wrapper{flex:1;display:flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:10px;padding:4px 4px 4px 14px;transition:border-color .15s ease}.comment-input-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f614}.comment-input{flex:1;border:none;outline:none;font-size:13.5px;font-family:var(--font);color:var(--text);background:none}.comment-input::placeholder{color:var(--text-muted)}.comment-submit-btn{font-size:12.5px;font-weight:600;color:#fff;background:var(--primary);border:none;border-radius:8px;padding:7px 14px;opacity:.5;transition:opacity .15s ease}.comment-submit-btn:not(:disabled):hover{opacity:1}.comment-list{display:flex;flex-direction:column;gap:0}.comment{display:flex;gap:12px;padding:16px 0;border-top:1px solid var(--border-light)}.comment:first-child{border-top:none}.comment-body{flex:1;min-width:0}.comment-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.comment-author{font-size:13px;font-weight:600;color:var(--text)}.comment-time{font-size:12px;color:var(--text-muted)}.comment-text{font-size:13.5px;color:var(--text-secondary);line-height:1.6;margin-bottom:8px}.comment-actions{display:flex;align-items:center;gap:12px}.comment-action-btn{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;color:var(--text-muted);background:none;border:none;padding:2px 0;transition:color .15s ease}.comment-action-btn:hover{color:var(--text-secondary)}.comment-item{display:flex;gap:12px;padding:16px 0;border-top:1px solid var(--border-light);animation:fadeUp .3s ease}.error-page{text-align:center;padding:80px 40px;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);max-width:480px;margin:0 auto}.error-illustration{margin-bottom:24px}.error-page h2{font-size:18px;font-weight:600;color:var(--text);margin-bottom:8px;letter-spacing:-.01em}.error-page p{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:24px}.error-page code{background:var(--bg);padding:2px 8px;border-radius:6px;font-size:13px;font-family:SF Mono,Fira Code,Consolas,monospace;color:var(--primary);border:1px solid var(--border)}.home-page{max-width:800px;margin:0 auto}.hero{text-align:center;padding:24px 0 36px}.hero-title{font-size:40px;font-weight:700;letter-spacing:-.03em;line-height:1.15;color:var(--text);margin-bottom:14px}.hero-accent{background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:16px;color:var(--text-secondary);line-height:1.6;max-width:420px;margin:0 auto}.upload-zone{margin-bottom:40px}.upload-dropzone{background:var(--surface);border:2px dashed var(--border);border-radius:var(--radius-lg);padding:48px 32px;text-align:center;transition:all .2s ease;cursor:pointer}.upload-dropzone:hover{border-color:var(--primary);background:var(--primary-light)}.upload-icon{color:var(--text-muted);margin-bottom:16px;display:inline-flex;transition:color .2s ease}.upload-dropzone:hover .upload-icon{color:var(--primary)}.upload-text{font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px}.upload-hint{font-size:13px;color:var(--text-muted);margin-bottom:20px}.upload-browse-btn{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#fff;background:var(--primary);border:none;border-radius:10px;padding:10px 24px;transition:all .15s ease}.upload-browse-btn:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.upload-dropzone.hidden{display:none}.upload-dropzone.drag-over{border-color:var(--primary);background:var(--primary-light)}.upload-dropzone.drag-over .upload-icon{color:var(--primary)}.upload-preview{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;animation:fadeUp .3s ease}.upload-preview.hidden{display:none}.preview-image-wrap{background:#fafafa;display:flex;align-items:center;justify-content:center;max-height:500px;overflow:hidden}.preview-image-wrap img{width:100%;height:auto;display:block;object-fit:contain;max-height:500px}.preview-info{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid var(--border-light);gap:12px}.preview-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.preview-filename{font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-filesize{font-size:12px;color:var(--text-muted)}.preview-actions{display:flex;gap:8px;flex-shrink:0}.preview-btn{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;font-family:var(--font);border:none;border-radius:10px;padding:8px 16px;cursor:pointer;transition:all .15s ease}.preview-btn.primary{background:var(--primary);color:#fff}.preview-btn.primary:hover{background:var(--primary-hover)}.preview-btn.secondary{background:var(--bg);color:var(--text-secondary);border:1px solid var(--border)}.preview-btn.secondary:hover{background:#f0f0f2;color:var(--text)}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:40px}.feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px 20px;transition:all .2s ease}.feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.feature-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}.feature-icon.blue{background:#eff6ff;color:#3b82f6}.feature-icon.purple{background:#f5f3ff;color:#8b5cf6}.feature-icon.green{background:#ecfdf5;color:#10b981}.feature-card h3{font-size:14px;font-weight:600;color:var(--text);margin-bottom:6px}.feature-card p{font-size:13px;color:var(--text-secondary);line-height:1.55}.legal-page{max-width:720px;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:48px 40px 56px;animation:fadeUp .4s ease}.legal-page h1{font-size:28px;font-weight:700;letter-spacing:-.02em;margin-bottom:6px;color:var(--text)}.legal-updated{font-size:13px;color:var(--text-muted);margin-bottom:36px}.legal-subtitle{font-size:15px;color:var(--text-secondary);line-height:1.6;margin-bottom:36px}.legal-page section{margin-bottom:28px}.legal-page section:last-child{margin-bottom:0}.legal-page h2{font-size:16px;font-weight:600;color:var(--text);margin-bottom:10px;letter-spacing:-.01em}.legal-page h3{font-size:14.5px;font-weight:600;color:var(--text);margin-top:18px;margin-bottom:8px}.legal-page p{font-size:14px;color:var(--text-secondary);line-height:1.75;margin-bottom:10px}.legal-page ul{list-style:none;padding:0;margin:10px 0}.legal-page li{position:relative;font-size:14px;color:var(--text-secondary);line-height:1.75;padding-left:20px;margin-bottom:6px}.legal-page li:before{content:"";position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--primary);opacity:.5}.legal-page a{color:var(--primary);font-weight:500;transition:color .15s ease}.legal-page a:hover{color:var(--primary-hover)}.footer-links a.active{color:var(--primary)}.contact-form{margin-bottom:36px}.form-group{margin-bottom:18px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;font-family:var(--font);font-size:14px;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:10px 14px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f614}.form-group textarea{resize:vertical;min-height:100px}.form-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.contact-submit-btn{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;font-family:var(--font);color:#fff;background:var(--primary);border:none;border-radius:10px;padding:12px 28px;cursor:pointer;transition:all .15s ease}.contact-submit-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f640}.contact-alt{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.contact-alt-card{text-align:center;padding:24px 16px;background:var(--bg);border-radius:var(--radius);border:1px solid var(--border-light);transition:all .2s ease}.contact-alt-card:hover{border-color:var(--border);box-shadow:var(--shadow-sm)}.contact-alt-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:10px;background:var(--surface);color:var(--primary);margin-bottom:12px;border:1px solid var(--border)}.contact-alt-card h3{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.contact-alt-card p{font-size:13px;color:var(--text-muted)}.contact-success{text-align:center;padding:40px 20px;animation:fadeUp .4s ease}.contact-success.hidden,.contact-form.hidden{display:none}.success-icon{margin-bottom:16px;display:inline-flex}.contact-success h2{font-size:20px;font-weight:600;color:var(--text);margin-bottom:8px}.contact-success p{font-size:14px;color:var(--text-secondary);margin-bottom:24px}.contact-another-btn{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;font-family:var(--font);color:var(--primary);background:var(--primary-light);border:none;border-radius:10px;padding:10px 24px;cursor:pointer;transition:all .15s ease}.contact-another-btn:hover{background:#dbeafe}.contact-submit-btn{opacity:1}.contact-submit-btn:disabled{opacity:.6;cursor:not-allowed}.download-cta{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;margin-bottom:4px;background:linear-gradient(135deg,#f0f7ff,#eef0ff);border-bottom:1px solid var(--border-light)}.download-cta-info{display:flex;flex-direction:column;gap:2px}.download-cta-title{font-size:14px;font-weight:600;color:var(--text)}.download-cta-meta{font-size:12px;color:var(--text-muted)}.download-cta-btn{display:flex;align-items:center;gap:8px;background:var(--primary);color:#fff;border:none;border-radius:12px;padding:12px 28px;font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .2s ease;box-shadow:0 2px 12px #3b82f640}.download-cta-btn:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 16px #3b82f659}.download-cta-btn svg{stroke:#fff}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000000e0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;padding:60px 40px 80px}.lightbox.active{opacity:1;visibility:visible}.lightbox img{max-width:90vw;max-height:80vh;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px #0000004d;animation:lightboxZoom .3s ease}@keyframes lightboxZoom{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.lightbox-close{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;background:#ffffff1f;border:1px solid rgba(255,255,255,.1);color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.lightbox-close:hover{background:#ffffff38}.lightbox-close svg{stroke:#fff}.lightbox-actions{position:absolute;bottom:28px;display:flex;gap:12px}.lightbox-download{display:flex;align-items:center;gap:8px;background:var(--primary);color:#fff;border:none;border-radius:12px;padding:12px 32px;font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #3b82f64d}.lightbox-download:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 24px #3b82f666}.lightbox-download svg{stroke:#fff}.tester-page{max-width:520px;width:100%;margin:0 auto;animation:fadeUp .4s ease}.tester-header{text-align:center;margin-bottom:32px}.tester-header h1{font-size:24px;font-weight:700;letter-spacing:-.02em;color:var(--text);margin-bottom:8px}.tester-header p{font-size:14px;color:var(--text-secondary)}.tester-input-area{display:flex;gap:10px;margin-bottom:32px}.tester-input-wrapper{flex:1;display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 16px;transition:border-color .15s ease,box-shadow .15s ease}.tester-input-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.tester-input-wrapper svg{color:var(--text-muted);flex-shrink:0}.tester-input-wrapper input{flex:1;border:none;outline:none;background:none;font-size:15px;font-family:var(--font);color:var(--text)}.tester-input-wrapper input::placeholder{color:var(--text-muted)}.tester-go-btn{display:flex;align-items:center;gap:8px;background:var(--primary);color:#fff;border:none;border-radius:12px;padding:12px 24px;font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .15s ease;white-space:nowrap}.tester-go-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f640}.tester-go-btn:disabled{opacity:.5;cursor:not-allowed}.tester-go-btn svg{stroke:#fff}.tester-preview{border-radius:var(--radius-lg);overflow:hidden}.footer{border-top:1px solid var(--border);background:var(--surface);margin-top:auto}.footer-inner{max-width:1140px;margin:0 auto;padding:24px;display:flex;align-items:center;justify-content:space-between}.footer-left{display:flex;align-items:center;gap:20px}.footer-logo{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.02em}.footer-copy{font-size:12.5px;color:var(--text-muted)}.footer-links{display:flex;gap:24px}.footer-links a{font-size:13px;font-weight:500;color:var(--text-secondary);transition:color .15s ease}.footer-links a:hover{color:var(--text)}.skeleton{background:linear-gradient(90deg,#f0f0f3 25%,#e8e8ec,#f0f0f3 75%);background-size:200% 100%;animation:shimmer 1.6s ease-in-out infinite;border-radius:8px}.skeleton-hero{width:100%;aspect-ratio:16 / 10}.skeleton-circle{width:44px;height:44px;border-radius:50%;flex-shrink:0}.skeleton-line{height:12px}.skeleton-line.short{height:10px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:768px){.nav-links,.nav-search{display:none}.nav-inner{padding:0 16px}.main-content{padding:12px 12px 16px}.action-bar{flex-direction:column;gap:12px;padding:12px 16px}.action-bar-left,.action-bar-right{width:100%;justify-content:space-between}.shot-details{flex-direction:column;align-items:flex-start;gap:12px;padding:16px}.shot-meta-section,.comments-section{padding:16px}.divider{margin:0 16px}.shot-meta-inline{flex-direction:column;align-items:flex-start;gap:8px}.shot-image-area{padding:20px 16px}.shot-image-area img{max-width:85%;max-height:280px}.download-cta{flex-direction:column;gap:12px;text-align:center}.download-cta-btn{width:100%;justify-content:center}.lightbox{padding:20px 12px 72px}.lightbox-download{padding:10px 24px;font-size:13px}.shot-info-grid{grid-template-columns:repeat(2,1fr)}.primary-action{flex:1;justify-content:center}.hero-title{font-size:28px}.hero-subtitle{font-size:14px}.legal-page{padding:32px 20px 40px}.legal-page h1{font-size:22px}.contact-alt{grid-template-columns:1fr}.footer-inner{flex-direction:column;gap:16px;text-align:center}.footer-left{flex-direction:column;gap:8px}.footer-links{gap:16px}.features-grid{grid-template-columns:1fr}.recent-grid{grid-template-columns:repeat(2,1fr)}.upload-dropzone{padding:36px 20px}.preview-info{flex-direction:column;align-items:stretch;gap:12px}.preview-actions{width:100%}.preview-btn{flex:1;justify-content:center}}@media(max-width:480px){.shot-info-grid{grid-template-columns:1fr 1fr}.action-bar-left{gap:0}.icon-btn{padding:8px}}
